mirror of
https://github.com/discourse/discourse.git
synced 2025-01-12 13:13:52 +08:00
cbc0ece6e8
`<DSelect />` is a wrapper similar to our existing `<DButton />` over the html element `<select>`. The code is ported from form kit which is now directly using `<DSelect />`. Note this component has also been used in edit topic timer modal. This component is recommended for a small list of text items (no icons, no rich formatting...). Usage: ```gjs <DSelect class="my-select" @onChange={{this.handleChange}} as |select|> <select.Option @value="foo" class="my-favorite-option">Foo</select.Option> <select.Option @value="bar">Bar</select.Option> </DSelect> ``` This commit comes with a set of assertions: ```gjs import dselect from "discourse/tests/helpers/d-select-helper"; import { select } from "@ember/test-helpers"; assert .dselect(".my-select") .hasOption({ value: "bar", label: "Bar" }) .hasOption({ value: "foo", label: "Foo" }) .hasNoOption("baz"); await select(".my-select", "foo"); assert.dselect(".my-select").hasSelectedOption({value: "foo", label: "Foo"}); ```
51 lines
1.1 KiB
SCSS
51 lines
1.1 KiB
SCSS
@mixin default-input {
|
|
width: 100% !important;
|
|
height: 2em;
|
|
background: var(--secondary);
|
|
border: 1px solid var(--primary-low-mid) !important;
|
|
border-radius: var(--d-input-border-radius);
|
|
padding: 0 0.5em !important;
|
|
box-sizing: border-box;
|
|
margin: 0 !important;
|
|
appearance: none;
|
|
|
|
@include breakpoint(mobile-large) {
|
|
width: 100% !important;
|
|
height: 2.25em;
|
|
}
|
|
|
|
&:focus,
|
|
&:focus-visible,
|
|
&:focus:focus-visible,
|
|
&:active {
|
|
//these importants are another great case for having a button element without that pesky default styling
|
|
&:not(:disabled) {
|
|
background-color: var(--secondary) !important;
|
|
color: var(--primary) !important;
|
|
border-color: var(--tertiary);
|
|
outline: 2px solid var(--tertiary);
|
|
outline-offset: -2px;
|
|
|
|
.d-icon {
|
|
color: inherit !important;
|
|
}
|
|
}
|
|
}
|
|
|
|
&:hover:not(:disabled) {
|
|
.discourse-no-touch & {
|
|
background-color: var(--secondary);
|
|
color: var(--primary);
|
|
border-color: var(--tertiary);
|
|
|
|
.d-icon {
|
|
color: inherit;
|
|
}
|
|
}
|
|
}
|
|
|
|
.has-errors & {
|
|
border-color: var(--danger);
|
|
}
|
|
}
|