useEmailInboundMessagesForm.ts 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
  2. import { shallowRef, reactive } from 'vue'
  3. import type { FormRef } from '#shared/components/Form/types.ts'
  4. import { i18n } from '#shared/i18n/index.ts'
  5. import { markup } from '#shared/utils/markup.ts'
  6. import type { EmailInboundMetaInformation } from '../types/email-inbound-outbound.ts'
  7. import type { ShallowRef, Ref } from 'vue'
  8. export const useEmailInboundMessagesForm = (
  9. metaInformationInbound: Ref<Maybe<EmailInboundMetaInformation>>,
  10. ) => {
  11. const formEmailInboundMessages: ShallowRef<FormRef | undefined> = shallowRef()
  12. const emailInboundMessageSchema = [
  13. {
  14. isLayout: true,
  15. element: 'div',
  16. attrs: {
  17. class: 'flex flex-col gap-y-2.5 gap-x-3',
  18. },
  19. children: [
  20. {
  21. isLayout: true,
  22. component: 'CommonLabel',
  23. children:
  24. '$t("%s email(s) were found in your mailbox. They will all be moved from your mailbox into Zammad.", $metaInformationInbound.contentMessages)',
  25. },
  26. {
  27. if: '$metaInformationInbound.archivePossible === true',
  28. isLayout: true,
  29. element: 'div',
  30. attrs: {
  31. class: 'flex flex-col gap-y-2.5 gap-x-3',
  32. },
  33. children: [
  34. {
  35. isLayout: true,
  36. component: 'CommonLabel',
  37. children: {
  38. if: '$metaInformationInbound.archivePossibleIsFallback === true',
  39. then: '$t(\'Since the mail server does not support sorting messages by date, it was not possible to detect if there is any mail older than %s weeks in the connected mailbox. You can import such emails as an "archive", which means that no notifications are sent and the tickets have the status "closed". However, you can find them in Zammad anytime using the search function.\', $metaInformationInbound.archiveWeekRange)',
  40. else: '$t(\'In addition, emails were found in your mailbox that are older than %s weeks. You can import such emails as an "archive", which means that no notifications are sent and the tickets have the status "closed". However, you can find them in Zammad anytime using the search function.\', $metaInformationInbound.archiveWeekRange)',
  41. },
  42. },
  43. {
  44. isLayout: true,
  45. component: 'CommonLabel',
  46. children:
  47. '$t("Should the emails from this mailbox be imported as an archive or as regular emails?")',
  48. },
  49. {
  50. isLayout: true,
  51. element: 'ul',
  52. attrs: {
  53. class:
  54. 'text-sm dark:text-neutral-400 text-gray-100 gap-1 list-disc ltr:ml-5 rtl:mr-5',
  55. },
  56. children: [
  57. {
  58. isLayout: true,
  59. element: 'li',
  60. attrs: {
  61. innerHTML: markup(
  62. i18n.t(
  63. 'Import as archive: |No notifications are sent|, the |tickets are closed|, and original timestamps are used. You can still find them in Zammad using the search.',
  64. ),
  65. ),
  66. },
  67. children: '',
  68. },
  69. {
  70. isLayout: true,
  71. element: 'li',
  72. attrs: {
  73. innerHTML: markup(
  74. i18n.t(
  75. 'Import as regular: |Notifications are sent| and the |tickets are open| - you can find the tickets in the overview of open tickets.',
  76. ),
  77. ),
  78. },
  79. children: '',
  80. },
  81. ],
  82. },
  83. {
  84. if: '$metaInformationInbound.archivePossible === true',
  85. name: 'importAs',
  86. label: __('Email import mode'),
  87. type: 'select',
  88. value: 'false',
  89. options: [
  90. {
  91. value: 'true',
  92. label: __('Import as archive'),
  93. },
  94. {
  95. value: 'false',
  96. label: __('Import as regular'),
  97. },
  98. ],
  99. },
  100. ],
  101. },
  102. ],
  103. },
  104. ]
  105. const emailInboundMessageSchemaData = reactive({
  106. metaInformationInbound,
  107. })
  108. return {
  109. formEmailInboundMessages,
  110. emailInboundMessageSchema,
  111. emailInboundMessageSchemaData,
  112. }
  113. }