lbry-desktop/ui/scss/component/_form-field.scss

866 lines
17 KiB
SCSS
Raw Normal View History

2021-07-29 11:11:13 -04:00
@import '../init/mixins';
2020-07-24 13:17:43 -04:00
input,
select,
.date-picker-input {
2020-07-24 13:17:43 -04:00
height: var(--height-input);
border-radius: var(--border-radius);
color: var(--color-input);
border-color: var(--color-input-border);
background-color: var(--color-input-bg);
padding-right: var(--spacing-s);
padding-left: var(--spacing-s);
&::placeholder {
color: var(--color-input-placeholder);
opacity: 0.4;
}
&:disabled {
opacity: 0.4;
& + label {
opacity: 0.4;
}
}
&[type='range'] {
height: 0.5rem;
background-color: var(--color-secondary);
}
}
textarea {
height: var(--height-input);
border-radius: var(--border-radius);
color: var(--color-input);
background-color: var(--color-input-bg);
}
@media (min-width: $breakpoint-small) {
textarea {
height: var(--height-input);
border-radius: var(--border-radius);
color: var(--color-input);
background-color: var(--color-input-bg);
padding-right: var(--spacing-s);
padding-left: var(--spacing-s);
&::placeholder {
color: var(--color-input-placeholder);
opacity: 0.4;
}
&:disabled {
opacity: 0.4;
& + label {
opacity: 0.4;
}
}
&[type='range'] {
height: 0.5rem;
background-color: var(--color-secondary);
}
}
}
2020-07-24 13:17:43 -04:00
checkbox-element,
radio-element,
select {
cursor: pointer;
}
select {
2020-11-13 15:25:18 -05:00
background-image: var(--select-toggle-background);
background-position: right var(--spacing-s) center;
2020-07-24 13:17:43 -04:00
background-repeat: no-repeat;
background-size: 1rem;
padding-right: var(--spacing-xl);
2020-07-24 13:17:43 -04:00
padding-left: var(--spacing-s);
2020-11-13 15:25:18 -05:00
font-weight: bold;
2020-07-24 13:17:43 -04:00
}
fieldset-group {
display: flex;
flex-direction: row;
justify-content: space-between;
&.fieldset-group--smushed {
fieldset-section + fieldset-section {
margin-top: 0;
}
}
}
fieldset-section,
fieldset-group,
form,
.checkbox,
.radio,
.form-field--SimpleMDE,
.form-field__help {
+ fieldset-section,
+ fieldset-group,
+ form,
+ .checkbox,
+ .radio,
+ .form-field--SimpleMDE {
margin-top: var(--spacing-l);
}
+ .form-field__help {
margin-top: var(--spacing-s);
}
&:last-child {
margin-bottom: 0;
}
input,
select {
width: 100%;
}
}
fieldset-section {
background-color: unset; // imp
select:focus-visible {
background-color: var(--color-header-background); // ip
}
select {
background-color: var(--color-header-background);
}
option {
background-color: var(--color-header-background);
}
}
2020-07-24 13:17:43 -04:00
fieldset-section,
.checkbox,
.radio {
display: flex;
flex-direction: column;
}
label {
font-size: var(--font-small);
color: var(--color-input-label);
display: inline-block;
margin-bottom: 0.1rem;
2020-09-10 11:54:41 -04:00
.icon__lbc {
margin-bottom: 4px;
}
.compound-label {
display: flex;
flex-direction: row;
justify-content: flex-start;
align-items: baseline;
*:not(:first-child) {
margin-left: var(--spacing-s);
}
.compount-label__strong {
}
.compound-label__details {
color: var(--color-text-subtitle);
}
}
2020-07-24 13:17:43 -04:00
}
input-submit {
display: flex;
& > *:first-child,
& > *:nth-child(2) {
margin: 0;
}
& > *:not(:first-child):not(:last-child) {
border-top-right-radius: 0;
border-bottom-right-radius: 0;
border-top-left-radius: 0;
border-bottom-left-radius: 0;
}
2020-07-24 13:17:43 -04:00
& > *:first-child {
border-top-right-radius: 0;
border-bottom-right-radius: 0;
border-top-left-radius: var(--border-radius);
border-bottom-left-radius: var(--border-radius);
border-right: none;
}
& > *:last-child {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
border-top-right-radius: var(--border-radius);
border-bottom-right-radius: var(--border-radius);
2020-07-24 13:17:43 -04:00
border-right: none;
}
}
.checkbox,
.radio {
position: relative;
input[type='checkbox'],
input[type='radio'] {
height: var(--height-checkbox);
width: var(--height-checkbox);
position: absolute;
border: none;
left: 0;
padding: 0;
background-color: transparent;
&:disabled + label {
cursor: default;
pointer-events: none;
}
}
label {
position: relative;
display: inline-block;
margin: 0;
font-size: var(--font-base);
padding-left: calc(var(--height-checkbox) + 10px);
2020-07-24 13:17:43 -04:00
min-height: var(--height-checkbox);
&::before {
background-color: var(--color-input-toggle-bg);
}
&:hover {
&::before {
background-color: var(--color-input-toggle-bg-hover);
}
}
}
label::before,
label::after {
position: absolute;
content: '';
}
// Hide the checkmark by default
input[type='checkbox'] + label::after,
input[type='radio'] + label::after {
content: none;
}
// Unhide on the checked state
input[type='checkbox']:checked + label::after,
input[type='radio']:checked + label::after {
content: '';
}
}
.checkbox {
// Outer box of the fake checkbox
label::before {
height: var(--height-checkbox);
width: var(--height-checkbox);
border-radius: var(--border-radius);
left: 0px;
top: -1px;
}
// Checkmark of the fake checkbox
label::after {
height: 6px;
width: 12px;
border-left: 2px solid;
border-bottom: 2px solid;
border-color: var(--color-primary);
border-left-color: var(--color-primary);
2020-07-24 13:17:43 -04:00
transform: rotate(-45deg);
left: 6px;
top: 6px;
}
}
.radio {
input[type='radio'] {
border-radius: 50%;
}
// Outer box of the fake radio
label::before {
height: var(--height-radio);
width: var(--height-radio);
border: 1px solid var(--color-input-border);
border-radius: calc(var(--height-radio) * 0.5);
left: 0px;
top: -1px;
}
// Checkmark of the fake radio
label::after {
height: 12px;
width: 12px;
border-radius: 50%;
2021-04-26 15:19:17 -04:00
background-color: var(--color-primary);
2020-07-24 13:17:43 -04:00
left: 6px;
top: 5px;
}
}
.range__label {
display: flex;
justify-content: space-between;
width: 100%;
margin-bottom: var(--spacing-m);
2020-07-24 13:17:43 -04:00
> * {
width: 33%;
text-align: center;
&:first-of-type {
text-align: left;
}
&:last-of-type {
text-align: right;
}
}
}
.fieldset-group {
@extend fieldset-group;
}
.fieldset-section {
@extend fieldset-section;
}
.input-submit {
@extend input-submit;
}
2019-05-01 01:16:12 -04:00
input-submit {
align-items: center;
input {
z-index: 2;
}
2019-05-01 01:16:12 -04:00
}
2019-02-13 12:27:20 -04:00
2019-02-18 12:24:56 -05:00
input[type='number'] {
2020-06-16 09:38:35 -04:00
width: 8rem;
2019-02-18 12:24:56 -05:00
}
2019-02-20 00:20:29 -05:00
fieldset-group {
2019-11-22 16:13:00 -05:00
+ fieldset-group {
margin-top: var(--spacing-s);
2019-11-22 16:13:00 -05:00
}
2019-10-28 10:04:37 -04:00
2019-02-20 00:20:29 -05:00
&.fieldset-group--smushed {
justify-content: flex-start;
2018-03-26 14:32:43 -07:00
2019-02-20 00:20:29 -05:00
fieldset-section {
width: auto;
2019-11-19 12:41:31 -05:00
margin: 0;
2019-08-19 12:10:48 -04:00
&:first-child {
input,
select {
2019-02-20 00:20:29 -05:00
border-right: none;
border-top-right-radius: 0;
border-bottom-right-radius: 0;
}
}
&:nth-of-type(2) {
input,
select {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
}
label {
margin-left: var(--spacing-s);
2020-09-04 13:14:48 -04:00
}
2019-02-20 00:20:29 -05:00
}
}
&.fieldgroup--paginate {
2020-06-01 13:03:19 -04:00
padding-bottom: var(--spacing-l);
margin-top: var(--spacing-l);
align-items: center;
2019-02-20 00:20:29 -05:00
justify-content: center;
fieldset-section {
input {
margin-left: var(--spacing-s);
border-radius: calc(var(--height-button) / 2);
height: var(--height-button);
}
}
2019-02-13 12:27:20 -04:00
}
&.fieldgroup--paginate-top {
padding-bottom: var(--spacing-m);
align-items: flex-end;
justify-content: center;
}
2017-10-14 16:37:40 -06:00
}
2019-02-20 00:20:29 -05:00
// This is a special case where the prefix appears "inside" the input
// It would be way simpler to just use position: absolute and give it a width
// but the width can change when we use it for the name prefix
// lbry:// {input}, lbry://@short {input}, @lbry://longername {input}
// The spacing/alignment isn't very robust and will probably need to be changed
// if we use this in more places
&.fieldset-group--disabled-prefix {
align-items: flex-end;
label {
min-height: 18px;
2019-08-27 10:43:42 -04:00
white-space: nowrap;
// Set width 0 and overflow visible so the label can act as if it's the input label and not a random text node in a side by side div
overflow: visible;
width: 0;
}
2019-02-20 00:20:29 -05:00
fieldset-section:first-child {
max-width: 40%;
2019-02-20 00:20:29 -05:00
.form-field__prefix {
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
2019-11-22 16:13:00 -05:00
padding: 0.5rem;
height: var(--height-input);
border-top-left-radius: var(--border-radius);
border-bottom-left-radius: var(--border-radius);
border-color: var(--color-input-border);
border-right-color: var(--color-input-prefix-border);
color: var(--color-text);
background-color: var(--color-input-prefix-bg);
2019-02-20 00:20:29 -05:00
}
}
fieldset-section:last-child {
width: 100%;
label {
// Overwrite the input's label to wrap instead. This is usually
// an error message, which could be long in other languages.
width: 100%;
white-space: normal;
}
2019-02-20 00:20:29 -05:00
input {
border-left: 0;
border-top-left-radius: 0;
border-bottom-left-radius: 0;
2019-11-22 16:13:00 -05:00
border-color: var(--color-input-border);
2020-06-01 13:03:19 -04:00
padding-left: var(--spacing-xs);
2019-07-23 20:12:34 -04:00
}
2019-02-13 12:27:20 -04:00
}
2018-06-13 01:20:53 -04:00
}
2017-04-09 11:06:23 -04:00
}
.form-field--with-button {
padding: 0.2rem 0.75rem;
text-overflow: ellipsis;
user-select: text;
cursor: default;
}
.form-field--with-button ~ button {
border-bottom-left-radius: 0;
border-top-left-radius: 0;
}
2019-02-13 12:27:20 -04:00
.form-field--copyable {
padding: 0.2rem 0.75rem;
text-overflow: ellipsis;
user-select: text;
2019-02-20 00:20:29 -05:00
cursor: default;
2017-04-09 11:06:23 -04:00
}
.form-field--copyable ~ button {
border-bottom-left-radius: 0;
border-top-left-radius: 0;
}
2019-09-26 12:07:11 -04:00
.form-field--short {
2020-09-03 16:05:38 -04:00
width: 100%;
@media (min-width: $breakpoint-small) {
width: 25em;
}
2019-09-26 12:07:11 -04:00
}
2019-02-13 12:27:20 -04:00
.form-field--price-amount {
2021-05-26 21:25:09 -03:00
max-width: 6em;
2017-04-09 11:06:23 -04:00
}
2018-03-26 14:32:43 -07:00
2021-03-25 19:24:49 +08:00
.form-field--price-amount--auto {
width: auto;
min-width: 100%;
}
2019-02-13 12:27:20 -04:00
.form-field--address {
2019-09-30 17:48:30 -04:00
min-width: 18em;
2021-05-26 21:25:09 -03:00
@media (max-width: $breakpoint-xxsmall) {
min-width: 10em;
}
2018-05-25 00:36:43 -04:00
}
2019-12-13 14:47:50 -05:00
.form-field__help {
@extend .help;
color: var(--color-text);
2019-12-13 14:47:50 -05:00
}
2019-12-18 00:27:08 -05:00
.form-field__help + .checkbox,
.form-field__help + .radio {
2020-06-01 13:03:19 -04:00
margin-top: var(--spacing-l);
2019-12-18 00:27:08 -05:00
}
2019-12-13 14:47:50 -05:00
.form-field__conjuction {
padding-top: 1rem;
}
.form-field__two-column {
2020-08-24 13:35:21 -04:00
@media (min-width: $breakpoint-small) {
column-count: 2;
}
@media (max-width: $breakpoint-small) {
span {
font-size: var(--font-xxsmall);
}
}
}
.form-field__quick-action {
text-align: right;
font-size: var(--font-xsmall);
}
.form-field__hint {
font-size: var(--font-xsmall);
color: var(--color-input-label);
}
2021-04-23 15:59:48 -04:00
.form-field__textarea-info {
justify-content: space-between;
margin-top: var(--spacing-xxs);
margin-bottom: var(--spacing-s);
text-align: right;
span {
vertical-align: super;
padding-right: 0px;
}
2021-04-23 15:59:48 -04:00
}
2019-12-13 14:47:50 -05:00
fieldset-section {
.form-field__internal-option {
2020-06-01 13:03:19 -04:00
margin-top: var(--spacing-s);
2019-12-13 14:47:50 -05:00
margin-left: 2.2rem;
&:first-of-type {
2020-06-01 13:03:19 -04:00
margin-top: var(--spacing-s); // Extra specificity needed here since _section.scss is applied after this file
2019-12-13 14:47:50 -05:00
}
}
2020-08-24 13:35:21 -04:00
.select--slim {
margin-bottom: var(--spacing-xxs);
@media (min-width: $breakpoint-small) {
max-width: none;
select {
max-height: 1.5rem !important;
padding: 0 var(--spacing-xs);
padding-right: var(--spacing-l);
}
}
2020-08-24 13:35:21 -04:00
select {
max-height: var(--height-input-slim) !important;
2020-08-24 13:35:21 -04:00
padding: 0 var(--spacing-xs);
2020-08-24 14:57:19 -04:00
padding-right: var(--spacing-l);
2020-08-24 13:35:21 -04:00
}
@media (max-width: $breakpoint-small) {
select {
max-height: 1.25rem !important;
}
}
2020-08-24 13:35:21 -04:00
}
label {
.icon--help {
vertical-align: middle;
}
}
2019-12-13 14:47:50 -05:00
}
#automatic_dark_mode_range_start,
#automatic_dark_mode_range_end {
min-width: 6em;
}
.date-picker-input {
font-weight: bold;
.react-datetime-picker__wrapper {
border: 0;
}
}
.form-field-date-picker {
margin-bottom: var(--spacing-l);
font-size: var(--font-base);
label {
display: block;
}
.controls {
display: flex;
.date-picker-input,
.button--link {
margin-right: var(--spacing-m);
}
}
.react-datetime-picker__button {
svg {
stroke: var(--color-text);
}
}
.react-datetime-picker__button:enabled:hover .react-datetime-picker__button__icon,
.react-datetime-picker__button:enabled:focus .react-datetime-picker__button__icon {
stroke: var(--color-primary);
}
.react-date-picker__calendar {
z-index: 1000;
}
.react-calendar {
width: 350px;
max-width: 100%;
background: var(--color-card-background);
border: 1px solid #a0a096;
font-family: inherit;
line-height: 1;
}
.react-calendar--doubleView {
width: 700px;
}
.react-calendar--doubleView .react-calendar__viewContainer {
display: flex;
margin: -0.5em;
}
.react-calendar--doubleView .react-calendar__viewContainer > * {
width: 50%;
margin: 0.5em;
}
.react-calendar,
.react-calendar *,
.react-calendar *:before,
.react-calendar *:after {
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
padding: 2px 1px;
}
.react-calendar button {
margin: 0;
border: 0;
outline: none;
}
.react-calendar button:enabled:hover {
cursor: pointer;
}
.react-calendar button:disabled {
background-color: rgba(var(--color-header-background-base), 1);
}
.react-calendar__navigation {
height: 44px;
margin-bottom: 1em;
color: var(--color-text);
}
.react-calendar__navigation__label {
color: var(--color-text);
}
.react-calendar__navigation button {
min-width: 44px;
background: none;
color: var(--color-text);
}
.react-calendar__navigation button:enabled:hover,
.react-calendar__navigation button:enabled:focus {
background: var(--color-button-alt-bg-hover);
}
.react-calendar__navigation button[disabled] {
color: var(--color-text);
}
.react-calendar__month-view__weekdays {
text-align: center;
text-transform: uppercase;
font-weight: bold;
font-size: 0.75em;
color: var(--color-text-alt);
}
.react-calendar__month-view__weekdays__weekday {
padding: 0.5em;
}
.react-calendar__month-view__weekNumbers {
font-weight: bold;
}
.react-calendar__month-view__weekNumbers .react-calendar__tile {
display: flex;
align-items: center;
justify-content: center;
font-size: 0.75em;
padding: calc(0.75em / 0.75) calc(0.5em / 0.75);
}
.react-calendar__month-view__days__day,
.react-calendar__month-view__days__day--weekend {
color: var(--color-text);
font-weight: normal;
}
.react-calendar__month-view__days__day--neighboringMonth {
color: var(--color-gray-5);
}
.react-calendar__year-view .react-calendar__tile,
.react-calendar__decade-view .react-calendar__tile,
.react-calendar__century-view .react-calendar__tile {
padding: 2em 0.5em;
}
.react-calendar__tile {
max-width: 100%;
text-align: center;
padding: 0.75em 0.5em;
background: none;
border-radius: var(--border-radius);
color: var(--color-text);
}
.react-calendar__tile:enabled:hover,
.react-calendar__tile:enabled:focus {
background: var(--color-button-alt-bg-hover);
}
.react-calendar__tile:disabled {
background-color: rgba(var(--color-primary-dynamic), 0.4);
}
.react-calendar__tile--now {
background: var(--color-button-secondary-bg);
}
.react-calendar__tile--now:enabled:hover,
.react-calendar__tile--now:enabled:focus {
background: var(--color-button-secondary-bg-hover);
}
.react-calendar__tile--hasActive {
color: var(--color-button-primary-text);
background: var(--color-button-primary-bg);
}
.react-calendar__tile--hasActive:enabled:hover,
.react-calendar__tile--hasActive:enabled:focus {
background: var(--color-button-primary-bg-hover);
}
.react-calendar__tile--active {
color: var(--color-button-primary-text);
background: var(--color-button-primary-bg);
}
.react-calendar__tile--active:enabled:hover,
.react-calendar__tile--active:enabled:focus {
background: var(--color-button-primary-bg-hover);
}
.react-calendar--selectRange .react-calendar__tile--hover {
background-color: #e6e6e6;
}
.react-datetime-picker__inputGroup__amPm {
background: var(--color-input-bg);
}
.react-datetime-picker__inputGroup__leadingZero {
// Not perfect, but good enough for our standard zoom levels.
margin-bottom: 1px;
}
.react-datetime-picker__inputGroup__input--hasLeadingZero {
margin-left: -0.54em;
padding-left: calc(1px + 0.54em);
}
.react-calendar__month-view__days__day--neighboringMonth {
color: var(--color-gray-5);
}
}
.form-field-calendar {
border-radius: var(--border-radius);
border: 1px solid var(--color-border);
margin-left: calc(var(--spacing-xs) * -1);
margin-bottom: var(--spacing-xs);
animation: menu-animate-in var(--animation-duration) var(--animation-style);
box-shadow: 3px 3px rgba(0, 0, 0, 0.1);
}
2022-03-29 12:58:21 -04:00
.editable-text__field {
2022-03-29 13:13:36 -04:00
height: 2rem;
2022-03-29 12:58:21 -04:00
border-radius: unset;
border: unset;
border-bottom: 2px solid;
color: var(--color-text);
border-color: var(--color-text);
padding-right: var(--spacing-s);
padding-left: var(--spacing-s);
2022-03-29 13:05:42 -04:00
background-color: unset;
2022-03-29 12:58:21 -04:00
}
.editable-text__input-button {
2022-03-29 13:13:36 -04:00
height: 2rem;
2022-03-29 12:58:21 -04:00
border-radius: unset;
border: unset;
color: var(--color-text);
border-color: var(--color-text);
padding-right: var(--spacing-s);
padding-left: var(--spacing-s);
input-submit {
border-top-left-radius: unset;
border-bottom-left-radius: unset;
border: unset;
}
}