useChecker.ts 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import {ref} from "@nuxtjs/composition-api";
  2. import {QUERY_TYPE} from "~/types/enums";
  3. import {DataProviders} from "~/types/interfaces";
  4. import VueI18n from "vue-i18n";
  5. /**
  6. * @category Use/form
  7. * @class UseChecker
  8. * Use Classe pour des utils de verifications
  9. */
  10. class UseChecker{
  11. /**
  12. * Use méthode fournissant une fonction pour tester la validité d'une Siret ainsi que la gestion du message d'erreur
  13. */
  14. public static useHandleSiret(i18n:VueI18n, $dataProvider: DataProviders){
  15. const siretError = ref(false)
  16. const siretErrorMessage = ref('')
  17. const checkSiret = async (siret:string) => {
  18. const response = await $dataProvider.invoke({
  19. type: QUERY_TYPE.DEFAULT,
  20. url: '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 UseChecker