useValidator.ts 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import { ref, Ref } from '@nuxtjs/composition-api'
  2. import VueI18n from 'vue-i18n'
  3. import { QUERY_TYPE } from '~/types/enums'
  4. import { DataManager } from '~/types/interfaces'
  5. /**
  6. * @category composables/form
  7. * @class UseValidator
  8. * Use Classe pour des utils de verifications
  9. */
  10. class UseValidator {
  11. /**
  12. * Use méthode fournissant une fonction pour tester la validité d'un Siret ainsi que la gestion du message d'erreur
  13. */
  14. public static useHandleSiret (i18n: VueI18n, $dataManager: DataManager) {
  15. const siretError: Ref<boolean> = ref(false)
  16. const siretErrorMessage: Ref<string> = ref('')
  17. const checkSiret = async (siret: string) => {
  18. const response = await $dataManager.invoke({
  19. type: QUERY_TYPE.DEFAULT,
  20. url: '/api/siret-checking',
  21. id: siret
  22. })
  23. if (typeof response !== 'undefined') {
  24. siretError.value = !response.isCorrect
  25. siretErrorMessage.value = response.isCorrect ? '' : i18n.t('siret_error') as string
  26. } else {
  27. siretError.value = false
  28. siretErrorMessage.value = ''
  29. }
  30. }
  31. return {
  32. siretError,
  33. siretErrorMessage,
  34. checkSiret
  35. }
  36. }
  37. }
  38. export default UseValidator