amis2/scss/components/form/_textarea.scss

87 lines
1.9 KiB
SCSS

.#{$ns}TextareaControl {
--Form-input-clearBtn-padding: #{px2rem(2px)};
position: relative;
> textarea {
@include input-border();
border: 1px solid var(--Form-input-borderColor);
border-radius: var(--Form-input-borderRadius);
background: var(--Form-input-bg);
padding: var(--Form-input-paddingY) var(--Form-input-paddingX);
font-size: var(--Form-input-fontSize);
display: block;
width: 100%;
line-height: var(--Form-input-lineHeight);
outline: none;
resize: none;
&::placeholder {
color: var(--Form-input-placeholderColor);
}
// yunshe4.0
&:hover {
border-color: var(--Form-input-onHover-borderColor);
}
}
& > textarea:focus,
&.is-focused > textarea {
border-color: var(--Form-input-onFocused-borderColor);
box-shadow: var(--Form-input-boxShadow);
// yunshe4.0
&:hover {
border-color: var(--Form-input-onFocused-borderColor);
}
}
&.is-disabled > textarea,
& > textarea[disabled] {
background: $gray200;
color: var(--text--muted-color);
}
&.is-error {
> textarea {
border-color: var(--Form-input-onError-borderColor);
}
}
&-counter {
position: absolute;
right: var(--Form-input-paddingX);
bottom: var(--Form-input-paddingY);
font-size: var(--fontSizeSm);
padding: 0 5px;
border-radius: 3px;
color: #fff;
background: rgba(0, 0, 0, 0.6);
&.is-empty {
color: #666;
background: rgba(0, 0, 0, 0.4);
}
&.is-clearable {
right: calc(
var(--Form-input-paddingX) + var(--Form-input-clearBtn-size) +
var(--Form-input-clearBtn-padding) * 2 + #{px2rem(5px)}
);
}
}
.has-error--maxLength &-counter {
background: var(--danger);
}
&-clear {
@include input-clear();
position: absolute;
right: var(--Form-input-paddingX);
bottom: var(--Form-input-paddingY);
}
}