1
0
mirror of https://github.com/lana-k/sqliteviz.git synced 2025-12-06 18:18:53 +08:00

add hint and disabled state for TextField

This commit is contained in:
lana-k
2021-04-08 19:53:15 +02:00
parent ba75685a23
commit c2864b4308

View File

@@ -1,22 +1,28 @@
<template>
<div>
<div :class="['text-field-label', { error: errorMsg }]">{{ label }}</div>
<div :class="['text-field-label', { error: errorMsg }, {'disabled': disabled}]">
{{ label }}
<hint-icon class="hint" v-if="hint" :hint="hint" :max-width="maxHintWidth || '149px'"/>
</div>
<input
type="text"
:placeholder="placeholder"
:class="{ error: errorMsg }"
:style="{ width: width }"
:value="value"
:disabled="disabled"
@input="$emit('input', $event.target.value)"
/>
<div class="text-field-error">{{ errorMsg }}</div>
<div v-show="errorMsg" class="text-field-error">{{ errorMsg }}</div>
</div>
</template>
<script>
import HintIcon from '@/components/svg/hint'
export default {
name: 'textField',
props: ['placeholder', 'label', 'errorMsg', 'value', 'width']
props: ['placeholder', 'label', 'errorMsg', 'value', 'width', 'hint', 'maxHintWidth', 'disabled'],
components: { HintIcon }
}
</script>
@@ -30,6 +36,7 @@ input {
padding: 0 8px;
font-size: 13px;
box-sizing: border-box;
display: block;
}
input::placeholder {
@@ -40,24 +47,44 @@ input:focus {
outline: none;
}
input:disabled {
background: var(--color-bg-light);
color: var(--color-text-light-2);
cursor: default;
}
input.error {
border-color: var(--color-text-error);
}
.text-field-label {
font-size: 12px;
color: var(--color-text-base);
padding-left: 8px;
margin-bottom: 2px;
display: inline-block;
position: relative;
}
.text-field-label .hint{
position: absolute;
top: -2px;
right: -22px;
}
.text-field-label.error {
color: var(--color-text-error);
}
.text-field-label.disabled {
color: var(--color-text-light-2);
}
.text-field-error {
color: var(--color-text-error);
font-size: 12px;
padding-left: 8px;
margin-top: 2px;
position: absolute;
}
</style>