Text.vue 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <!--
  2. Champs de saisie de texte
  3. @see https://vuetifyjs.com/en/components/text-fields/
  4. -->
  5. <template>
  6. <v-text-field
  7. autocomplete="off"
  8. :value="data"
  9. :label="$t(label_field)"
  10. :rules="rules"
  11. :disabled="readonly"
  12. :type="type === 'password' ? (show ? 'text' : type) : type"
  13. :error="error || !!violation"
  14. :error-messages="errorMessage || violation ? $t(violation) : ''"
  15. @change="onChange($event)"
  16. v-mask="mask"
  17. :append-icon="type === 'password' ? (show ? 'mdi-eye' : 'mdi-eye-off') : ''"
  18. @click:append="show = !show"
  19. />
  20. </template>
  21. <script lang="ts">
  22. import {defineComponent, ref, useContext} from '@nuxtjs/composition-api'
  23. import {useError} from "~/composables/form/useError";
  24. import {mask} from 'vue-the-mask';
  25. import {Num} from "@vuex-orm/core";
  26. export default defineComponent({
  27. props: {
  28. label: {
  29. type: String,
  30. required: false,
  31. default: null
  32. },
  33. field: {
  34. type: String,
  35. required: false,
  36. default: null
  37. },
  38. type: {
  39. type: String,
  40. required: false,
  41. default: null
  42. },
  43. data: {
  44. type: [String, Number],
  45. required: false,
  46. default: null
  47. },
  48. readonly: {
  49. type: Boolean,
  50. required: false
  51. },
  52. rules: {
  53. type: Array,
  54. required: false,
  55. default: () => []
  56. },
  57. error: {
  58. type: Boolean,
  59. required: false
  60. },
  61. errorMessage: {
  62. type: String,
  63. required: false,
  64. default: null
  65. },
  66. mask: {
  67. type: [Array, Boolean],
  68. required: false,
  69. default: false
  70. }
  71. },
  72. setup (props, {emit}) {
  73. const {store} = useContext()
  74. const {violation, onChange} = useError(props.field, emit, store)
  75. return {
  76. label_field: props.label ?? props.field,
  77. violation,
  78. show: ref(false),
  79. onChange
  80. }
  81. },
  82. directives: {
  83. mask: (el, binding, vnode, oldVnode) => {
  84. if (!binding.value) return;
  85. mask(el, binding, vnode, oldVnode);
  86. }
  87. }
  88. })
  89. </script>
  90. <style>
  91. input:read-only{
  92. color: #666 !important;
  93. }
  94. </style>