2020-11-25 21:31:34 +09:00
|
|
|
<template>
|
|
|
|
<div class="yrtfrpux _formItem" :class="{ disabled, inline }">
|
|
|
|
<div class="_formLabel"><slot name="label"></slot></div>
|
|
|
|
<div class="icon" ref="icon"><slot name="icon"></slot></div>
|
|
|
|
<div class="input _formPanel _formClickable" @click="focus">
|
|
|
|
<div class="prefix" ref="prefix"><slot name="prefix"></slot></div>
|
|
|
|
<select ref="input"
|
|
|
|
v-model="v"
|
|
|
|
:required="required"
|
|
|
|
:disabled="disabled"
|
|
|
|
@focus="focused = true"
|
|
|
|
@blur="focused = false"
|
|
|
|
>
|
|
|
|
<slot></slot>
|
|
|
|
</select>
|
|
|
|
<div class="suffix">
|
2021-04-20 23:22:59 +09:00
|
|
|
<i class="fas fa-chevron-down"></i>
|
2020-11-25 21:31:34 +09:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="_formCaption"><slot name="caption"></slot></div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
|
|
|
import { defineComponent } from 'vue';
|
|
|
|
import './form.scss';
|
|
|
|
|
|
|
|
export default defineComponent({
|
|
|
|
props: {
|
|
|
|
value: {
|
|
|
|
required: false
|
|
|
|
},
|
|
|
|
required: {
|
|
|
|
type: Boolean,
|
|
|
|
required: false
|
|
|
|
},
|
|
|
|
disabled: {
|
|
|
|
type: Boolean,
|
|
|
|
required: false
|
|
|
|
},
|
|
|
|
inline: {
|
|
|
|
type: Boolean,
|
|
|
|
required: false,
|
|
|
|
default: false
|
|
|
|
},
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
};
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
v: {
|
|
|
|
get() {
|
|
|
|
return this.value;
|
|
|
|
},
|
|
|
|
set(v) {
|
|
|
|
this.$emit('update:value', v);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
focus() {
|
|
|
|
this.$refs.input.focus();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
.yrtfrpux {
|
|
|
|
position: relative;
|
|
|
|
|
|
|
|
> .icon {
|
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
left: 0;
|
|
|
|
width: 24px;
|
|
|
|
text-align: center;
|
|
|
|
line-height: 32px;
|
|
|
|
|
|
|
|
&:not(:empty) + .input {
|
|
|
|
margin-left: 28px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
> .input {
|
|
|
|
display: flex;
|
|
|
|
position: relative;
|
|
|
|
|
|
|
|
> select {
|
|
|
|
display: block;
|
|
|
|
flex: 1;
|
|
|
|
width: 100%;
|
|
|
|
padding: 0 16px;
|
|
|
|
font: inherit;
|
|
|
|
font-weight: normal;
|
|
|
|
font-size: 1em;
|
2021-04-12 23:13:58 +09:00
|
|
|
height: 48px;
|
2020-11-25 21:31:34 +09:00
|
|
|
background: none;
|
|
|
|
border: none;
|
|
|
|
border-radius: 0;
|
|
|
|
outline: none;
|
|
|
|
box-shadow: none;
|
|
|
|
appearance: none;
|
|
|
|
-webkit-appearance: none;
|
|
|
|
color: var(--fg);
|
|
|
|
|
|
|
|
option,
|
|
|
|
optgroup {
|
|
|
|
color: var(--fg);
|
|
|
|
background: var(--bg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
> .prefix,
|
|
|
|
> .suffix {
|
|
|
|
display: block;
|
|
|
|
align-self: center;
|
|
|
|
justify-self: center;
|
|
|
|
font-size: 1em;
|
|
|
|
line-height: 32px;
|
|
|
|
color: var(--inputLabel);
|
|
|
|
pointer-events: none;
|
|
|
|
|
|
|
|
&:empty {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
> * {
|
|
|
|
display: block;
|
|
|
|
min-width: 16px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
> .prefix {
|
|
|
|
padding-right: 4px;
|
|
|
|
}
|
|
|
|
|
|
|
|
> .suffix {
|
|
|
|
padding: 0 16px 0 0;
|
|
|
|
opacity: 0.7;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|