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'apparation de message si le formulaire est dirty
  6. */
  7. export class UseDirtyForm{
  8. private store:AnyStore
  9. private 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()