useValidator.ts 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import { ref, Ref } from '@nuxtjs/composition-api'
  2. import VueI18n from 'vue-i18n'
  3. import { QUERY_TYPE } from '~/types/enums'
  4. import DataProvider from "~/services/data/dataProvider";
  5. import {ApiResponse} from "~/types/interfaces";
  6. /**
  7. * @category composables/form
  8. * Composable pour des utils de verifications
  9. */
  10. export function useValidator($dataProvider: DataProvider, i18n: VueI18n) {
  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. function useHandleSiret() {
  15. const siretError: Ref<boolean> = ref(false)
  16. const siretErrorMessage: Ref<string> = ref('')
  17. const checkSiret = async (siret: string) => {
  18. const response = await $dataProvider.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. function useHandleSubdomain() {
  38. const checkSubdomainAvailability = async (subdomain: string | null) => {
  39. const response = await $dataProvider.invoke({
  40. type: QUERY_TYPE.DEFAULT,
  41. url: '/api/subdomains/?subdomain[]=' + subdomain
  42. })
  43. return typeof response !== 'undefined' && response.metadata.totalItems === 0
  44. }
  45. return {
  46. checkSubdomainAvailability
  47. }
  48. }
  49. return {
  50. useHandleSiret,
  51. useHandleSubdomain
  52. }
  53. }