useValidator.ts 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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. /**
  6. * @category composables/form
  7. * Composable pour des utils de verifications
  8. */
  9. export function useValidator($dataProvider: DataProvider, i18n: VueI18n) {
  10. /**
  11. * Use méthode fournissant une fonction pour tester la validité d'un Siret ainsi que la gestion du message d'erreur
  12. */
  13. function useHandleSiret() {
  14. const siretError: Ref<boolean> = ref(false)
  15. const siretErrorMessage: Ref<string> = ref('')
  16. const checkSiret = async (siret: string) => {
  17. const response = await $dataProvider.invoke({
  18. type: QUERY_TYPE.DEFAULT,
  19. url: '/api/siret-checking',
  20. id: siret
  21. })
  22. if (typeof response !== 'undefined') {
  23. siretError.value = !response.isCorrect
  24. siretErrorMessage.value = response.isCorrect ? '' : i18n.t('siret_error') as string
  25. } else {
  26. siretError.value = false
  27. siretErrorMessage.value = ''
  28. }
  29. }
  30. return {
  31. siretError,
  32. siretErrorMessage,
  33. checkSiret
  34. }
  35. }
  36. function useHandleSubdomain() {
  37. const checkSubdomainAvailability = async (subdomain: string | null): Promise<boolean> => {
  38. if (subdomain === null) {
  39. return true
  40. }
  41. const response = await $dataProvider.invoke({
  42. type: QUERY_TYPE.DEFAULT,
  43. url: '/api/subdomains',
  44. listArgs: {
  45. filters:[
  46. {key: 'subdomain', value: subdomain}
  47. ]
  48. }
  49. })
  50. return typeof response !== 'undefined' && response.metadata.totalItems === 0
  51. }
  52. return {
  53. checkSubdomainAvailability
  54. }
  55. }
  56. return {
  57. useHandleSiret,
  58. useHandleSubdomain
  59. }
  60. }