App.vue 3.1 KB

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