- Claims & Payments: save npiProviderId when submitting MH claim; sync between claim and payment on update - Claims table: add Provider column showing rendering provider name - Payments table: add Provider column + purple Commissioned badge on status - Claim edit modal: add Rendering Provider dropdown (defaults to Mary Scannell) - Payment edit modal: add Rendering Provider dropdown + Commissioned metadata display - Reports page: add Provider filter dropdown (dynamic from NPI providers settings) - Reports page: remove Collections by Doctor report type and Select Doctor dropdown - Commission section: new section in reports page with date range + provider filter, shows eligible paid claims/payments per provider, multi-select checkboxes, Pay Commission modal with print + save, marks payments as commissioned so they are excluded from future cycles - DB: add CommissionBatch and CommissionBatchItem tables; backfill Payment.npiProviderId from linked claims - Backend: PATCH /api/payments/:id/provider syncs to linked claim; PUT /api/claims/:id syncs to linked payment; new /api/commissions routes Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
30 lines
2.7 KiB
TypeScript
30 lines
2.7 KiB
TypeScript
import * as z from 'zod';
|
|
import type { Prisma } from '../../../generated/prisma';
|
|
import { IntFilterObjectSchema as IntFilterObjectSchema } from './IntFilter.schema';
|
|
import { StringFilterObjectSchema as StringFilterObjectSchema } from './StringFilter.schema';
|
|
import { DateTimeFilterObjectSchema as DateTimeFilterObjectSchema } from './DateTimeFilter.schema';
|
|
import { UserScalarRelationFilterObjectSchema as UserScalarRelationFilterObjectSchema } from './UserScalarRelationFilter.schema';
|
|
import { UserWhereInputObjectSchema as UserWhereInputObjectSchema } from './UserWhereInput.schema';
|
|
import { ClaimListRelationFilterObjectSchema as ClaimListRelationFilterObjectSchema } from './ClaimListRelationFilter.schema';
|
|
import { PaymentListRelationFilterObjectSchema as PaymentListRelationFilterObjectSchema } from './PaymentListRelationFilter.schema';
|
|
import { CommissionBatchListRelationFilterObjectSchema as CommissionBatchListRelationFilterObjectSchema } from './CommissionBatchListRelationFilter.schema';
|
|
import { AppointmentProcedureListRelationFilterObjectSchema as AppointmentProcedureListRelationFilterObjectSchema } from './AppointmentProcedureListRelationFilter.schema'
|
|
|
|
const npiproviderwhereinputSchema = z.object({
|
|
AND: z.union([z.lazy(() => NpiProviderWhereInputObjectSchema), z.lazy(() => NpiProviderWhereInputObjectSchema).array()]).optional(),
|
|
OR: z.lazy(() => NpiProviderWhereInputObjectSchema).array().optional(),
|
|
NOT: z.union([z.lazy(() => NpiProviderWhereInputObjectSchema), z.lazy(() => NpiProviderWhereInputObjectSchema).array()]).optional(),
|
|
id: z.union([z.lazy(() => IntFilterObjectSchema), z.number().int()]).optional(),
|
|
userId: z.union([z.lazy(() => IntFilterObjectSchema), z.number().int()]).optional(),
|
|
npiNumber: z.union([z.lazy(() => StringFilterObjectSchema), z.string()]).optional(),
|
|
providerName: z.union([z.lazy(() => StringFilterObjectSchema), z.string()]).optional(),
|
|
createdAt: z.union([z.lazy(() => DateTimeFilterObjectSchema), z.coerce.date()]).optional(),
|
|
user: z.union([z.lazy(() => UserScalarRelationFilterObjectSchema), z.lazy(() => UserWhereInputObjectSchema)]).optional(),
|
|
claims: z.lazy(() => ClaimListRelationFilterObjectSchema).optional(),
|
|
payments: z.lazy(() => PaymentListRelationFilterObjectSchema).optional(),
|
|
commissionBatches: z.lazy(() => CommissionBatchListRelationFilterObjectSchema).optional(),
|
|
appointmentProcedures: z.lazy(() => AppointmentProcedureListRelationFilterObjectSchema).optional()
|
|
}).strict();
|
|
export const NpiProviderWhereInputObjectSchema: z.ZodType<Prisma.NpiProviderWhereInput> = npiproviderwhereinputSchema as unknown as z.ZodType<Prisma.NpiProviderWhereInput>;
|
|
export const NpiProviderWhereInputObjectZodSchema = npiproviderwhereinputSchema;
|