fork download
  1. import React, { useState } from 'react';
  2. import { ChevronLeft, ChevronRight, TrendingUp, BarChart4, PieChart, DollarSign, Briefcase, Target } from 'lucide-react';
  3. import { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, Legend, BarChart, Bar, PieChart as RechartPieChart, Pie, Cell, ResponsiveContainer } from 'recharts';
  4.  
  5. const InvestmentPlanPresentation = () => {
  6. const [currentSlide, setCurrentSlide] = useState(0);
  7.  
  8. const totalSlides = 12;
  9.  
  10. const goToNextSlide = () => {
  11. setCurrentSlide((prev) => (prev < totalSlides - 1 ? prev + 1 : prev));
  12. };
  13.  
  14. const goToPrevSlide = () => {
  15. setCurrentSlide((prev) => (prev > 0 ? prev - 1 : prev));
  16. };
  17.  
  18. // ข้อมูลสำหรับกราฟต่างๆ
  19. const salaryData = [
  20. { age: 23, salary: 240000, position: 'Financial Analyst' },
  21. { age: 25, salary: 274776, position: 'Financial Analyst' },
  22. { age: 30, salary: 385392, position: 'Senior Financial Analyst' },
  23. { age: 35, salary: 491832, position: 'Finance Manager' },
  24. { age: 40, salary: 626940, position: 'Senior Finance Manager' },
  25. { age: 45, salary: 727416, position: 'Finance Director' },
  26. { age: 50, salary: 843000, position: 'VP of Finance' },
  27. { age: 55, salary: 930744, position: 'CFO' },
  28. { age: 60, salary: 1027608, position: 'CFO' }
  29. ];
  30.  
  31. const portfolioGrowthData = [
  32. { age: 23, value: 38880 },
  33. { age: 25, value: 127053 },
  34. { age: 30, value: 650000 },
  35. { age: 35, value: 1700000 },
  36. { age: 40, value: 3200000 },
  37. { age: 45, value: 5500000 },
  38. { age: 50, value: 7500000 },
  39. { age: 55, value: 14000000 },
  40. { age: 60, value: 23000000 }
  41. ];
  42.  
  43. const allocationData = [
  44. { name: 'ETF', value: 50 },
  45. { name: 'หุ้น', value: 20 },
  46. { name: 'REITs', value: 10 },
  47. { name: 'พันธบัตร', value: 10 },
  48. { name: 'ทอง/คริปโต', value: 10 }
  49. ];
  50.  
  51. const expenseData = [
  52. { name: 'ค่ากินอยู่', value: 30 },
  53. { name: 'ค่าผ่อนบ้าน/รถ', value: 20 },
  54. { name: 'ค่าใช้จ่ายส่วนตัว', value: 15 },
  55. { name: 'ค่าประกันและสุขภาพ', value: 10 },
  56. { name: 'เงินออมและลงทุน', value: 15 },
  57. { name: 'ภาษีและกองทุน', value: 10 }
  58. ];
  59.  
  60. const careerPathData = [
  61. { position: 'Financial Analyst', ageRange: '23-29', salary: '20,000-30,200 บาท' },
  62. { position: 'Senior Financial Analyst', ageRange: '30-34', salary: '32,100-39,200 บาท' },
  63. { position: 'Finance Manager', ageRange: '35-39', salary: '41,000-50,000 บาท' },
  64. { position: 'Senior Finance Manager', ageRange: '40-44', salary: '52,200-58,900 บาท' },
  65. { position: 'Finance Director', ageRange: '45-49', salary: '60,600-68,300 บาท' },
  66. { position: 'VP of Finance', ageRange: '50-54', salary: '70,200-76,100 บาท' },
  67. { position: 'CFO', ageRange: '55-60', salary: '77,600-85,600 บาท' }
  68. ];
  69.  
  70. const COLORS = ['#0088FE', '#00C49F', '#FFBB28', '#FF8042', '#8884d8', '#82ca9d'];
  71.  
  72. const formatMoney = (amount) => {
  73. return new Intl.NumberFormat('th-TH').format(amount);
  74. };
  75.  
  76. const renderSlide = () => {
  77. switch (currentSlide) {
  78. // สไลด์ที่ 1: ปกนำเสนอ
  79. case 0:
  80. return (
  81. <div className="flex flex-col items-center justify-center h-full text-center">
  82. <div className="mb-8">
  83. <DollarSign size={64} className="text-blue-600 mx-auto mb-4" />
  84. </div>
  85. <h1 className="text-4xl font-bold text-blue-800 mb-4">การวางแผนการลงทุนทางการเงินระยะยาว</h1>
  86. <h2 className="text-2xl text-blue-600 mb-10">กลยุทธ์การสร้างความมั่งคั่งตามช่วงอายุและระดับรายได้</h2>
  87. <div className="mt-16">
  88. <p className="text-lg">วันที่ 31 มีนาคม 2025</p>
  89. <p className="text-lg mt-2">ฝ่ายวางแผนการลงทุน</p>
  90. </div>
  91. </div>
  92. );
  93.  
  94. // สไลด์ที่ 2: บทนำและวัตถุประสงค์
  95. case 1:
  96. return (
  97. <div className="h-full">
  98. <h2 className="text-2xl font-bold text-blue-800 mb-6">วัตถุประสงค์การนำเสนอ</h2>
  99. <div className="bg-blue-50 p-6 rounded-lg shadow-md">
  100. <ul className="space-y-4">
  101. <li className="flex items-start">
  102. <div className="mr-4 mt-1 text-blue-600"><Target size={24} /></div>
  103. <p>นำเสนอแผนการลงทุนตั้งแต่อายุ 23-60 ปี</p>
  104. </li>
  105. <li className="flex items-start">
  106. <div className="mr-4 mt-1 text-blue-600"><PieChart size={24} /></div>
  107. <p>วิเคราะห์รูปแบบการจัดสรรเงินลงทุนในสินทรัพย์ประเภทต่างๆ</p>
  108. </li>
  109. <li className="flex items-start">
  110. <div className="mr-4 mt-1 text-blue-600"><TrendingUp size={24} /></div>
  111. <p>แสดงการเติบโตของพอร์ตโฟลิโอและความมั่งคั่งระยะยาว</p>
  112. </li>
  113. <li className="flex items-start">
  114. <div className="mr-4 mt-1 text-blue-600"><BarChart4 size={24} /></div>
  115. <p>นำเสนอกลยุทธ์การบริหารรายได้และรายจ่าย</p>
  116. </li>
  117. </ul>
  118. </div>
  119. <div className="mt-8 p-4 bg-yellow-50 border-l-4 border-yellow-400 rounded">
  120. <p className="text-lg">การวางแผนการลงทุนที่ดีจะช่วยให้คุณสร้างความมั่งคั่งได้อย่างมีประสิทธิภาพและบรรลุเป้าหมายทางการเงินในระยะยาว</p>
  121. </div>
  122. </div>
  123. );
  124.  
  125. // สไลด์ที่ 3: ภาพรวมของข้อมูล
  126. case 2:
  127. return (
  128. <div className="h-full">
  129. <h2 className="text-2xl font-bold text-blue-800 mb-6">ภาพรวมการวางแผนการเงิน</h2>
  130. <div className="mb-4">
  131. <p className="mb-4">ความสัมพันธ์ระหว่างอายุกับระดับเงินเดือน และการเติบโตของตำแหน่งงาน</p>
  132. <div className="h-64">
  133. <ResponsiveContainer width="100%" height="100%">
  134. <LineChart
  135. data={salaryData}
  136. margin={{ top: 5, right: 30, left: 20, bottom: 5 }}
  137. >
  138. <CartesianGrid strokeDasharray="3 3" />
  139. <XAxis dataKey="age" />
  140. <YAxis />
  141. <Tooltip formatter={(value) => [`${formatMoney(value)} บาท`, 'เงินเดือนต่อปี']} />
  142. <Legend />
  143. <Line type="monotone" dataKey="salary" stroke="#8884d8" activeDot={{ r: 8 }} name="เงินเดือนต่อปี (บาท)" />
  144. </LineChart>
  145. </ResponsiveContainer>
  146. </div>
  147. </div>
  148. <div className="mt-6 p-4 bg-blue-50 rounded-lg">
  149. <h3 className="font-semibold mb-2">การเติบโตของตำแหน่งงาน:</h3>
  150. <p>Financial Analyst → Senior Financial Analyst → Finance Manager → Senior Finance Manager → Finance Director → VP of Finance → CFO</p>
  151. </div>
  152. </div>
  153. );
  154.  
  155. // สไลด์ที่ 4: การจัดสรรรายได้
  156. case 3:
  157. return (
  158. <div className="h-full">
  159. <h2 className="text-2xl font-bold text-blue-800 mb-6">การจัดสรรรายได้ประจำปี</h2>
  160. <div className="grid grid-cols-2 gap-4">
  161. <div className="h-64">
  162. <ResponsiveContainer width="100%" height="100%">
  163. <RechartPieChart>
  164. <Pie
  165. data={expenseData}
  166. cx="50%"
  167. cy="50%"
  168. labelLine={false}
  169. label={({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`}
  170. outerRadius={80}
  171. fill="#8884d8"
  172. dataKey="value"
  173. >
  174. {expenseData.map((entry, index) => (
  175. <Cell key={`cell-${index}`} fill={COLORS[index % COLORS.length]} />
  176. ))}
  177. </Pie>
  178. <Tooltip />
  179. </RechartPieChart>
  180. </ResponsiveContainer>
  181. </div>
  182. <div>
  183. <h3 className="font-semibold mb-3">สัดส่วนการจัดสรรรายได้</h3>
  184. <ul className="space-y-2">
  185. {expenseData.map((item, index) => (
  186. <li key={index} className="flex items-center">
  187. <div className="w-4 h-4 mr-2" style={{ backgroundColor: COLORS[index % COLORS.length] }}></div>
  188. <span>{item.name}: {item.value}%</span>
  189. </li>
  190. ))}
  191. </ul>
  192. <div className="mt-4 p-3 bg-blue-50 rounded">
  193. <p>การจัดสรรรายได้อย่างสมดุลช่วยให้มีเงินเพียงพอสำหรับการใช้จ่ายปัจจุบันและการสร้างความมั่งคั่งในอนาคต</p>
  194. </div>
  195. </div>
  196. </div>
  197. </div>
  198. );
  199.  
  200. // สไลด์ที่ 5: กลยุทธ์การลงทุน
  201. case 4:
  202. return (
  203. <div className="h-full">
  204. <h2 className="text-2xl font-bold text-blue-800 mb-6">การจัดสรรเงินลงทุน</h2>
  205. <div className="grid grid-cols-2 gap-4">
  206. <div className="h-64">
  207. <ResponsiveContainer width="100%" height="100%">
  208. <RechartPieChart>
  209. <Pie
  210. data={allocationData}
  211. cx="50%"
  212. cy="50%"
  213. labelLine={false}
  214. label={({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`}
  215. outerRadius={80}
  216. fill="#8884d8"
  217. dataKey="value"
  218. >
  219. {allocationData.map((entry, index) => (
  220. <Cell key={`cell-${index}`} fill={COLORS[index % COLORS.length]} />
  221. ))}
  222. </Pie>
  223. <Tooltip />
  224. </RechartPieChart>
  225. </ResponsiveContainer>
  226. </div>
  227. <div>
  228. <h3 className="font-semibold mb-3">สัดส่วนการลงทุนในสินทรัพย์ต่างๆ</h3>
  229. <ul className="space-y-2">
  230. {allocationData.map((item, index) => (
  231. <li key={index} className="flex items-center">
  232. <div className="w-4 h-4 mr-2" style={{ backgroundColor: COLORS[index % COLORS.length] }}></div>
  233. <span>{item.name}: {item.value}%</span>
  234. </li>
  235. ))}
  236. </ul>
  237. <div className="mt-4 p-3 bg-blue-50 rounded">
  238. <p>การกระจายการลงทุนช่วยลดความเสี่ยงและเพิ่มโอกาสในการได้รับผลตอบแทนที่มั่นคงในระยะยาว</p>
  239. </div>
  240. </div>
  241. </div>
  242. </div>
  243. );
  244.  
  245. // สไลด์ที่ 6: การเติบโตของรายได้และตำแหน่ง
  246. case 5:
  247. return (
  248. <div className="h-full">
  249. <h2 className="text-2xl font-bold text-blue-800 mb-6">เส้นทางความก้าวหน้าในอาชีพและรายได้</h2>
  250. <div className="overflow-auto h-64 mb-6">
  251. <table className="min-w-full bg-white border">
  252. <thead className="bg-blue-100">
  253. <tr>
  254. <th className="py-2 px-4 border">ตำแหน่ง</th>
  255. <th className="py-2 px-4 border">ช่วงอายุ</th>
  256. <th className="py-2 px-4 border">เงินเดือนโดยประมาณ</th>
  257. </tr>
  258. </thead>
  259. <tbody>
  260. {careerPathData.map((item, index) => (
  261. <tr key={index} className={index % 2 === 0 ? 'bg-gray-50' : 'bg-white'}>
  262. <td className="py-2 px-4 border font-medium">{item.position}</td>
  263. <td className="py-2 px-4 border text-center">{item.ageRange}</td>
  264. <td className="py-2 px-4 border text-right">{item.salary}</td>
  265. </tr>
  266. ))}
  267. </tbody>
  268. </table>
  269. </div>
  270. <div className="p-4 bg-blue-50 rounded-lg">
  271. <p><span className="font-medium">ข้อสังเกต:</span> อัตราการเติบโตของเงินเดือนจะสูงในช่วงต้นของอาชีพ (7-8% ต่อปี) และค่อยๆ ลดลงในช่วงปลาย (2-3% ต่อปี) แต่ฐานเงินเดือนที่สูงขึ้นทำให้รายได้รวมยังคงเพิ่มขึ้นอย่างมีนัยสำคัญ</p>
  272. </div>
  273. </div>
  274. );
  275.  
  276. // สไลด์ที่ 7: การเติบโตของรายได้และตำแหน่ง (ต่อ)
  277. case 6:
  278. return (
  279. <div className="h-full">
  280. <h2 className="text-2xl font-bold text-blue-800 mb-6">การเติบโตของรายได้ตามช่วงอายุ</h2>
  281. <div className="h-64 mb-6">
  282. <ResponsiveContainer width="100%" height="100%">
  283. <BarChart
  284. data={salaryData}
  285. margin={{ top: 5, right: 30, left: 20, bottom: 5 }}
  286. >
  287. <CartesianGrid strokeDasharray="3 3" />
  288. <XAxis dataKey="age" />
  289. <YAxis />
  290. <Tooltip formatter={(value) => [`${formatMoney(value)} บาท`, 'เงินเดือนต่อปี']} />
  291. <Legend />
  292. <Bar dataKey="salary" name="เงินเดือนต่อปี (บาท)" fill="#8884d8" />
  293. </BarChart>
  294. </ResponsiveContainer>
  295. </div>
  296. <div className="grid grid-cols-3 gap-4 mt-4">
  297. <div className="p-4 bg-blue-50 rounded-lg text-center">
  298. <p className="font-medium">ช่วงต้นอาชีพ (23-35 ปี)</p>
  299. <p>อัตราเติบโต: 5-8% ต่อปี</p>
  300. </div>
  301. <div className="p-4 bg-green-50 rounded-lg text-center">
  302. <p className="font-medium">ช่วงกลางอาชีพ (36-45 ปี)</p>
  303. <p>อัตราเติบโต: 3-5% ต่อปี</p>
  304. </div>
  305. <div className="p-4 bg-yellow-50 rounded-lg text-center">
  306. <p className="font-medium">ช่วงปลายอาชีพ (46-60 ปี)</p>
  307. <p>อัตราเติบโต: 2-3% ต่อปี</p>
  308. </div>
  309. </div>
  310. </div>
  311. );
  312.  
  313. // สไลด์ที่ 8: การเติบโตของพอร์ตการลงทุน
  314. case 7:
  315. return (
  316. <div className="h-full">
  317. <h2 className="text-2xl font-bold text-blue-800 mb-6">การเติบโตของพอร์ตการลงทุน</h2>
  318. <div className="h-64 mb-6">
  319. <ResponsiveContainer width="100%" height="100%">
  320. <LineChart
  321. data={portfolioGrowthData}
  322. margin={{ top: 5, right: 30, left: 20, bottom: 5 }}
  323. >
  324. <CartesianGrid strokeDasharray="3 3" />
  325. <XAxis dataKey="age" />
  326. <YAxis />
  327. <Tooltip formatter={(value) => [`${formatMoney(value)} บาท`, 'มูลค่าพอร์ต']} />
  328. <Legend />
  329. <Line type="monotone" dataKey="value" stroke="#00C49F" activeDot={{ r: 8 }} name="มูลค่าพอร์ตสะสม (บาท)" />
  330. </LineChart>
  331. </ResponsiveContainer>
  332. </div>
  333. <div className="p-4 bg-green-50 rounded-lg">
  334. <p className="font-medium mb-2">ข้อสังเกตสำคัญ:</p>
  335. <p>มูลค่าพอร์ตการลงทุนมีการเติบโตแบบก้าวกระโดดในช่วงอายุ 45-60 ปี ซึ่งเป็นผลมาจากการสะสมเงินลงทุนอย่างต่อเนื่องรวมกับผลตอบแทนที่ทบต้น (Compound Effect) ที่ชัดเจนมากขึ้นเมื่อเวลาผ่านไป</p>
  336. </div>
  337. </div>
  338. );
  339.  
  340. // สไลด์ที่ 9: การเติบโตของพอร์ตการลงทุน (ต่อ)
  341. case 8:
  342. return (
  343. <div className="h-full">
  344. <h2 className="text-2xl font-bold text-blue-800 mb-6">มูลค่าพอร์ตสะสมตามช่วงอายุสำคัญ</h2>
  345. <div className="grid grid-cols-2 gap-6">
  346. <div className="col-span-2 mb-4">
  347. <p className="mb-2">มูลค่าพอร์ตการลงทุนเติบโตแบบทวีคูณด้วยอัตราผลตอบแทนเฉลี่ย 8% ต่อปี</p>
  348. </div>
  349. <div className="space-y-4">
  350. <div className="p-4 bg-blue-50 rounded-lg">
  351. <h3 className="font-semibold text-lg mb-2">อายุ 30 ปี</h3>
  352. <p className="text-xl text-blue-700 font-bold">{formatMoney(650000)} บาท</p>
  353. <p className="text-sm mt-1">ช่วงเริ่มต้นการสะสมความมั่งคั่ง</p>
  354. </div>
  355. <div className="p-4 bg-blue-50 rounded-lg">
  356. <h3 className="font-semibold text-lg mb-2">อายุ 40 ปี</h3>
  357. <p className="text-xl text-blue-700 font-bold">{formatMoney(3200000)} บาท</p>
  358. <p className="text-sm mt-1">การเติบโตของพอร์ตเริ่มมีนัยสำคัญ</p>
  359. </div>
  360. </div>
  361. <div className="space-y-4">
  362. <div className="p-4 bg-blue-50 rounded-lg">
  363. <h3 className="font-semibold text-lg mb-2">อายุ 50 ปี</h3>
  364. <p className="text-xl text-blue-700 font-bold">{formatMoney(7500000)} บาท</p>
  365. <p className="text-sm mt-1">ผลของการลงทุนระยะยาวเริ่มชัดเจน</p>
  366. </div>
  367. <div className="p-4 bg-blue-50 rounded-lg">
  368. <h3 className="font-semibold text-lg mb-2">อายุ 60 ปี</h3>
  369. <p className="text-xl text-blue-700 font-bold">{formatMoney(23000000)} บาท</p>
  370. <p className="text-sm mt-1">เป้าหมายความมั่งคั่งก่อนเกษียณ</p>
  371. </div>
  372. </div>
  373. </div>
  374. </div>
  375. );
  376.  
  377. // สไลด์ที่ 10: จุดเปลี่ยนทางการเงินที่สำคัญ
  378. case 9:
  379. return (
  380. <div className="h-full">
  381. <h2 className="text-2xl font-bold text-blue-800 mb-6">จุดเปลี่ยนสำคัญในเส้นทางการเงิน</h2>
  382. <div className="space-y-4">
  383. <div className="p-4 bg-blue-50 rounded-lg border-l-4 border-blue-600 flex">
  384. <div className="text-center mr-6 flex-shrink-0">
  385. <h3 className="text-lg font-bold">อายุ 35 ปี</h3>
  386. <Briefcase size={32} className="text-blue-600 mx-auto my-2" />
  387. </div>
  388. <div>
  389. <p className="font-medium">การเลื่อนตำแหน่งเป็น Finance Manager</p>
  390. <p>พอร์ตลงทุนมูลค่า 1.7 ล้านบาท</p>
  391. <p className="text-sm text-gray-600 mt-1">เงินเดือนเพิ่มขึ้นเป็น 41,000 บาท/เดือน</p>
  392. </div>
  393. </div>
  394.  
  395. <div className="p-4 bg-green-50 rounded-lg border-l-4 border-green-600 flex">
  396. <div className="text-center mr-6 flex-shrink-0">
  397. <h3 className="text-lg font-bold">อายุ 45 ปี</h3>
  398. <Briefcase size={32} className="text-green-600 mx-auto my-2" />
  399. </div>
  400. <div>
  401. <p className="font-medium">การเลื่อนตำแหน่งเป็น Finance Director</p>
  402. <p>พอร์ตลงทุนมูลค่า 5.5 ล้านบาท</p>
  403. <p className="text-sm text-gray-600 mt-1">เงินเดือนเพิ่มขึ้นเป็น 60,600 บาท/เดือน</p>
  404. </div>
  405. </div>
  406.  
  407. <div className="p-4 bg-yellow-50 rounded-lg border-l-4 border-yellow-600 flex">
  408. <div className="text-center mr-6 flex-shrink-0">
  409. <h3 className="text-lg font-bold">อายุ 55 ปี</h3>
  410. <Briefcase size={32} className="text-yellow-600 mx-auto my-2" />
  411. </div>
  412. <div>
  413. <p className="font-medium">การเลื่อนตำแหน่งเป็น CFO</p>
  414. <p>พอร์ตลงทุนมูลค่า 14 ล้านบาท</p>
  415. <p className="text-sm text-gray-600 mt-1">เงินเดือนเพิ่มขึ้นเป็น 77,600 บาท/เดือน</p>
  416. </div>
  417. </div>
  418.  
  419. <div className="p-4 bg-purple-50 rounded-lg border-l-4 border-purple-600 flex">
  420. <div className="text-center mr-6 flex-shrink-0">
  421. <h3 className="text-lg font-bold">อายุ 60 ปี</h3>
  422. <DollarSign size={32} className="text-purple-600 mx-auto my-2" />
  423. </div>
  424. <div>
  425. <p className="font-medium">เกษียณอายุ</p>
  426. <p>พอร์ตลงทุนมูลค่า 23 ล้านบาท</p>
  427. <p className="text-sm text-gray-600 mt-1">สามารถใช้ผลตอบแทนจากการลงทุนเป็นรายได้หลังเกษียณ</p>
  428. </div>
  429. </div>
  430. </div>
  431. </div>
  432. );
  433.  
  434. // สไลด์ที่ 11: ปัจจัยความสำเร็จ
  435. case 10:
  436. return (
  437. <div className="h-full">
  438. <h2 className="text-2xl font-bold text-blue-800 mb-6">ปัจจัยสู่ความสำเร็จทางการเงิน</h2>
  439. <div className="grid grid-cols-2 gap-4">
  440. <div className="p-4 bg-blue-50 rounded-lg shadow-sm">
  441. <h3 className="font-semibold text-lg mb-2 flex items-center">
  442. <span className="mr-2 text-blue-600"><DollarSign size
Success #stdin #stdout 0.02s 25972KB
stdin
Standard input is empty
stdout
import React, { useState } from 'react';
import { ChevronLeft, ChevronRight, TrendingUp, BarChart4, PieChart, DollarSign, Briefcase, Target } from 'lucide-react';
import { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, Legend, BarChart, Bar, PieChart as RechartPieChart, Pie, Cell, ResponsiveContainer } from 'recharts';

const InvestmentPlanPresentation = () => {
  const [currentSlide, setCurrentSlide] = useState(0);
  
  const totalSlides = 12;
  
  const goToNextSlide = () => {
    setCurrentSlide((prev) => (prev < totalSlides - 1 ? prev + 1 : prev));
  };
  
  const goToPrevSlide = () => {
    setCurrentSlide((prev) => (prev > 0 ? prev - 1 : prev));
  };
  
  // ข้อมูลสำหรับกราฟต่างๆ
  const salaryData = [
    { age: 23, salary: 240000, position: 'Financial Analyst' },
    { age: 25, salary: 274776, position: 'Financial Analyst' },
    { age: 30, salary: 385392, position: 'Senior Financial Analyst' },
    { age: 35, salary: 491832, position: 'Finance Manager' },
    { age: 40, salary: 626940, position: 'Senior Finance Manager' },
    { age: 45, salary: 727416, position: 'Finance Director' },
    { age: 50, salary: 843000, position: 'VP of Finance' },
    { age: 55, salary: 930744, position: 'CFO' },
    { age: 60, salary: 1027608, position: 'CFO' }
  ];
  
  const portfolioGrowthData = [
    { age: 23, value: 38880 },
    { age: 25, value: 127053 },
    { age: 30, value: 650000 },
    { age: 35, value: 1700000 },
    { age: 40, value: 3200000 },
    { age: 45, value: 5500000 },
    { age: 50, value: 7500000 },
    { age: 55, value: 14000000 },
    { age: 60, value: 23000000 }
  ];
  
  const allocationData = [
    { name: 'ETF', value: 50 },
    { name: 'หุ้น', value: 20 },
    { name: 'REITs', value: 10 },
    { name: 'พันธบัตร', value: 10 },
    { name: 'ทอง/คริปโต', value: 10 }
  ];
  
  const expenseData = [
    { name: 'ค่ากินอยู่', value: 30 },
    { name: 'ค่าผ่อนบ้าน/รถ', value: 20 },
    { name: 'ค่าใช้จ่ายส่วนตัว', value: 15 },
    { name: 'ค่าประกันและสุขภาพ', value: 10 },
    { name: 'เงินออมและลงทุน', value: 15 },
    { name: 'ภาษีและกองทุน', value: 10 }
  ];
  
  const careerPathData = [
    { position: 'Financial Analyst', ageRange: '23-29', salary: '20,000-30,200 บาท' },
    { position: 'Senior Financial Analyst', ageRange: '30-34', salary: '32,100-39,200 บาท' },
    { position: 'Finance Manager', ageRange: '35-39', salary: '41,000-50,000 บาท' },
    { position: 'Senior Finance Manager', ageRange: '40-44', salary: '52,200-58,900 บาท' },
    { position: 'Finance Director', ageRange: '45-49', salary: '60,600-68,300 บาท' },
    { position: 'VP of Finance', ageRange: '50-54', salary: '70,200-76,100 บาท' },
    { position: 'CFO', ageRange: '55-60', salary: '77,600-85,600 บาท' }
  ];
  
  const COLORS = ['#0088FE', '#00C49F', '#FFBB28', '#FF8042', '#8884d8', '#82ca9d'];
  
  const formatMoney = (amount) => {
    return new Intl.NumberFormat('th-TH').format(amount);
  };
  
  const renderSlide = () => {
    switch (currentSlide) {
      // สไลด์ที่ 1: ปกนำเสนอ
      case 0:
        return (
          <div className="flex flex-col items-center justify-center h-full text-center">
            <div className="mb-8">
              <DollarSign size={64} className="text-blue-600 mx-auto mb-4" />
            </div>
            <h1 className="text-4xl font-bold text-blue-800 mb-4">การวางแผนการลงทุนทางการเงินระยะยาว</h1>
            <h2 className="text-2xl text-blue-600 mb-10">กลยุทธ์การสร้างความมั่งคั่งตามช่วงอายุและระดับรายได้</h2>
            <div className="mt-16">
              <p className="text-lg">วันที่ 31 มีนาคม 2025</p>
              <p className="text-lg mt-2">ฝ่ายวางแผนการลงทุน</p>
            </div>
          </div>
        );
      
      // สไลด์ที่ 2: บทนำและวัตถุประสงค์
      case 1:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">วัตถุประสงค์การนำเสนอ</h2>
            <div className="bg-blue-50 p-6 rounded-lg shadow-md">
              <ul className="space-y-4">
                <li className="flex items-start">
                  <div className="mr-4 mt-1 text-blue-600"><Target size={24} /></div>
                  <p>นำเสนอแผนการลงทุนตั้งแต่อายุ 23-60 ปี</p>
                </li>
                <li className="flex items-start">
                  <div className="mr-4 mt-1 text-blue-600"><PieChart size={24} /></div>
                  <p>วิเคราะห์รูปแบบการจัดสรรเงินลงทุนในสินทรัพย์ประเภทต่างๆ</p>
                </li>
                <li className="flex items-start">
                  <div className="mr-4 mt-1 text-blue-600"><TrendingUp size={24} /></div>
                  <p>แสดงการเติบโตของพอร์ตโฟลิโอและความมั่งคั่งระยะยาว</p>
                </li>
                <li className="flex items-start">
                  <div className="mr-4 mt-1 text-blue-600"><BarChart4 size={24} /></div>
                  <p>นำเสนอกลยุทธ์การบริหารรายได้และรายจ่าย</p>
                </li>
              </ul>
            </div>
            <div className="mt-8 p-4 bg-yellow-50 border-l-4 border-yellow-400 rounded">
              <p className="text-lg">การวางแผนการลงทุนที่ดีจะช่วยให้คุณสร้างความมั่งคั่งได้อย่างมีประสิทธิภาพและบรรลุเป้าหมายทางการเงินในระยะยาว</p>
            </div>
          </div>
        );
      
      // สไลด์ที่ 3: ภาพรวมของข้อมูล
      case 2:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">ภาพรวมการวางแผนการเงิน</h2>
            <div className="mb-4">
              <p className="mb-4">ความสัมพันธ์ระหว่างอายุกับระดับเงินเดือน และการเติบโตของตำแหน่งงาน</p>
              <div className="h-64">
                <ResponsiveContainer width="100%" height="100%">
                  <LineChart
                    data={salaryData}
                    margin={{ top: 5, right: 30, left: 20, bottom: 5 }}
                  >
                    <CartesianGrid strokeDasharray="3 3" />
                    <XAxis dataKey="age" />
                    <YAxis />
                    <Tooltip formatter={(value) => [`${formatMoney(value)} บาท`, 'เงินเดือนต่อปี']} />
                    <Legend />
                    <Line type="monotone" dataKey="salary" stroke="#8884d8" activeDot={{ r: 8 }} name="เงินเดือนต่อปี (บาท)" />
                  </LineChart>
                </ResponsiveContainer>
              </div>
            </div>
            <div className="mt-6 p-4 bg-blue-50 rounded-lg">
              <h3 className="font-semibold mb-2">การเติบโตของตำแหน่งงาน:</h3>
              <p>Financial Analyst → Senior Financial Analyst → Finance Manager → Senior Finance Manager → Finance Director → VP of Finance → CFO</p>
            </div>
          </div>
        );
      
      // สไลด์ที่ 4: การจัดสรรรายได้
      case 3:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">การจัดสรรรายได้ประจำปี</h2>
            <div className="grid grid-cols-2 gap-4">
              <div className="h-64">
                <ResponsiveContainer width="100%" height="100%">
                  <RechartPieChart>
                    <Pie
                      data={expenseData}
                      cx="50%"
                      cy="50%"
                      labelLine={false}
                      label={({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`}
                      outerRadius={80}
                      fill="#8884d8"
                      dataKey="value"
                    >
                      {expenseData.map((entry, index) => (
                        <Cell key={`cell-${index}`} fill={COLORS[index % COLORS.length]} />
                      ))}
                    </Pie>
                    <Tooltip />
                  </RechartPieChart>
                </ResponsiveContainer>
              </div>
              <div>
                <h3 className="font-semibold mb-3">สัดส่วนการจัดสรรรายได้</h3>
                <ul className="space-y-2">
                  {expenseData.map((item, index) => (
                    <li key={index} className="flex items-center">
                      <div className="w-4 h-4 mr-2" style={{ backgroundColor: COLORS[index % COLORS.length] }}></div>
                      <span>{item.name}: {item.value}%</span>
                    </li>
                  ))}
                </ul>
                <div className="mt-4 p-3 bg-blue-50 rounded">
                  <p>การจัดสรรรายได้อย่างสมดุลช่วยให้มีเงินเพียงพอสำหรับการใช้จ่ายปัจจุบันและการสร้างความมั่งคั่งในอนาคต</p>
                </div>
              </div>
            </div>
          </div>
        );
      
      // สไลด์ที่ 5: กลยุทธ์การลงทุน
      case 4:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">การจัดสรรเงินลงทุน</h2>
            <div className="grid grid-cols-2 gap-4">
              <div className="h-64">
                <ResponsiveContainer width="100%" height="100%">
                  <RechartPieChart>
                    <Pie
                      data={allocationData}
                      cx="50%"
                      cy="50%"
                      labelLine={false}
                      label={({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`}
                      outerRadius={80}
                      fill="#8884d8"
                      dataKey="value"
                    >
                      {allocationData.map((entry, index) => (
                        <Cell key={`cell-${index}`} fill={COLORS[index % COLORS.length]} />
                      ))}
                    </Pie>
                    <Tooltip />
                  </RechartPieChart>
                </ResponsiveContainer>
              </div>
              <div>
                <h3 className="font-semibold mb-3">สัดส่วนการลงทุนในสินทรัพย์ต่างๆ</h3>
                <ul className="space-y-2">
                  {allocationData.map((item, index) => (
                    <li key={index} className="flex items-center">
                      <div className="w-4 h-4 mr-2" style={{ backgroundColor: COLORS[index % COLORS.length] }}></div>
                      <span>{item.name}: {item.value}%</span>
                    </li>
                  ))}
                </ul>
                <div className="mt-4 p-3 bg-blue-50 rounded">
                  <p>การกระจายการลงทุนช่วยลดความเสี่ยงและเพิ่มโอกาสในการได้รับผลตอบแทนที่มั่นคงในระยะยาว</p>
                </div>
              </div>
            </div>
          </div>
        );
      
      // สไลด์ที่ 6: การเติบโตของรายได้และตำแหน่ง
      case 5:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">เส้นทางความก้าวหน้าในอาชีพและรายได้</h2>
            <div className="overflow-auto h-64 mb-6">
              <table className="min-w-full bg-white border">
                <thead className="bg-blue-100">
                  <tr>
                    <th className="py-2 px-4 border">ตำแหน่ง</th>
                    <th className="py-2 px-4 border">ช่วงอายุ</th>
                    <th className="py-2 px-4 border">เงินเดือนโดยประมาณ</th>
                  </tr>
                </thead>
                <tbody>
                  {careerPathData.map((item, index) => (
                    <tr key={index} className={index % 2 === 0 ? 'bg-gray-50' : 'bg-white'}>
                      <td className="py-2 px-4 border font-medium">{item.position}</td>
                      <td className="py-2 px-4 border text-center">{item.ageRange}</td>
                      <td className="py-2 px-4 border text-right">{item.salary}</td>
                    </tr>
                  ))}
                </tbody>
              </table>
            </div>
            <div className="p-4 bg-blue-50 rounded-lg">
              <p><span className="font-medium">ข้อสังเกต:</span> อัตราการเติบโตของเงินเดือนจะสูงในช่วงต้นของอาชีพ (7-8% ต่อปี) และค่อยๆ ลดลงในช่วงปลาย (2-3% ต่อปี) แต่ฐานเงินเดือนที่สูงขึ้นทำให้รายได้รวมยังคงเพิ่มขึ้นอย่างมีนัยสำคัญ</p>
            </div>
          </div>
        );
      
      // สไลด์ที่ 7: การเติบโตของรายได้และตำแหน่ง (ต่อ)
      case 6:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">การเติบโตของรายได้ตามช่วงอายุ</h2>
            <div className="h-64 mb-6">
              <ResponsiveContainer width="100%" height="100%">
                <BarChart
                  data={salaryData}
                  margin={{ top: 5, right: 30, left: 20, bottom: 5 }}
                >
                  <CartesianGrid strokeDasharray="3 3" />
                  <XAxis dataKey="age" />
                  <YAxis />
                  <Tooltip formatter={(value) => [`${formatMoney(value)} บาท`, 'เงินเดือนต่อปี']} />
                  <Legend />
                  <Bar dataKey="salary" name="เงินเดือนต่อปี (บาท)" fill="#8884d8" />
                </BarChart>
              </ResponsiveContainer>
            </div>
            <div className="grid grid-cols-3 gap-4 mt-4">
              <div className="p-4 bg-blue-50 rounded-lg text-center">
                <p className="font-medium">ช่วงต้นอาชีพ (23-35 ปี)</p>
                <p>อัตราเติบโต: 5-8% ต่อปี</p>
              </div>
              <div className="p-4 bg-green-50 rounded-lg text-center">
                <p className="font-medium">ช่วงกลางอาชีพ (36-45 ปี)</p>
                <p>อัตราเติบโต: 3-5% ต่อปี</p>
              </div>
              <div className="p-4 bg-yellow-50 rounded-lg text-center">
                <p className="font-medium">ช่วงปลายอาชีพ (46-60 ปี)</p>
                <p>อัตราเติบโต: 2-3% ต่อปี</p>
              </div>
            </div>
          </div>
        );
      
      // สไลด์ที่ 8: การเติบโตของพอร์ตการลงทุน
      case 7:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">การเติบโตของพอร์ตการลงทุน</h2>
            <div className="h-64 mb-6">
              <ResponsiveContainer width="100%" height="100%">
                <LineChart
                  data={portfolioGrowthData}
                  margin={{ top: 5, right: 30, left: 20, bottom: 5 }}
                >
                  <CartesianGrid strokeDasharray="3 3" />
                  <XAxis dataKey="age" />
                  <YAxis />
                  <Tooltip formatter={(value) => [`${formatMoney(value)} บาท`, 'มูลค่าพอร์ต']} />
                  <Legend />
                  <Line type="monotone" dataKey="value" stroke="#00C49F" activeDot={{ r: 8 }} name="มูลค่าพอร์ตสะสม (บาท)" />
                </LineChart>
              </ResponsiveContainer>
            </div>
            <div className="p-4 bg-green-50 rounded-lg">
              <p className="font-medium mb-2">ข้อสังเกตสำคัญ:</p>
              <p>มูลค่าพอร์ตการลงทุนมีการเติบโตแบบก้าวกระโดดในช่วงอายุ 45-60 ปี ซึ่งเป็นผลมาจากการสะสมเงินลงทุนอย่างต่อเนื่องรวมกับผลตอบแทนที่ทบต้น (Compound Effect) ที่ชัดเจนมากขึ้นเมื่อเวลาผ่านไป</p>
            </div>
          </div>
        );
      
      // สไลด์ที่ 9: การเติบโตของพอร์ตการลงทุน (ต่อ)
      case 8:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">มูลค่าพอร์ตสะสมตามช่วงอายุสำคัญ</h2>
            <div className="grid grid-cols-2 gap-6">
              <div className="col-span-2 mb-4">
                <p className="mb-2">มูลค่าพอร์ตการลงทุนเติบโตแบบทวีคูณด้วยอัตราผลตอบแทนเฉลี่ย 8% ต่อปี</p>
              </div>
              <div className="space-y-4">
                <div className="p-4 bg-blue-50 rounded-lg">
                  <h3 className="font-semibold text-lg mb-2">อายุ 30 ปี</h3>
                  <p className="text-xl text-blue-700 font-bold">{formatMoney(650000)} บาท</p>
                  <p className="text-sm mt-1">ช่วงเริ่มต้นการสะสมความมั่งคั่ง</p>
                </div>
                <div className="p-4 bg-blue-50 rounded-lg">
                  <h3 className="font-semibold text-lg mb-2">อายุ 40 ปี</h3>
                  <p className="text-xl text-blue-700 font-bold">{formatMoney(3200000)} บาท</p>
                  <p className="text-sm mt-1">การเติบโตของพอร์ตเริ่มมีนัยสำคัญ</p>
                </div>
              </div>
              <div className="space-y-4">
                <div className="p-4 bg-blue-50 rounded-lg">
                  <h3 className="font-semibold text-lg mb-2">อายุ 50 ปี</h3>
                  <p className="text-xl text-blue-700 font-bold">{formatMoney(7500000)} บาท</p>
                  <p className="text-sm mt-1">ผลของการลงทุนระยะยาวเริ่มชัดเจน</p>
                </div>
                <div className="p-4 bg-blue-50 rounded-lg">
                  <h3 className="font-semibold text-lg mb-2">อายุ 60 ปี</h3>
                  <p className="text-xl text-blue-700 font-bold">{formatMoney(23000000)} บาท</p>
                  <p className="text-sm mt-1">เป้าหมายความมั่งคั่งก่อนเกษียณ</p>
                </div>
              </div>
            </div>
          </div>
        );
      
      // สไลด์ที่ 10: จุดเปลี่ยนทางการเงินที่สำคัญ
      case 9:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">จุดเปลี่ยนสำคัญในเส้นทางการเงิน</h2>
            <div className="space-y-4">
              <div className="p-4 bg-blue-50 rounded-lg border-l-4 border-blue-600 flex">
                <div className="text-center mr-6 flex-shrink-0">
                  <h3 className="text-lg font-bold">อายุ 35 ปี</h3>
                  <Briefcase size={32} className="text-blue-600 mx-auto my-2" />
                </div>
                <div>
                  <p className="font-medium">การเลื่อนตำแหน่งเป็น Finance Manager</p>
                  <p>พอร์ตลงทุนมูลค่า 1.7 ล้านบาท</p>
                  <p className="text-sm text-gray-600 mt-1">เงินเดือนเพิ่มขึ้นเป็น 41,000 บาท/เดือน</p>
                </div>
              </div>
              
              <div className="p-4 bg-green-50 rounded-lg border-l-4 border-green-600 flex">
                <div className="text-center mr-6 flex-shrink-0">
                  <h3 className="text-lg font-bold">อายุ 45 ปี</h3>
                  <Briefcase size={32} className="text-green-600 mx-auto my-2" />
                </div>
                <div>
                  <p className="font-medium">การเลื่อนตำแหน่งเป็น Finance Director</p>
                  <p>พอร์ตลงทุนมูลค่า 5.5 ล้านบาท</p>
                  <p className="text-sm text-gray-600 mt-1">เงินเดือนเพิ่มขึ้นเป็น 60,600 บาท/เดือน</p>
                </div>
              </div>
              
              <div className="p-4 bg-yellow-50 rounded-lg border-l-4 border-yellow-600 flex">
                <div className="text-center mr-6 flex-shrink-0">
                  <h3 className="text-lg font-bold">อายุ 55 ปี</h3>
                  <Briefcase size={32} className="text-yellow-600 mx-auto my-2" />
                </div>
                <div>
                  <p className="font-medium">การเลื่อนตำแหน่งเป็น CFO</p>
                  <p>พอร์ตลงทุนมูลค่า 14 ล้านบาท</p>
                  <p className="text-sm text-gray-600 mt-1">เงินเดือนเพิ่มขึ้นเป็น 77,600 บาท/เดือน</p>
                </div>
              </div>
              
              <div className="p-4 bg-purple-50 rounded-lg border-l-4 border-purple-600 flex">
                <div className="text-center mr-6 flex-shrink-0">
                  <h3 className="text-lg font-bold">อายุ 60 ปี</h3>
                  <DollarSign size={32} className="text-purple-600 mx-auto my-2" />
                </div>
                <div>
                  <p className="font-medium">เกษียณอายุ</p>
                  <p>พอร์ตลงทุนมูลค่า 23 ล้านบาท</p>
                  <p className="text-sm text-gray-600 mt-1">สามารถใช้ผลตอบแทนจากการลงทุนเป็นรายได้หลังเกษียณ</p>
                </div>
              </div>
            </div>
          </div>
        );
      
      // สไลด์ที่ 11: ปัจจัยความสำเร็จ
      case 10:
        return (
          <div className="h-full">
            <h2 className="text-2xl font-bold text-blue-800 mb-6">ปัจจัยสู่ความสำเร็จทางการเงิน</h2>
            <div className="grid grid-cols-2 gap-4">
              <div className="p-4 bg-blue-50 rounded-lg shadow-sm">
                <h3 className="font-semibold text-lg mb-2 flex items-center">
                  <span className="mr-2 text-blue-600"><DollarSign size