naive-ui/styles/Form.scss

161 lines
4.0 KiB
SCSS
Raw Normal View History

2019-07-22 19:14:47 +08:00
@import './mixins/mixins.scss';
2020-02-11 14:44:29 +08:00
2019-07-22 19:14:47 +08:00
@include b(form) {
width: 100%;
font-size: 14px;
2020-03-03 14:34:24 +08:00
line-height: 1.5;
2019-11-01 19:01:55 +08:00
@include m(inline) {
width: 100%;
2019-11-01 19:01:55 +08:00
display: inline-flex;
align-items: flex-start;
2019-07-22 19:14:47 +08:00
align-content: space-around;
@include b(form-item) {
width: auto;
&:last-child {
margin-right: 0;
}
2019-07-22 19:14:47 +08:00
}
}
}
2020-03-03 14:34:24 +08:00
$form-item-label-height: (
'small': 20px,
'medium': 22px,
'large': 24px
) !global;
@mixin form-item-size-mixin ($size) {
$form-item-feedback-font-size: (
'small': 13px,
'medium': 14px,
'large': 14px
) !global;
@include m($size + '-size') {
@include m(top-labelled) {
@include m(no-label) {
padding-top: map-get($form-item-label-height, $size);
}
@include b(form-item-label) {
font-size: map-get($--n-font-size, $size) - 1px;
height: map-get($form-item-label-height, $size);
}
}
@include m(left-labelled) {
@include b(form-item-label) {
font-size: map-get($--n-font-size, $size);
height: map-get($--n-height, $size) + 6px;
line-height: map-get($--n-height, $size) + 6px;
}
}
@include b(form-item-blank) {
min-height: map-get($--n-height, $size);
}
@include b(form-item-feedback-wrapper) {
font-size: map-get($--n-font-size, $size) - 1px;
}
}
}
@include themes-mixin {
@include b(form-item) {
2019-12-12 18:36:30 +08:00
@include once {
width: 100%;
2020-03-03 14:34:24 +08:00
@include form-item-size-mixin('small');
@include form-item-size-mixin('medium');
@include form-item-size-mixin('large');
2019-12-12 18:36:30 +08:00
@include m(top-labelled) {
margin-right: 18px;
@include m(no-label) {
2020-03-03 14:34:24 +08:00
padding-top: map-get($form-item-label-height, 'medium');
}
2019-12-12 18:36:30 +08:00
@include b(form-item-label) {
display: block;
width: 100%;
padding-bottom: 8px;
padding-left: 2px;
}
}
2019-12-12 18:36:30 +08:00
@include m(left-labelled) {
display: flex;
flex-wrap: nowrap;
@include b(form-item-label) {
box-sizing: border-box;
padding-right: 12px;
white-space: nowrap;
flex-shrink: 0;
flex-grow: 0;
}
@include b(form-item-control) {
flex-grow: 1;
}
}
2020-03-03 14:34:24 +08:00
@include m(right-label-aligned) {
@include b(form-item-label) {
text-align: right;
&::after {
display: none;
}
}
}
@include m(left-label-aligned) {
@include b(form-item-label) {
text-align: left;
&::before {
display: none;
}
}
}
2019-12-12 18:36:30 +08:00
@include m(has-feedback) {
padding-bottom: 0px;
}
@include b(form-item-blank) {
padding-top: 3px;
padding-bottom: 3px;
min-height: map-get($--n-height, 'medium');
2019-12-12 18:36:30 +08:00
display: flex;
align-items: center;
position: relative;
}
}
2020-01-17 14:25:24 +08:00
@include m(required) {
@include b(form-item-label) {
2020-02-21 16:48:45 +08:00
&::after, &::before {
2020-01-17 14:25:24 +08:00
@include once {
content: ' *';
2019-12-12 18:36:30 +08:00
}
2020-02-21 16:48:45 +08:00
color: $--form-item-required-asterisk;
2019-12-12 18:36:30 +08:00
}
}
2019-11-06 15:57:03 +08:00
}
@include b(form-item-label) {
2019-12-12 18:36:30 +08:00
@include once {
display: inline-block;
2020-03-03 14:34:24 +08:00
height: map-get($form-item-label-height, 'medium');
2019-12-12 18:36:30 +08:00
box-sizing: border-box;
font-size: 14px;
transition: color .3s $--n-ease-in-out-cubic-bezier;
2019-12-12 18:36:30 +08:00
&::after {
transition: color .3s $--n-ease-in-out-cubic-bezier;
2019-12-12 18:36:30 +08:00
}
2019-11-06 15:57:03 +08:00
}
2020-02-21 16:48:45 +08:00
color: $--form-item-label-text-color;
2019-07-22 19:14:47 +08:00
}
2019-11-09 13:38:06 +08:00
@include b(form-item-feedback-wrapper) {
2019-12-12 18:36:30 +08:00
@include once {
padding-left: 2px;
padding-top: 0px;
box-sizing: border-box;
2020-03-03 14:34:24 +08:00
min-height: 1.5em;
2019-12-12 18:36:30 +08:00
font-size: 14px;
transform-origin: top left;
2020-03-03 14:34:24 +08:00
line-height: 1.5;
transition: color .3s $--n-ease-in-out-cubic-bezier;
2019-12-12 18:36:30 +08:00
@include b(form-item-feedback) {
2020-02-11 14:44:29 +08:00
@include fade-down-transition($name: form-item-feedback, $from-offset: -3px);
2019-12-12 18:36:30 +08:00
}
2019-11-09 13:38:06 +08:00
}
2020-02-21 16:48:45 +08:00
color: map-get($--form-item-feedback-text-color, 'default');
}
2019-07-22 19:14:47 +08:00
}
}