App.vue 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <!-- Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/ -->
  2. <script setup lang="ts">
  3. import { onBeforeUnmount, onMounted } from 'vue'
  4. import { useRouter } from 'vue-router'
  5. import CommonNotifications from '@shared/components/CommonNotifications/CommonNotifications.vue'
  6. import { useApplicationStore } from '@shared/stores/application'
  7. import { useAuthenticationStore } from '@shared/stores/authentication'
  8. import useMetaTitle from '@shared/composables/useMetaTitle'
  9. import emitter from '@shared/utils/emitter'
  10. import useAppMaintenanceCheck from '@shared/composables/useAppMaintenanceCheck'
  11. import usePushMessages from '@shared/composables/usePushMessages'
  12. import { useLocaleStore } from '@shared/stores/locale'
  13. import useFormKitConfig from '@shared/composables/form/useFormKitConfig'
  14. import { useAppTheme } from '@shared/composables/useAppTheme'
  15. import useAuthenticationChanges from '@shared/composables/useAuthenticationUpdates'
  16. import DynamicInitializer from '@shared/components/DynamicInitializer/DynamicInitializer.vue'
  17. import CommonConfirmation from '@mobile/components/CommonConfirmation/CommonConfirmation.vue'
  18. const router = useRouter()
  19. const authentication = useAuthenticationStore()
  20. useMetaTitle().initializeMetaTitle()
  21. const application = useApplicationStore()
  22. onMounted(() => {
  23. // If Zammad was not properly set up yet, redirect to desktop front end.
  24. if (!application.config.system_init_done) {
  25. window.location.pathname = '/'
  26. } else {
  27. application.setLoaded()
  28. }
  29. })
  30. useAppMaintenanceCheck()
  31. usePushMessages()
  32. useAppTheme()
  33. // Add a check for authenticated changes (e.g. login/logout in a other
  34. // browser tab or maintenance mode switch).
  35. useAuthenticationChanges()
  36. // We need to trigger a manual translation update for the form related strings.
  37. const formConfig = useFormKitConfig()
  38. useLocaleStore().$subscribe(() => {
  39. formConfig.locale = 'staticLocale'
  40. })
  41. // The handling for invalid sessions. The event will be emitted, when from the server a "NotAuthorized"
  42. // response is received.
  43. emitter.on('sessionInvalid', async () => {
  44. if (authentication.authenticated) {
  45. await authentication.clearAuthentication()
  46. router.replace({
  47. name: 'Login',
  48. params: {
  49. invalidatedSession: '1',
  50. },
  51. })
  52. }
  53. })
  54. onBeforeUnmount(() => {
  55. emitter.off('sessionInvalid')
  56. })
  57. </script>
  58. <template>
  59. <template v-if="application.loaded">
  60. <CommonNotifications />
  61. <CommonConfirmation />
  62. </template>
  63. <div
  64. v-if="application.loaded"
  65. class="h-full min-w-full bg-black font-sans text-sm text-white antialiased"
  66. >
  67. <router-view />
  68. </div>
  69. <DynamicInitializer
  70. name="dialog"
  71. :transition="{
  72. enterActiveClass: 'duration-300 ease-out',
  73. enterFromClass: 'opacity-0 translate-y-3/4',
  74. enterToClass: 'opacity-100 translate-y-0',
  75. leaveActiveClass: 'duration-200 ease-in',
  76. leaveFromClass: 'opacity-100 translate-y-0',
  77. leaveToClass: 'opacity-0 translate-y-3/4',
  78. }"
  79. />
  80. </template>