Playground.vue 42 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478
  1. <!-- Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/ -->
  2. <!-- eslint-disable zammad/zammad-detect-translatable-string -->
  3. <script setup lang="ts">
  4. import { reset } from '@formkit/core'
  5. import gql from 'graphql-tag'
  6. import { storeToRefs } from 'pinia'
  7. import { computed, h, onMounted, reactive, ref, watch } from 'vue'
  8. import CommonAlert from '#shared/components/CommonAlert/CommonAlert.vue'
  9. import CommonUserAvatar from '#shared/components/CommonUserAvatar/CommonUserAvatar.vue'
  10. import Form from '#shared/components/Form/Form.vue'
  11. import type {
  12. FormSchemaNode,
  13. FormValues,
  14. } from '#shared/components/Form/types.ts'
  15. import { useConfirmation } from '#shared/composables/useConfirmation.ts'
  16. import { useSessionStore } from '#shared/stores/session.ts'
  17. import CommonActionMenu from '#desktop/components/CommonActionMenu/CommonActionMenu.vue'
  18. import CommonButton from '#desktop/components/CommonButton/CommonButton.vue'
  19. import CommonButtonGroup from '#desktop/components/CommonButtonGroup/CommonButtonGroup.vue'
  20. import type { CommonButtonItem } from '#desktop/components/CommonButtonGroup/types.ts'
  21. import CommonDialog from '#desktop/components/CommonDialog/CommonDialog.vue'
  22. import { useDialog } from '#desktop/components/CommonDialog/useDialog.ts'
  23. import CommonFlyout from '#desktop/components/CommonFlyout/CommonFlyout.vue'
  24. import { useFlyout } from '#desktop/components/CommonFlyout/useFlyout.ts'
  25. import CommonInputCopyToClipboard from '#desktop/components/CommonInputCopyToClipboard/CommonInputCopyToClipboard.vue'
  26. import CommonPopover from '#desktop/components/CommonPopover/CommonPopover.vue'
  27. import CommonPopoverMenu from '#desktop/components/CommonPopover/CommonPopoverMenu.vue'
  28. import type { MenuItem } from '#desktop/components/CommonPopover/types.ts'
  29. import { usePopover } from '#desktop/components/CommonPopover/usePopover.ts'
  30. import CommonProgressBar from '#desktop/components/CommonProgressBar/CommonProgressBar.vue'
  31. import CommonSimpleTable from '#desktop/components/CommonSimpleTable/CommonSimpleTable.vue'
  32. import CommonTabManager from '#desktop/components/CommonTabManager/CommonTabManager.vue'
  33. import type { Tab } from '#desktop/components/CommonTabManager/types.ts'
  34. import { useTabManager } from '#desktop/components/CommonTabManager/useTabManager.ts'
  35. import LayoutContent from '#desktop/components/layout/LayoutContent.vue'
  36. import ThemeSwitch from '#desktop/components/ThemeSwitch/ThemeSwitch.vue'
  37. import type { ThemeSwitchInstance } from '#desktop/components/ThemeSwitch/types.ts'
  38. const alphabetOptions = computed(() =>
  39. [...Array(26).keys()].map((i) => ({
  40. value: i,
  41. label: `Item ${String.fromCharCode(65 + i)}`,
  42. disabled: Math.random() < 0.5,
  43. })),
  44. )
  45. const longOption = ref({
  46. value: 999,
  47. label:
  48. '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',
  49. })
  50. const permissions = [
  51. {
  52. value: 'admin',
  53. label: 'Admin interface',
  54. description: 'To configure your system.',
  55. children: [
  56. {
  57. value: 'admin.user',
  58. label: 'Users',
  59. description: 'To manage all users of your system.',
  60. },
  61. {
  62. value: 'admin.group',
  63. label: 'Groups',
  64. description: 'To manage groups of your system.',
  65. },
  66. {
  67. value: 'admin.role',
  68. label: 'Roles',
  69. description: 'To manage roles of your system.',
  70. },
  71. {
  72. value: 'admin.organization',
  73. label: 'Organizations',
  74. description: 'To manage all organizations of your system.',
  75. },
  76. {
  77. value: 'admin.overview',
  78. label: 'Overviews',
  79. description: 'To manage ticket overviews of your system.',
  80. },
  81. {
  82. value: 'admin.text_module',
  83. label: 'Text modules',
  84. description: 'To manage text modules of your system.',
  85. },
  86. {
  87. value: 'admin.macro',
  88. label: 'Macros',
  89. description: 'To manage ticket macros of your system.',
  90. },
  91. {
  92. value: 'admin.template',
  93. label: 'Templates',
  94. description: 'To manage ticket templates of your system.',
  95. },
  96. {
  97. value: 'admin.tag',
  98. label: 'Tags',
  99. description: 'To manage ticket tags of your system.',
  100. },
  101. {
  102. value: 'admin.calendar',
  103. label: 'Calendar',
  104. description: 'To manage calendars of your system.',
  105. },
  106. {
  107. value: 'admin.sla',
  108. label: 'SLAs',
  109. description: 'To manage Service Level Agreements of your system.',
  110. },
  111. {
  112. value: 'admin.trigger',
  113. label: 'Trigger',
  114. description: 'To manage triggers of your system.',
  115. },
  116. {
  117. value: 'admin.public_links',
  118. label: 'Public Links',
  119. description: 'To manage public links of your system.',
  120. },
  121. {
  122. value: 'admin.webhook',
  123. label: 'Webhook',
  124. description: 'To manage webhooks of your system.',
  125. },
  126. {
  127. value: 'admin.scheduler',
  128. label: 'Scheduler',
  129. description: 'To manage schedulers of your system.',
  130. },
  131. {
  132. value: 'admin.report_profile',
  133. label: 'Report Profiles',
  134. description: 'To manage report profiles of your system.',
  135. },
  136. {
  137. value: 'admin.time_accounting',
  138. label: 'Time Accounting',
  139. description: 'To manage time accounting settings of your system.',
  140. },
  141. {
  142. value: 'admin.knowledge_base',
  143. label: 'Knowledge Base',
  144. description: 'To create and set up Knowledge Base.',
  145. },
  146. {
  147. value: 'admin.channel_web',
  148. label: 'Web',
  149. description: 'To manage web channel of your system.',
  150. },
  151. {
  152. value: 'admin.channel_formular',
  153. label: 'Form',
  154. description: 'To manage form channel of your system.',
  155. },
  156. {
  157. value: 'admin.channel_email',
  158. label: 'Email',
  159. description: 'To manage email channel of your system.',
  160. },
  161. {
  162. value: 'admin.channel_sms',
  163. label: 'SMS',
  164. description: 'To manage SMS channel of your system.',
  165. },
  166. {
  167. value: 'admin.channel_chat',
  168. label: 'Chat',
  169. description: 'To manage chat channel of your system.',
  170. },
  171. {
  172. value: 'admin.channel_google',
  173. label: 'Google',
  174. description: 'To manage Google channel of your system.',
  175. },
  176. {
  177. value: 'admin.channel_microsoft365',
  178. label: ' Microsoft 365',
  179. description: 'To manage Microsoft 365 channel of your system.',
  180. },
  181. {
  182. value: 'admin.channel_twitter',
  183. label: 'Twitter',
  184. description: 'To manage Twitter channel of your system.',
  185. },
  186. {
  187. value: 'admin.channel_facebook',
  188. label: 'Facebook',
  189. description: 'To manage Facebook channel of your system.',
  190. },
  191. {
  192. value: 'admin.channel_telegram',
  193. label: 'Telegram',
  194. description: 'To manage Telegram channel of your system.',
  195. },
  196. {
  197. value: 'admin.channel_whatsapp',
  198. label: 'WhatsApp',
  199. description: 'To manage WhatsApp channel of your system.',
  200. },
  201. {
  202. value: 'admin.branding',
  203. label: 'Branding',
  204. description: 'To manage branding settings of your system.',
  205. },
  206. {
  207. value: 'admin.setting_system',
  208. label: 'System',
  209. description: 'To manage core system settings.',
  210. },
  211. {
  212. value: 'admin.security',
  213. label: 'Security',
  214. description: 'To manage security settings of your system.',
  215. },
  216. {
  217. value: 'admin.ticket',
  218. label: 'Ticket',
  219. description: 'To manage ticket settings of your system.',
  220. },
  221. {
  222. value: 'admin.integration',
  223. label: 'Integrations',
  224. description: 'To manage integrations of your system.',
  225. },
  226. {
  227. value: 'admin.api',
  228. label: 'API',
  229. description: 'To manage API of your system.',
  230. },
  231. {
  232. value: 'admin.object',
  233. label: 'Objects',
  234. description: 'To manage object attributes of your system.',
  235. },
  236. {
  237. value: 'admin.ticket_state',
  238. label: 'Ticket States',
  239. description: 'To manage ticket states of your system.',
  240. },
  241. {
  242. value: 'admin.ticket_priority',
  243. label: 'Ticket Priorities',
  244. description: 'To manage ticket priorities of your system.',
  245. },
  246. {
  247. value: 'admin.core_workflow',
  248. label: 'Core Workflows',
  249. description: 'To manage core workflows of your system.',
  250. },
  251. {
  252. value: 'admin.translation',
  253. label: 'Translations',
  254. description: 'To manage translations of your system.',
  255. },
  256. {
  257. value: 'admin.data_privacy',
  258. label: 'Data Privacy',
  259. description: 'To delete existing data of your system.',
  260. },
  261. {
  262. value: 'admin.maintenance',
  263. label: 'Maintenance',
  264. description: 'To manage maintenance mode of your system.',
  265. },
  266. {
  267. value: 'admin.monitoring',
  268. label: 'Monitoring',
  269. description: 'To manage monitoring of your system.',
  270. },
  271. {
  272. value: 'admin.package',
  273. label: 'Packages',
  274. description: 'To manage packages of your system.',
  275. },
  276. {
  277. value: 'admin.session',
  278. label: 'Sessions',
  279. description: 'To manage active user sessions of your system.',
  280. },
  281. {
  282. value: 'admin.system_report',
  283. label: 'System Report',
  284. description: 'To manage system report of your system.',
  285. },
  286. ],
  287. },
  288. {
  289. value: 'chat',
  290. label: 'Chat',
  291. description: 'To access the chat interface.',
  292. disabled: true,
  293. children: [
  294. {
  295. value: 'chat.agent',
  296. label: 'Agent Chat',
  297. description: 'To access the agent chat features.',
  298. },
  299. ],
  300. },
  301. {
  302. value: 'cti',
  303. label: 'Phone',
  304. description: 'To access the phone interface.',
  305. disabled: true,
  306. children: [
  307. {
  308. value: 'cti.agent',
  309. label: 'Agent Phone',
  310. description: 'To access the agent phone features.',
  311. },
  312. ],
  313. },
  314. {
  315. value: 'knowledge_base',
  316. label: 'Knowledge Base',
  317. description: 'To access the knowledge base interface.',
  318. disabled: true,
  319. children: [
  320. {
  321. value: 'knowledge_base.editor',
  322. label: 'Knowledge Base Editor',
  323. description: 'To access the knowledge base editor features.',
  324. },
  325. {
  326. value: 'knowledge_base.reader',
  327. label: 'Knowledge Base Reader',
  328. description: 'To access the knowledge base reader features.',
  329. },
  330. ],
  331. },
  332. {
  333. value: 'report',
  334. label: 'Report',
  335. description: 'To access the report interface.',
  336. },
  337. {
  338. value: 'ticket',
  339. label: 'Ticket',
  340. description: 'To access the ticket interface.',
  341. disabled: true,
  342. children: [
  343. {
  344. value: 'ticket.agent',
  345. label: 'Agent Tickets',
  346. description: 'To access the agent tickets based on group access.',
  347. },
  348. {
  349. value: 'ticket.customer',
  350. label: 'Customer Tickets',
  351. description: 'To access the customer tickets.',
  352. },
  353. ],
  354. },
  355. {
  356. value: 'user_preferences',
  357. label: 'Profile settings',
  358. description: 'To access the personal settings.',
  359. children: [
  360. {
  361. value: 'user_preferences.appearance',
  362. label: 'Appearance',
  363. description: 'To access the appearance personal setting.',
  364. },
  365. {
  366. value: 'user_preferences.language',
  367. label: 'Language',
  368. description: 'To access the language personal setting.',
  369. },
  370. {
  371. value: 'user_preferences.avatar',
  372. label: 'Avatar',
  373. description: 'To access the avatar personal setting.',
  374. },
  375. {
  376. value: 'user_preferences.out_of_office',
  377. label: 'Out of Office',
  378. description: 'To access the out of office personal setting.',
  379. },
  380. {
  381. value: 'user_preferences.password',
  382. label: 'Password',
  383. description: 'To access the change password personal setting.',
  384. },
  385. {
  386. value: 'user_preferences.two_factor_authentication',
  387. label: 'Two-factor Authentication',
  388. description:
  389. 'To access the two-factor authentication personal setting.',
  390. },
  391. {
  392. value: 'user_preferences.device',
  393. label: 'Devices',
  394. description: 'To access the devices personal setting.',
  395. },
  396. {
  397. value: 'user_preferences.access_token',
  398. label: 'Token Access',
  399. description: 'To access the API token personal setting.',
  400. },
  401. {
  402. value: 'user_preferences.linked_accounts',
  403. label: 'Linked Accounts',
  404. description: 'To access the linked accounts personal setting.',
  405. },
  406. {
  407. value: 'user_preferences.notifications',
  408. label: 'Notifications',
  409. description: 'To access the notifications personal setting.',
  410. },
  411. {
  412. value: 'user_preferences.overview_sorting',
  413. label: 'Overviews',
  414. description: 'To access the overviews personal setting.',
  415. },
  416. {
  417. value: 'user_preferences.calendar',
  418. label: 'Calendar',
  419. description: 'To access the calendar personal setting.',
  420. },
  421. ],
  422. },
  423. ]
  424. const treeselectOptions = [
  425. {
  426. value: 0,
  427. label: 'Item A',
  428. disabled: true,
  429. children: [
  430. {
  431. value: 1,
  432. label: 'Item 1',
  433. children: [
  434. {
  435. value: 2,
  436. label: 'Item I',
  437. },
  438. {
  439. value: 3,
  440. label: 'Item II',
  441. },
  442. {
  443. value: 4,
  444. label: 'Item III',
  445. },
  446. ],
  447. },
  448. {
  449. value: 5,
  450. label: 'Item 2',
  451. children: [
  452. ...[longOption.value],
  453. {
  454. value: 6,
  455. label: 'Item IV',
  456. },
  457. ],
  458. },
  459. {
  460. value: 7,
  461. label: 'Item 3',
  462. },
  463. ],
  464. },
  465. {
  466. value: 8,
  467. label: 'Item B',
  468. },
  469. {
  470. value: 9,
  471. label: 'Ítem C',
  472. },
  473. ]
  474. const buttonGroupOptions: CommonButtonItem[] = [
  475. {
  476. label: 'Button 1',
  477. variant: 'primary',
  478. icon: 'logo-flat',
  479. onActionClick: () => console.debug('Button 1 clicked'),
  480. },
  481. {
  482. label: 'Button 2',
  483. variant: 'secondary',
  484. },
  485. {
  486. label: 'Button 3',
  487. variant: 'tertiary',
  488. },
  489. {
  490. label: 'Button 4',
  491. variant: 'submit',
  492. },
  493. {
  494. label: 'Button 5',
  495. variant: 'danger',
  496. },
  497. {
  498. label: 'Button 6',
  499. variant: 'subtle',
  500. },
  501. {
  502. label: 'Button 7',
  503. variant: 'neutral',
  504. },
  505. ]
  506. const formSchema = [
  507. {
  508. isLayout: true,
  509. element: 'div',
  510. attrs: {
  511. class: 'grid md:grid-cols-2 gap-y-2.5 gap-x-3',
  512. },
  513. children: [
  514. {
  515. name: 'select_0',
  516. label: 'Column select',
  517. type: 'select',
  518. outerClass: 'col-span-1',
  519. props: {
  520. maxLength: 150,
  521. options: [...alphabetOptions.value, ...[longOption.value]],
  522. clearable: true,
  523. help: 'Testing',
  524. },
  525. },
  526. {
  527. name: 'toggle_1',
  528. label: 'Column toggle',
  529. type: 'toggle',
  530. outerClass: 'col-span-1',
  531. wrapperClass: 'md:mt-6',
  532. props: {
  533. variants: {
  534. true: 'yes',
  535. false: 'no',
  536. },
  537. },
  538. },
  539. {
  540. name: 'toggle_2',
  541. label: 'Row toggle',
  542. type: 'toggle',
  543. props: {
  544. variants: {
  545. true: 'yes',
  546. false: 'no',
  547. },
  548. },
  549. },
  550. ],
  551. },
  552. {
  553. type: 'permissions',
  554. name: 'permissions',
  555. label: 'Permissions',
  556. props: {
  557. options: permissions,
  558. },
  559. value: ['ticket.agent'],
  560. },
  561. {
  562. type: 'autocomplete',
  563. name: 'autocomplete',
  564. label: 'Autocomplete',
  565. props: {
  566. clearable: true,
  567. gqlQuery: gql`
  568. query autocompleteSearchUser($input: AutocompleteSearchUserInput!) {
  569. autocompleteSearchUser(input: $input) {
  570. value
  571. label
  572. disabled
  573. icon
  574. }
  575. }
  576. `,
  577. },
  578. },
  579. {
  580. type: 'externalDataSource',
  581. name: 'external_data_source',
  582. label: 'External Data Source',
  583. object: 'Ticket',
  584. help: 'Please add external_data_source attribute on Ticket object. Otherwise this field will not work.',
  585. },
  586. {
  587. type: 'agent',
  588. name: 'agent',
  589. label: 'Agent',
  590. props: {
  591. clearable: true,
  592. },
  593. },
  594. {
  595. type: 'recipient',
  596. name: 'recipient',
  597. label: 'Recipient',
  598. props: {
  599. clearable: true,
  600. },
  601. },
  602. {
  603. type: 'recipient',
  604. name: 'recipient_multiple',
  605. label: 'Recipient (multiple)',
  606. props: {
  607. clearable: true,
  608. multiple: true,
  609. },
  610. },
  611. {
  612. type: 'customer',
  613. name: 'customer',
  614. label: 'Customer',
  615. props: {
  616. clearable: true,
  617. link: '/',
  618. linkIcon: 'person-add',
  619. },
  620. },
  621. {
  622. type: 'organization',
  623. name: 'organization',
  624. label: 'Organization',
  625. props: {
  626. clearable: true,
  627. options: [
  628. {
  629. value: 1,
  630. label: 'Zammad Foundation',
  631. organization: {
  632. active: true,
  633. },
  634. },
  635. ],
  636. },
  637. },
  638. {
  639. name: 'date_0',
  640. label: 'Date',
  641. type: 'date',
  642. props: {
  643. clearable: true,
  644. },
  645. },
  646. {
  647. name: 'date_1',
  648. label: 'Date range',
  649. type: 'date',
  650. props: {
  651. clearable: true,
  652. range: true,
  653. },
  654. },
  655. {
  656. name: 'datetime_0',
  657. label: 'Date/Time',
  658. type: 'datetime',
  659. props: {
  660. clearable: true,
  661. },
  662. },
  663. {
  664. name: 'group_permission_0',
  665. label: 'Group permissions',
  666. type: 'groupPermissions',
  667. props: {
  668. options: [
  669. {
  670. value: 1,
  671. label: 'Users',
  672. },
  673. {
  674. value: 2,
  675. label: 'some_group1',
  676. children: [
  677. {
  678. value: 3,
  679. label: 'Nested group',
  680. },
  681. ],
  682. },
  683. ],
  684. },
  685. },
  686. {
  687. type: 'select',
  688. name: 'select_1',
  689. label: 'Single select',
  690. clearable: true,
  691. props: {
  692. options: [...alphabetOptions.value, ...[longOption.value]],
  693. },
  694. },
  695. {
  696. type: 'select',
  697. name: 'select_2',
  698. label: 'Multi select',
  699. clearable: true,
  700. props: {
  701. multiple: true,
  702. options: [...alphabetOptions.value, ...[longOption.value]],
  703. },
  704. },
  705. {
  706. type: 'treeselect',
  707. name: 'treeselect_1',
  708. label: 'Single treeselect',
  709. clearable: true,
  710. props: {
  711. options: treeselectOptions,
  712. },
  713. },
  714. {
  715. type: 'treeselect',
  716. name: 'treeselect_2',
  717. label: 'Multi treeselect',
  718. clearable: true,
  719. props: {
  720. multiple: true,
  721. options: treeselectOptions,
  722. },
  723. },
  724. {
  725. type: 'toggleList',
  726. name: 'roles',
  727. label: 'Roles',
  728. props: {
  729. options: [
  730. { value: 3, label: 'name only' },
  731. { value: 1, label: 'Long name', description: 'Note here' },
  732. {
  733. value: 1111,
  734. label: 'Another long name',
  735. description: 'Note here again',
  736. },
  737. ],
  738. },
  739. },
  740. {
  741. type: 'radioList',
  742. name: 'radioRoles',
  743. label: 'Radio roles',
  744. value: 1,
  745. props: {
  746. options: [
  747. { value: 3, label: 'name only' },
  748. { value: 33333, label: 'name onlyyyy' },
  749. { value: 1, label: 'Long name', description: 'Note here' },
  750. {
  751. value: 1111,
  752. label: 'Another long name',
  753. description: 'Note here again',
  754. },
  755. ],
  756. },
  757. },
  758. ]
  759. const formValues = ref()
  760. const formInitialValues: FormValues = {
  761. roles: [3, 1],
  762. // date_0: [new Date(), new Date(new Date().setDate(new Date().getDate() + 7))],
  763. }
  764. const progressBarValue = ref(0)
  765. const increaseProgressBar = () => {
  766. progressBarValue.value += 25
  767. }
  768. onMounted(() => {
  769. setInterval(increaseProgressBar, 2000)
  770. })
  771. watch(progressBarValue, (newValue) => {
  772. if (newValue < 100) return
  773. setTimeout(() => {
  774. progressBarValue.value = 0
  775. }, 1000)
  776. })
  777. const session = useSessionStore()
  778. const { user } = storeToRefs(session)
  779. const { isOpen: popoverIsOpen, popover, popoverTarget, toggle } = usePopover()
  780. const themeSwitch = ref<ThemeSwitchInstance>()
  781. const cycleThemeSwitchValue = () => {
  782. themeSwitch.value?.cycleValue()
  783. }
  784. const appearance = ref('auto')
  785. const schema: FormSchemaNode[] = [
  786. {
  787. type: 'text',
  788. name: 'code',
  789. label: 'Test',
  790. required: true,
  791. props: {
  792. help: 'Enter here something',
  793. },
  794. },
  795. ]
  796. const flyout = useFlyout({
  797. name: 'playground',
  798. component: () =>
  799. new Promise((resolve) => {
  800. return resolve(
  801. h(
  802. CommonFlyout,
  803. {
  804. onClose: () => {
  805. console.log(
  806. '%c %s',
  807. 'color: red; font-size: 16px',
  808. 'Flyout closed!',
  809. )
  810. },
  811. onAction: () => {
  812. console.log(
  813. '%c %s',
  814. 'color: green; font-size: 16px',
  815. 'Flyout action!',
  816. )
  817. },
  818. name: 'playground',
  819. headerTitle: 'Hello Playground',
  820. persistWidth: true,
  821. headerIcon: 'buildings',
  822. footerActionOptions: {
  823. actionLabel: 'Submit test',
  824. cancelLabel: 'Adios',
  825. actionButton: {
  826. type: 'submit',
  827. variant: 'primary',
  828. prefixIcon: 'check2',
  829. },
  830. },
  831. },
  832. {
  833. default: () => [
  834. h('div', { class: 'py-1' }, [
  835. h('input'),
  836. h(Form, { ref: 'flyoutForm', schema }),
  837. h('div', { class: 'w-[400px]', innerHTML: 'Hello world!' }),
  838. h(
  839. 'p',
  840. ' 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!',
  841. ),
  842. ]),
  843. ],
  844. },
  845. ),
  846. )
  847. }),
  848. })
  849. const dialog = useDialog({
  850. name: 'playground',
  851. component: () =>
  852. new Promise((resolve) => {
  853. return resolve(
  854. h(CommonDialog, {
  855. name: 'playground',
  856. headerTitle: 'Confirmation',
  857. content: 'Do you want to continue?',
  858. }),
  859. )
  860. }),
  861. })
  862. const { waitForVariantConfirmation } = useConfirmation()
  863. const deleteTest = async () => {
  864. const confirmed = await waitForVariantConfirmation('delete')
  865. if (confirmed) {
  866. console.log('Item deleted!')
  867. } else {
  868. console.log('Item not deleted!')
  869. }
  870. }
  871. const vip = ref(false)
  872. const tableHeaders = [
  873. {
  874. key: 'name',
  875. label: 'User name',
  876. },
  877. {
  878. key: 'title',
  879. label: 'Job position',
  880. truncate: true,
  881. },
  882. {
  883. key: 'email',
  884. label: 'Email',
  885. },
  886. {
  887. key: 'role',
  888. label: 'Role',
  889. },
  890. ]
  891. const tableItems = reactive([
  892. {
  893. id: 1,
  894. name: 'Lindsay Walton',
  895. title: 'Front-end Developer',
  896. email: 'lindsay.walton@example.com',
  897. role: 'Member',
  898. },
  899. {
  900. id: 2,
  901. name: 'Courtney Henry',
  902. title: 'Designer',
  903. email: 'courtney.henry@example.com',
  904. role: 'Admin',
  905. },
  906. {
  907. id: 3,
  908. name: 'Tom Cook',
  909. title: 'Director of Product',
  910. email: 'tom.cook@example.com',
  911. role: 'Member',
  912. },
  913. {
  914. id: 4,
  915. name: 'Whitney Francis',
  916. title: 'Copywriter',
  917. email: 'whitney.francis@example.com',
  918. role: 'Admin',
  919. },
  920. {
  921. id: 5,
  922. name: 'Leonard Krasner',
  923. title: 'Senior Designer Principal Designer ',
  924. email: 'leonard.krasner@example.com',
  925. role: 'Owner',
  926. },
  927. {
  928. id: 6,
  929. name: 'Floyd Miles',
  930. title:
  931. 'Principal Designer for a very long way to go to see the end of the title. It is a very long title, indeed.',
  932. email: 'floyd.miles@example.com',
  933. role: 'Member',
  934. },
  935. ])
  936. const tableActions: MenuItem[] = [
  937. {
  938. key: 'delete',
  939. label: 'Delete this row',
  940. icon: 'trash3',
  941. show: (data) => !!data?.role,
  942. onClick: (data) => {
  943. console.log(data)
  944. },
  945. },
  946. {
  947. key: 'download',
  948. label: 'Download this row',
  949. icon: 'download',
  950. onClick: (data) => {
  951. console.log(data)
  952. },
  953. },
  954. ]
  955. const changeRow = () => {
  956. tableItems[0].role = tableItems[0].role ? '' : 'Member'
  957. }
  958. const { activeTab } = useTabManager<string>()
  959. const { activeTab: activeFilters } = useTabManager<Tab[]>()
  960. </script>
  961. <template>
  962. <LayoutContent :breadcrumb-items="[]">
  963. <div>
  964. <div class="w-1/2">
  965. <h1 id="test" v-tooltip="'Hello world'" class="w-fit">
  966. Tooltip example
  967. </h1>
  968. <h2 title="Buttons" class="text-xl">Buttons</h2>
  969. <h3 v-tooltip="'another example'">Text only</h3>
  970. <div class="flex space-x-3 py-2">
  971. <CommonButton variant="primary" />
  972. <CommonButton variant="secondary" />
  973. <CommonButton variant="tertiary" />
  974. <CommonButton variant="submit" />
  975. <CommonButton variant="danger" />
  976. <CommonButton variant="subtle" />
  977. <CommonButton variant="neutral" />
  978. </div>
  979. <h3>With icon</h3>
  980. <div class="flex space-x-3 py-2">
  981. <CommonButton variant="primary" prefix-icon="logo-flat" />
  982. <CommonButton variant="secondary" prefix-icon="logo-flat" />
  983. <CommonButton variant="tertiary" prefix-icon="logo-flat" />
  984. <CommonButton variant="submit" prefix-icon="logo-flat" />
  985. <CommonButton variant="danger" prefix-icon="logo-flat" />
  986. <CommonButton variant="subtle" prefix-icon="logo-flat" />
  987. <CommonButton variant="neutral" prefix-icon="logo-flat" />
  988. </div>
  989. <h3>Icon only</h3>
  990. <div class="flex items-center space-x-3 py-2">
  991. <CommonButton variant="primary" icon="logo-flat" />
  992. <CommonButton variant="secondary" icon="logo-flat" />
  993. <CommonButton variant="tertiary" icon="logo-flat" />
  994. <CommonButton variant="submit" icon="logo-flat" />
  995. <CommonButton variant="danger" icon="logo-flat" />
  996. <CommonButton variant="subtle" icon="logo-flat" />
  997. <CommonButton variant="neutral" icon="logo-flat" />
  998. <CommonButton variant="primary" icon="logo-flat" size="medium" />
  999. <CommonButton variant="secondary" icon="logo-flat" size="medium" />
  1000. <CommonButton variant="tertiary" icon="logo-flat" size="medium" />
  1001. <CommonButton variant="submit" icon="logo-flat" size="medium" />
  1002. <CommonButton variant="danger" icon="logo-flat" size="medium" />
  1003. <CommonButton variant="subtle" icon="logo-flat" size="medium" />
  1004. <CommonButton variant="neutral" icon="logo-flat" size="medium" />
  1005. <CommonButton variant="primary" icon="logo-flat" size="large" />
  1006. <CommonButton variant="secondary" icon="logo-flat" size="large" />
  1007. <CommonButton variant="tertiary" icon="logo-flat" size="large" />
  1008. <CommonButton variant="submit" icon="logo-flat" size="large" />
  1009. <CommonButton variant="danger" icon="logo-flat" size="large" />
  1010. <CommonButton variant="subtle" icon="logo-flat" size="large" />
  1011. <CommonButton variant="neutral" icon="logo-flat" size="large" />
  1012. </div>
  1013. <h3>Misc</h3>
  1014. <div class="flex-wrap space-x-3 space-y-2 py-2">
  1015. <CommonButton variant="submit" block>Block</CommonButton>
  1016. <CommonButton variant="primary" disabled>Disabled</CommonButton>
  1017. <CommonButton variant="secondary" disabled>Disabled</CommonButton>
  1018. <CommonButton variant="tertiary" disabled>Disabled</CommonButton>
  1019. <CommonButton variant="submit" disabled>Disabled</CommonButton>
  1020. <CommonButton variant="danger" disabled>Disabled</CommonButton>
  1021. <CommonButton variant="subtle" disabled>Disabled</CommonButton>
  1022. <CommonButton variant="neutral" disabled>Disabled</CommonButton>
  1023. </div>
  1024. <h3>Group</h3>
  1025. <div class="w-1/2 space-x-3 space-y-2 py-2">
  1026. <CommonButtonGroup :items="buttonGroupOptions" />
  1027. </div>
  1028. </div>
  1029. <div class="w-1/2">
  1030. <h2 class="text-xl">Alerts</h2>
  1031. <CommonAlert
  1032. variant="info"
  1033. dismissible
  1034. link="https://youtu.be/U6n2NcJ7rLc"
  1035. link-text="Party 🎉"
  1036. class="mb-2.5"
  1037. >It's Friday!
  1038. </CommonAlert>
  1039. <CommonAlert variant="success" class="mb-2.5"
  1040. >Hooray! Ticket got updated.
  1041. </CommonAlert>
  1042. <CommonAlert variant="warning" class="mb-2.5"
  1043. >Heee! You're typing too fast.
  1044. </CommonAlert>
  1045. <CommonAlert variant="danger" class="mb-2.5"
  1046. >Ooops! You broke it.
  1047. </CommonAlert>
  1048. </div>
  1049. <div>
  1050. <h2>Labels</h2>
  1051. <CommonLabel size="small" prefix-icon="logo" suffix-icon="logo-flat">
  1052. Small
  1053. </CommonLabel>
  1054. <br />
  1055. <CommonLabel size="medium" prefix-icon="logo" suffix-icon="logo-flat">
  1056. Medium
  1057. </CommonLabel>
  1058. <br />
  1059. <CommonLabel size="large" prefix-icon="logo" suffix-icon="logo-flat">
  1060. Large
  1061. </CommonLabel>
  1062. <br />
  1063. <CommonLabel size="xl" prefix-icon="logo" suffix-icon="logo-flat">
  1064. Extra large
  1065. </CommonLabel>
  1066. </div>
  1067. <div>
  1068. <h2>Badges</h2>
  1069. <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="neutral">
  1070. Neutral
  1071. </CommonBadge>
  1072. <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="info">Info</CommonBadge>
  1073. <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="success">
  1074. Success
  1075. </CommonBadge>
  1076. <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="warning">
  1077. Warning
  1078. </CommonBadge>
  1079. <CommonBadge class="ltr:mr-2 rtl:ml-2" variant="danger">
  1080. Danger
  1081. </CommonBadge>
  1082. <CommonBadge
  1083. class="bg-pink-300 text-white ltr:mr-2 rtl:ml-2 dark:bg-pink-300"
  1084. variant="custom"
  1085. >Custom
  1086. </CommonBadge>
  1087. </div>
  1088. <div class="w-1/5">
  1089. <h2>Progress Bar</h2>
  1090. <div class="flex flex-col gap-3">
  1091. <div class="flex flex-col gap-2">
  1092. <CommonLabel size="small">What is the meaning of life?</CommonLabel>
  1093. <CommonProgressBar />
  1094. </div>
  1095. <div class="flex items-end gap-2">
  1096. <div class="mb-1 flex grow flex-col gap-1">
  1097. <div class="flex justify-between">
  1098. <CommonLabel size="small">Organizations</CommonLabel>
  1099. <CommonLabel
  1100. class="text-stone-200 dark:text-neutral-500"
  1101. size="small"
  1102. >
  1103. {{ progressBarValue }} of 100
  1104. </CommonLabel>
  1105. </div>
  1106. <CommonProgressBar
  1107. :value="progressBarValue.toString()"
  1108. max="100"
  1109. />
  1110. </div>
  1111. <CommonIcon
  1112. class="shrink-0 fill-green-500"
  1113. :class="progressBarValue !== 100 ? 'invisible' : undefined"
  1114. name="check2"
  1115. size="tiny"
  1116. decorative
  1117. />
  1118. </div>
  1119. </div>
  1120. </div>
  1121. <h2 class="mb-2 mt-8">Table</h2>
  1122. <div class="mb-6 flex flex-col gap-4">
  1123. <CommonButton variant="primary" @click="changeRow()"
  1124. >Change row</CommonButton
  1125. >
  1126. <CommonSimpleTable
  1127. :headers="tableHeaders"
  1128. :items="tableItems"
  1129. :actions="tableActions"
  1130. ></CommonSimpleTable>
  1131. </div>
  1132. <div class="w-1/2">
  1133. <h2 class="text-lg">Avatar</h2>
  1134. <div class="my-4 flex items-center gap-4">
  1135. <CommonUserAvatar
  1136. 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"
  1137. tabindex="0"
  1138. :entity="{
  1139. id: 'gid://zammad/User/1',
  1140. vip,
  1141. }"
  1142. size="medium"
  1143. />
  1144. <CommonButton
  1145. :variant="vip ? 'neutral' : 'subtle'"
  1146. @click="vip = !vip"
  1147. >
  1148. {{ vip ? 'Make us unimportant :(' : 'Make us important :)' }}
  1149. </CommonButton>
  1150. </div>
  1151. <div class="flex gap-4">
  1152. <CommonUserAvatar
  1153. 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"
  1154. tabindex="0"
  1155. :entity="{
  1156. id: 'gid://zammad/User/2',
  1157. firstname: 'Alfa',
  1158. lastname: 'Bravo',
  1159. vip,
  1160. }"
  1161. size="xs"
  1162. />
  1163. <CommonUserAvatar
  1164. 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"
  1165. tabindex="0"
  1166. :entity="{
  1167. id: 'gid://zammad/User/3',
  1168. firstname: 'Charlie',
  1169. lastname: 'Delta',
  1170. vip,
  1171. }"
  1172. size="small"
  1173. />
  1174. <CommonUserAvatar
  1175. 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"
  1176. tabindex="0"
  1177. :entity="{
  1178. id: 'gid://zammad/User/4',
  1179. firstname: 'Echo',
  1180. lastname: 'Foxtrot',
  1181. vip,
  1182. }"
  1183. size="medium"
  1184. />
  1185. <CommonUserAvatar
  1186. 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"
  1187. tabindex="0"
  1188. :entity="{
  1189. id: 'gid://zammad/User/5',
  1190. firstname: 'Golf',
  1191. lastname: 'Hotel',
  1192. vip,
  1193. }"
  1194. size="normal"
  1195. />
  1196. <CommonUserAvatar
  1197. 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"
  1198. tabindex="0"
  1199. :entity="{
  1200. id: 'gid://zammad/User/6',
  1201. firstname: 'India',
  1202. lastname: 'Juliett',
  1203. vip,
  1204. }"
  1205. size="large"
  1206. />
  1207. <CommonUserAvatar
  1208. 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"
  1209. tabindex="0"
  1210. :entity="{
  1211. id: 'gid://zammad/User/7',
  1212. firstname: 'Kilo',
  1213. lastname: 'Lima',
  1214. vip,
  1215. }"
  1216. size="xl"
  1217. />
  1218. </div>
  1219. </div>
  1220. <div>
  1221. <h2 class="text-lg">Popover</h2>
  1222. <template v-if="user">
  1223. <CommonPopover
  1224. ref="popover"
  1225. :owner="popoverTarget"
  1226. orientation="autoVertical"
  1227. placement="start"
  1228. >
  1229. <CommonPopoverMenu
  1230. :popover="popover"
  1231. header-label="Erika Mustermann"
  1232. :items="[
  1233. {
  1234. key: 'appearance',
  1235. label: 'Appearance',
  1236. icon: 'brightness-alt-high',
  1237. noCloseOnClick: true,
  1238. onClick: cycleThemeSwitchValue,
  1239. },
  1240. {
  1241. key: 'keyboard-shortcuts',
  1242. label: 'Keyboard shortcuts',
  1243. onClick: () => {
  1244. console.log('OPEN KEYBOARD SHORTCUTS DIALOG')
  1245. },
  1246. icon: 'keyboard',
  1247. },
  1248. {
  1249. key: 'personal-setting',
  1250. label: 'Profile settings',
  1251. link: '/personal-setting',
  1252. icon: 'person-gear',
  1253. },
  1254. {
  1255. key: 'sign-out',
  1256. label: 'Sign out',
  1257. link: '/logout',
  1258. icon: 'box-arrow-in-right',
  1259. separatorTop: true,
  1260. },
  1261. ]"
  1262. >
  1263. <template #itemRight-appearance>
  1264. <div class="flex items-center px-2">
  1265. <ThemeSwitch
  1266. ref="themeSwitch"
  1267. v-model="appearance"
  1268. size="small"
  1269. />
  1270. </div>
  1271. </template>
  1272. </CommonPopoverMenu>
  1273. </CommonPopover>
  1274. <button
  1275. ref="popoverTarget"
  1276. class="-:outline-transparent hover:-:outline-blue-900 rounded-full outline outline-2 focus:outline-blue-800 hover:focus:outline-blue-800"
  1277. :class="{
  1278. 'outline-blue-800 hover:outline-blue-800': popoverIsOpen,
  1279. }"
  1280. @click="toggle(true)"
  1281. >
  1282. <CommonUserAvatar :entity="user" size="large" personal />
  1283. </button>
  1284. </template>
  1285. </div>
  1286. <section>
  1287. <h2>Common Action Menu</h2>
  1288. <CommonActionMenu
  1289. :entity="{ id: 'test-me', name: 'playground' }"
  1290. :actions="[
  1291. {
  1292. key: 'delete-customer',
  1293. label: 'Delete Customer',
  1294. variant: 'danger',
  1295. icon: 'trash3',
  1296. onClick: (data) => {
  1297. console.log(data?.id, data?.name, 'Delete customer')
  1298. },
  1299. },
  1300. {
  1301. key: 'change-customer',
  1302. label: 'Change Customer',
  1303. icon: 'person-gear',
  1304. onClick: (data) => {
  1305. console.log(data?.id, data?.name, 'Change customer')
  1306. },
  1307. },
  1308. ]"
  1309. />
  1310. <h3>Single Action Item</h3>
  1311. <CommonActionMenu
  1312. :entity="{ id: 'test-me', name: 'playground' }"
  1313. :actions="[
  1314. {
  1315. key: 'change-customer',
  1316. label: 'Change Customer',
  1317. icon: 'person-gear',
  1318. onClick: (id) => {
  1319. console.log(id, 'Delete customer')
  1320. },
  1321. },
  1322. ]"
  1323. />
  1324. </section>
  1325. <div class="w-1/2">
  1326. <h2 class="mb-2 mt-8">Flyout and Dialog</h2>
  1327. <div class="mb-6 flex gap-4">
  1328. <CommonButton variant="tertiary" @click="dialog.open()"
  1329. >Show Dialog
  1330. </CommonButton>
  1331. <CommonButton variant="primary" @click="flyout.open()">
  1332. Open Flyout
  1333. </CommonButton>
  1334. </div>
  1335. <h2 class="mb-2">Confirmation</h2>
  1336. <div class="mb-6 flex gap-4">
  1337. <CommonButton variant="tertiary" @click="deleteTest()"
  1338. >Delete
  1339. </CommonButton>
  1340. </div>
  1341. <h2 class="mb-2 mt-8">Input Copy To Clipboard</h2>
  1342. <div class="mb-6">
  1343. <CommonInputCopyToClipboard
  1344. value="some text to copy"
  1345. label="A label"
  1346. />
  1347. </div>
  1348. </div>
  1349. <div class="w-1/2">
  1350. <h2 class="text-lg">Form</h2>
  1351. <Form
  1352. id="playground-form"
  1353. v-model="formValues"
  1354. form-class="mb-2.5 space-y-2.5"
  1355. :schema="formSchema"
  1356. :initial-values="formInitialValues"
  1357. @submit="console.debug($event)"
  1358. >
  1359. <template #after-fields>
  1360. <div class="my-5 flex items-center justify-end gap-2">
  1361. <CommonButton
  1362. variant="secondary"
  1363. size="medium"
  1364. @click="reset('playground-form')"
  1365. >
  1366. Reset
  1367. </CommonButton>
  1368. <CommonButton variant="submit" type="submit" size="medium">
  1369. Submit
  1370. </CommonButton>
  1371. </div>
  1372. </template>
  1373. </Form>
  1374. <pre
  1375. class="flex flex-wrap gap-5 rounded-lg bg-blue-200 p-5 font-mono text-sm text-gray-100 dark:bg-gray-700 dark:text-neutral-400"
  1376. >{{ formValues }}</pre
  1377. >
  1378. </div>
  1379. <h3>Tabs Groups</h3>
  1380. <CommonTabManager
  1381. v-model="activeTab"
  1382. :tabs="[
  1383. { label: 'Tab 1', key: 'tab-1' },
  1384. { label: 'Tab 2', default: true, key: 'tab-2' },
  1385. { label: 'Tab 3', key: 'tab-3' },
  1386. ]"
  1387. />
  1388. <h3>Filter Selector</h3>
  1389. <CommonTabManager
  1390. v-model="activeFilters"
  1391. label="Roles"
  1392. :tabs="[
  1393. { label: 'Admin', key: 'admin' },
  1394. { label: 'Agent', key: 'agent' },
  1395. { label: 'Customer', key: 'customer' },
  1396. ]"
  1397. multiple
  1398. />
  1399. </div>
  1400. </LayoutContent>
  1401. </template>