12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { checkbox as checkboxDefinition } from '@formkit/inputs'
- import { has } from '@formkit/utils'
- import { useAppName } from '#shared/composables/useAppName.ts'
- import initializeFieldDefinition from '#shared/form/core/initializeFieldDefinition.ts'
- import formUpdaterTrigger from '#shared/form/features/formUpdaterTrigger.ts'
- import extendSchemaDefinition from '#shared/form/utils/extendSchemaDefinition.ts'
- import type { FormKitNode } from '@formkit/core'
- const addCheckedDataAttribute = (node: FormKitNode) => {
- extendSchemaDefinition(node, 'wrapper', {
- attrs: {
- 'data-is-checked': {
- if: '$value',
- then: 'true',
- else: undefined,
- },
- 'data-test-id': 'checkbox-label',
- },
- })
- }
- const handleAlternativeBorder = (node: FormKitNode) => {
- // The alternative border color below is specific to desktop field design only.
- if (useAppName() !== 'desktop') return
- const { props } = node
- node.addProps(['alternativeBorder'])
- const setClasses = (alternativeBorder: boolean) => {
- if (alternativeBorder) {
- props.decoratorClass =
- 'border-stone-200 dark:border-neutral-500 text-stone-200 dark:text-neutral-500 formkit-checked:border-gray-300 dark:formkit-checked:border-neutral-400 formkit-checked:text-gray-300 dark:formkit-checked:text-neutral-400'
- } else {
- props.decoratorClass =
- 'border-stone-200 dark:border-neutral-500 text-stone-200 dark:text-neutral-500 formkit-checked:border-gray-100 dark:formkit-checked:border-neutral-400 formkit-checked:text-gray-100 dark:formkit-checked:text-neutral-400'
- }
- }
- node.on('created', () => {
- if (!has(props, 'alternativeBorder')) props.alternativeBorder = false
- setClasses(props.alternativeBorder)
- node.on('prop:alternativeBorder', ({ payload }) => {
- setClasses(payload)
- })
- })
- }
- initializeFieldDefinition(checkboxDefinition, {
- props: ['alternativeBorder'],
- features: [
- addCheckedDataAttribute,
- handleAlternativeBorder,
- formUpdaterTrigger(),
- ],
- })
- export default {
- fieldType: 'checkbox',
- definition: checkboxDefinition,
- }
|