mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-11 02:37:22 +03:00
Reused dropdown-btn styles in sorting dropdown
This commit is contained in:
parent
90d4fe72db
commit
16f4f7eac8
4 changed files with 17 additions and 15 deletions
|
@ -1,18 +1,18 @@
|
|||
@import '../utils/mixins/vertical-align';
|
||||
|
||||
.dropdown__btn.dropdown__btn,
|
||||
.dropdown__btn.dropdown__btn:not(:disabled):not(.disabled).active,
|
||||
.dropdown__btn.dropdown__btn:not(:disabled):not(.disabled):active,
|
||||
.dropdown__btn.dropdown__btn:not(:disabled):not(.disabled):focus,
|
||||
.dropdown__btn.dropdown__btn:not(:disabled):not(.disabled):hover,
|
||||
.show > .dropdown__btn.dropdown__btn.dropdown-toggle {
|
||||
.dropdown-btn__toggle.dropdown-btn__toggle,
|
||||
.dropdown-btn__toggle.dropdown-btn__toggle:not(:disabled):not(.disabled).active,
|
||||
.dropdown-btn__toggle.dropdown-btn__toggle:not(:disabled):not(.disabled):active,
|
||||
.dropdown-btn__toggle.dropdown-btn__toggle:not(:disabled):not(.disabled):focus,
|
||||
.dropdown-btn__toggle.dropdown-btn__toggle:not(:disabled):not(.disabled):hover,
|
||||
.show > .dropdown-btn__toggle.dropdown-btn__toggle.dropdown-toggle {
|
||||
color: #6c757d;
|
||||
background-color: white;
|
||||
text-align: left;
|
||||
border-color: rgba(0, 0, 0, .125);
|
||||
}
|
||||
|
||||
.dropdown__btn.dropdown__btn:after {
|
||||
.dropdown-btn__toggle.dropdown-btn__toggle:after {
|
||||
@include vertical-align();
|
||||
|
||||
right: .75rem;
|
||||
|
|
|
@ -11,7 +11,7 @@ export interface DropdownBtnProps {
|
|||
|
||||
export const DropdownBtn: FC<DropdownBtnProps> = ({ text, disabled = false, className = '', children }) => {
|
||||
const [ isOpen, toggle ] = useToggle();
|
||||
const toggleClasses = `dropdown__btn btn-block ${className}`;
|
||||
const toggleClasses = `dropdown-btn__toggle btn-block ${className}`;
|
||||
|
||||
return (
|
||||
<Dropdown isOpen={isOpen} toggle={toggle} disabled={disabled}>
|
||||
|
|
|
@ -28,10 +28,12 @@ export default function SortingDropdown<T extends string = string>(
|
|||
<UncontrolledDropdown>
|
||||
<DropdownToggle
|
||||
caret
|
||||
color={isButton ? 'secondary' : 'link'}
|
||||
className={classNames({ 'btn-block': isButton, 'btn-sm p-0': !isButton })}
|
||||
color={isButton ? 'primary' : 'link'}
|
||||
className={classNames({ 'dropdown-btn__toggle btn-block': isButton, 'btn-sm p-0': !isButton })}
|
||||
>
|
||||
Order by
|
||||
{!isButton && <>Order by</>}
|
||||
{isButton && !orderField && <>Order by...</>}
|
||||
{isButton && orderField && <>Order by: {items[orderField]} - {orderDir}</>}
|
||||
</DropdownToggle>
|
||||
<DropdownMenu
|
||||
right={right}
|
||||
|
|
|
@ -28,10 +28,10 @@ describe('<DropdownBtn />', () => {
|
|||
});
|
||||
|
||||
it.each([
|
||||
[ undefined, 'dropdown__btn btn-block' ],
|
||||
[ '', 'dropdown__btn btn-block' ],
|
||||
[ 'foo', 'dropdown__btn btn-block foo' ],
|
||||
[ 'bar', 'dropdown__btn btn-block bar' ],
|
||||
[ undefined, 'dropdown-btn__toggle btn-block' ],
|
||||
[ '', 'dropdown-btn__toggle btn-block' ],
|
||||
[ 'foo', 'dropdown-btn__toggle btn-block foo' ],
|
||||
[ 'bar', 'dropdown-btn__toggle btn-block bar' ],
|
||||
])('includes provided classes', (className, expectedClasses) => {
|
||||
const wrapper = createWrapper({ text: '', className });
|
||||
const toggle = wrapper.find(DropdownToggle);
|
||||
|
|
Loading…
Reference in a new issue