/* Fees page — branch + programme switcher with itemized breakdown */
const FEE_DATA = {
'bukit-jelutong': {
label: 'Bukit Jelutong',
color: 'orange',
discount: 200,
discountNote: 'Discount valid until 25th Dec 2025 / Open Day',
playschool: {
enrolment: [
{ name: 'Registration', sub: 'one-off, non-refundable', amt: 330 },
{ name: 'Insurance Takaful', sub: 'coverage', amt: 11 },
{ name: 'Learning Materials', sub: 'stationaries, arts & crafts', amt: 500 },
{ name: 'Activities', sub: 'monthly themed activities', amt: 680 },
{ name: 'Filing & assessments', sub: '', amt: 120 },
{ name: 'Events', sub: 'sports, t-shirt, hajj cilik, PTM', amt: 120 },
],
monthly: [
{ age: '2–3 years', basic: null, midday: 700, midday_hours: '8am–2pm', fullday: 850 },
],
},
preschool: {
enrolment: [
{ name: 'Registration', sub: 'one-off, non-refundable', amt: { nursery: 300, reception: 300, year1: 300 } },
{ name: 'Administration', sub: '', amt: { nursery: 90, reception: 90, year1: 90 } },
{ name: 'Uniform', sub: '1 set sports wear', amt: 'FOC' },
{ name: 'Insurance Takaful', sub: 'coverage', amt: { nursery: 11, reception: 11, year1: 11 } },
{ name: 'Learning Materials', sub: 'stationaries, arts & crafts, filing', amt: { nursery: 930, reception: 790, year1: 790 } },
{ name: 'Activities', sub: 'monthly activities, science', amt: { nursery: 950, reception: 900, year1: 900 } },
{ name: 'Books & worksheets', sub: '', amt: { nursery: 110, reception: 250, year1: 280 } },
{ name: 'Events', sub: 'school trip, sports, hajj cilik, PTM', amt: { nursery: 300, reception: 400, year1: 470 }, sub2: 'Nursery: minus trip' },
],
monthly: [
{ age: 'Nursery (4 yo)', basic: 400, midday: 550, midday_hours: '8am–2pm', fullday: 690 },
{ age: 'Reception (5 yo)', basic: null, midday: 550, midday_hours: '8am–2.30pm', fullday: 690 },
{ age: 'Year One (6 yo)', basic: null, midday: 550, midday_hours: '8am–3pm', fullday: 690 },
],
},
},
'cyberjaya': {
label: 'Cyberjaya',
color: 'mint',
discount: 200,
discountNote: 'Discount valid until 25th Dec 2025 / Open Day',
playschool: {
enrolment: [
{ name: 'Registration', sub: 'one-off, non-refundable', amt: 330 },
{ name: 'Insurance Takaful', sub: 'coverage', amt: 11 },
{ name: 'Learning Materials', sub: 'stationaries, arts & crafts', amt: 500 },
{ name: 'Activities', sub: 'monthly themed activities', amt: 680 },
{ name: 'Filing & assessments', sub: '', amt: 120 },
{ name: 'Events', sub: 'sports, t-shirt, hajj cilik, PTM', amt: 120 },
],
monthly: [
{ age: '2–3 years', basic: null, midday: 700, midday_hours: '8am–2pm', fullday: 850 },
],
},
preschool: {
enrolment: [
{ name: 'Registration', sub: 'one-off, non-refundable', amt: { nursery: 300, reception: 300, year1: 300 } },
{ name: 'Administration', sub: '', amt: { nursery: 90, reception: 90, year1: 90 } },
{ name: 'Uniform', sub: '1 set sports wear', amt: 'FOC' },
{ name: 'Insurance Takaful', sub: 'coverage', amt: { nursery: 11, reception: 11, year1: 11 } },
{ name: 'Learning Materials', sub: 'stationaries, arts & crafts, filing', amt: { nursery: 930, reception: 790, year1: 790 } },
{ name: 'Activities', sub: 'monthly activities, science', amt: { nursery: 950, reception: 900, year1: 900 } },
{ name: 'Books & worksheets', sub: '', amt: { nursery: 110, reception: 250, year1: 280 } },
{ name: 'Events', sub: 'school trip, sports, hajj cilik, PTM', amt: { nursery: 300, reception: 400, year1: 470 } },
],
monthly: [
{ age: 'Nursery (4 yo)', basic: 400, midday: 550, midday_hours: '8am–2pm', fullday: 690 },
{ age: 'Reception (5 yo)', basic: null, midday: 550, midday_hours: '8am–2.30pm', fullday: 690 },
{ age: 'Year One (6 yo)', basic: null, midday: 550, midday_hours: '8am–3pm', fullday: 690 },
],
},
},
'kota-damansara': {
label: 'Kota Damansara',
color: 'sky',
discount: 500,
discountNote: 'Discount valid during Open Day only',
playschool: null,
preschool: {
enrolment: [
{ name: 'Registration', sub: 'one-off, non-refundable', amt: { nursery: 330, reception: 330, year1: 330 } },
{ name: 'Insurance Takaful', sub: 'coverage', amt: { nursery: 11, reception: 11, year1: 11 } },
{ name: 'Learning Materials', sub: 'stationaries, arts & crafts, filing', amt: { nursery: 990, reception: 850, year1: 850 } },
{ name: 'Activities', sub: 'monthly activities, science', amt: { nursery: 950, reception: 900, year1: 900 } },
{ name: 'Books & worksheets', sub: '', amt: { nursery: 110, reception: 250, year1: 280 } },
{ name: 'Events', sub: 'school trip, sports, hajj cilik, PTM', amt: { nursery: 300, reception: 400, year1: 470 } },
],
monthly: [
{ age: 'Nursery (4 yo)', basic: 400, midday: 500, midday_hours: '8am–2pm', fullday: 620, fullday2: 650 },
{ age: 'Reception (5 yo)', basic: 400, midday: 500, midday_hours: '8am–2.30pm', fullday: 620, fullday2: 650 },
{ age: 'Year One (6 yo)', basic: null, midday: 500, midday_hours: '8am–3pm', fullday: 620, fullday2: 650 },
],
},
},
};
const OPTIONAL_FEES = [
{ name: 'Sports uniform', amt: 60 },
{ name: 'Formal uniform', amt: 60 },
{ name: 'Bedding', sub: 'one-off, full-day only', amt: 100 },
{ name: 'Scarf for girls', amt: 25, unit: '/pc' },
{ name: 'Potty training', sub: 'children with diapers', amt: 300 },
{ name: 'Graduation', sub: 'Year One only', amt: 150 },
];
function FeesHero() {
return (
Pick a branch and programme to see the full breakdown. All amounts are in Malaysian Ringgit (MYR).
Transparent fees,
no hidden surprises.
| Item | {cols.map(c =>{colLabels[c]} | )}
|---|---|
|
{item.name}
{item.sub && {item.sub} }
|
{cols.map(c => {
const a = typeof item.amt === 'object' ? item.amt[c] : item.amt;
return {a === 'FOC' ? 'FOC' : `RM ${a}`} | ; })}
| Total before discount | {cols.map(c =>RM {totals[c]} | )}
|
Total after discount (–RM{branchData.discount})
{branchData.discountNote}
|
{cols.map(c => RM {afterDiscount[c]} | )}
|
{item.name}
{item.sub && {item.sub} }
|
RM {item.amt} |
| Total before discount | RM {total} |
|
Total after discount (–RM{branchData.discount})
{branchData.discountNote}
|
RM {afterDiscount} |
| Age group | Basic Mon–Fri 8am–12pm |
Midday incl. lunch |
Full Day 7am–6pm/6.30pm |
|---|---|---|---|
| {row.age} | {row.basic ? RM {row.basic} : Not available} |
RM {row.midday}
{row.midday_hours && {row.midday_hours} }
|
RM {row.fullday}
{row.fullday2 && or RM {row.fullday2} · 7am–6.30pm }
|
Enroll now or chat with our admissions team — we'll walk you through every detail.