// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { initializeFileClasses } from '#shared/components/Form/fields/FieldFile/initializeFileClasses.ts' import { initializeToggleClasses } from '#shared/components/Form/fields/FieldToggle/initializeToggleClasses.ts' import { initializeFieldEditorClasses, initializeFieldEditorProps, } from '#shared/components/Form/initializeFieldEditor.ts' import { initializeFieldLinkClasses } from '#shared/components/Form/initializeFieldLinkClasses.ts' import { initializeFormClasses } from '#shared/components/Form/initializeFormClasses.ts' import { initializeFormGroupClasses } from '#shared/components/Form/initializeFormGroupClasses.ts' import mainInitializeForm, { getFormPlugins } from '#shared/form/index.ts' import type { FormFieldTypeImportModules, FormThemeExtension, InitializeAppForm, } from '#shared/types/form.ts' import type { ImportGlobEagerOutput } from '#shared/types/utils.ts' import { getCoreDesktopClasses } from './theme/global/getCoreDesktopClasses.ts' import type { FormKitPlugin } from '@formkit/core' import type { App } from 'vue' const pluginModules: ImportGlobEagerOutput = import.meta.glob( './plugins/global/*.ts', { eager: true }, ) export const desktopFormFieldModules: ImportGlobEagerOutput = import.meta.glob('../components/Form/fields/**/index.ts', { eager: true }) const themeExtensionModules: ImportGlobEagerOutput = import.meta.glob('./theme/global/extensions/*.ts', { eager: true }) export const initializeForm: InitializeAppForm = (app: App) => { const plugins = getFormPlugins(pluginModules) const theme = { coreClasses: getCoreDesktopClasses, extensions: themeExtensionModules, } const decoratorIcons = { checkboxDecorator: '', } mainInitializeForm( app, undefined, desktopFormFieldModules, plugins, theme, decoratorIcons, ) } export const initializeFormFields = () => { initializeFormClasses({ loading: 'my-9 fill-yellow-300', }) initializeFieldLinkClasses({ container: 'formkit-link', base: 'ms-3 mb-2.5', link: 'hover:rounded-sm hover:outline hover:outline-1 hover:outline-offset-1 hover:outline-blue-600 dark:hover:outline-blue-900', }) initializeFormGroupClasses({ container: 'form-group grid grid-cols-2 gap-y-2.5 gap-x-3', help: 'text-xs', dirtyMark: 'form-group-mark-dirty', bottomMargin: 'mb-4 last:mb-0', }) initializeToggleClasses({ track: 'bg-stone-200 dark:bg-gray-500 ring-1 ring-neutral-100 dark:ring-gray-900 hover:outline hover:outline-1 hover:outline-offset-2 hover:outline-blue-600 dark:hover:outline-blue-900 focus:outline focus:outline-1 focus:outline-offset-2 focus:outline-blue-800 hover:focus:outline-blue-800 dark:hover:focus:outline-blue-800 formkit-invalid:outline formkit-invalid:outline-1 formkit-invalid:outline-offset-2 formkit-invalid:outline-red-500 dark:hover:formkit-invalid:outline-red-500 formkit-errors:outline formkit-errors:outline-1 formkit-errors:outline-offset-2 formkit-errors:outline-red-500 dark:hover:formkit-errors:outline-red-500', trackOn: '!bg-blue-800', knob: 'bg-white', }) initializeFieldEditorClasses({ actionBar: { buttonContainer: 'gap-1.5 px-2.5 py-2 focus:outline focus:outline-1 focus:outline-offset-2 rounded-md focus:outline-blue-800', tableMenuContainer: 'gap-1.5 px-1.5 py-1.5 focus:outline focus:outline-1 focus:outline-offset-2 rounded-md focus:outline-blue-800', leftGradient: { left: '0', before: { background: { light: `linear-gradient( 270deg, rgba(0, 0, 0, 0), #EDF1F2)`, dark: `linear-gradient( 270deg, rgba(255, 255, 255, 0), #262627`, // :TODO inject tailwind theme colors }, }, }, rightGradient: { before: { background: { light: `linear-gradient( 90deg, rgba(0, 0, 0, 0), #EDF1F2)`, dark: `linear-gradient( 90deg, rgba(255, 255, 255, 0), #262627`, // :TODO inject tailwind theme colors }, }, }, shadowGradient: { before: { top: 'calc(0px - 20px - 1.5rem)', height: 'calc(28px + 1rem)', }, }, button: { base: 'bg-green-200 focus:outline focus:outline-1 focus:outline-offset-2 focus:outline-blue-800 transition-color hover:bg-green-300 dark:hover:bg-neutral-950 text-gray-300 dark:bg-gray-600 dark:text-neutral-400 rounded-lg p-1.5', active: 'bg-green-300 dark:bg-neutral-950', // :TODO adapt if gets adapted in figma }, }, input: { container: 'px-2.5 py-2', }, }) initializeFieldEditorProps({ actionBar: { visible: true, // show action bar always button: { icon: { size: 'tiny', }, }, }, }) initializeFileClasses({ button: 'disabled:opacity-60', divider: 'bg-neutral-100 dark:bg-gray-900', listContainer: 'max-h-96', dropZoneContainer: 'bg-blue-200 dark:bg-gray-700', dropZoneBorder: 'border-blue-800', }) }