@ember-eui/core 5.0.0-alpha.1 → 5.0.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/addon/components/eui-combo-box/index.ts +1 -1
- package/addon/components/eui-empty-prompt/index.hbs +79 -73
- package/addon/components/eui-field-number/types.ts +4 -1
- package/addon/components/eui-flyout/index.ts +1 -1
- package/addon/components/eui-form-control-layout-custom-icon/types.ts +3 -1
- package/addon/components/eui-form-control-layout-icons/types.ts +4 -1
- package/addon/components/eui-global-toast-list/index.ts +5 -6
- package/addon/components/eui-image/index.ts +7 -2
- package/addon/components/eui-loading-logo/index.hbs +14 -0
- package/addon/components/eui-page-header/index.hbs +2 -2
- package/addon/components/eui-page-header-content/index.ts +1 -1
- package/addon/components/eui-page-template/index.ts +1 -1
- package/addon/components/eui-portal/index.ts +2 -1
- package/addon/components/eui-range-levels/index.ts +14 -3
- package/addon/components/eui-split-panel/inner/index.hbs +2 -1
- package/addon/components/eui-tab/index.hbs +57 -68
- package/addon/components/eui-tab/index.ts +6 -7
- package/addon/components/eui-tabs/index.hbs +2 -10
- package/addon/helpers/arg-or-default.ts +4 -1
- package/addon/helpers/eui-palette.ts +4 -1
- package/addon/helpers/get-tab-id.ts +8 -2
- package/addon/helpers/hex-to-rgb.ts +4 -1
- package/addon/helpers/inline-styles.ts +10 -3
- package/addon/helpers/is-within-number.ts +4 -1
- package/addon/helpers/starts-with.ts +3 -1
- package/addon/initializers/eui-config.ts +12 -0
- package/addon/modifiers/mutation-observer.ts +4 -1
- package/addon/modifiers/outside-click-detector.ts +4 -4
- package/addon/utils/accesibility/cascading-menu-keys.ts +8 -1
- package/addon/utils/code/utils.ts +1 -1
- package/addon/utils/color/color_palette.ts +3 -3
- package/addon/utils/color/eui_palettes.ts +23 -6
- package/addon/utils/css-mappings/eui-health.ts +1 -4
- package/addon/utils/css-mappings/eui-icon.ts +1 -2
- package/addon/utils/css-mappings/eui-list-group.ts +5 -1
- package/addon/utils/css-mappings/eui-modal.ts +5 -1
- package/addon/utils/markdown/markdown-types.ts +10 -11
- package/addon/utils/markdown/plugins/markdown-default-plugins/parsing-plugins.ts +1 -1
- package/addon/utils/markdown/plugins/markdown-default-plugins/plugins.ts +1 -1
- package/addon/utils/markdown/plugins/markdown-default-plugins/processing-plugins.ts +1 -1
- package/addon/utils/markdown/plugins/markdown-default-plugins/ui-plugins.ts +1 -1
- package/addon/utils/transition.ts +10 -3
- package/addon/version.ts +6 -0
- package/app/components/eui-avatar/index.js +1 -1
- package/app/components/eui-badge-group/badge-group-item/index.js +1 -1
- package/app/components/eui-badge-group/index.js +1 -1
- package/app/components/eui-button-icon/index.js +1 -1
- package/app/components/eui-combo-box/create-option/index.js +1 -1
- package/app/components/eui-comment/eui-comment-timeline/index.js +1 -1
- package/app/components/eui-comment/index.js +1 -1
- package/app/components/eui-dual-range/index.js +1 -1
- package/app/components/eui-field-number/index.js +1 -1
- package/app/components/eui-field-password/index.js +1 -1
- package/app/components/eui-field-search/index.js +1 -1
- package/app/components/eui-field-text/index.js +1 -1
- package/app/components/eui-file-picker/index.js +1 -1
- package/app/components/eui-form/index.js +1 -1
- package/app/components/eui-form-control-layout/index.js +1 -1
- package/app/components/eui-form-control-layout-clear-button/index.js +1 -1
- package/app/components/eui-form-control-layout-custom-icon/index.js +1 -1
- package/app/components/eui-form-control-layout-delimited/index.js +1 -1
- package/app/components/eui-form-control-layout-icons/index.js +1 -1
- package/app/components/eui-form-error-text/index.js +1 -1
- package/app/components/eui-form-fieldset/index.js +1 -1
- package/app/components/eui-form-help-text/index.js +1 -1
- package/app/components/eui-form-label/index.js +1 -1
- package/app/components/eui-form-legend/index.js +1 -1
- package/app/components/eui-form-row/index.js +1 -1
- package/app/components/eui-image.js +1 -1
- package/app/components/eui-list-group/index.js +1 -1
- package/app/components/eui-list-group-item/index.js +1 -1
- package/app/components/eui-loading-logo/index.js +1 -0
- package/app/components/eui-overlay-mask.js +1 -1
- package/app/components/eui-page/index.js +1 -1
- package/app/components/eui-page-body/index.js +1 -1
- package/app/components/eui-page-content/index.js +1 -1
- package/app/components/eui-page-content-body/index.js +1 -1
- package/app/components/eui-page-content-header/index.js +1 -1
- package/app/components/eui-page-content-header-section/index.js +1 -1
- package/app/components/eui-page-header/index.js +1 -1
- package/app/components/eui-page-header-content/index.js +1 -1
- package/app/components/eui-page-header-section/index.js +1 -1
- package/app/components/eui-panel/index.js +1 -1
- package/app/components/eui-popover/index.js +1 -1
- package/app/components/eui-popover-footer/index.js +1 -1
- package/app/components/eui-popover-title/index.js +1 -1
- package/app/components/eui-portal/index.js +1 -1
- package/app/components/eui-progress/index.js +1 -1
- package/app/components/eui-radio/index.js +1 -1
- package/app/components/eui-radio-group/index.js +1 -1
- package/app/components/eui-range/index.js +1 -1
- package/app/components/eui-range-highlight/index.js +1 -1
- package/app/components/eui-range-input/index.js +1 -1
- package/app/components/eui-range-label/index.js +1 -1
- package/app/components/eui-range-levels/index.js +1 -1
- package/app/components/eui-range-slider/index.js +1 -1
- package/app/components/eui-range-thumb/index.js +1 -1
- package/app/components/eui-range-ticks/index.js +1 -1
- package/app/components/eui-range-tooltip/index.js +1 -1
- package/app/components/eui-range-track/index.js +1 -1
- package/app/components/eui-range-wrapper/index.js +1 -1
- package/app/components/eui-select/index.js +1 -1
- package/app/components/eui-side-nav/index.js +1 -1
- package/app/components/eui-side-nav-item/button/index.js +1 -1
- package/app/components/eui-side-nav-item/index.js +1 -1
- package/app/components/eui-spacer/index.js +1 -1
- package/app/components/eui-switch/index.js +1 -1
- package/app/components/eui-tab/index.js +1 -1
- package/app/components/eui-tabs/index.js +1 -1
- package/app/components/eui-text/index.js +1 -1
- package/app/components/eui-text-align/index.js +1 -1
- package/app/components/eui-text-area/index.js +1 -1
- package/app/components/eui-text-color/index.js +1 -1
- package/app/components/eui-title/index.js +1 -1
- package/app/components/eui-tool-tip/index.js +1 -1
- package/app/components/eui-tool-tip-popover/index.js +1 -1
- package/app/helpers/eui-palette.js +1 -1
- package/app/helpers/hex-to-rgb.js +1 -1
- package/app/initializers/eui-config.js +1 -0
- package/docs/display/avatar.md +1 -9
- package/docs/display/badge-demo/demo1.md +93 -95
- package/docs/display/badge-demo/demo2.md +15 -17
- package/docs/display/badge-demo/demo3.md +19 -22
- package/docs/display/badge-demo/demo4.md +12 -14
- package/docs/display/badge-demo/demo5.md +16 -18
- package/docs/display/badge-demo/demo6.md +39 -51
- package/docs/display/badge-demo/demo7.md +43 -47
- package/docs/display/badge-demo/demo8.md +3 -6
- package/docs/display/badge.md +1 -9
- package/docs/display/callout.md +3 -9
- package/docs/display/comment-list.md +1 -9
- package/docs/display/description-list-demo/demo1.md +0 -1
- package/docs/display/description-list.md +1 -9
- package/docs/display/empty-prompt-demo/demo1.md +0 -24
- package/docs/display/empty-prompt-demo/demo2.md +16 -0
- package/docs/display/empty-prompt-demo/demo3.md +67 -0
- package/docs/display/empty-prompt-demo/demo4.md +21 -0
- package/docs/display/empty-prompt-demo/demo5.md +33 -0
- package/docs/display/empty-prompt-demo/demo6.md +43 -0
- package/docs/display/empty-prompt-demo/demo7.md +162 -0
- package/docs/display/empty-prompt-demo/demo8.md +57 -0
- package/docs/display/empty-prompt.md +1 -11
- package/docs/display/health-demo/demo1.md +0 -1
- package/docs/display/health.md +4 -10
- package/docs/display/icons.md +1 -9
- package/docs/display/image.md +6 -10
- package/docs/display/list-group.md +1 -9
- package/docs/display/loading/logo-demo/demo1.md +15 -0
- package/docs/display/loading/logo.md +1 -0
- package/docs/display/progress.md +1 -9
- package/docs/display/stat.md +4 -11
- package/docs/display/text.md +4 -12
- package/docs/display/title.md +1 -9
- package/docs/display/tool-tip-demo/demo1.md +40 -42
- package/docs/display/tool-tip-demo/demo2.md +24 -27
- package/docs/display/tool-tip-demo/demo3.md +33 -35
- package/docs/display/tool-tip-demo/demo4.md +4 -7
- package/docs/display/tool-tip.md +6 -10
- package/docs/editors/code/code-block.md +3 -9
- package/docs/editors/code/inline.md +1 -9
- package/docs/editors/markdown-editor/base-editor.md +1 -9
- package/docs/forms/form-controls/checkbox/index.md +1 -9
- package/docs/forms/form-controls/checkbox-group/index.md +1 -9
- package/docs/forms/form-controls/combo-box/index.md +1 -9
- package/docs/forms/form-controls/file-picker/index.md +1 -9
- package/docs/forms/form-controls/form-control-layout/index.md +1 -9
- package/docs/forms/form-controls/form-control-layout-delimited/index.md +1 -9
- package/docs/forms/form-controls/number-field/index.md +1 -9
- package/docs/forms/form-controls/password-field/index.md +1 -9
- package/docs/forms/form-controls/radio/index.md +1 -9
- package/docs/forms/form-controls/radio-group/index.md +1 -9
- package/docs/forms/form-controls/range/index.md +1 -9
- package/docs/forms/form-controls/search-field/index.md +1 -9
- package/docs/forms/form-controls/select/index.md +1 -9
- package/docs/forms/form-controls/switch/index.md +1 -9
- package/docs/forms/form-controls/text-field/index.md +1 -9
- package/docs/forms/form-controls/textarea/index.md +1 -10
- package/docs/forms/form-layouts/described-form-groups.md +1 -9
- package/docs/layout/accordion.md +1 -10
- package/docs/layout/bottom-bar.md +1 -9
- package/docs/layout/flex.md +1 -9
- package/docs/layout/flyout.md +1 -9
- package/docs/layout/header.md +1 -9
- package/docs/layout/horizontal-rule.md +1 -9
- package/docs/layout/modal.md +1 -9
- package/docs/layout/page.md +1 -9
- package/docs/layout/panel.md +2 -10
- package/docs/layout/popover.md +1 -9
- package/docs/navigation/breadcrumbs.md +1 -9
- package/docs/navigation/button.md +1 -9
- package/docs/navigation/collapsible-nav.md +1 -9
- package/docs/navigation/key-pad-menu.md +1 -9
- package/docs/navigation/link.md +1 -9
- package/docs/navigation/side-nav.md +1 -9
- package/docs/navigation/steps.md +1 -9
- package/docs/navigation/tabs-demo/demo1.md +38 -111
- package/docs/navigation/tabs-demo/demo2.md +56 -0
- package/docs/navigation/tabs-demo/demo3.md +79 -0
- package/docs/navigation/tabs-demo/demo4.md +102 -0
- package/docs/navigation/tabs.md +1 -9
- package/docs/utilities/auto-sizer.md +1 -9
- package/docs/utilities/copy.md +1 -9
- package/docs/utilities/mutation-observer.md +1 -9
- package/docs/utilities/outside-click-detector.md +1 -9
- package/docs/utilities/overlay-mask.md +1 -9
- package/docs/utilities/portal.md +1 -9
- package/docs/utilities/resize-observer.md +1 -9
- package/docs/utilities/responsive.md +1 -9
- package/index.js +4 -1
- package/package.json +2 -2
package/docs/layout/flyout.md
CHANGED
package/docs/layout/header.md
CHANGED
package/docs/layout/modal.md
CHANGED
package/docs/layout/page.md
CHANGED
package/docs/layout/panel.md
CHANGED
|
@@ -1,15 +1,7 @@
|
|
|
1
|
-
<EuiPageHeader
|
|
2
|
-
|
|
3
|
-
<EuiTitle @size="l">
|
|
4
|
-
<h1>
|
|
5
|
-
Panel
|
|
6
|
-
</h1>
|
|
7
|
-
</EuiTitle>
|
|
8
|
-
<EuiSpacer @size='l' />
|
|
1
|
+
<EuiPageHeader @pageTitle="Panel"/>
|
|
2
|
+
|
|
9
3
|
<EuiText>
|
|
10
4
|
<p>
|
|
11
5
|
<strong>EuiPanel</strong> is a building block component. Use it as a layout helper for containing content. It is also commonly used as a base for other larger components like <strong>EuiPage</strong>, <strong>EuiPopover</strong> and <strong>EuiCard</strong>.
|
|
12
6
|
</p>
|
|
13
7
|
</EuiText>
|
|
14
|
-
</EuiPageHeaderSection>
|
|
15
|
-
</EuiPageHeader>
|
package/docs/layout/popover.md
CHANGED
package/docs/navigation/link.md
CHANGED
package/docs/navigation/steps.md
CHANGED
|
@@ -1,109 +1,36 @@
|
|
|
1
|
-
|
|
1
|
+
---
|
|
2
|
+
order: 4
|
|
3
|
+
---
|
|
2
4
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
<
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
</b>
|
|
10
|
-
and
|
|
11
|
-
<b>
|
|
12
|
-
display = condensed
|
|
13
|
-
</b>
|
|
14
|
-
</EuiTitle>
|
|
15
|
-
<EuiTabs @display="condensed" as |Tab|>
|
|
16
|
-
<Tab @isSelected={{true}}>
|
|
17
|
-
Example 1
|
|
18
|
-
</Tab>
|
|
19
|
-
<Tab>
|
|
20
|
-
Example 2
|
|
21
|
-
</Tab>
|
|
22
|
-
<Tab>
|
|
23
|
-
Example 3
|
|
24
|
-
</Tab>
|
|
25
|
-
</EuiTabs>
|
|
26
|
-
<EuiSpacer @size="xxl" />
|
|
27
|
-
<EuiTitle @size="s">
|
|
28
|
-
Simple tabs with
|
|
29
|
-
<b>
|
|
30
|
-
disabled
|
|
31
|
-
</b>
|
|
32
|
-
and
|
|
33
|
-
<b>
|
|
34
|
-
expand = true
|
|
35
|
-
</b>
|
|
36
|
-
</EuiTitle>
|
|
37
|
-
<EuiTabs @expand={{true}} as |Tab|>
|
|
38
|
-
<Tab @disabled={{true}}>
|
|
39
|
-
Example 1
|
|
40
|
-
</Tab>
|
|
41
|
-
<Tab>
|
|
42
|
-
Example 2
|
|
43
|
-
</Tab>
|
|
44
|
-
</EuiTabs>
|
|
45
|
-
<EuiSpacer @size="xxl" />
|
|
46
|
-
<EuiTitle @size="s">
|
|
47
|
-
Tabbed content
|
|
48
|
-
</EuiTitle>
|
|
49
|
-
<EuiTabbedContent @tabs={{this.tabsItems1}} />
|
|
50
|
-
<EuiSpacer @size="xxl" />
|
|
51
|
-
<EuiTitle @size="s">
|
|
52
|
-
Tabbed content with
|
|
53
|
-
<b>
|
|
54
|
-
onTabClick
|
|
55
|
-
</b>
|
|
56
|
-
</EuiTitle>
|
|
57
|
-
<EuiTabbedContent @tabs={{this.tabsItems2}} @onTabClick={{this.sayMyName}} />
|
|
58
|
-
<EuiSpacer @size="xxl" />
|
|
59
|
-
<EuiTitle @size="s">
|
|
60
|
-
Tabbed content with
|
|
61
|
-
<b>
|
|
62
|
-
initialSelectedTab
|
|
63
|
-
</b>
|
|
64
|
-
</EuiTitle>
|
|
65
|
-
<EuiTabbedContent
|
|
66
|
-
@tabs={{this.tabsItems2}}
|
|
67
|
-
@initialSelectedTab={{object-at 2 this.tabsItems2}}
|
|
68
|
-
/>
|
|
69
|
-
<EuiSpacer @size="xxl" />
|
|
70
|
-
<EuiTitle @size="s">
|
|
71
|
-
Tabbed content with
|
|
72
|
-
<b>
|
|
73
|
-
selectedTab
|
|
74
|
-
</b>
|
|
75
|
-
</EuiTitle>
|
|
76
|
-
<p>
|
|
77
|
-
This is used if you want to control the tabs from the outside, however the internal state is not propagated to the
|
|
78
|
-
outside
|
|
79
|
-
</p>
|
|
80
|
-
<EuiSpacer />
|
|
81
|
-
<EuiButton @color="primary" {{on "click" this.cycleTabs}}>
|
|
82
|
-
Next tab
|
|
83
|
-
</EuiButton>
|
|
84
|
-
Outer selected tab:
|
|
85
|
-
{{get (object-at this.tabsIndex2 this.tabsItems2) "name"}}
|
|
86
|
-
<EuiTabbedContent
|
|
87
|
-
@tabs={{this.tabsItems2}}
|
|
88
|
-
@selectedTab={{object-at this.tabsIndex2 this.tabsItems2}}
|
|
89
|
-
/>
|
|
5
|
+
# Tab sizes
|
|
6
|
+
|
|
7
|
+
<EuiText>
|
|
8
|
+
<p><strong>EuiTabs</strong> allow a <EuiCode>size</EuiCode> prop. In general you should always use the default (medium) size. The small size is best for when placing inside popovers or other small containers. Reserve using the large size for when using as primary page navigation, like inside of <a href="#/layout/page-header"><strong>EuiPageHeader</strong></a>.</p>
|
|
9
|
+
<p>You can also use the <EuiCode>expand</EuiCode> prop to evenly stretch each tab horizontally.</p>
|
|
10
|
+
</EuiText>
|
|
90
11
|
|
|
91
|
-
|
|
92
|
-
<
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
</
|
|
12
|
+
```hbs template
|
|
13
|
+
<div>
|
|
14
|
+
<EuiPopover
|
|
15
|
+
@ownFocus={{true}}
|
|
16
|
+
@isOpen={{this.popover}}
|
|
17
|
+
@anchorPosition='downLeft'
|
|
18
|
+
@closePopover={{set this 'popover' false}}
|
|
19
|
+
>
|
|
20
|
+
<:button>
|
|
21
|
+
<EuiButton
|
|
22
|
+
@iconType='arrowDown'
|
|
23
|
+
@iconSide='right'
|
|
24
|
+
{{on 'click' (set this 'popover' true)}}
|
|
25
|
+
>
|
|
26
|
+
Show Popover
|
|
27
|
+
</EuiButton>
|
|
28
|
+
</:button>
|
|
29
|
+
<:content>
|
|
30
|
+
<EuiTabbedContent @tabs={{this.tabsItems1}} />
|
|
31
|
+
</:content>
|
|
32
|
+
</EuiPopover>
|
|
33
|
+
</div>
|
|
107
34
|
```
|
|
108
35
|
|
|
109
36
|
```js component
|
|
@@ -121,31 +48,31 @@ export default class DemoTabsComponent extends Component {
|
|
|
121
48
|
{
|
|
122
49
|
id: 'example1',
|
|
123
50
|
name: 'Example 1',
|
|
124
|
-
content: 'Example 1 content.'
|
|
51
|
+
content: 'Example 1 content.'
|
|
125
52
|
},
|
|
126
53
|
{
|
|
127
54
|
id: 'example2',
|
|
128
55
|
name: 'Example 2',
|
|
129
|
-
content: 'Example 2 content.'
|
|
130
|
-
}
|
|
56
|
+
content: 'Example 2 content.'
|
|
57
|
+
}
|
|
131
58
|
];
|
|
132
59
|
|
|
133
60
|
this.tabsItems2 = [
|
|
134
61
|
{
|
|
135
62
|
id: 'one',
|
|
136
63
|
name: 'Click me 1!',
|
|
137
|
-
content: "Same ol' 1 content."
|
|
64
|
+
content: "Same ol' 1 content."
|
|
138
65
|
},
|
|
139
66
|
{
|
|
140
67
|
id: 'two',
|
|
141
68
|
name: 'Click me 2!',
|
|
142
|
-
content: "Same ol' 2 content."
|
|
69
|
+
content: "Same ol' 2 content."
|
|
143
70
|
},
|
|
144
71
|
{
|
|
145
72
|
id: 'three',
|
|
146
73
|
name: 'Click me 3!',
|
|
147
|
-
content: "Same ol' 3 content."
|
|
148
|
-
}
|
|
74
|
+
content: "Same ol' 3 content."
|
|
75
|
+
}
|
|
149
76
|
];
|
|
150
77
|
}
|
|
151
78
|
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
---
|
|
2
|
+
order: 1
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Tabbed Content
|
|
6
|
+
|
|
7
|
+
<EuiText>
|
|
8
|
+
<p><strong>EuiTabbedContent</strong> makes it easier to associate tabs with content based on the selected tab. Use the <EuiCode>initialSelectedTab</EuiCode> prop to specify which tab to initially select.</p>
|
|
9
|
+
</EuiText>
|
|
10
|
+
|
|
11
|
+
```hbs template
|
|
12
|
+
<EuiTabbedContent @tabs={{this.tabsItems1}} />
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
```js component
|
|
16
|
+
import Component from '@ember/component';
|
|
17
|
+
import { action } from '@ember/object';
|
|
18
|
+
import { tracked } from '@glimmer/tracking';
|
|
19
|
+
|
|
20
|
+
export default class DemoTabsComponent extends Component {
|
|
21
|
+
@tracked tabsIndex2 = 0;
|
|
22
|
+
|
|
23
|
+
constructor() {
|
|
24
|
+
super(...arguments);
|
|
25
|
+
|
|
26
|
+
this.tabsItems1 = [
|
|
27
|
+
{
|
|
28
|
+
id: 'cobalt--id',
|
|
29
|
+
name: 'Cobalt',
|
|
30
|
+
content:
|
|
31
|
+
' Cobalt is a chemical element with symbol Co and atomic number 27. Like nickel, cobalt is found in the Earth’s crust only in chemically combined form, save for small deposits found in alloys of natural meteoric iron. The free element, produced by reductive smelting, is a hard, lustrous, silver-gray metal.'
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
id: 'dextrose--id',
|
|
35
|
+
name: 'Dextrose',
|
|
36
|
+
content:
|
|
37
|
+
'Intravenous sugar solution, also known as dextrose solution, is a mixture of dextrose (glucose) and water. It is used to treat low blood sugar or water loss without electrolyte loss.'
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
id: 'hydrogen--id',
|
|
41
|
+
name: 'Hydrogen',
|
|
42
|
+
prepend: 'heatmap',
|
|
43
|
+
disabled: true,
|
|
44
|
+
content:
|
|
45
|
+
'Intravenous sugar solution, also known as dextrose solution, is a mixture of dextrose (glucose) and water. It is used to treat low blood sugar or water loss without electrolyte loss.'
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
id: 'monosodium_glutammate--id',
|
|
49
|
+
name: 'Monosodium Glutamate',
|
|
50
|
+
content:
|
|
51
|
+
' Monosodium glutamate (MSG, also known as sodium glutamate) is the sodium salt of glutamic acid, one of the most abundant naturally occurring non-essential amino acids. Monosodium glutamate is found naturally in tomatoes, cheese and other foods.'
|
|
52
|
+
}
|
|
53
|
+
];
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
```
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
---
|
|
2
|
+
order: 2
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Controlled tabbed content
|
|
6
|
+
|
|
7
|
+
<EuiText>
|
|
8
|
+
<p>You can also use the <code class="euiCode" data-code-language="text">selectedTab</code> and <code class="euiCode" data-code-language="text">onTabClick</code> props to take complete control over tab selection. This can be useful if you want to change tabs based on user interaction with another part of the UI.</p>
|
|
9
|
+
</EuiText>
|
|
10
|
+
|
|
11
|
+
```hbs template
|
|
12
|
+
<EuiButton @color='primary' {{on 'click' this.cycleTabs}}>
|
|
13
|
+
Next tab
|
|
14
|
+
</EuiButton>
|
|
15
|
+
Outer selected tab:
|
|
16
|
+
{{get (object-at this.tabsIndex2 this.tabsItems1) 'name'}}
|
|
17
|
+
<EuiTabbedContent
|
|
18
|
+
@tabs={{this.tabsItems1}}
|
|
19
|
+
@selectedTab={{object-at this.tabsIndex2 this.tabsItems1}}
|
|
20
|
+
/>
|
|
21
|
+
|
|
22
|
+
<EuiSpacer />
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
```js component
|
|
26
|
+
import Component from '@ember/component';
|
|
27
|
+
import { action } from '@ember/object';
|
|
28
|
+
import { tracked } from '@glimmer/tracking';
|
|
29
|
+
|
|
30
|
+
export default class DemoTabsComponent extends Component {
|
|
31
|
+
@tracked tabsIndex2 = 0;
|
|
32
|
+
|
|
33
|
+
constructor() {
|
|
34
|
+
super(...arguments);
|
|
35
|
+
|
|
36
|
+
this.tabsItems1 = [
|
|
37
|
+
{
|
|
38
|
+
id: 'cobalt--id',
|
|
39
|
+
name: 'Cobalt',
|
|
40
|
+
content:
|
|
41
|
+
' Cobalt is a chemical element with symbol Co and atomic number 27. Like nickel, cobalt is found in the Earth’s crust only in chemically combined form, save for small deposits found in alloys of natural meteoric iron. The free element, produced by reductive smelting, is a hard, lustrous, silver-gray metal.'
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
id: 'dextrose--id',
|
|
45
|
+
name: 'Dextrose',
|
|
46
|
+
content:
|
|
47
|
+
'Intravenous sugar solution, also known as dextrose solution, is a mixture of dextrose (glucose) and water. It is used to treat low blood sugar or water loss without electrolyte loss.'
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
id: 'hydrogen--id',
|
|
51
|
+
name: 'Hydrogen',
|
|
52
|
+
prepend: 'heatmap',
|
|
53
|
+
|
|
54
|
+
content:
|
|
55
|
+
'Intravenous sugar solution, also known as dextrose solution, is a mixture of dextrose (glucose) and water. It is used to treat low blood sugar or water loss without electrolyte loss.'
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
id: 'monosodium_glutammate--id',
|
|
59
|
+
name: 'Monosodium Glutamate',
|
|
60
|
+
content:
|
|
61
|
+
' Monosodium glutamate (MSG, also known as sodium glutamate) is the sodium salt of glutamic acid, one of the most abundant naturally occurring non-essential amino acids. Monosodium glutamate is found naturally in tomatoes, cheese and other foods.'
|
|
62
|
+
}
|
|
63
|
+
];
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
sayMyName(tab) {
|
|
67
|
+
alert(`I am ${tab.name || tab.id}`);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
@action
|
|
71
|
+
cycleTabs() {
|
|
72
|
+
this.tabsIndex2++;
|
|
73
|
+
|
|
74
|
+
if (this.tabsIndex2 >= this.tabsItems2.length) {
|
|
75
|
+
this.tabsIndex2 = 0;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
```
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
---
|
|
2
|
+
order: 3
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Bottom border
|
|
6
|
+
|
|
7
|
+
<EuiText>
|
|
8
|
+
<p>The <EuiCode>bottomBorder</EuiCode> helps to separate the tab group from the content below and is on by default. However, some components like <a href="#/layout/flyout">flyouts</a> already provide borders which can act as the divider. In this case you can turn the border off with <EuiCode>bottomBorder<span class="token operator">=</span><span class="token punctuation">{</span><span class="token boolean">false</span><span class="token punctuation">}</span></EuiCode>.</p>
|
|
9
|
+
</EuiText>
|
|
10
|
+
|
|
11
|
+
```hbs template
|
|
12
|
+
<EuiButton {{on 'click' this.openFlyout}}>
|
|
13
|
+
Show tabs flyout header
|
|
14
|
+
</EuiButton>
|
|
15
|
+
{{#if this.flyoutOpen}}
|
|
16
|
+
<EuiFlyout @onClose={{this.closeFlyout}}>
|
|
17
|
+
<EuiFlyoutHeader @hasBorder={{true}}>
|
|
18
|
+
<EuiTitle @size='l'>Flyout header</EuiTitle>
|
|
19
|
+
<EuiTabbedContent @tabs={{this.tabsItems1}} />
|
|
20
|
+
</EuiFlyoutHeader>
|
|
21
|
+
<EuiFlyoutBody />
|
|
22
|
+
<EuiFlyoutFooter>
|
|
23
|
+
<EuiFlexGroup @justifyContent='spaceBetween' @gutterSize='s'>
|
|
24
|
+
<EuiButton {{on 'click' this.closeFlyout}}>
|
|
25
|
+
Cancel
|
|
26
|
+
</EuiButton>
|
|
27
|
+
<EuiButton @fill={{true}} {{on 'click' this.closeFlyout}}>
|
|
28
|
+
Send
|
|
29
|
+
</EuiButton>
|
|
30
|
+
</EuiFlexGroup>
|
|
31
|
+
</EuiFlyoutFooter>
|
|
32
|
+
</EuiFlyout>
|
|
33
|
+
{{/if}}
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
```js component
|
|
37
|
+
import Component from '@ember/component';
|
|
38
|
+
import { action } from '@ember/object';
|
|
39
|
+
import { tracked } from '@glimmer/tracking';
|
|
40
|
+
|
|
41
|
+
export default class DemoTabsComponent extends Component {
|
|
42
|
+
@tracked tabsIndex2 = 0;
|
|
43
|
+
|
|
44
|
+
@tracked flyoutOpen = false;
|
|
45
|
+
|
|
46
|
+
@action
|
|
47
|
+
openFlyout() {
|
|
48
|
+
this.flyoutOpen = true;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
@action
|
|
52
|
+
closeFlyout(flyout) {
|
|
53
|
+
this.flyoutOpen = false;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
constructor() {
|
|
57
|
+
super(...arguments);
|
|
58
|
+
|
|
59
|
+
this.tabsItems1 = [
|
|
60
|
+
{
|
|
61
|
+
id: 'cobalt--id',
|
|
62
|
+
name: 'Cobalt',
|
|
63
|
+
content:
|
|
64
|
+
' Cobalt is a chemical element with symbol Co and atomic number 27. Like nickel, cobalt is found in the Earth’s crust only in chemically combined form, save for small deposits found in alloys of natural meteoric iron. The free element, produced by reductive smelting, is a hard, lustrous, silver-gray metal.'
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
id: 'dextrose--id',
|
|
68
|
+
name: 'Dextrose',
|
|
69
|
+
content:
|
|
70
|
+
'Intravenous sugar solution, also known as dextrose solution, is a mixture of dextrose (glucose) and water. It is used to treat low blood sugar or water loss without electrolyte loss.'
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
id: 'hydrogen--id',
|
|
74
|
+
name: 'Hydrogen',
|
|
75
|
+
prepend: 'heatmap',
|
|
76
|
+
|
|
77
|
+
content:
|
|
78
|
+
'Intravenous sugar solution, also known as dextrose solution, is a mixture of dextrose (glucose) and water. It is used to treat low blood sugar or water loss without electrolyte loss.'
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
id: 'monosodium_glutammate--id',
|
|
82
|
+
name: 'Monosodium Glutamate',
|
|
83
|
+
content:
|
|
84
|
+
' Monosodium glutamate (MSG, also known as sodium glutamate) is the sodium salt of glutamic acid, one of the most abundant naturally occurring non-essential amino acids. Monosodium glutamate is found naturally in tomatoes, cheese and other foods.'
|
|
85
|
+
}
|
|
86
|
+
];
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
sayMyName(tab) {
|
|
90
|
+
alert(`I am ${tab.name || tab.id}`);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
@action
|
|
94
|
+
cycleTabs() {
|
|
95
|
+
this.tabsIndex2++;
|
|
96
|
+
|
|
97
|
+
if (this.tabsIndex2 >= this.tabsItems2.length) {
|
|
98
|
+
this.tabsIndex2 = 0;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
```
|
package/docs/navigation/tabs.md
CHANGED
package/docs/utilities/copy.md
CHANGED