useDirtyForm.ts 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. import { AnyJson, AnyStore } from '~/types/interfaces'
  2. /**
  3. * @category Use/form
  4. * @class UseDirtyForm
  5. * Use Classe pour gérer l'apparition de message si le formulaire est dirty
  6. */
  7. export class UseDirtyForm {
  8. private store: AnyStore
  9. private readonly handler: any
  10. constructor (handler: any, store: AnyStore) {
  11. this.store = store
  12. this.handler = handler
  13. }
  14. /**
  15. * Composition function
  16. */
  17. public invoke (): AnyJson {
  18. return {
  19. markFormAsDirty: () => this.markAsDirty(),
  20. markFormAsNotDirty: () => this.markAsNotDirty()
  21. }
  22. }
  23. /**
  24. * définit le formulaire comme Dirty (modifié)
  25. */
  26. private markAsDirty () {
  27. this.store.commit('form/setDirty', true)
  28. this.addEventListener()
  29. }
  30. /**
  31. * Définit le formulaire comme non dirty (non modifié)
  32. */
  33. private markAsNotDirty () {
  34. this.store.commit('form/setDirty', false)
  35. this.clearEventListener()
  36. }
  37. /**
  38. * Ajoute un Event avant le départ de la page
  39. */
  40. private addEventListener () {
  41. if (process.browser) {
  42. window.addEventListener('beforeunload', this.handler)
  43. }
  44. }
  45. /**
  46. * Supprime l'Event avant le départ de la page
  47. */
  48. private clearEventListener () {
  49. if (process.browser) {
  50. window.removeEventListener('beforeunload', this.handler)
  51. }
  52. }
  53. }
  54. function getEventHandler () {
  55. return function (e: any) {
  56. // Cancel the event
  57. e.preventDefault()
  58. // Chrome requires returnValue to be set
  59. e.returnValue = ''
  60. }
  61. }
  62. const handler = getEventHandler()
  63. export const $useDirtyForm = (store: AnyStore) => new UseDirtyForm(handler, store).invoke()