Input.vue 866 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. <template>
  2. <el-input v-bind="$attrs" :class="[variant]" />
  3. </template>
  4. <script setup lang="ts">
  5. withDefaults(
  6. defineProps<{
  7. variant?: 'outlined' | 'borderless' | 'filled' | 'underline'
  8. }>(),
  9. { variant: 'outlined' }
  10. )
  11. </script>
  12. <style lang="less" scoped>
  13. .borderless {
  14. :deep(.el-input__wrapper) {
  15. box-shadow: none;
  16. &:hover,
  17. &.is-focus {
  18. box-shadow: 0 0 0 1px var(--el-input-focus-border-color) inset;
  19. }
  20. }
  21. }
  22. .underline {
  23. :deep(.el-input__wrapper) {
  24. box-shadow: none;
  25. border-radius: 0;
  26. border-bottom: solid 1px var(--el-input-border-color);
  27. &:hover,
  28. &.is-focus {
  29. border-bottom: solid 1px var(--el-input-focus-border-color);
  30. }
  31. }
  32. }
  33. .filled {
  34. :deep(.el-input__wrapper) {
  35. box-shadow: none;
  36. background-color: #f5f5f5;
  37. &:hover {
  38. background-color: #f0f0f0;
  39. }
  40. &.is-focus {
  41. background-color: transparent;
  42. }
  43. }
  44. }
  45. </style>