mirror of
				https://github.com/hay-kot/homebox.git
				synced 2025-10-26 19:06:43 +00:00 
			
		
		
		
	add support for custom text fields
This commit is contained in:
		
							parent
							
								
									57f9372e49
								
							
						
					
					
						commit
						434f1fa411
					
				
					 11 changed files with 384 additions and 38 deletions
				
			
		|  | @ -2,11 +2,23 @@ import { faker } from "@faker-js/faker"; | |||
| import { expect } from "vitest"; | ||||
| import { overrideParts } from "../../base/urls"; | ||||
| import { PublicApi } from "../../public"; | ||||
| import { LabelCreate, LocationCreate, UserRegistration } from "../../types/data-contracts"; | ||||
| import { ItemField, LabelCreate, LocationCreate, UserRegistration } from "../../types/data-contracts"; | ||||
| import * as config from "../../../../test/config"; | ||||
| import { UserClient } from "../../user"; | ||||
| import { Requests } from "../../../requests"; | ||||
| 
 | ||||
| function itemField(id = null): ItemField { | ||||
|   return { | ||||
|     id, | ||||
|     name: faker.lorem.word(), | ||||
|     type: "text", | ||||
|     textValue: faker.lorem.sentence(), | ||||
|     booleanValue: false, | ||||
|     numberValue: faker.datatype.number(), | ||||
|     timeValue: null, | ||||
|   }; | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * Returns a random user registration object that can be | ||||
|  * used to signup a new user. | ||||
|  | @ -72,6 +84,7 @@ export const factories = { | |||
|   user, | ||||
|   location, | ||||
|   label, | ||||
|   itemField, | ||||
|   client: { | ||||
|     public: publicClient, | ||||
|     user: userClient, | ||||
|  |  | |||
|  | @ -1,7 +1,9 @@ | |||
| import { faker } from "@faker-js/faker"; | ||||
| import { describe, test, expect } from "vitest"; | ||||
| import { LocationOut } from "../../types/data-contracts"; | ||||
| import { ItemField, LocationOut } from "../../types/data-contracts"; | ||||
| import { AttachmentTypes } from "../../types/non-generated"; | ||||
| import { UserClient } from "../../user"; | ||||
| import { factories } from "../factories"; | ||||
| import { sharedUserClient } from "../test-utils"; | ||||
| 
 | ||||
| describe("user should be able to create an item and add an attachment", () => { | ||||
|  | @ -58,4 +60,57 @@ describe("user should be able to create an item and add an attachment", () => { | |||
|     api.items.delete(item.id); | ||||
|     await cleanup(); | ||||
|   }); | ||||
| 
 | ||||
|   test("user should be able to create and delete fields on an item", async () => { | ||||
|     const api = await sharedUserClient(); | ||||
|     const [location, cleanup] = await useLocation(api); | ||||
| 
 | ||||
|     const { response, data: item } = await api.items.create({ | ||||
|       name: faker.vehicle.model(), | ||||
|       labelIds: [], | ||||
|       description: faker.lorem.paragraph(1), | ||||
|       locationId: location.id, | ||||
|     }); | ||||
|     expect(response.status).toBe(201); | ||||
| 
 | ||||
|     const fields: ItemField[] = [ | ||||
|       factories.itemField(), | ||||
|       factories.itemField(), | ||||
|       factories.itemField(), | ||||
|       factories.itemField(), | ||||
|     ]; | ||||
| 
 | ||||
|     // Add fields
 | ||||
|     const itemUpdate = { | ||||
|       ...item, | ||||
|       locationId: item.location.id, | ||||
|       labelIds: item.labels.map(l => l.id), | ||||
|       fields, | ||||
|     }; | ||||
| 
 | ||||
|     const { response: updateResponse, data: item2 } = await api.items.update(item.id, itemUpdate); | ||||
|     expect(updateResponse.status).toBe(200); | ||||
| 
 | ||||
|     expect(item2.fields).toHaveLength(fields.length); | ||||
| 
 | ||||
|     for (let i = 0; i < fields.length; i++) { | ||||
|       expect(item2.fields[i].name).toBe(fields[i].name); | ||||
|       expect(item2.fields[i].textValue).toBe(fields[i].textValue); | ||||
|       expect(item2.fields[i].numberValue).toBe(fields[i].numberValue); | ||||
|     } | ||||
| 
 | ||||
|     itemUpdate.fields = [fields[0], fields[1]]; | ||||
| 
 | ||||
|     const { response: updateResponse2, data: item3 } = await api.items.update(item.id, itemUpdate); | ||||
|     expect(updateResponse2.status).toBe(200); | ||||
| 
 | ||||
|     expect(item3.fields).toHaveLength(2); | ||||
|     for (let i = 0; i < item3.fields.length; i++) { | ||||
|       expect(item3.fields[i].name).toBe(itemUpdate.fields[i].name); | ||||
|       expect(item3.fields[i].textValue).toBe(itemUpdate.fields[i].textValue); | ||||
|       expect(item3.fields[i].numberValue).toBe(itemUpdate.fields[i].numberValue); | ||||
|     } | ||||
| 
 | ||||
|     cleanup(); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -51,10 +51,23 @@ export interface ItemCreate { | |||
|   name: string; | ||||
| } | ||||
| 
 | ||||
| export interface ItemField { | ||||
|   booleanValue: boolean; | ||||
|   id: string; | ||||
|   name: string; | ||||
|   numberValue: number; | ||||
|   textValue: string; | ||||
|   timeValue: string; | ||||
|   type: string; | ||||
| } | ||||
| 
 | ||||
| export interface ItemOut { | ||||
|   attachments: ItemAttachment[]; | ||||
|   createdAt: Date; | ||||
|   description: string; | ||||
| 
 | ||||
|   /** Future */ | ||||
|   fields: ItemField[]; | ||||
|   id: string; | ||||
|   insured: boolean; | ||||
|   labels: LabelSummary[]; | ||||
|  | @ -108,6 +121,7 @@ export interface ItemSummary { | |||
| 
 | ||||
| export interface ItemUpdate { | ||||
|   description: string; | ||||
|   fields: ItemField[]; | ||||
|   id: string; | ||||
|   insured: boolean; | ||||
|   labelIds: string[]; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue