builds backend initated
This commit is contained in:
@@ -1,34 +1,30 @@
|
||||
'use server';
|
||||
import { NextResponse } from 'next/server';
|
||||
import { GraphQLClient, gql } from 'graphql-request';
|
||||
import { buildTypesAddSchema } from './schema';
|
||||
import { buildIbansAddSchema } from './schema';
|
||||
|
||||
const endpoint = "http://localhost:3001/graphql";
|
||||
|
||||
export async function POST(request: Request) {
|
||||
const body = await request.json();
|
||||
const validatedBody = buildTypesAddSchema.parse(body);
|
||||
const validatedBody = buildIbansAddSchema.parse(body);
|
||||
try {
|
||||
const client = new GraphQLClient(endpoint);
|
||||
const query = gql`
|
||||
mutation CreateBuildAddress($input: CreateBuildAddressInput!) {
|
||||
createBuildAddress(input: $input) {
|
||||
mutation CreateBuildIban($input: CreateBuildIbanInput!) {
|
||||
createBuildIban(input: $input) {
|
||||
_id
|
||||
buildNumber
|
||||
doorNumber
|
||||
floorNumber
|
||||
commentAddress
|
||||
letterAddress
|
||||
shortLetterAddress
|
||||
latitude
|
||||
longitude
|
||||
street
|
||||
uuid
|
||||
createdAt
|
||||
updatedAt
|
||||
expiryEnds
|
||||
expiryStarts
|
||||
}
|
||||
}
|
||||
`;
|
||||
const variables = { input: validatedBody };
|
||||
const data = await client.request(query, variables);
|
||||
return NextResponse.json({ data: data.createBuildAddress, status: 200 });
|
||||
return NextResponse.json({ data: data.createBuildIban, status: 200 });
|
||||
} catch (err: any) {
|
||||
console.error(err);
|
||||
return NextResponse.json({ error: err.message }, { status: 500 });
|
||||
|
||||
@@ -1,15 +1,15 @@
|
||||
import { z } from "zod"
|
||||
|
||||
export const buildTypesAddSchema = z.object({
|
||||
buildNumber: z.string(),
|
||||
doorNumber: z.string(),
|
||||
floorNumber: z.string(),
|
||||
commentAddress: z.string(),
|
||||
letterAddress: z.string(),
|
||||
shortLetterAddress: z.string(),
|
||||
latitude: z.number(),
|
||||
longitude: z.number(),
|
||||
street: z.string().optional(),
|
||||
export const buildIbansAddSchema = z.object({
|
||||
|
||||
iban: z.string(),
|
||||
startDate: z.string(),
|
||||
stopDate: z.string(),
|
||||
bankCode: z.string(),
|
||||
xcomment: z.string(),
|
||||
expiryStarts: z.string().optional(),
|
||||
expiryEnds: z.string().optional(),
|
||||
|
||||
});
|
||||
|
||||
export type BuildTypesAdd = z.infer<typeof buildTypesAddSchema>;
|
||||
export type BuildIbansAdd = z.infer<typeof buildIbansAddSchema>;
|
||||
|
||||
@@ -13,11 +13,17 @@ export async function POST(request: Request) {
|
||||
query BuildIbans($input: ListArguments!) {
|
||||
buildIbans(input: $input) {
|
||||
data {
|
||||
_id
|
||||
uuid
|
||||
iban
|
||||
startDate
|
||||
stopDate
|
||||
bankCode
|
||||
xcomment
|
||||
createdAt
|
||||
updatedAt
|
||||
expiryStarts
|
||||
expiryEnds
|
||||
}
|
||||
totalCount
|
||||
}
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
'use server';
|
||||
import { NextResponse } from 'next/server';
|
||||
import { GraphQLClient, gql } from 'graphql-request';
|
||||
import { UpdateBuildAddressSchema } from './schema';
|
||||
import { UpdateBuildIbansSchema } from './schema';
|
||||
|
||||
const endpoint = "http://localhost:3001/graphql";
|
||||
|
||||
@@ -9,29 +9,26 @@ export async function POST(request: Request) {
|
||||
const searchUrl = new URL(request.url);
|
||||
const uuid = searchUrl.searchParams.get("uuid") || "";
|
||||
const body = await request.json();
|
||||
const validatedBody = UpdateBuildAddressSchema.parse(body);
|
||||
const validatedBody = UpdateBuildIbansSchema.parse(body);
|
||||
if (uuid === "") { return NextResponse.json({ error: "UUID is required" }, { status: 400 }) }
|
||||
try {
|
||||
const client = new GraphQLClient(endpoint);
|
||||
const query = gql`
|
||||
mutation UpdateBuildAddress($uuid: String!, $input: UpdateBuildAddressInput!) {
|
||||
updateBuildAddress(uuid: $uuid, input: $input) {
|
||||
mutation UpdateBuildIban($uuid:String!,$input: UpdateBuildIbanInput!) {
|
||||
updateBuildIban(uuid: $uuid,input: $input) {
|
||||
_id
|
||||
buildNumber
|
||||
doorNumber
|
||||
floorNumber
|
||||
commentAddress
|
||||
letterAddress
|
||||
shortLetterAddress
|
||||
latitude
|
||||
longitude
|
||||
street
|
||||
uuid
|
||||
xcomment
|
||||
createdAt
|
||||
updatedAt
|
||||
expiryEnds
|
||||
expiryStarts
|
||||
}
|
||||
}
|
||||
`;
|
||||
const variables = { uuid: uuid, input: validatedBody };
|
||||
const data = await client.request(query, variables);
|
||||
return NextResponse.json({ data: data.updateBuildAddress, status: 200 });
|
||||
return NextResponse.json({ data: data.updateBuildIban, status: 200 });
|
||||
} catch (err: any) {
|
||||
console.error(err);
|
||||
return NextResponse.json({ error: err.message }, { status: 500 });
|
||||
|
||||
@@ -1,15 +1,15 @@
|
||||
import { z } from "zod"
|
||||
|
||||
export const UpdateBuildAddressSchema = z.object({
|
||||
buildNumber: z.string().optional(),
|
||||
doorNumber: z.string().optional(),
|
||||
floorNumber: z.string().optional(),
|
||||
commentAddress: z.string().optional(),
|
||||
letterAddress: z.string().optional(),
|
||||
shortLetterAddress: z.string().optional(),
|
||||
latitude: z.number().optional(),
|
||||
longitude: z.number().optional(),
|
||||
street: z.string().optional(),
|
||||
export const UpdateBuildIbansSchema = z.object({
|
||||
|
||||
iban: z.string().optional(),
|
||||
startDate: z.string().optional(),
|
||||
stopDate: z.string().optional(),
|
||||
bankCode: z.string().optional(),
|
||||
xcomment: z.string().optional(),
|
||||
expiryStarts: z.string().optional(),
|
||||
expiryEnds: z.string().optional(),
|
||||
|
||||
});
|
||||
|
||||
export type UpdateBuildAddress = z.infer<typeof UpdateBuildAddressSchema>;
|
||||
export type UpdateBuildIbans = z.infer<typeof UpdateBuildIbansSchema>;
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import { PageAddBuildAreas } from "@/pages/build-areas/add/page";
|
||||
|
||||
const BuildAreasAdd = () => { return <><div>BuildAreasAdd</div></> }
|
||||
const BuildAreasAdd = () => { return <><div><PageAddBuildAreas /></div></> }
|
||||
|
||||
export default BuildAreasAdd;
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
import { PageBuildAreas } from "@/pages/build-areas/page";
|
||||
|
||||
const BuildAreas = () => {
|
||||
return <><div>BuildAreas</div></>
|
||||
return <><div><PageBuildAreas /></div></>
|
||||
}
|
||||
|
||||
export default BuildAreas;
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { PageUpdateBuildSites } from "@/pages/build-areas/update/page";
|
||||
|
||||
const BuildAreasUpdate = () => {
|
||||
return <><div>BuildAreasUpdate</div></>
|
||||
}
|
||||
const BuildAreasUpdate = () => { return <><div><PageUpdateBuildSites /></div></> }
|
||||
|
||||
export default BuildAreasUpdate;
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import { PageAddBuildIbans } from "@/pages/build-ibans/add/page";
|
||||
|
||||
const BuildIbansAdd = () => { return <><div>BuildIbansAdd</div></> }
|
||||
const BuildIbansAdd = () => { return <><PageAddBuildIbans /></> }
|
||||
|
||||
export default BuildIbansAdd;
|
||||
export default BuildIbansAdd;
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { PageBuildIbans } from "@/pages/build-ibans/page";
|
||||
|
||||
const BuildIbans = () => {
|
||||
return <><div>BuildIbans</div></>
|
||||
}
|
||||
const BuildIbans = () => { return <><PageBuildIbans /></> }
|
||||
|
||||
export default BuildIbans;
|
||||
@@ -1,6 +1,7 @@
|
||||
import { PageUpdateBuildIbans } from "@/pages/build-ibans/update/page";
|
||||
|
||||
const BuildIbansUpdate = () => {
|
||||
return <><div>BuildIbansUpdate</div></>
|
||||
return <><PageUpdateBuildIbans /></>
|
||||
}
|
||||
|
||||
export default BuildIbansUpdate;
|
||||
5
frontend/app/build-parts/add/page.tsx
Normal file
5
frontend/app/build-parts/add/page.tsx
Normal file
@@ -0,0 +1,5 @@
|
||||
import { PageAddBuildIbans } from "@/pages/build-ibans/add/page";
|
||||
|
||||
const BuildPartsAdd = () => { return <><PageAddBuildIbans /></> }
|
||||
|
||||
export default BuildPartsAdd;
|
||||
5
frontend/app/build-parts/page.tsx
Normal file
5
frontend/app/build-parts/page.tsx
Normal file
@@ -0,0 +1,5 @@
|
||||
import { PageBuildIbans } from "@/pages/build-ibans/page";
|
||||
|
||||
const BuildParts = () => { return <><PageBuildIbans /></> }
|
||||
|
||||
export default BuildParts;
|
||||
7
frontend/app/build-parts/update/page.tsx
Normal file
7
frontend/app/build-parts/update/page.tsx
Normal file
@@ -0,0 +1,7 @@
|
||||
import { PageUpdateBuildIbans } from "@/pages/build-ibans/update/page";
|
||||
|
||||
const BuildPartsUpdate = () => {
|
||||
return <><PageUpdateBuildIbans /></>
|
||||
}
|
||||
|
||||
export default BuildPartsUpdate;
|
||||
5
frontend/app/builds/add/page.tsx
Normal file
5
frontend/app/builds/add/page.tsx
Normal file
@@ -0,0 +1,5 @@
|
||||
import { PageAddBuildTypes } from "@/pages/build-types/add/page";
|
||||
|
||||
const AddBuildPage = () => { return <><PageAddBuildTypes /></> }
|
||||
|
||||
export default AddBuildPage;
|
||||
5
frontend/app/builds/page.tsx
Normal file
5
frontend/app/builds/page.tsx
Normal file
@@ -0,0 +1,5 @@
|
||||
import { PageBuilds } from "@/pages/builds/page";
|
||||
|
||||
const BuildPage = () => { return <><PageBuilds /></> }
|
||||
|
||||
export default BuildPage;
|
||||
5
frontend/app/builds/update/page.tsx
Normal file
5
frontend/app/builds/update/page.tsx
Normal file
@@ -0,0 +1,5 @@
|
||||
import { PageUpdateBuildTypes } from '@/pages/build-types/update/page';
|
||||
|
||||
const UpdateBuildPage = async () => { return <PageUpdateBuildTypes /> }
|
||||
|
||||
export default UpdateBuildPage;
|
||||
Reference in New Issue
Block a user