mirror of
https://github.com/discourse/discourse.git
synced 2025-01-09 15:58:44 +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"}); ```
50 lines
1.3 KiB
SCSS
50 lines
1.3 KiB
SCSS
.d-select {
|
|
width: 100%;
|
|
height: 2.25em;
|
|
background: var(--secondary);
|
|
border: 1px solid var(--primary-400);
|
|
border-radius: var(--d-input-border-radius);
|
|
box-sizing: border-box;
|
|
margin: 0;
|
|
appearance: none;
|
|
padding: 0 2em 0 0.5em !important;
|
|
appearance: none;
|
|
background-image: svg-uri(
|
|
"<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='#{$primary-medium}' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m2 5 6 6 6-6'/></svg>"
|
|
);
|
|
background-repeat: no-repeat;
|
|
background-position: right 0.5rem center;
|
|
background-size: 16px 12px;
|
|
cursor: pointer;
|
|
|
|
&: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;
|
|
}
|
|
}
|
|
}
|
|
}
|