// Copyright (C) 2012-2024 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 getCoreClasses from './theme/global/getCoreMobileClasses.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 mobileFormFieldModules: 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: getCoreClasses, extensions: themeExtensionModules, } mainInitializeForm(app, undefined, mobileFormFieldModules, plugins, theme) } export const initializeFormFields = () => { initializeFormClasses({ loading: 'my-4', }) initializeFormGroupClasses({ container: 'form-group overflow-hidden rounded-xl bg-gray-500', help: 'text-xs text-gray-100 ltr:pl-3 rtl:pr-3', dirtyMark: 'form-group-mark-dirty', }) initializeFieldLinkClasses({ container: 'formkit-link flex items-center py-2', base: 'border-white/10 ltr:border-l ltr:pl-1 rtl:border-r rtl:pr-1', link: 'h-10 w-12', }) initializeToggleClasses({ track: 'bg-gray-300 border border-transparent focus-within:ring-1 focus-within:ring-white focus-within:ring-opacity-75 focus:outline-none formkit-invalid:border-solid formkit-invalid:border-red', trackOn: '!bg-blue', knob: 'bg-white shadow-lg ring-0', }) initializeFieldEditorClasses({ actionBar: { buttonContainer: 'gap-1 p-2', tableMenuContainer: 'gap-1 p-2', leftGradient: { left: '-0.5rem', before: { // Currently mobile supports only dark mode background: { light: `linear-gradient( 270deg, rgba(255, 255, 255, 0), #282829)`, dark: `linear-gradient( 270deg, rgba(255, 255, 255, 0), #282829)`, // :TODO inject tailwind theme colors }, }, }, rightGradient: { before: { // Currently mobile supports only dark mode background: { light: `linear-gradient( 90deg, rgba(255, 255, 255, 0), #282829)`, dark: `linear-gradient( 90deg, rgba(255, 255, 255, 0), #282829`, // :TODO inject tailwind theme colors }, }, }, shadowGradient: { before: { top: 'calc(0px - 30px - 1.5rem)', height: 'calc(30px + 1.5rem)', }, }, button: { base: 'rounded bg-black p-2 lg:hover:bg-gray-300', // Should we add a hover class here? It was there in the original code. active: 'bg-gray-300', }, }, input: { container: 'p-2', }, }) initializeFieldEditorProps({ actionBar: { button: { icon: { size: 'small', }, }, }, }) initializeFileClasses({ button: 'disabled:text-blue/60 text-blue p-2.5 w-full', listContainer: 'max-h-48 px-4 pt-4', }) }