123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683 |
- <!-- Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/ -->
- <!-- eslint-disable zammad/zammad-detect-translatable-string -->
- <script setup lang="ts">
- import { reset } from '@formkit/core'
- import gql from 'graphql-tag'
- import { storeToRefs } from 'pinia'
- import { computed, h, onMounted, reactive, ref, watch, type Ref } from 'vue'
- import CommonAlert from '#shared/components/CommonAlert/CommonAlert.vue'
- import CommonPopover from '#shared/components/CommonPopover/CommonPopover.vue'
- import type {
- Orientation,
- Placement,
- } from '#shared/components/CommonPopover/types.ts'
- import { usePopover } from '#shared/components/CommonPopover/usePopover.ts'
- import CommonUserAvatar from '#shared/components/CommonUserAvatar/CommonUserAvatar.vue'
- import Form from '#shared/components/Form/Form.vue'
- import type {
- FormSchemaNode,
- FormValues,
- } from '#shared/components/Form/types.ts'
- import { useConfirmation } from '#shared/composables/useConfirmation.ts'
- import { defineFormSchema } from '#shared/form/defineFormSchema.ts'
- import { EnumObjectManagerObjects } from '#shared/graphql/types.ts'
- import { useApplicationStore } from '#shared/stores/application.ts'
- import { useSessionStore } from '#shared/stores/session.ts'
- import CommonActionMenu from '#desktop/components/CommonActionMenu/CommonActionMenu.vue'
- import CommonBreadcrumb from '#desktop/components/CommonBreadcrumb/CommonBreadcrumb.vue'
- import CommonButton from '#desktop/components/CommonButton/CommonButton.vue'
- import CommonButtonGroup from '#desktop/components/CommonButtonGroup/CommonButtonGroup.vue'
- import type { CommonButtonItem } from '#desktop/components/CommonButtonGroup/types.ts'
- import CommonDialog from '#desktop/components/CommonDialog/CommonDialog.vue'
- import { useDialog } from '#desktop/components/CommonDialog/useDialog.ts'
- import CommonFlyout from '#desktop/components/CommonFlyout/CommonFlyout.vue'
- import { useFlyout } from '#desktop/components/CommonFlyout/useFlyout.ts'
- import CommonInlineEdit from '#desktop/components/CommonInlineEdit/CommonInlineEdit.vue'
- import CommonInputCopyToClipboard from '#desktop/components/CommonInputCopyToClipboard/CommonInputCopyToClipboard.vue'
- import CommonPopoverMenu from '#desktop/components/CommonPopoverMenu/CommonPopoverMenu.vue'
- import type { MenuItem } from '#desktop/components/CommonPopoverMenu/types.ts'
- import CommonProgressBar from '#desktop/components/CommonProgressBar/CommonProgressBar.vue'
- import CommonSimpleTable from '#desktop/components/CommonSimpleTable/CommonSimpleTable.vue'
- import CommonTabManager from '#desktop/components/CommonTabManager/CommonTabManager.vue'
- import { useTabManager } from '#desktop/components/CommonTabManager/useTabManager.ts'
- import LayoutContent from '#desktop/components/layout/LayoutContent.vue'
- import ThemeSwitch from '#desktop/components/ThemeSwitch/ThemeSwitch.vue'
- import type { ThemeSwitchInstance } from '#desktop/components/ThemeSwitch/types.ts'
- import { useCopyToClipboard } from '#desktop/composables/useCopyToClipboard.ts'
- const alphabetOptions = computed(() =>
- [...Array(26).keys()].map((i) => ({
- value: i,
- label: `Item ${String.fromCharCode(65 + i)}`,
- disabled: Math.random() < 0.5,
- })),
- )
- const { copyToClipboard } = useCopyToClipboard()
- const longOption = ref({
- value: 999,
- label:
- 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, nullam pulvinar nunc sapien, vitae malesuada justo interdum feugiat, mauris odio, mattis et malesuada quis, vulputate vitae enim',
- })
- const permissions = [
- {
- value: 'admin',
- label: 'Admin interface',
- description: 'To configure your system.',
- children: [
- {
- value: 'admin.user',
- label: 'Users',
- description: 'To manage all users of your system.',
- },
- {
- value: 'admin.group',
- label: 'Groups',
- description: 'To manage groups of your system.',
- },
- {
- value: 'admin.role',
- label: 'Roles',
- description: 'To manage roles of your system.',
- },
- {
- value: 'admin.organization',
- label: 'Organizations',
- description: 'To manage all organizations of your system.',
- },
- {
- value: 'admin.overview',
- label: 'Overviews',
- description: 'To manage ticket overviews of your system.',
- },
- {
- value: 'admin.text_module',
- label: 'Text modules',
- description: 'To manage text modules of your system.',
- },
- {
- value: 'admin.macro',
- label: 'Macros',
- description: 'To manage ticket macros of your system.',
- },
- {
- value: 'admin.template',
- label: 'Templates',
- description: 'To manage ticket templates of your system.',
- },
- {
- value: 'admin.tag',
- label: 'Tags',
- description: 'To manage ticket tags of your system.',
- },
- {
- value: 'admin.calendar',
- label: 'Calendar',
- description: 'To manage calendars of your system.',
- },
- {
- value: 'admin.sla',
- label: 'SLAs',
- description: 'To manage Service Level Agreements of your system.',
- },
- {
- value: 'admin.trigger',
- label: 'Trigger',
- description: 'To manage triggers of your system.',
- },
- {
- value: 'admin.public_links',
- label: 'Public Links',
- description: 'To manage public links of your system.',
- },
- {
- value: 'admin.webhook',
- label: 'Webhook',
- description: 'To manage webhooks of your system.',
- },
- {
- value: 'admin.scheduler',
- label: 'Scheduler',
- description: 'To manage schedulers of your system.',
- },
- {
- value: 'admin.report_profile',
- label: 'Report Profiles',
- description: 'To manage report profiles of your system.',
- },
- {
- value: 'admin.time_accounting',
- label: 'Time Accounting',
- description: 'To manage time accounting settings of your system.',
- },
- {
- value: 'admin.knowledge_base',
- label: 'Knowledge Base',
- description: 'To create and set up Knowledge Base.',
- },
- {
- value: 'admin.channel_web',
- label: 'Web',
- description: 'To manage web channel of your system.',
- },
- {
- value: 'admin.channel_formular',
- label: 'Form',
- description: 'To manage form channel of your system.',
- },
- {
- value: 'admin.channel_email',
- label: 'Email',
- description: 'To manage email channel of your system.',
- },
- {
- value: 'admin.channel_sms',
- label: 'SMS',
- description: 'To manage SMS channel of your system.',
- },
- {
- value: 'admin.channel_chat',
- label: 'Chat',
- description: 'To manage chat channel of your system.',
- },
- {
- value: 'admin.channel_google',
- label: 'Google',
- description: 'To manage Google channel of your system.',
- },
- {
- value: 'admin.channel_microsoft365',
- label: ' Microsoft 365',
- description: 'To manage Microsoft 365 channel of your system.',
- },
- {
- value: 'admin.channel_twitter',
- label: 'Twitter',
- description: 'To manage Twitter channel of your system.',
- },
- {
- value: 'admin.channel_facebook',
- label: 'Facebook',
- description: 'To manage Facebook channel of your system.',
- },
- {
- value: 'admin.channel_telegram',
- label: 'Telegram',
- description: 'To manage Telegram channel of your system.',
- },
- {
- value: 'admin.channel_whatsapp',
- label: 'WhatsApp',
- description: 'To manage WhatsApp channel of your system.',
- },
- {
- value: 'admin.branding',
- label: 'Branding',
- description: 'To manage branding settings of your system.',
- },
- {
- value: 'admin.setting_system',
- label: 'System',
- description: 'To manage core system settings.',
- },
- {
- value: 'admin.security',
- label: 'Security',
- description: 'To manage security settings of your system.',
- },
- {
- value: 'admin.ticket',
- label: 'Ticket',
- description: 'To manage ticket settings of your system.',
- },
- {
- value: 'admin.integration',
- label: 'Integrations',
- description: 'To manage integrations of your system.',
- },
- {
- value: 'admin.api',
- label: 'API',
- description: 'To manage API of your system.',
- },
- {
- value: 'admin.object',
- label: 'Objects',
- description: 'To manage object attributes of your system.',
- },
- {
- value: 'admin.ticket_state',
- label: 'Ticket States',
- description: 'To manage ticket states of your system.',
- },
- {
- value: 'admin.ticket_priority',
- label: 'Ticket Priorities',
- description: 'To manage ticket priorities of your system.',
- },
- {
- value: 'admin.core_workflow',
- label: 'Core Workflows',
- description: 'To manage core workflows of your system.',
- },
- {
- value: 'admin.translation',
- label: 'Translations',
- description: 'To manage translations of your system.',
- },
- {
- value: 'admin.data_privacy',
- label: 'Data Privacy',
- description: 'To delete existing data of your system.',
- },
- {
- value: 'admin.maintenance',
- label: 'Maintenance',
- description: 'To manage maintenance mode of your system.',
- },
- {
- value: 'admin.monitoring',
- label: 'Monitoring',
- description: 'To manage monitoring of your system.',
- },
- {
- value: 'admin.package',
- label: 'Packages',
- description: 'To manage packages of your system.',
- },
- {
- value: 'admin.session',
- label: 'Sessions',
- description: 'To manage active user sessions of your system.',
- },
- {
- value: 'admin.system_report',
- label: 'System Report',
- description: 'To manage system report of your system.',
- },
- ],
- },
- {
- value: 'chat',
- label: 'Chat',
- description: 'To access the chat interface.',
- disabled: true,
- children: [
- {
- value: 'chat.agent',
- label: 'Agent Chat',
- description: 'To access the agent chat features.',
- },
- ],
- },
- {
- value: 'cti',
- label: 'Phone',
- description: 'To access the phone interface.',
- disabled: true,
- children: [
- {
- value: 'cti.agent',
- label: 'Agent Phone',
- description: 'To access the agent phone features.',
- },
- ],
- },
- {
- value: 'knowledge_base',
- label: 'Knowledge Base',
- description: 'To access the knowledge base interface.',
- disabled: true,
- children: [
- {
- value: 'knowledge_base.editor',
- label: 'Knowledge Base Editor',
- description: 'To access the knowledge base editor features.',
- },
- {
- value: 'knowledge_base.reader',
- label: 'Knowledge Base Reader',
- description: 'To access the knowledge base reader features.',
- },
- ],
- },
- {
- value: 'report',
- label: 'Report',
- description: 'To access the report interface.',
- },
- {
- value: 'ticket',
- label: 'Ticket',
- description: 'To access the ticket interface.',
- disabled: true,
- children: [
- {
- value: 'ticket.agent',
- label: 'Agent Tickets',
- description: 'To access the agent tickets based on group access.',
- },
- {
- value: 'ticket.customer',
- label: 'Customer Tickets',
- description: 'To access the customer tickets.',
- },
- ],
- },
- {
- value: 'user_preferences',
- label: 'Profile settings',
- description: 'To access the personal settings.',
- children: [
- {
- value: 'user_preferences.appearance',
- label: 'Appearance',
- description: 'To access the appearance personal setting.',
- },
- {
- value: 'user_preferences.language',
- label: 'Language',
- description: 'To access the language personal setting.',
- },
- {
- value: 'user_preferences.avatar',
- label: 'Avatar',
- description: 'To access the avatar personal setting.',
- },
- {
- value: 'user_preferences.out_of_office',
- label: 'Out of Office',
- description: 'To access the out of office personal setting.',
- },
- {
- value: 'user_preferences.password',
- label: 'Password',
- description: 'To access the change password personal setting.',
- },
- {
- value: 'user_preferences.two_factor_authentication',
- label: 'Two-factor Authentication',
- description:
- 'To access the two-factor authentication personal setting.',
- },
- {
- value: 'user_preferences.device',
- label: 'Devices',
- description: 'To access the devices personal setting.',
- },
- {
- value: 'user_preferences.access_token',
- label: 'Token Access',
- description: 'To access the API token personal setting.',
- },
- {
- value: 'user_preferences.linked_accounts',
- label: 'Linked Accounts',
- description: 'To access the linked accounts personal setting.',
- },
- {
- value: 'user_preferences.notifications',
- label: 'Notifications',
- description: 'To access the notifications personal setting.',
- },
- {
- value: 'user_preferences.overview_sorting',
- label: 'Overviews',
- description: 'To access the overviews personal setting.',
- },
- {
- value: 'user_preferences.calendar',
- label: 'Calendar',
- description: 'To access the calendar personal setting.',
- },
- ],
- },
- ]
- const treeselectOptions = [
- {
- value: 0,
- label: 'Item A',
- disabled: true,
- children: [
- {
- value: 1,
- label: 'Item 1',
- children: [
- {
- value: 2,
- label: 'Item I',
- },
- {
- value: 3,
- label: 'Item II',
- },
- {
- value: 4,
- label: 'Item III',
- },
- ],
- },
- {
- value: 5,
- label: 'Item 2',
- children: [
- ...[longOption.value],
- {
- value: 6,
- label: 'Item IV',
- },
- ],
- },
- {
- value: 7,
- label: 'Item 3',
- },
- ],
- },
- {
- value: 8,
- label: 'Item B',
- },
- {
- value: 9,
- label: 'Ítem C',
- },
- ]
- const buttonGroupOptions: CommonButtonItem[] = [
- {
- label: 'Button 1',
- variant: 'primary',
- icon: 'logo-flat',
- onActionClick: () => console.debug('Button 1 clicked'),
- },
- {
- label: 'Button 2',
- variant: 'secondary',
- },
- {
- label: 'Button 3',
- variant: 'tertiary',
- },
- {
- label: 'Button 4',
- variant: 'submit',
- },
- {
- label: 'Button 5',
- variant: 'danger',
- },
- {
- label: 'Button 6',
- variant: 'subtle',
- },
- {
- label: 'Button 7',
- variant: 'neutral',
- },
- ]
- const application = useApplicationStore()
- const formSchema = defineFormSchema([
- {
- type: 'editor',
- name: 'editor',
- label: 'Editor',
- required: true,
- },
- {
- isLayout: true,
- element: 'div',
- attrs: {
- class: 'grid md:grid-cols-2 gap-y-2.5 gap-x-3',
- },
- children: [
- {
- name: 'select_0',
- label: 'Column select',
- type: 'select',
- outerClass: 'col-span-1',
- props: {
- maxLength: 150,
- options: [...alphabetOptions.value, ...[longOption.value]],
- clearable: true,
- help: 'Testing',
- },
- },
- {
- name: 'toggle_1',
- label: 'Column toggle',
- type: 'toggle',
- outerClass: 'col-span-1',
- wrapperClass: 'md:mt-6',
- props: {
- variants: {
- true: 'yes',
- false: 'no',
- },
- },
- },
- {
- name: 'toggle_2',
- label: 'Row toggle',
- type: 'toggle',
- props: {
- variants: {
- true: 'yes',
- false: 'no',
- },
- },
- },
- ],
- },
- {
- type: 'security',
- name: 'security',
- label: 'Security',
- props: {
- securityAllowed: {
- SMIME: [],
- PGP: ['sign', 'encryption'],
- },
- securityDefaultOptions: {
- SMIME: ['sign', 'encryption'],
- PGP: ['sign'],
- },
- securityMessages: {
- SMIME: {
- sign: {
- message: 'The certificate for %s was not found.',
- messagePlaceholder: ['zammad@localhost'],
- },
- encryption: {
- message: 'The certificates for %s were not found.',
- messagePlaceholder: ['nicole.braun@zammad.org'],
- },
- },
- PGP: {
- sign: {
- message: 'The PGP key for %s was found.',
- messagePlaceholder: ['zammad@localhost'],
- },
- encryption: {
- message: 'The PGP keys for %s were found.',
- messagePlaceholder: ['nicole.braun@zammad.org'],
- },
- },
- },
- },
- value: { method: 'SMIME', options: [] },
- },
- {
- type: 'permissions',
- name: 'permissions',
- label: 'Permissions',
- props: {
- options: permissions,
- },
- value: ['ticket.agent'],
- },
- {
- type: 'autocomplete',
- name: 'autocomplete',
- label: 'Autocomplete',
- props: {
- clearable: true,
- gqlQuery: gql`
- query autocompleteSearchUser($input: AutocompleteSearchUserInput!) {
- autocompleteSearchUser(input: $input) {
- value
- label
- disabled
- icon
- }
- }
- `,
- },
- },
- {
- type: 'externalDataSource',
- name: 'external_data_source',
- label: 'External Data Source',
- object: EnumObjectManagerObjects.Ticket,
- help: 'Please add external_data_source attribute on Ticket object. Otherwise this field will not work.',
- },
- {
- type: 'agent',
- name: 'agent',
- label: 'Agent',
- props: {
- clearable: true,
- },
- },
- {
- type: 'recipient',
- name: 'recipient',
- label: 'Recipient',
- props: {
- clearable: true,
- },
- },
- {
- type: 'recipient',
- name: 'recipient_multiple',
- label: 'Recipient (multiple)',
- props: {
- clearable: true,
- multiple: true,
- },
- },
- {
- type: 'customer',
- name: 'customer',
- label: 'Customer',
- props: {
- clearable: true,
- link: '/',
- linkIcon: 'person-add',
- },
- },
- {
- type: 'organization',
- name: 'organization',
- label: 'Organization',
- props: {
- clearable: true,
- options: [
- {
- value: 1,
- label: 'Zammad Foundation',
- organization: {
- active: true,
- },
- },
- ],
- },
- },
- {
- type: 'tags',
- name: 'tags',
- label: 'Tags',
- props: {
- clearable: true,
- canCreate: application.config.tag_new,
- },
- },
- {
- name: 'date_0',
- label: 'Date',
- type: 'date',
- props: {
- clearable: true,
- },
- },
- {
- name: 'date_1',
- label: 'Date range',
- type: 'date',
- props: {
- clearable: true,
- range: true,
- },
- },
- {
- name: 'datetime_0',
- label: 'Date/Time',
- type: 'datetime',
- props: {
- clearable: true,
- },
- },
- {
- name: 'group_permission_0',
- label: 'Group permissions',
- type: 'groupPermissions',
- props: {
- options: [
- {
- value: 1,
- label: 'Users',
- },
- {
- value: 2,
- label: 'some_group1',
- children: [
- {
- value: 3,
- label: 'Nested group',
- },
- ],
- },
- ],
- },
- },
- {
- type: 'select',
- name: 'select_1',
- label: 'Single select',
- props: {
- options: [...alphabetOptions.value, ...[longOption.value]],
- clearable: true,
- },
- },
- {
- type: 'select',
- name: 'select_2',
- label: 'Multi select',
- props: {
- multiple: true,
- options: [...alphabetOptions.value, ...[longOption.value]],
- clearable: true,
- },
- },
- {
- type: 'treeselect',
- name: 'treeselect_1',
- label: 'Single treeselect',
- props: {
- options: treeselectOptions,
- clearable: true,
- },
- },
- {
- type: 'treeselect',
- name: 'treeselect_2',
- label: 'Multi treeselect',
- props: {
- multiple: true,
- options: treeselectOptions,
- clearable: true,
- },
- },
- {
- type: 'toggleList',
- name: 'roles',
- label: 'Roles',
- props: {
- options: [
- { value: 3, label: 'name only' },
- { value: 1, label: 'Long name', description: 'Note here' },
- {
- value: 1111,
- label: 'Another long name',
- description: 'Note here again',
- },
- ],
- },
- },
- {
- type: 'radioList',
- name: 'radioRoles',
- label: 'Radio roles',
- value: 1,
- props: {
- options: [
- { value: 3, label: 'name only' },
- { value: 33333, label: 'name onlyyyy' },
- { value: 1, label: 'Long name', description: 'Note here' },
- {
- value: 1111,
- label: 'Another long name',
- description: 'Note here again',
- },
- ],
- },
- },
- {
- type: 'file',
- name: 'file',
- label: 'Attachment',
- props: {
- multiple: true,
- },
- },
- {
- type: 'toggleButtons',
- name: 'toggleButtons',
- label: 'Toggle Buttons',
- value: '1',
- props: {
- options: [
- { value: '3', label: 'name only' },
- { value: '33333', label: 'name onlyyyy' },
- { value: '1', label: 'Long name', icon: 'sun' },
- ],
- },
- },
- ])
- const formValues = ref()
- const formInitialValues: FormValues = {
- roles: [3, 1],
- // date_0: [new Date(), new Date(new Date().setDate(new Date().getDate() + 7))],
- }
- const progressBarValue = ref(0)
- const increaseProgressBar = () => {
- progressBarValue.value += 25
- }
- onMounted(() => {
- setInterval(increaseProgressBar, 2000)
- })
- watch(progressBarValue, (newValue) => {
- if (newValue < 100) return
- setTimeout(() => {
- progressBarValue.value = 0
- }, 1000)
- })
- const session = useSessionStore()
- const { user } = storeToRefs(session)
- const { isOpen: popoverIsOpen, popover, popoverTarget, toggle } = usePopover()
- const themeSwitch = ref<ThemeSwitchInstance>()
- const cycleThemeSwitchValue = () => {
- themeSwitch.value?.cycleValue()
- }
- const appearance = ref('auto')
- const schema: FormSchemaNode[] = [
- {
- type: 'text',
- name: 'code',
- label: 'Test',
- required: true,
- props: {
- help: 'Enter here something',
- },
- },
- ]
- const flyout = useFlyout({
- name: 'playground',
- component: () =>
- new Promise((resolve) => {
- return resolve(
- h(
- CommonFlyout,
- {
- onClose: () => {
- console.log(
- '%c %s',
- 'color: red; font-size: 16px',
- 'Flyout closed!',
- )
- },
- onAction: () => {
- console.log(
- '%c %s',
- 'color: green; font-size: 16px',
- 'Flyout action!',
- )
- },
- name: 'playground',
- headerTitle: 'Hello Playground',
- persistWidth: true,
- headerIcon: 'buildings',
- footerActionOptions: {
- actionLabel: 'Submit test',
- cancelLabel: 'Adios',
- actionButton: {
- type: 'submit',
- variant: 'primary',
- prefixIcon: 'check2',
- },
- },
- },
- {
- default: () => [
- h('div', { class: 'py-1' }, [
- h('input'),
- h(Form, { ref: 'flyoutForm', schema }),
- h('div', { class: 'w-[400px]', innerHTML: 'Hello world!' }),
- h(
- 'p',
- ' Lorem ipsum dolor sit amet, consectetur adipisicing elit. Ab laborum magnam omnis qui, ratione similique velit voluptatem. Cumque esse et, expedita inventore, iusto laboriosam magnam minus necessitatibus numquam odio odit optio quaerat, quidem quo quos reiciendis rem similique ut veniam vero. Aperiam at blanditiis dignissimos est et, ex harum id in itaque magni natus neque officia omnis perferendis quaerat, quasi ratione reiciendis sunt vitae voluptatum. At id obcaecati odio rerum sed! Accusamus aliquid assumenda cupiditate deleniti distinctio dolore dolores ea earum enim eos error esse ex expedita hic id incidunt iste laudantium molestias nisi obcaecati omnis placeat quam quibusdam quis, quod ratione rem repellendus reprehenderit sed sint soluta velit vitae voluptas voluptate voluptatem voluptates voluptatum. Delectus facilis nostrum praesentium quos sed. Ad assumenda atque cum cumque distinctio dolorem dolores excepturi explicabo harum impedit iusto labore, laboriosam laudantium libero minima nam pariatur quasi quisquam rem repellat reprehenderit saepe sapiente, tempora ut voluptates! Assumenda distinctio impedit veniam vitae voluptates! Aperiam, at commodi dignissimos ex exercitationem inventore quibusdam sequi veniam! A ab accusamus aperiam architecto atque beatae blanditiis commodi consequatur, deleniti deserunt dolor ducimus eaque ex excepturi illum incidunt ipsum laboriosam magni minus molestiae nam nesciunt nulla odit perferendis perspiciatis possimus quod quos similique sint suscipit temporibus unde veritatis voluptatibus? Ab ad, adipisci animi beatae ea eaque eligendi explicabo id impedit itaque magni mollitia nihil numquam obcaecati odit officia omnis perferendis porro quaerat quasi quod repellendus sint sunt suscipit, tenetur vel veniam. Ad animi architecto, aspernatur at blanditiis cumque delectus deleniti dolorem dolorum eos eum eveniet facilis fuga fugiat hic ipsam iure laboriosam maiores natus nisi nobis nulla officiis optio perferendis porro quaerat quam qui quo, repellat sed similique sint suscipit tenetur ullam veritatis vitae voluptates. A ad illo minima nisi nobis vitae voluptatem? Autem deleniti error maiores minus pariatur porro quidem suscipit!',
- ),
- ]),
- ],
- },
- ),
- )
- }),
- })
- const dialog = useDialog({
- name: 'playground',
- component: () =>
- new Promise((resolve) => {
- return resolve(
- h(CommonDialog, {
- name: 'playground',
- headerTitle: 'Confirmation',
- content: 'Do you want to continue?',
- }),
- )
- }),
- })
- const { waitForVariantConfirmation } = useConfirmation()
- const deleteTest = async () => {
- const confirmed = await waitForVariantConfirmation('delete')
- if (confirmed) {
- console.log('Item deleted!')
- } else {
- console.log('Item not deleted!')
- }
- }
- const vip = ref(false)
- const tableHeaders = [
- {
- key: 'name',
- label: 'User name',
- },
- {
- key: 'title',
- label: 'Job position',
- truncate: true,
- },
- {
- key: 'email',
- label: 'Email',
- },
- {
- key: 'role',
- label: 'Role',
- },
- ]
- const tableItems = reactive([
- {
- id: 1,
- name: 'Lindsay Walton',
- title: 'Front-end Developer',
- email: 'lindsay.walton@example.com',
- role: 'Member',
- },
- {
- id: 2,
- name: 'Courtney Henry',
- title: 'Designer',
- email: 'courtney.henry@example.com',
- role: 'Admin',
- },
- {
- id: 3,
- name: 'Tom Cook',
- title: 'Director of Product',
- email: 'tom.cook@example.com',
- role: 'Member',
- },
- {
- id: 4,
- name: 'Whitney Francis',
- title: 'Copywriter',
- email: 'whitney.francis@example.com',
- role: 'Admin',
- },
- {
- id: 5,
- name: 'Leonard Krasner',
- title: 'Senior Designer Principal Designer ',
- email: 'leonard.krasner@example.com',
- role: 'Owner',
- },
- {
- id: 6,
- name: 'Floyd Miles',
- title:
- 'Principal Designer for a very long way to go to see the end of the title. It is a very long title, indeed.',
- email: 'floyd.miles@example.com',
- role: 'Member',
- },
- ])
- const tableActions: MenuItem[] = [
- {
- key: 'delete',
- label: 'Delete this row',
- icon: 'trash3',
- show: (data) => !!data?.role,
- onClick: (data) => {
- console.log(data)
- },
- },
- {
- key: 'download',
- label: 'Download this row',
- icon: 'download',
- onClick: (data) => {
- console.log(data)
- },
- },
- ]
- const changeRow = () => {
- tableItems[0].role = tableItems[0].role ? '' : 'Member'
- }
- const { activeTab } = useTabManager<string>()
- const { activeTab: activeFilters } = useTabManager<string[]>()
- const popoverOrientation: Ref<Orientation> = ref('autoVertical')
- const popoverOrientationOptions = [
- {
- value: 'autoVertical',
- label: 'Auto vertical',
- },
- {
- value: 'autoHorizontal',
- label: 'Auto horizontal',
- },
- {
- value: 'top',
- label: 'Top',
- },
- {
- value: 'bottom',
- label: 'Bottom',
- },
- {
- value: 'left',
- label: 'Left',
- },
- {
- value: 'right',
- label: 'Right',
- },
- ]
- const popoverPlacement: Ref<Placement> = ref('start')
- const popoverPlacementOptions = [
- {
- value: 'start',
- label: 'Start',
- },
- {
- value: 'arrowStart',
- label: 'Arrow Start',
- },
- {
- value: 'arrowEnd',
- label: 'Arrow End',
- },
- {
- value: 'end',
- label: 'End',
- },
- ]
- const breadcrumbItems = [
- {
- label: 'Tickets',
- icon: 'logo-flat',
- },
- {
- label: '123456',
- route: 'tickets/1',
- },
- ]
- const popoverHideArrow = ref(false)
- const inlineEditValue = ref('Edit me inline')
- </script>
- <template>
- <LayoutContent :breadcrumb-items="[]">
- <div>
- <div class="w-1/2">
- <h1 id="test" v-tooltip="'Hello world'" class="w-fit">
- Tooltip example
- </h1>
- <h2 title="Buttons" class="text-xl">Buttons</h2>
- <h3 v-tooltip="'another example'">Text only</h3>
- <div class="flex space-x-3 py-2">
- <CommonButton variant="primary" />
- <CommonButton variant="secondary" />
- <CommonButton variant="tertiary" />
- <CommonButton variant="submit" />
- <CommonButton variant="danger" />
- <CommonButton variant="subtle" />
- <CommonButton variant="neutral" />
- </div>
- <h3>With icon</h3>
- <div class="flex space-x-3 py-2">
- <CommonButton variant="primary" prefix-icon="logo-flat" />
- <CommonButton variant="secondary" prefix-icon="logo-flat" />
- <CommonButton variant="tertiary" prefix-icon="logo-flat" />
- <CommonButton variant="submit" prefix-icon="logo-flat" />
- <CommonButton variant="danger" prefix-icon="logo-flat" />
- <CommonButton variant="subtle" prefix-icon="logo-flat" />
- <CommonButton variant="neutral" prefix-icon="logo-flat" />
- </div>
- <h3>Icon only</h3>
- <div class="flex items-center space-x-3 py-2">
- <CommonButton variant="primary" icon="logo-flat" />
- <CommonButton variant="secondary" icon="logo-flat" />
- <CommonButton variant="tertiary" icon="logo-flat" />
- <CommonButton variant="submit" icon="logo-flat" />
- <CommonButton variant="danger" icon="logo-flat" />
- <CommonButton variant="subtle" icon="logo-flat" />
- <CommonButton variant="neutral" icon="logo-flat" />
- <CommonButton variant="primary" icon="logo-flat" size="medium" />
- <CommonButton variant="secondary" icon="logo-flat" size="medium" />
- <CommonButton variant="tertiary" icon="logo-flat" size="medium" />
- <CommonButton variant="submit" icon="logo-flat" size="medium" />
- <CommonButton variant="danger" icon="logo-flat" size="medium" />
- <CommonButton variant="subtle" icon="logo-flat" size="medium" />
- <CommonButton variant="neutral" icon="logo-flat" size="medium" />
- <CommonButton variant="primary" icon="logo-flat" size="large" />
- <CommonButton variant="secondary" icon="logo-flat" size="large" />
- <CommonButton variant="tertiary" icon="logo-flat" size="large" />
- <CommonButton variant="submit" icon="logo-flat" size="large" />
- <CommonButton variant="danger" icon="logo-flat" size="large" />
- <CommonButton variant="subtle" icon="logo-flat" size="large" />
- <CommonButton variant="neutral" icon="logo-flat" size="large" />
- </div>
- <h3>Misc</h3>
- <div class="flex-wrap space-x-3 space-y-2 py-2">
- <CommonButton variant="submit" block>Block</CommonButton>
- <CommonButton variant="primary" disabled>Disabled</CommonButton>
- <CommonButton variant="secondary" disabled>Disabled</CommonButton>
- <CommonButton variant="tertiary" disabled>Disabled</CommonButton>
- <CommonButton variant="submit" disabled>Disabled</CommonButton>
- <CommonButton variant="danger" disabled>Disabled</CommonButton>
- <CommonButton variant="subtle" disabled>Disabled</CommonButton>
- <CommonButton variant="neutral" disabled>Disabled</CommonButton>
- </div>
- <h3>Group</h3>
- <div class="w-1/2 space-x-3 space-y-2 py-2">
- <CommonButtonGroup :items="buttonGroupOptions" />
- </div>
- </div>
- <div class="flex">
- <CommonBreadcrumb class="grow" :items="breadcrumbItems">
- <template #trailing>
- <CommonIcon
- name="clipboard2"
- size="xs"
- class="text-blue-800"
- @click="copyToClipboard('123456')"
- />
- </template>
- </CommonBreadcrumb>
- </div>
- <div class="w-1/2">
- <h2 class="text-xl">Alerts</h2>
- <CommonAlert variant="info" dismissible class="mb-2.5"
- >It's Friday!
- </CommonAlert>
- <CommonAlert variant="success" class="mb-2.5">
- <div class="flex flex-col gap-1.5">
- <CommonLabel class="text-yellow-600" size="large"
- >Similar tickets found</CommonLabel
- >
- <CommonLabel class="text-yellow-600"
- >Tickets with the same attributes were found.</CommonLabel
- >
- <ul class="list-inside list-disc">
- <li>31001 Test Ticket</li>
- </ul>
- </div>
- </CommonAlert>
- <CommonAlert variant="warning" class="mb-2.5"
- >Heee! You're typing too fast.
- </CommonAlert>
- <CommonAlert variant="danger" class="mb-2.5"
- >Ooops! You broke it.
- </CommonAlert>
- </div>
- <div>
- <h2>Labels</h2>
- <CommonLabel size="small" prefix-icon="logo" suffix-icon="logo-flat">
- Small
- </CommonLabel>
- <br />
- <CommonLabel size="medium" prefix-icon="logo" suffix-icon="logo-flat">
- Medium
- </CommonLabel>
- <br />
- <CommonLabel size="large" prefix-icon="logo" suffix-icon="logo-flat">
- Large
- </CommonLabel>
- <br />
- <CommonLabel size="xl" prefix-icon="logo" suffix-icon="logo-flat">
- Extra large
- </CommonLabel>
- </div>
- <div>
- <h2>Badges</h2>
- <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="neutral">
- Neutral
- </CommonBadge>
- <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="info">Info</CommonBadge>
- <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="success">
- Success
- </CommonBadge>
- <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="warning">
- Warning
- </CommonBadge>
- <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="danger">
- Danger
- </CommonBadge>
- <CommonBadge
- class="bg-pink-300 text-white ltr:mr-2 rtl:ml-2 dark:bg-pink-300"
- variant="custom"
- >Custom
- </CommonBadge>
- </div>
- <div class="w-1/5">
- <h2>Progress Bar</h2>
- <div class="flex flex-col gap-3">
- <div class="flex flex-col gap-2">
- <CommonLabel size="small">What is the meaning of life?</CommonLabel>
- <CommonProgressBar />
- </div>
- <div class="flex items-end gap-2">
- <div class="mb-1 flex grow flex-col gap-1">
- <div class="flex justify-between">
- <CommonLabel size="small">Organizations</CommonLabel>
- <CommonLabel
- class="text-stone-200 dark:text-neutral-500"
- size="small"
- >
- {{ progressBarValue }} of 100
- </CommonLabel>
- </div>
- <CommonProgressBar
- :value="progressBarValue.toString()"
- max="100"
- />
- </div>
- <CommonIcon
- class="shrink-0 fill-green-500"
- :class="progressBarValue !== 100 ? 'invisible' : undefined"
- name="check2"
- size="tiny"
- decorative
- />
- </div>
- </div>
- </div>
- <h2 class="mb-2 mt-8">Table</h2>
- <div class="mb-6 flex flex-col gap-4">
- <CommonButton variant="primary" @click="changeRow()"
- >Change row</CommonButton
- >
- <CommonSimpleTable
- :headers="tableHeaders"
- :items="tableItems"
- :actions="tableActions"
- ></CommonSimpleTable>
- </div>
- <div class="w-1/2">
- <h2 class="text-lg">Avatar</h2>
- <div class="my-4 flex items-center gap-4">
- <CommonUserAvatar
- class="cursor-pointer border border-neutral-100 outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:border-gray-900 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/1',
- vip,
- }"
- size="medium"
- />
- <CommonButton
- :variant="vip ? 'neutral' : 'subtle'"
- @click="vip = !vip"
- >
- {{ vip ? 'Make us unimportant :(' : 'Make us important :)' }}
- </CommonButton>
- </div>
- <div class="flex gap-4">
- <CommonUserAvatar
- class="cursor-pointer border border-neutral-100 outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:border-gray-900 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/2',
- firstname: 'Alfa',
- lastname: 'Bravo',
- vip,
- }"
- size="xs"
- />
- <CommonUserAvatar
- class="cursor-pointer border border-neutral-100 outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:border-gray-900 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/3',
- firstname: 'Charlie',
- lastname: 'Delta',
- vip,
- }"
- size="small"
- />
- <CommonUserAvatar
- class="cursor-pointer border border-neutral-100 outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:border-gray-900 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/4',
- firstname: 'Echo',
- lastname: 'Foxtrot',
- vip,
- }"
- size="medium"
- />
- <CommonUserAvatar
- class="cursor-pointer outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/5',
- firstname: 'Golf',
- lastname: 'Hotel',
- vip,
- }"
- size="normal"
- />
- <CommonUserAvatar
- class="cursor-pointer border border-neutral-100 outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:border-gray-900 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/6',
- firstname: 'India',
- lastname: 'Juliett',
- vip,
- }"
- size="large"
- />
- <CommonUserAvatar
- class="cursor-pointer border border-neutral-100 outline outline-2 outline-transparent hover:outline-blue-600 focus:outline-blue-800 dark:border-gray-900 dark:hover:outline-blue-900 dark:hover:focus:outline-blue-800"
- tabindex="0"
- :entity="{
- id: 'gid://zammad/User/7',
- firstname: 'Kilo',
- lastname: 'Lima',
- vip,
- }"
- size="xl"
- />
- </div>
- </div>
- <div>
- <h2 class="text-lg">Popover</h2>
- <div class="mb-2 flex gap-2">
- <FormKit
- v-model="popoverOrientation"
- type="select"
- name="orientation"
- :options="popoverOrientationOptions"
- />
- <FormKit
- v-model="popoverPlacement"
- type="select"
- name="placement"
- :options="popoverPlacementOptions"
- />
- <FormKit
- v-model="popoverHideArrow"
- type="toggle"
- name="placement"
- label="Hide arrow"
- :variants="{ true: 'yes', false: 'no' }"
- />
- </div>
- <template v-if="user">
- <CommonPopover
- ref="popover"
- :owner="popoverTarget"
- :orientation="popoverOrientation"
- :placement="popoverPlacement"
- :hide-arrow="popoverHideArrow"
- >
- <CommonPopoverMenu
- :popover="popover"
- header-label="Erika Mustermann"
- :items="[
- {
- key: 'appearance',
- label: 'Appearance',
- icon: 'brightness-alt-high',
- noCloseOnClick: true,
- onClick: cycleThemeSwitchValue,
- },
- {
- key: 'keyboard-shortcuts',
- label: 'Keyboard shortcuts',
- onClick: () => {
- console.log('OPEN KEYBOARD SHORTCUTS DIALOG')
- },
- icon: 'keyboard',
- },
- {
- key: 'personal-setting',
- label: 'Profile settings',
- link: '/personal-setting',
- icon: 'person-gear',
- },
- {
- key: 'sign-out',
- label: 'Sign out',
- link: '/logout',
- icon: 'box-arrow-in-right',
- separatorTop: true,
- },
- ]"
- >
- <template #itemRight-appearance>
- <div class="flex items-center px-2">
- <ThemeSwitch
- ref="themeSwitch"
- v-model="appearance"
- size="small"
- />
- </div>
- </template>
- </CommonPopoverMenu>
- </CommonPopover>
- <button
- ref="popoverTarget"
- class="-:outline-transparent hover:-:outline-blue-900 rounded-full outline outline-2 focus:outline-blue-800 hover:focus:outline-blue-800"
- :class="{
- 'outline-blue-800 hover:outline-blue-800': popoverIsOpen,
- }"
- @click="toggle(true)"
- >
- <CommonUserAvatar :entity="user" size="large" personal />
- </button>
- </template>
- </div>
- <section>
- <h2>Common Action Menu</h2>
- <CommonActionMenu
- :entity="{ id: 'test-me', name: 'playground' }"
- :actions="[
- {
- key: 'delete-customer',
- label: 'Delete Customer',
- variant: 'danger',
- icon: 'trash3',
- onClick: (data) => {
- console.log(data?.id, data?.name, 'Delete customer')
- },
- },
- {
- key: 'change-customer',
- label: 'Change Customer',
- icon: 'person-gear',
- onClick: (data) => {
- console.log(data?.id, data?.name, 'Change customer')
- },
- },
- ]"
- />
- <h3>Single Action Item</h3>
- <CommonActionMenu
- :entity="{ id: 'test-me', name: 'playground' }"
- :actions="[
- {
- key: 'change-customer',
- label: 'Change Customer',
- icon: 'person-gear',
- onClick: (id) => {
- console.log(id, 'Delete customer')
- },
- },
- ]"
- />
- </section>
- <div>
- <span> Inline Edit </span>
- <CommonInlineEdit
- id="test"
- :value="inlineEditValue"
- @submit-edit="
- (value) => {
- inlineEditValue = value
- }
- "
- />
- </div>
- <div class="w-1/2">
- <h2 class="mb-2 mt-8">Flyout and Dialog</h2>
- <div class="mb-6 flex gap-4">
- <CommonButton variant="tertiary" @click="dialog.open()"
- >Show Dialog
- </CommonButton>
- <CommonButton variant="primary" @click="flyout.open()">
- Open Flyout
- </CommonButton>
- </div>
- <h2 class="mb-2">Confirmation</h2>
- <div class="mb-6 flex gap-4">
- <CommonButton variant="tertiary" @click="deleteTest()"
- >Delete
- </CommonButton>
- </div>
- <h2 class="mb-2 mt-8">Input Copy To Clipboard</h2>
- <div class="mb-6">
- <CommonInputCopyToClipboard
- value="some text to copy"
- label="A label"
- />
- </div>
- </div>
- <div class="w-1/2">
- <h2 class="text-lg">Form</h2>
- <Form
- id="playground-form"
- v-model="formValues"
- form-class="mb-2.5 space-y-2.5"
- :schema="formSchema"
- :initial-values="formInitialValues"
- @submit="console.debug($event)"
- >
- <template #after-fields>
- <div class="my-5 flex items-center justify-end gap-2">
- <CommonButton
- variant="secondary"
- size="medium"
- @click="reset('playground-form')"
- >
- Reset
- </CommonButton>
- <CommonButton variant="submit" type="submit" size="medium">
- Submit
- </CommonButton>
- </div>
- </template>
- </Form>
- <pre
- class="flex flex-wrap gap-5 text-wrap rounded-lg bg-blue-200 p-5 font-mono text-sm text-gray-100 dark:bg-gray-700 dark:text-neutral-400"
- >{{ formValues }}</pre
- >
- </div>
- <h3>Tabs Groups</h3>
- <CommonTabManager
- v-model="activeTab"
- :tabs="[
- { label: 'Tab 1', key: 'tab-1' },
- { label: 'Tab 2', default: true, key: 'tab-2' },
- { label: 'Tab 3', key: 'tab-3' },
- ]"
- />
- <h3>Filter Selector</h3>
- <CommonTabManager
- v-model="activeFilters"
- label="Roles"
- :tabs="[
- { label: 'Admin', key: 'admin' },
- { label: 'Agent', key: 'agent' },
- { label: 'Customer', key: 'customer' },
- ]"
- multiple
- />
- </div>
- </LayoutContent>
- </template>
|