mirror of
https://github.com/ruvnet/RuVector.git
synced 2026-06-01 14:39:33 +00:00
Major additions: - Complete Next.js studio application with 1600+ components - Docker support (Dockerfile.combined, docker-compose.yml) - GCP deployment documentation and benchmarks - SQL benchmark scripts for performance testing - Sentry integration for monitoring - Comprehensive test suite and mocks Studio features: - Dashboard and admin interfaces - Data visualization components - Authentication and user management - API integration with RuVector backend - Static data and public assets 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
67 lines
2.2 KiB
TypeScript
67 lines
2.2 KiB
TypeScript
import { z } from 'zod'
|
|
|
|
import { isFeatureEnabled } from 'common'
|
|
import { PLAN_REQUEST_EMPTY_PLACEHOLDER } from 'components/ui/UpgradePlanButton'
|
|
import { CATEGORY_OPTIONS, type ExtendedSupportCategories } from './Support.constants'
|
|
|
|
const createFormSchema = (showClientLibraries: boolean) => {
|
|
const baseSchema = z.object({
|
|
organizationSlug: z.string().min(1, 'Please select an organization'),
|
|
projectRef: z.string().min(1, 'Please select a project'),
|
|
category: z.enum(
|
|
CATEGORY_OPTIONS.map((opt) => opt.value) as [
|
|
ExtendedSupportCategories,
|
|
...ExtendedSupportCategories[],
|
|
]
|
|
),
|
|
severity: z.string(),
|
|
library: z.string(),
|
|
subject: z.string().min(1, 'Please add a subject heading'),
|
|
message: z.string().min(1, "Please add a message about the issue that you're facing"),
|
|
affectedServices: z.string(),
|
|
allowSupportAccess: z.boolean(),
|
|
attachDashboardLogs: z.boolean(),
|
|
dashboardSentryIssueId: z.string().optional(),
|
|
})
|
|
|
|
if (showClientLibraries) {
|
|
return baseSchema
|
|
.refine(
|
|
(data) => {
|
|
return !(data.category === 'Problem' && data.library === '')
|
|
},
|
|
{
|
|
message: "Please select the library that you're facing issues with",
|
|
path: ['library'],
|
|
}
|
|
)
|
|
.refine(
|
|
(data) => {
|
|
return !data.message.includes(PLAN_REQUEST_EMPTY_PLACEHOLDER)
|
|
},
|
|
{
|
|
message: `Please let us know which plan you'd like to upgrade to for your organization`,
|
|
path: ['message'],
|
|
}
|
|
)
|
|
}
|
|
|
|
// When showClientLibraries is false, make library optional and remove the refine validation
|
|
return baseSchema
|
|
.extend({
|
|
library: z.string().optional(),
|
|
})
|
|
.refine(
|
|
(data) => {
|
|
return !data.message.includes(PLAN_REQUEST_EMPTY_PLACEHOLDER)
|
|
},
|
|
{
|
|
message: `Please let us know which plan you'd like to upgrade to for your organization`,
|
|
path: ['message'],
|
|
}
|
|
)
|
|
}
|
|
|
|
const showClientLibraries = isFeatureEnabled('support:show_client_libraries')
|
|
export const SupportFormSchema = createFormSchema(showClientLibraries)
|
|
export type SupportFormValues = z.infer<typeof SupportFormSchema>
|