TransitionViewNavigation.vue 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <!-- Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/ -->
  2. <script setup lang="ts">
  3. import useViewTransition from './composable'
  4. const { viewTransition } = useViewTransition()
  5. </script>
  6. <template>
  7. <main class="grid flex-1 overflow-hidden">
  8. <transition class="z-10 flex-auto" :name="viewTransition">
  9. <slot></slot>
  10. </transition>
  11. </main>
  12. </template>
  13. <style scoped>
  14. /* TODO: Styles needs to be aligned/beautified. */
  15. /* Example from: https://codesandbox.io/s/zq5mw2zk9x */
  16. main {
  17. grid-template: 'main';
  18. }
  19. main > * {
  20. grid-area: main; /* Transition: make sections overlap on same cell */
  21. }
  22. /* next */
  23. .next-leave-to {
  24. animation: leaveToLeft 300ms both cubic-bezier(0.19, 0.61, 0.44, 1);
  25. z-index: 0;
  26. }
  27. .next-enter-to {
  28. animation: enterFromRight 400ms both cubic-bezier(0.19, 0.61, 0.44, 1);
  29. z-index: 1;
  30. }
  31. @keyframes leaveToLeft {
  32. from {
  33. transform: translateX(0);
  34. }
  35. to {
  36. transform: translateX(-25%);
  37. filter: brightness(0.4);
  38. }
  39. }
  40. @keyframes enterFromRight {
  41. from {
  42. transform: translateX(100%);
  43. }
  44. to {
  45. transform: translateX(0);
  46. }
  47. }
  48. /* prev */
  49. .prev-leave-to {
  50. animation: leaveToRight 400ms both cubic-bezier(0.19, 0.61, 0.44, 1);
  51. z-index: 1;
  52. }
  53. .prev-enter-to {
  54. animation: enterFromLeft 300ms both cubic-bezier(0.19, 0.61, 0.44, 1);
  55. z-index: 0;
  56. }
  57. @keyframes enterFromLeft {
  58. from {
  59. transform: translateX(-25%);
  60. filter: brightness(0.5);
  61. }
  62. to {
  63. transform: translateX(0);
  64. }
  65. }
  66. @keyframes leaveToRight {
  67. from {
  68. transform: translateX(0);
  69. filter: brightness(0.9);
  70. }
  71. to {
  72. transform: translateX(100%);
  73. filter: brightness(0.8);
  74. }
  75. }
  76. </style>