I am currently working on creating a nested JSON object and have defined an interface for it. However, I am encountering an error message stating that the type of property 'servicesAndHeads' is incompatible and it is missing. Here is my interface setup:
interface Head {
HeadNumber?: string;
HeadDescription?: string;
};
interface ServicesAndHead {
majorService?: string;
subMajorService?: string;
servicesAndHeads: Head[];
}
export interface MyTableItem {
demandNo?: string;
demandName?: string;
servicesAndHeads?: ServicesAndHead;
//servicesAndHeads?:ServicesAndHead[];
}
This is how my JSON data is structured:
const dataItem: MyTableItem =
{
demandNo: 'Demand Number 2',
demandName: 'Animal Husbandary, Livestock, Fisheries and Veterinary Services',
servicesAndHeads: [
{
majorService: 'C-Economic Service',
subMajorService: '(a) Agriculture and Allied Activities',
majorHead: [
{ majorHeadNumber: '3098', majorHeadDescription: 'Animal Husbandry' },
{ majorHeadNumber: '3999', majorHeadDescription: 'Diary Development' },
{ majorHeadNumber: '4902', majorHeadDescription: 'Fisheries' }
]
},
{
majorService: 'C- Capital Account of Economic Services',
subMajorService: '(a) Capital Account of Agriculture and Allied Activities',
majorHead: [
{ majorHeadNumber: '0012', majorHeadDescription: 'Capital Outlay on Animal ' },
{ majorHeadNumber: '3245', majorHeadDescription: 'Capital Outlay on Fisheries' }
]
}
]
}
I have also attempted another approach for nesting 'servicesAndHeads':
servicesAndHeads?: {
[key: string]: ServicesAndHead,
majorHeads?: {
[key: string]: MajorHead
};
};
How can I correct my code to accommodate the given JSON structure?