refactor(frontend): use css modules

This commit is contained in:
syuilo 2023-05-02 09:07:57 +09:00
parent e48926b01d
commit 1631e62739

View file

@ -1,12 +1,13 @@
<template>
<div class="matxzzsk">
<div class="label" @click="focus"><slot name="label"></slot></div>
<div class="input" :class="{ inline, disabled, focused }">
<div ref="prefixEl" class="prefix"><slot name="prefix"></slot></div>
<div>
<div :class="$style.label" @click="focus"><slot name="label"></slot></div>
<div :class="$style.input" :class="{ inline, disabled, focused }">
<div ref="prefixEl" :class="$style.prefix"><div :class="$style.prefixOrSuffixText"><slot name="prefix"></slot></div></div>
<input
ref="inputEl"
v-model="v"
v-adaptive-border
:class="$style.inputCore"
:type="type"
:disabled="disabled"
:required="required"
@ -25,11 +26,11 @@
<datalist v-if="datalist" :id="id">
<option v-for="data in datalist" :key="data" :value="data"/>
</datalist>
<div ref="suffixEl" class="suffix"><slot name="suffix"></slot></div>
<div ref="suffixEl" :class="$style.suffix"><div :class="$style.prefixOrSuffixText"><slot name="suffix"></slot></div></div>
</div>
<div class="caption"><slot name="caption"></slot></div>
<div :class="$style.caption"><slot name="caption"></slot></div>
<MkButton v-if="manualSave && changed" primary class="save" @click="updated"><i class="ti ti-check"></i> {{ i18n.ts.save }}</MkButton>
<MkButton v-if="manualSave && changed" primary :class="$style.save" @click="updated"><i class="ti ti-check"></i> {{ i18n.ts.save }}</MkButton>
</div>
</template>
@ -151,9 +152,8 @@ onMounted(() => {
});
</script>
<style lang="scss" scoped>
.matxzzsk {
> .label {
<style lang="scss" module>
.label {
font-size: 0.85em;
padding: 0 0 8px 0;
user-select: none;
@ -163,7 +163,7 @@ onMounted(() => {
}
}
> .caption {
.caption {
font-size: 0.85em;
padding: 8px 0 0 0;
color: var(--fgTransparentWeak);
@ -173,10 +173,32 @@ onMounted(() => {
}
}
> .input {
.input {
position: relative;
> input {
&.inline {
display: inline-block;
margin: 0;
}
&.focused {
> .inputCore {
border-color: var(--accent) !important;
//box-shadow: 0 0 0 4px var(--focus);
}
}
&.disabled {
opacity: 0.7;
&,
> .inputCore {
cursor: not-allowed !important;
}
}
}
.inputCore {
appearance: none;
-webkit-appearance: none;
display: block;
@ -201,8 +223,8 @@ onMounted(() => {
}
}
> .prefix,
> .suffix {
.prefix,
.suffix {
display: flex;
align-items: center;
position: absolute;
@ -216,8 +238,19 @@ onMounted(() => {
&:empty {
display: none;
}
}
> * {
.prefix {
left: 0;
padding-right: 6px;
}
.suffix {
right: 0;
padding-left: 6px;
}
.prefixOrSuffixText {
display: inline-block;
min-width: 16px;
max-width: 150px;
@ -225,41 +258,8 @@ onMounted(() => {
white-space: nowrap;
text-overflow: ellipsis;
}
}
> .prefix {
left: 0;
padding-right: 6px;
}
> .suffix {
right: 0;
padding-left: 6px;
}
&.inline {
display: inline-block;
margin: 0;
}
&.focused {
> input {
border-color: var(--accent) !important;
//box-shadow: 0 0 0 4px var(--focus);
}
}
&.disabled {
opacity: 0.7;
&, * {
cursor: not-allowed !important;
}
}
}
> .save {
.save {
margin: 8px 0 0 0;
}
}
</style>