prompthub.krudevtech.com
สำหรับครูและนักพัฒนา
ค้นพบ Prompt ที่หลากหลายเพื่อช่วยในการสอน การสร้างสื่อ การจัดการเรียนการสอน และการทำงานอย่างมีประสิทธิภาพ
สร้างระบบแบบทดสอบออนไลน์ (Online Quiz System) โดยใช้
* Google Apps Script (code.gs)
* HTML/CSS/JavaScript (index.html)
* Google Sheets เป็นฐานข้อมูล
* รองรับการนำเข้าข้อสอบจากไฟล์ CSV หรือ Excel ได้ง่าย
* รองรับการจัดการข้อสอบผ่านหน้า Admin
* รองรับการกำหนดเวลาสอบ
* ป้องกันการทำข้อสอบซ้ำด้วยรหัสนักเรียน
* แสดงคะแนนและเฉลยหลังส่งข้อสอบได้
* รองรับภาษาไทยเต็มรูปแบบ
* ดีไซน์สวยงาม Responsive ใช้งานได้ทั้งมือถือและคอมพิวเตอร์
---
## โครงสร้างระบบ
### Google Sheet ให้มี 4 ชีต
#### 1. Sheet: QUESTIONS
เก็บข้อสอบ
คอลัมน์ดังนี้
| A | B | C | D | E | F | G | H |
| -- | -------- | ------- | ------- | ------- | ------- | ------- | ----- |
| ID | Question | ChoiceA | ChoiceB | ChoiceC | ChoiceD | Correct | Score |
ตัวอย่าง
| 1 | AI คืออะไร | ปัญญาประดิษฐ์ | เกม | อินเทอร์เน็ต | โปรแกรมพิมพ์งาน | A | 1 |
---
#### 2. Sheet: SETTINGS
เก็บค่าระบบ
| A | B |
| --------------- | ------------------ |
| quiz_title | แบบทดสอบความรู้ AI |
| duration | 30 |
| show_score | TRUE |
| show_answer | TRUE |
| random_question | FALSE |
duration = เวลาสอบ (นาที)
---
#### 3. Sheet: STUDENTS
เก็บข้อมูลผู้เข้าสอบ
| รหัสนักเรียน | คำนำหน้า | ชื่อ | นามสกุล | เวลาส่ง | คะแนน |
---
#### 4. Sheet: ANSWERS
เก็บคำตอบนักเรียน
| รหัสนักเรียน | ข้อที่ | คำตอบ | ถูกต้อง |
---
# ความสามารถที่ต้องมี
## 1. หน้า Login นักเรียน
ให้นักเรียนกรอก
* รหัสนักเรียน
* คำนำหน้า
* ชื่อ
* นามสกุล
ตรวจสอบว่า
* หากรหัสนักเรียนนี้เคยสอบแล้ว → ห้ามเข้าสอบซ้ำ
* แจ้งเตือนว่า “คุณได้ทำแบบทดสอบไปแล้ว”
---
## 2. หน้าแบบทดสอบ
### คุณสมบัติ
* ดึงข้อสอบจาก Google Sheets
* แสดงทีละข้อหรือทั้งหมดก็ได้
* รองรับข้อสอบ 4 ตัวเลือก
* มีตัวจับเวลาถอยหลัง
* เมื่อหมดเวลาให้ส่งอัตโนมัติ
* ปุ่ม “ส่งคำตอบ”
---
## 3. ระบบตรวจคะแนนอัตโนมัติ
เมื่อส่งข้อสอบ
* ตรวจคำตอบ
* คำนวณคะแนน
* บันทึกลง Google Sheets
* บันทึกคำตอบทุกข้อ
---
## 4. หน้าแสดงผลคะแนน
แสดง
* คะแนนรวม
* จำนวนข้อถูก
* จำนวนข้อผิด
* เฉลย (ถ้าเปิดใน SETTINGS)
---
## 5. ระบบ Admin
สร้างหน้า Admin สำหรับจัดการข้อสอบ
### ความสามารถ
* เพิ่มข้อสอบ
* แก้ไขข้อสอบ
* ลบข้อสอบ
* ตั้งเวลาสอบ
* เปิด/ปิดการแสดงคะแนน
* เปิด/ปิดเฉลย
* ดูรายชื่อนักเรียน
* ดูคะแนนทั้งหมด
---
## 6. ระบบ Import CSV / Excel
### ต้องรองรับ
* อัปโหลดไฟล์ CSV
* อัปโหลดไฟล์ Excel (.xlsx)
เมื่ออัปโหลดแล้ว
* นำข้อมูลเข้าสู่ชีต QUESTIONS อัตโนมัติ
* ตรวจสอบรูปแบบคอลัมน์
* แจ้งเตือนหากข้อมูลผิดรูปแบบ
---
# ไฟล์ที่ต้องสร้าง
## 1. code.gs
ให้มีฟังก์ชัน
* doGet()
* getQuestions()
* submitQuiz()
* checkDuplicateStudent()
* importCSV()
* importExcel()
* getSettings()
* saveSettings()
และเชื่อม Google Sheets
---
## 2. index.html
ประกอบด้วย
* หน้า Login
* หน้า Quiz
* หน้า Result
* Timer
* Responsive Design
* ใช้ Bootstrap หรือ Tailwind CSS
---
## 3. admin.html
สำหรับผู้ดูแลระบบ
มีเมนู
* จัดการข้อสอบ
* Import CSV/Excel
* ตั้งค่าเวลา
* ดูคะแนน
---
## 4. script.html
JavaScript Frontend
ประกอบด้วย
* โหลดข้อสอบ
* นับเวลา
* ส่งคำตอบ
* ตรวจสอบข้อมูล
* เรียกใช้งาน google.script.run
---
# UI/UX
ขอให้ดีไซน์สวย ทันสมัย
โทนสี
* น้ำเงิน
* ขาว
* Gradient
มี
* Card Layout
* Progress Bar
* SweetAlert2
* Loading Animation
---
# ความปลอดภัย
* ป้องกันการรีเฟรชแล้วเริ่มใหม่
* ป้องกันส่งซ้ำ
* ตรวจสอบข้อมูลก่อนบันทึก
* จำกัดสิทธิ์ Admin
---
# Deployment
อธิบายวิธี Deploy
1. Deploy as Web App
2. Anyone with link
3. วิธีเชื่อม Google Sheet
4. วิธี Import CSV/Excel
---
# ต้องการผลลัพธ์
ให้สร้างโค้ดแบบพร้อมใช้งานจริงทั้งหมด ได้แก่
* code.gs
* index.html
* admin.html
* script.html
* style.css
พร้อมอธิบายการติดตั้งทีละขั้นตอน
สร้างระบบแบบทดสอบออนไลน์ (Online Quiz System) โดยใช้
* Google Apps Script (code.gs)
* HTML/CSS/JavaScript (index.html)
* Google Sheets เป็นฐานข้อมูล
* รองรับการนำเข้าข้อสอบจากไฟล์ CSV หรือ Excel ได้ง่าย
* รองรับการจัดการข้อสอบผ่านหน้า Admin
* รองรับการกำหนดเวลาสอบ
* ป้องกันการทำข้อสอบซ้ำด้วยรหัสนักเรียน
* แสดงคะแนนและเฉลยหลังส่งข้อสอบได้
* รองรับภาษาไทยเต็มรูปแบบ
* ดีไซน์สวยงาม Responsive ใช้งานได้ทั้งมือถือและคอมพิวเตอร์
---
## โครงสร้างระบบ
### Google Sheet ให้มี 4 ชีต
#### 1. Sheet: QUESTIONS
เก็บข้อสอบ
คอลัมน์ดังนี้
| A | B | C | D | E | F | G | H |
| -- | -------- | ------- | ------- | ------- | ------- | ------- | ----- |
| ID | Question | ChoiceA | ChoiceB | ChoiceC | ChoiceD | Correct | Score |
ตัวอย่าง
| 1 | AI คืออะไร | ปัญญาประดิษฐ์ | เกม | อินเทอร์เน็ต | โปรแกรมพิมพ์งาน | A | 1 |
---
#### 2. Sheet: SETTINGS
เก็บค่าระบบ
| A | B |
| --------------- | ------------------ |
| quiz_title | แบบทดสอบความรู้ AI |
| duration | 30 |
| show_score | TRUE |
| show_answer | TRUE |
| random_question | FALSE |
duration = เวลาสอบ (นาที)
---
#### 3. Sheet: STUDENTS
เก็บข้อมูลผู้เข้าสอบ
| รหัสนักเรียน | คำนำหน้า | ชื่อ | นามสกุล | เวลาส่ง | คะแนน |
---
#### 4. Sheet: ANSWERS
เก็บคำตอบนักเรียน
| รหัสนักเรียน | ข้อที่ | คำตอบ | ถูกต้อง |
---
# ความสามารถที่ต้องมี
## 1. หน้า Login นักเรียน
ให้นักเรียนกรอก
* รหัสนักเรียน
* คำนำหน้า
* ชื่อ
* นามสกุล
ตรวจสอบว่า
* หากรหัสนักเรียนนี้เคยสอบแล้ว → ห้ามเข้าสอบซ้ำ
* แจ้งเตือนว่า “คุณได้ทำแบบทดสอบไปแล้ว”
---
## 2. หน้าแบบทดสอบ
### คุณสมบัติ
* ดึงข้อสอบจาก Google Sheets
* แสดงทีละข้อหรือทั้งหมดก็ได้
* รองรับข้อสอบ 4 ตัวเลือก
* มีตัวจับเวลาถอยหลัง
* เมื่อหมดเวลาให้ส่งอัตโนมัติ
* ปุ่ม “ส่งคำตอบ”
---
## 3. ระบบตรวจคะแนนอัตโนมัติ
เมื่อส่งข้อสอบ
* ตรวจคำตอบ
* คำนวณคะแนน
* บันทึกลง Google Sheets
* บันทึกคำตอบทุกข้อ
---
## 4. หน้าแสดงผลคะแนน
แสดง
* คะแนนรวม
* จำนวนข้อถูก
* จำนวนข้อผิด
* เฉลย (ถ้าเปิดใน SETTINGS)
---
## 5. ระบบ Admin
สร้างหน้า Admin สำหรับจัดการข้อสอบ
### ความสามารถ
* เพิ่มข้อสอบ
* แก้ไขข้อสอบ
* ลบข้อสอบ
* ตั้งเวลาสอบ
* เปิด/ปิดการแสดงคะแนน
* เปิด/ปิดเฉลย
* ดูรายชื่อนักเรียน
* ดูคะแนนทั้งหมด
---
## 6. ระบบ Import CSV / Excel
### ต้องรองรับ
* อัปโหลดไฟล์ CSV
* อัปโหลดไฟล์ Excel (.xlsx)
เมื่ออัปโหลดแล้ว
* นำข้อมูลเข้าสู่ชีต QUESTIONS อัตโนมัติ
* ตรวจสอบรูปแบบคอลัมน์
* แจ้งเตือนหากข้อมูลผิดรูปแบบ
---
# ไฟล์ที่ต้องสร้าง
## 1. code.gs
ให้มีฟังก์ชัน
* doGet()
* getQuestions()
* submitQuiz()
* checkDuplicateStudent()
* importCSV()
* importExcel()
* getSettings()
* saveSettings()
และเชื่อม Google Sheets
---
## 2. index.html
ประกอบด้วย
* หน้า Login
* หน้า Quiz
* หน้า Result
* Timer
* Responsive Design
* ใช้ Bootstrap หรือ Tailwind CSS
---
## 3. admin.html
สำหรับผู้ดูแลระบบ
มีเมนู
* จัดการข้อสอบ
* Import CSV/Excel
* ตั้งค่าเวลา
* ดูคะแนน
---
## 4. script.html
JavaScript Frontend
ประกอบด้วย
* โหลดข้อสอบ
* นับเวลา
* ส่งคำตอบ
* ตรวจสอบข้อมูล
* เรียกใช้งาน google.script.run
---
# UI/UX
ขอให้ดีไซน์สวย ทันสมัย
โทนสี
* น้ำเงิน
* ขาว
* Gradient
มี
* Card Layout
* Progress Bar
* SweetAlert2
* Loading Animation
---
# ความปลอดภัย
* ป้องกันการรีเฟรชแล้วเริ่มใหม่
* ป้องกันส่งซ้ำ
* ตรวจสอบข้อมูลก่อนบันทึก
* จำกัดสิทธิ์ Admin
---
# Deployment
อธิบายวิธี Deploy
1. Deploy as Web App
2. Anyone with link
3. วิธีเชื่อม Google Sheet
4. วิธี Import CSV/Excel
---
# ต้องการผลลัพธ์
ให้สร้างโค้ดแบบพร้อมใช้งานจริงทั้งหมด ได้แก่
* code.gs
* index.html
* admin.html
* script.html
* style.css
พร้อมอธิบายการติดตั้งทีละขั้นตอน
คุณคือ Senior Full Stack Developer และ UI/UX Designer มืออาชีพ
จงออกแบบและพัฒนา “เว็บไซต์โรงเรียน” แบบครบระบบ โดยใช้เทคโนโลยีดังนี้
- PHP 8+
- MySQL
- HTML5
- CSS3
- JavaScript
- Bootstrap 5
- Responsive Design
- รองรับ Dark Mode
- ใช้งานได้ทั้งมือถือ Tablet และ Desktop
แนวคิดการออกแบบ:
- ทันสมัย สวยงาม น่าเชื่อถือ
- ใช้โทนสีหลักของโรงเรียน (แดง-เหลือง)
- UI ดูเป็นทางการแต่ทันสมัย
- โหลดเร็ว
- รองรับ SEO
- มี Animation เบา ๆ
- ใช้ Font ภาษาไทยที่อ่านง่าย
- Dashboard ดู Professional
โครงสร้างเว็บไซต์ประกอบด้วย:
1. หน้าแรก (Home)
- Hero Section พร้อมภาพโรงเรียน
- ข่าวประชาสัมพันธ์
- ปฏิทินกิจกรรม
- ผู้บริหาร
- สถิติผู้ใช้งาน
- แนะนำโรงเรียน
- Quick Links
- แกลเลอรีภาพ
- วิดีโอแนะนำโรงเรียน
- Footer ครบถ้วน
2. ระบบข่าวประชาสัมพันธ์
- เพิ่ม/แก้ไข/ลบข่าว
- อัปโหลดรูปภาพ
- แสดงข่าวล่าสุด
- ระบบหมวดหมู่ข่าว
- ระบบค้นหาข่าว
3. ระบบบุคลากร
- ข้อมูลครูและบุคลากร
- แสดงรูปภาพ
- แบ่งกลุ่มสาระ
- ระบบค้นหา
4. ระบบนักเรียน
- แสดงข้อมูลนักเรียน
- ห้องเรียน
- ระดับชั้น
- ระบบค้นหา
5. ระบบดาวน์โหลดเอกสาร
- อัปโหลดไฟล์ PDF/Word
- แบ่งหมวดหมู่
- นับจำนวนดาวน์โหลด
6. ระบบแกลเลอรี
- อัลบั้มรูป
- Lightbox
- Lazy Load
7. ระบบติดต่อโรงเรียน
- ฟอร์มติดต่อ
- Google Map
- Social Media
8. ระบบ Admin
- Login / Logout
- Dashboard
- จัดการผู้ใช้งาน
- จัดการข่าว
- จัดการแกลเลอรี
- จัดการเอกสาร
- จัดการ Banner
9. ระบบความปลอดภัย
- Password Hashing
- Prepared Statements (PDO)
- CSRF Protection
- Session Security
- Validation Input
- Upload Security
10. ฐานข้อมูล MySQL
ออกแบบ ER Diagram และ SQL Script สำหรับ:
- users
- news
- galleries
- gallery_images
- teachers
- students
- downloads
- categories
- banners
- settings
11. สิ่งที่ต้องการเพิ่มเติม
- ใช้ MVC Structure
- แยกไฟล์เป็นระบบระเบียบ
- Clean Code
- Comment อธิบายโค้ด
- รองรับ .htaccess Rewrite URL
- ระบบ Pagination
- Toast Notification
- SweetAlert2
- DataTables
- CKEditor
12. ต้องการผลลัพธ์ดังนี้
- โครงสร้างโฟลเดอร์ทั้งหมด
- SQL Script
- ตัวอย่างไฟล์ config.php
- ตัวอย่างระบบ Login
- ตัวอย่าง CRUD ข่าวประชาสัมพันธ์
- ตัวอย่าง Dashboard Admin
- ตัวอย่างหน้า Home
- ตัวอย่าง CSS Modern Design
- ตัวอย่าง JavaScript
- วิธีติดตั้งระบบบน XAMPP/MAMP
- วิธี Deploy ขึ้น Hosting
13. รูปแบบการเขียนโค้ด
- เขียนโค้ดแบบ Production Ready
- ใช้มาตรฐาน PSR
- อธิบายทุกส่วน
- แสดงตัวอย่างไฟล์ครบ
- แสดงโค้ดเต็ม ไม่ตัด
14. เพิ่มฟีเจอร์ AI ภายในเว็บไซต์
- AI Chatbot ตอบคำถามโรงเรียน
- AI สรุปข่าวอัตโนมัติ
- AI สร้างประกาศ
- AI ช่วยค้นหาเอกสาร
15. ต้องการ UI เพิ่มเติม
- Glassmorphism
- Soft Shadow
- Gradient Modern
- Card Design
- Hover Effect
- Animated Counter
- Loading Animation
กรุณาสร้าง:
- Wireframe
- Database Schema
- Folder Structure
- Full Source Code Example
- Responsive UI Design
- Modern Admin Dashboard
- Beautiful Landing Page
- พร้อมอธิบายทุกขั้นตอนแบบละเอียด
คุณคือ Senior Full Stack Developer และ UI/UX Designer มืออาชีพ
จงออกแบบและพัฒนา “เว็บไซต์โรงเรียน” แบบครบระบบ โดยใช้เทคโนโลยีดังนี้
- PHP 8+
- MySQL
- HTML5
- CSS3
- JavaScript
- Bootstrap 5
- Responsive Design
- รองรับ Dark Mode
- ใช้งานได้ทั้งมือถือ Tablet และ Desktop
แนวคิดการออกแบบ:
- ทันสมัย สวยงาม น่าเชื่อถือ
- ใช้โทนสีหลักของโรงเรียน (แดง-เหลือง)
- UI ดูเป็นทางการแต่ทันสมัย
- โหลดเร็ว
- รองรับ SEO
- มี Animation เบา ๆ
- ใช้ Font ภาษาไทยที่อ่านง่าย
- Dashboard ดู Professional
โครงสร้างเว็บไซต์ประกอบด้วย:
1. หน้าแรก (Home)
- Hero Section พร้อมภาพโรงเรียน
- ข่าวประชาสัมพันธ์
- ปฏิทินกิจกรรม
- ผู้บริหาร
- สถิติผู้ใช้งาน
- แนะนำโรงเรียน
- Quick Links
- แกลเลอรีภาพ
- วิดีโอแนะนำโรงเรียน
- Footer ครบถ้วน
2. ระบบข่าวประชาสัมพันธ์
- เพิ่ม/แก้ไข/ลบข่าว
- อัปโหลดรูปภาพ
- แสดงข่าวล่าสุด
- ระบบหมวดหมู่ข่าว
- ระบบค้นหาข่าว
3. ระบบบุคลากร
- ข้อมูลครูและบุคลากร
- แสดงรูปภาพ
- แบ่งกลุ่มสาระ
- ระบบค้นหา
4. ระบบนักเรียน
- แสดงข้อมูลนักเรียน
- ห้องเรียน
- ระดับชั้น
- ระบบค้นหา
5. ระบบดาวน์โหลดเอกสาร
- อัปโหลดไฟล์ PDF/Word
- แบ่งหมวดหมู่
- นับจำนวนดาวน์โหลด
6. ระบบแกลเลอรี
- อัลบั้มรูป
- Lightbox
- Lazy Load
7. ระบบติดต่อโรงเรียน
- ฟอร์มติดต่อ
- Google Map
- Social Media
8. ระบบ Admin
- Login / Logout
- Dashboard
- จัดการผู้ใช้งาน
- จัดการข่าว
- จัดการแกลเลอรี
- จัดการเอกสาร
- จัดการ Banner
9. ระบบความปลอดภัย
- Password Hashing
- Prepared Statements (PDO)
- CSRF Protection
- Session Security
- Validation Input
- Upload Security
10. ฐานข้อมูล MySQL
ออกแบบ ER Diagram และ SQL Script สำหรับ:
- users
- news
- galleries
- gallery_images
- teachers
- students
- downloads
- categories
- banners
- settings
11. สิ่งที่ต้องการเพิ่มเติม
- ใช้ MVC Structure
- แยกไฟล์เป็นระบบระเบียบ
- Clean Code
- Comment อธิบายโค้ด
- รองรับ .htaccess Rewrite URL
- ระบบ Pagination
- Toast Notification
- SweetAlert2
- DataTables
- CKEditor
12. ต้องการผลลัพธ์ดังนี้
- โครงสร้างโฟลเดอร์ทั้งหมด
- SQL Script
- ตัวอย่างไฟล์ config.php
- ตัวอย่างระบบ Login
- ตัวอย่าง CRUD ข่าวประชาสัมพันธ์
- ตัวอย่าง Dashboard Admin
- ตัวอย่างหน้า Home
- ตัวอย่าง CSS Modern Design
- ตัวอย่าง JavaScript
- วิธีติดตั้งระบบบน XAMPP/MAMP
- วิธี Deploy ขึ้น Hosting
13. รูปแบบการเขียนโค้ด
- เขียนโค้ดแบบ Production Ready
- ใช้มาตรฐาน PSR
- อธิบายทุกส่วน
- แสดงตัวอย่างไฟล์ครบ
- แสดงโค้ดเต็ม ไม่ตัด
14. เพิ่มฟีเจอร์ AI ภายในเว็บไซต์
- AI Chatbot ตอบคำถามโรงเรียน
- AI สรุปข่าวอัตโนมัติ
- AI สร้างประกาศ
- AI ช่วยค้นหาเอกสาร
15. ต้องการ UI เพิ่มเติม
- Glassmorphism
- Soft Shadow
- Gradient Modern
- Card Design
- Hover Effect
- Animated Counter
- Loading Animation
กรุณาสร้าง:
- Wireframe
- Database Schema
- Folder Structure
- Full Source Code Example
- Responsive UI Design
- Modern Admin Dashboard
- Beautiful Landing Page
- พร้อมอธิบายทุกขั้นตอนแบบละเอียด
"จงสร้างและออกแบบระบบปฏิทินกิจกรรมหน่วยงาน (Public Calendar) โดยใช้ Google Apps Script ทำงานร่วมกับ Google Sheets โดยมีรายละเอียดความต้องการดังต่อไปนี้:
1. ข้อกำหนดทางเทคนิค (Tech Stack):
ใช้ไลบรารี FullCalendar.js สำหรับแสดงผลปฏิทิน
ใช้ Bootstrap 5 สำหรับออกแบบ UI ให้สวยงาม ทันสมัย และรองรับการแสดงผลบนมือถือ (Responsive)
ใช้การเขียนโค้ดแบบฝั่ง Server (Code.gs) และฝั่ง Client (Index.html)
2. ฟีเจอร์ที่ต้องการ (Features):
ระบบสามารถดึงข้อมูลจาก Google Sheets (ชื่อกิจกรรม, วันเวลาเริ่มต้น, วันเวลาสิ้นสุด, รายละเอียด, สีของป้ายกิจกรรม) มาแสดงบนปฏิทินได้
มีปุ่ม "เพิ่มกิจกรรม" เปิดเป็น Modal Form ให้ผู้ใช้กรอกข้อมูล
เมื่อกดบันทึก ให้ข้อมูลถูกส่งไปเพิ่มในแถวใหม่ของ Google Sheets ทันที (พร้อมอัปเดตปฏิทินบนหน้าเว็บโดยไม่ต้องรีเฟรชหน้า)
คลิกที่กิจกรรมบนปฏิทินเพื่อดูรายละเอียดเพิ่มเติมแบบ Modal ได้
3. สิ่งที่ต้องการให้ตอบกลับ (Deliverables):
โค้ดทั้งหมด: Code.gs และ Index.html พร้อมคอมเมนต์อธิบายโค้ด
การตั้งค่า Google Sheets: อธิบายวิธีตั้งชื่อแผ่นงานและระบุหัวคอลัมน์ที่ต้องใช้
ข้อมูลจำลอง (Mock Data): ขอตารางข้อมูลตัวอย่างประมาณ 5 แถว เพื่อนำไปกรอกทดสอบ
วิธีติดตั้ง (Deployment): อธิบายขั้นตอนการนำไปใช้งาน (Deploy as Web App)
สรุประบบ (Overview): สรุปภาพรวมสถาปัตยกรรมของระบบ (System Architecture) และเส้นทางการไหลของข้อมูล (Data Flow) แบบเข้าใจง่าย"
"จงสร้างและออกแบบระบบปฏิทินกิจกรรมหน่วยงาน (Public Calendar) โดยใช้ Google Apps Script ทำงานร่วมกับ Google Sheets โดยมีรายละเอียดความต้องการดังต่อไปนี้:
1. ข้อกำหนดทางเทคนิค (Tech Stack):
ใช้ไลบรารี FullCalendar.js สำหรับแสดงผลปฏิทิน
ใช้ Bootstrap 5 สำหรับออกแบบ UI ให้สวยงาม ทันสมัย และรองรับการแสดงผลบนมือถือ (Responsive)
ใช้การเขียนโค้ดแบบฝั่ง Server (Code.gs) และฝั่ง Client (Index.html)
2. ฟีเจอร์ที่ต้องการ (Features):
ระบบสามารถดึงข้อมูลจาก Google Sheets (ชื่อกิจกรรม, วันเวลาเริ่มต้น, วันเวลาสิ้นสุด, รายละเอียด, สีของป้ายกิจกรรม) มาแสดงบนปฏิทินได้
มีปุ่ม "เพิ่มกิจกรรม" เปิดเป็น Modal Form ให้ผู้ใช้กรอกข้อมูล
เมื่อกดบันทึก ให้ข้อมูลถูกส่งไปเพิ่มในแถวใหม่ของ Google Sheets ทันที (พร้อมอัปเดตปฏิทินบนหน้าเว็บโดยไม่ต้องรีเฟรชหน้า)
คลิกที่กิจกรรมบนปฏิทินเพื่อดูรายละเอียดเพิ่มเติมแบบ Modal ได้
3. สิ่งที่ต้องการให้ตอบกลับ (Deliverables):
โค้ดทั้งหมด: Code.gs และ Index.html พร้อมคอมเมนต์อธิบายโค้ด
การตั้งค่า Google Sheets: อธิบายวิธีตั้งชื่อแผ่นงานและระบุหัวคอลัมน์ที่ต้องใช้
ข้อมูลจำลอง (Mock Data): ขอตารางข้อมูลตัวอย่างประมาณ 5 แถว เพื่อนำไปกรอกทดสอบ
วิธีติดตั้ง (Deployment): อธิบายขั้นตอนการนำไปใช้งาน (Deploy as Web App)
สรุประบบ (Overview): สรุปภาพรวมสถาปัตยกรรมของระบบ (System Architecture) และเส้นทางการไหลของข้อมูล (Data Flow) แบบเข้าใจง่าย"
ช่วยเขียนโค้ดสำหรับ "ระบบจองห้องประชุมออนไลน์" (Meeting Room Booking System) โดยใช้ Google Apps Script ทำงานร่วมกับ Google Sheets ให้หน่อยครับ ระบบต้องเป็นแบบ Single Page Application (SPA) ประกอบด้วยไฟล์ Code.gs และ index.html
ข้อกำหนดของระบบมีดังนี้:
1. โครงสร้าง Database (Google Sheets)
- เมื่อรันระบบครั้งแรก ให้สคริปต์ตรวจสอบว่ามีชีตชื่อ "Bookings" หรือไม่ ถ้าไม่มีให้สร้างใหม่
- กำหนด Header ของชีตดังนี้: ['ID', 'ชื่อผู้จอง', 'ห้องประชุม', 'วันที่', 'เวลาเริ่ม', 'เวลาสิ้นสุด', 'วัตถุประสงค์', 'เวลาที่บันทึก', 'สถานะ']
2. ข้อกำหนดฝั่ง Backend (Code.gs)
- มีฟังก์ชัน doGet() สำหรับ render หน้าเว็บแบบ ALLOWALL
- ฟังก์ชัน getBookings(): ดึงข้อมูลจากชีตเพื่อส่งให้ Frontend **สำคัญมาก:** ต้องมีการแปลงค่าเวลาจาก Google Sheets ให้อยู่ในรูปแบบ String 'HH:mm' และวันที่เป็น 'YYYY-MM-DD' เพื่อป้องกันบั๊กเวลาส่งข้อมูลไปแสดงผลในปฏิทิน
- ฟังก์ชัน addBooking(): รับข้อมูลจากฟอร์มมาบันทึก
- **Conflict Checking:** ในฟังก์ชัน addBooking ต้องมีการเช็คเวลาทับซ้อน หากผู้ใช้เลือกห้องเดียวกัน วันเดียวกัน และมีเวลาคาบเกี่ยวกับการจองที่มีอยู่แล้ว ให้ return error กลับไปและไม่อนุญาตให้บันทึก
3. ข้อกำหนดฝั่ง Frontend (index.html)
- การออกแบบ: ใช้ Tailwind CSS (ผ่าน CDN), ใช้ฟอนต์ Google Fonts (Kanit), และ FontAwesome (Icons) แบบ Responsive หน้าจอมือถือ
- Layout แบ่งเป็น 2 ส่วน (Grid):
- ด้านซ้าย/ด้านบน: "ฟอร์มจองห้องประชุม" (ชื่อ, เลือกห้อง [Room A, Room B, Boardroom], วันที่, เวลาเริ่ม, เวลาสิ้นสุด, วัตถุประสงค์)
- ด้านขวา/ด้านล่าง: "ปฏิทินแสดงการจอง" ใช้ไลบรารี FullCalendar (ผ่าน CDN)
- UX/UI Interactivity:
- ไม่ใช้ alert() ธรรมดา ให้สร้าง Custom Toast Notification (มุมขวาล่าง) สีเขียวสำหรับสำเร็จ สีแดงสำหรับ error
- ปุ่ม Submit ต้องมี Loading Spinner และ disable ระหว่างรอ Google Apps Script ประมวลผล
- ฟอร์มตรวจสอบขั้นพื้นฐาน: เวลาสิ้นสุดต้องมากกว่าเวลาเริ่ม และวันที่ต้องไม่ใช่อดีต
- เมื่อบันทึกสำเร็จ ให้ดึงข้อมูลมาอัปเดตปฏิทินใหม่ทันทีโดยที่หน้าเว็บไม่ต้อง Refresh (ผ่าน google.script.run)
- การทำงานของ FullCalendar:
- นำข้อมูลจากฝั่ง Backend มา render เป็น Event บนปฏิทิน
- ตั้งค่าแถบสี (Background Color) ของ Event ตามชื่อห้องให้แตกต่างกัน
- เมื่อผู้ใช้ "คลิก" ที่ Event บนปฏิทิน ให้เปิดหน้าต่าง Modal (Tailwind Modal) ขึ้นมาตรงกลางจอ เพื่อแสดงรายละเอียด (ชื่อผู้จอง, ห้อง, เวลา, วัตถุประสงค์) พร้อมปุ่มปิด Modal
กรุณาเขียนโค้ดออกมาให้ครบถ้วน พร้อมใช้งาน และแยกไฟล์ Code.gs กับ index.html ออกจากกันอย่างชัดเจน โค้ดควรมีการคอมเมนต์อธิบายภาษาไทยในจุดสำคัญด้วย
ช่วยเขียนโค้ดสำหรับ "ระบบจองห้องประชุมออนไลน์" (Meeting Room Booking System) โดยใช้ Google Apps Script ทำงานร่วมกับ Google Sheets ให้หน่อยครับ ระบบต้องเป็นแบบ Single Page Application (SPA) ประกอบด้วยไฟล์ Code.gs และ index.html
ข้อกำหนดของระบบมีดังนี้:
1. โครงสร้าง Database (Google Sheets)
- เมื่อรันระบบครั้งแรก ให้สคริปต์ตรวจสอบว่ามีชีตชื่อ "Bookings" หรือไม่ ถ้าไม่มีให้สร้างใหม่
- กำหนด Header ของชีตดังนี้: ['ID', 'ชื่อผู้จอง', 'ห้องประชุม', 'วันที่', 'เวลาเริ่ม', 'เวลาสิ้นสุด', 'วัตถุประสงค์', 'เวลาที่บันทึก', 'สถานะ']
2. ข้อกำหนดฝั่ง Backend (Code.gs)
- มีฟังก์ชัน doGet() สำหรับ render หน้าเว็บแบบ ALLOWALL
- ฟังก์ชัน getBookings(): ดึงข้อมูลจากชีตเพื่อส่งให้ Frontend **สำคัญมาก:** ต้องมีการแปลงค่าเวลาจาก Google Sheets ให้อยู่ในรูปแบบ String 'HH:mm' และวันที่เป็น 'YYYY-MM-DD' เพื่อป้องกันบั๊กเวลาส่งข้อมูลไปแสดงผลในปฏิทิน
- ฟังก์ชัน addBooking(): รับข้อมูลจากฟอร์มมาบันทึก
- **Conflict Checking:** ในฟังก์ชัน addBooking ต้องมีการเช็คเวลาทับซ้อน หากผู้ใช้เลือกห้องเดียวกัน วันเดียวกัน และมีเวลาคาบเกี่ยวกับการจองที่มีอยู่แล้ว ให้ return error กลับไปและไม่อนุญาตให้บันทึก
3. ข้อกำหนดฝั่ง Frontend (index.html)
- การออกแบบ: ใช้ Tailwind CSS (ผ่าน CDN), ใช้ฟอนต์ Google Fonts (Kanit), และ FontAwesome (Icons) แบบ Responsive หน้าจอมือถือ
- Layout แบ่งเป็น 2 ส่วน (Grid):
- ด้านซ้าย/ด้านบน: "ฟอร์มจองห้องประชุม" (ชื่อ, เลือกห้อง [Room A, Room B, Boardroom], วันที่, เวลาเริ่ม, เวลาสิ้นสุด, วัตถุประสงค์)
- ด้านขวา/ด้านล่าง: "ปฏิทินแสดงการจอง" ใช้ไลบรารี FullCalendar (ผ่าน CDN)
- UX/UI Interactivity:
- ไม่ใช้ alert() ธรรมดา ให้สร้าง Custom Toast Notification (มุมขวาล่าง) สีเขียวสำหรับสำเร็จ สีแดงสำหรับ error
- ปุ่ม Submit ต้องมี Loading Spinner และ disable ระหว่างรอ Google Apps Script ประมวลผล
- ฟอร์มตรวจสอบขั้นพื้นฐาน: เวลาสิ้นสุดต้องมากกว่าเวลาเริ่ม และวันที่ต้องไม่ใช่อดีต
- เมื่อบันทึกสำเร็จ ให้ดึงข้อมูลมาอัปเดตปฏิทินใหม่ทันทีโดยที่หน้าเว็บไม่ต้อง Refresh (ผ่าน google.script.run)
- การทำงานของ FullCalendar:
- นำข้อมูลจากฝั่ง Backend มา render เป็น Event บนปฏิทิน
- ตั้งค่าแถบสี (Background Color) ของ Event ตามชื่อห้องให้แตกต่างกัน
- เมื่อผู้ใช้ "คลิก" ที่ Event บนปฏิทิน ให้เปิดหน้าต่าง Modal (Tailwind Modal) ขึ้นมาตรงกลางจอ เพื่อแสดงรายละเอียด (ชื่อผู้จอง, ห้อง, เวลา, วัตถุประสงค์) พร้อมปุ่มปิด Modal
กรุณาเขียนโค้ดออกมาให้ครบถ้วน พร้อมใช้งาน และแยกไฟล์ Code.gs กับ index.html ออกจากกันอย่างชัดเจน โค้ดควรมีการคอมเมนต์อธิบายภาษาไทยในจุดสำคัญด้วย
ทำหน้าที่เป็น Full Stack Web Developer และผู้เชี่ยวชาญด้าน Google Apps Script โปรดสร้าง "ระบบบริหารจัดการครุภัณฑ์ (Equipment Management System)" โดยใช้ Google Sheets เป็นฐานข้อมูล
ข้อกำหนดของระบบ:
1. เทคโนโลยีที่ใช้:
- Frontend: HTML, CSS, JavaScript (เขียนรวมในไฟล์เดียว) โดยใช้ Bootstrap 5 (CDN) และ Bootstrap Icons
- Backend: Google Apps Script (Code.gs)
- QR Code: ใช้ไลบรารี qrcodejs (CDN)
2. โครงสร้างไฟล์ที่ต้องการ:
- ไฟล์ 1: `index.html` (สำหรับ Frontend ทั้งหมด)
- ไฟล์ 2: `Code.gs` (สำหรับ Google Apps Script)
3. ฟีเจอร์ของแอปพลิเคชัน (Frontend - Single Page Application):
ออกแบบให้มี Navbar ด้านบน และมี 3 เมนูหลักที่สามารถสลับหน้าจอ (ซ่อน/แสดง) ได้ด้วย JavaScript:
3.1) หน้า "เพิ่มครุภัณฑ์":
- มีฟอร์มรับข้อมูล: รหัสครุภัณฑ์, ชื่อรายการ, หมวดหมู่ (Dropdown), วันที่รับเข้า, สถานที่ตั้ง, ผู้รับผิดชอบ และ สถานะ (ใช้งานปกติ, ส่งซ่อม, ชำรุด)
- เมื่อกด "บันทึก" ให้แสดง Loading Overlay
- ส่งข้อมูลไปที่ Backend ด้วยคำสั่ง `google.script.run`
- เมื่อบันทึกสำเร็จ ให้ซ่อนฟอร์ม แล้วแสดงหน้าต่าง "ผลลัพธ์" ที่มี QR Code (สร้างจาก URL ปัจจุบันต่อท้ายด้วย ?view=รหัสครุภัณฑ์) พร้อมปุ่มสำหรับ "พิมพ์ QR Code" (Print) และปุ่ม "เพิ่มรายการใหม่"
3.2) หน้า "รายการครุภัณฑ์":
- แสดงตารางข้อมูลครุภัณฑ์ทั้งหมด โดยดึงข้อมูลจาก Backend ด้วย `google.script.run`
- คอลัมน์สถานะ ให้ใช้ Badge สีของ Bootstrap (เช่น สีเขียว=ใช้งานปกติ, สีเหลือง=ส่งซ่อม, สีแดง=ชำรุด)
- ในคอลัมน์สุดท้ายของตาราง ให้มีปุ่มไอคอน QR Code เพื่อกดดูและพิมพ์ QR Code ของครุภัณฑ์ชิ้นนั้นๆ ได้แบบย้อนหลัง
3.3) หน้า "สแกน QR":
- ออกแบบ UI ให้ดูเหมือนพื้นที่สำหรับเปิดกล้อง (มีไอคอนกล้องตรงกลาง)
- ทำปุ่ม "จำลองการสแกน" โดยใช้ JavaScript `prompt()` เพื่อรับค่ารหัสครุภัณฑ์จำลอง และแสดง `alert()` แจ้งเตือน
4. ฟีเจอร์ของ Backend (Code.gs):
- มีฟังก์ชัน `doGet(e)` สำหรับ render หน้าเว็บ (ตั้งค่า SandboxMode.IFRAME)
- มีฟังก์ชัน `addEquipmentData(data)` สำหรับบันทึกข้อมูลลง Google Sheet ที่ชื่อแท็บว่า "Data" (ต่อท้ายด้วยคอลัมน์ Timestamp)
- มีฟังก์ชัน `getEquipmentData()` สำหรับอ่านข้อมูลทั้งหมดจาก Sheet ส่งกลับไปให้ Frontend
5. การออกแบบ (UI/UX):
- เน้นความสวยงาม ทันสมัย สะอาดตา (Clean Design) ขอบมน (border-radius) และมีการใช้ Box-shadow เล็กน้อย
- รองรับการใช้งานบนมือถือ (Responsive)
- มีระบบ Loading (Spinner) ตรงกลางจอระหว่างที่มีการติดต่อกับ Google Apps Script เพื่อป้องกันผู้ใช้กดปุ่มซ้ำ
- จัดการ Error Handling ให้ครบถ้วน (เช่น try-catch ตอน parse JSON กลับมาจาก Apps Script)
ขอโค้ดที่สมบูรณ์ นำไปวางใน Google Apps Script แล้วใช้งานได้ทันที พร้อมอธิบายวิธีการติดตั้ง (Setup) ทีละขั้นตอนเป็นภาษาไทย
ทำหน้าที่เป็น Full Stack Web Developer และผู้เชี่ยวชาญด้าน Google Apps Script โปรดสร้าง "ระบบบริหารจัดการครุภัณฑ์ (Equipment Management System)" โดยใช้ Google Sheets เป็นฐานข้อมูล
ข้อกำหนดของระบบ:
1. เทคโนโลยีที่ใช้:
- Frontend: HTML, CSS, JavaScript (เขียนรวมในไฟล์เดียว) โดยใช้ Bootstrap 5 (CDN) และ Bootstrap Icons
- Backend: Google Apps Script (Code.gs)
- QR Code: ใช้ไลบรารี qrcodejs (CDN)
2. โครงสร้างไฟล์ที่ต้องการ:
- ไฟล์ 1: `index.html` (สำหรับ Frontend ทั้งหมด)
- ไฟล์ 2: `Code.gs` (สำหรับ Google Apps Script)
3. ฟีเจอร์ของแอปพลิเคชัน (Frontend - Single Page Application):
ออกแบบให้มี Navbar ด้านบน และมี 3 เมนูหลักที่สามารถสลับหน้าจอ (ซ่อน/แสดง) ได้ด้วย JavaScript:
3.1) หน้า "เพิ่มครุภัณฑ์":
- มีฟอร์มรับข้อมูล: รหัสครุภัณฑ์, ชื่อรายการ, หมวดหมู่ (Dropdown), วันที่รับเข้า, สถานที่ตั้ง, ผู้รับผิดชอบ และ สถานะ (ใช้งานปกติ, ส่งซ่อม, ชำรุด)
- เมื่อกด "บันทึก" ให้แสดง Loading Overlay
- ส่งข้อมูลไปที่ Backend ด้วยคำสั่ง `google.script.run`
- เมื่อบันทึกสำเร็จ ให้ซ่อนฟอร์ม แล้วแสดงหน้าต่าง "ผลลัพธ์" ที่มี QR Code (สร้างจาก URL ปัจจุบันต่อท้ายด้วย ?view=รหัสครุภัณฑ์) พร้อมปุ่มสำหรับ "พิมพ์ QR Code" (Print) และปุ่ม "เพิ่มรายการใหม่"
3.2) หน้า "รายการครุภัณฑ์":
- แสดงตารางข้อมูลครุภัณฑ์ทั้งหมด โดยดึงข้อมูลจาก Backend ด้วย `google.script.run`
- คอลัมน์สถานะ ให้ใช้ Badge สีของ Bootstrap (เช่น สีเขียว=ใช้งานปกติ, สีเหลือง=ส่งซ่อม, สีแดง=ชำรุด)
- ในคอลัมน์สุดท้ายของตาราง ให้มีปุ่มไอคอน QR Code เพื่อกดดูและพิมพ์ QR Code ของครุภัณฑ์ชิ้นนั้นๆ ได้แบบย้อนหลัง
3.3) หน้า "สแกน QR":
- ออกแบบ UI ให้ดูเหมือนพื้นที่สำหรับเปิดกล้อง (มีไอคอนกล้องตรงกลาง)
- ทำปุ่ม "จำลองการสแกน" โดยใช้ JavaScript `prompt()` เพื่อรับค่ารหัสครุภัณฑ์จำลอง และแสดง `alert()` แจ้งเตือน
4. ฟีเจอร์ของ Backend (Code.gs):
- มีฟังก์ชัน `doGet(e)` สำหรับ render หน้าเว็บ (ตั้งค่า SandboxMode.IFRAME)
- มีฟังก์ชัน `addEquipmentData(data)` สำหรับบันทึกข้อมูลลง Google Sheet ที่ชื่อแท็บว่า "Data" (ต่อท้ายด้วยคอลัมน์ Timestamp)
- มีฟังก์ชัน `getEquipmentData()` สำหรับอ่านข้อมูลทั้งหมดจาก Sheet ส่งกลับไปให้ Frontend
5. การออกแบบ (UI/UX):
- เน้นความสวยงาม ทันสมัย สะอาดตา (Clean Design) ขอบมน (border-radius) และมีการใช้ Box-shadow เล็กน้อย
- รองรับการใช้งานบนมือถือ (Responsive)
- มีระบบ Loading (Spinner) ตรงกลางจอระหว่างที่มีการติดต่อกับ Google Apps Script เพื่อป้องกันผู้ใช้กดปุ่มซ้ำ
- จัดการ Error Handling ให้ครบถ้วน (เช่น try-catch ตอน parse JSON กลับมาจาก Apps Script)
ขอโค้ดที่สมบูรณ์ นำไปวางใน Google Apps Script แล้วใช้งานได้ทันที พร้อมอธิบายวิธีการติดตั้ง (Setup) ทีละขั้นตอนเป็นภาษาไทย
ทำหน้าที่เป็นผู้เชี่ยวชาญด้าน Google Apps Script และ Web Development
ช่วยเขียนโค้ดสร้าง Web App "ระบบประเมินความพึงพอใจและดาวน์โหลดเกียรติบัตร" โดยใช้ Google Apps Script (ไฟล์ Code.gs) และ HTML/JS (ไฟล์ index.html) โดยมี Requirement ดังนี้:
1. ส่วน Frontend (index.html)
ใช้ Framework Bootstrap 5 ในการจัด Layout ให้ Responsive รองรับทั้งมือถือและคอมพิวเตอร์
ใช้ฟอนต์ภาษาไทย "Sarabun" โทนสีเว็บไซต์เป็นสีฟ้า-ขาว เรียบง่าย สบายตา
มีฟอร์มให้กรอกข้อมูลดังนี้:
ชื่อ-นามสกุล (สำหรับพิมพ์ลงเกียรติบัตร) *บังคับกรอก
แบบประเมิน 5 ข้อ เป็น Radio Button 1-5 (1=น้อยที่สุด, 5=มากที่สุด) ได้แก่:
ความสะดวกในการใช้งานเว็บไซต์
ความรวดเร็วในการโหลดหน้าเว็บ
ความเหมาะสมของการจัดวางข้อมูล
ความสวยงามและความน่าสนใจของเว็บไซต์
ความพึงพอใจโดยรวม
ข้อเสนอแนะเพิ่มเติม (Textarea)
การส่งข้อมูล: ให้ดึงคะแนนจากข้อ 5 เป็นคะแนนหลัก (Rating) ส่วนคะแนนข้อ 1-4 ให้นำไปต่อท้ายข้อความในช่องข้อเสนอแนะ (Comment) เพื่อส่งไปเก็บใน Database รวดเดียว
มีปุ่ม "ส่งแบบประเมิน"
เมื่อกดส่ง ต้องมีการซ่อนฟอร์มและแสดงหน้าจอ Loading (กำลังประมวลผล)
เมื่อประมวลผลสำเร็จ ให้เปลี่ยนหน้าจอเป็น Success พร้อมแสดงปุ่ม "ดาวน์โหลดเกียรติบัตร (PDF)" และปุ่ม "ทำรายการใหม่"
2. ส่วน Backend (Code.gs)
ฟังก์ชัน doGet() สำหรับเรียกหน้า index.html
ฟังก์ชันรับข้อมูลจากฟอร์ม นำไปบันทึกลง Google Sheets (ประกอบด้วย Timestamp, ชื่อ, คะแนนรวม, ความคิดเห็น)
ฟังก์ชันสร้างเกียรติบัตร:
ดึงไฟล์ Google Slides ที่เป็น Template (ใช้ ID)
สร้างไฟล์สำเนา (Copy)
ค้นหาคำว่า {{name}} ใน Slide และแทนที่ด้วยชื่อผู้ใช้งานที่กรอกมา
แปลงไฟล์ Slide เป็น PDF
ลบไฟล์ Slide สำเนาทิ้งเพื่อไม่ให้รก Drive
แปลงไฟล์ PDF เป็น Base64 String เพื่อส่งกลับไปให้หน้า Frontend สร้างปุ่มดาวน์โหลด
ขอโค้ดที่สมบูรณ์ สะอาด จัดระเบียบอย่างดี และมีคอมเมนต์อธิบายการทำงานที่สำคัญ รวมถึงขั้นตอนสั้นๆ ในการเตรียม Sheet, Slide และวิธีการ Deploy ด้วย
ทำหน้าที่เป็นผู้เชี่ยวชาญด้าน Google Apps Script และ Web Development
ช่วยเขียนโค้ดสร้าง Web App "ระบบประเมินความพึงพอใจและดาวน์โหลดเกียรติบัตร" โดยใช้ Google Apps Script (ไฟล์ Code.gs) และ HTML/JS (ไฟล์ index.html) โดยมี Requirement ดังนี้:
1. ส่วน Frontend (index.html)
ใช้ Framework Bootstrap 5 ในการจัด Layout ให้ Responsive รองรับทั้งมือถือและคอมพิวเตอร์
ใช้ฟอนต์ภาษาไทย "Sarabun" โทนสีเว็บไซต์เป็นสีฟ้า-ขาว เรียบง่าย สบายตา
มีฟอร์มให้กรอกข้อมูลดังนี้:
ชื่อ-นามสกุล (สำหรับพิมพ์ลงเกียรติบัตร) *บังคับกรอก
แบบประเมิน 5 ข้อ เป็น Radio Button 1-5 (1=น้อยที่สุด, 5=มากที่สุด) ได้แก่:
ความสะดวกในการใช้งานเว็บไซต์
ความรวดเร็วในการโหลดหน้าเว็บ
ความเหมาะสมของการจัดวางข้อมูล
ความสวยงามและความน่าสนใจของเว็บไซต์
ความพึงพอใจโดยรวม
ข้อเสนอแนะเพิ่มเติม (Textarea)
การส่งข้อมูล: ให้ดึงคะแนนจากข้อ 5 เป็นคะแนนหลัก (Rating) ส่วนคะแนนข้อ 1-4 ให้นำไปต่อท้ายข้อความในช่องข้อเสนอแนะ (Comment) เพื่อส่งไปเก็บใน Database รวดเดียว
มีปุ่ม "ส่งแบบประเมิน"
เมื่อกดส่ง ต้องมีการซ่อนฟอร์มและแสดงหน้าจอ Loading (กำลังประมวลผล)
เมื่อประมวลผลสำเร็จ ให้เปลี่ยนหน้าจอเป็น Success พร้อมแสดงปุ่ม "ดาวน์โหลดเกียรติบัตร (PDF)" และปุ่ม "ทำรายการใหม่"
2. ส่วน Backend (Code.gs)
ฟังก์ชัน doGet() สำหรับเรียกหน้า index.html
ฟังก์ชันรับข้อมูลจากฟอร์ม นำไปบันทึกลง Google Sheets (ประกอบด้วย Timestamp, ชื่อ, คะแนนรวม, ความคิดเห็น)
ฟังก์ชันสร้างเกียรติบัตร:
ดึงไฟล์ Google Slides ที่เป็น Template (ใช้ ID)
สร้างไฟล์สำเนา (Copy)
ค้นหาคำว่า {{name}} ใน Slide และแทนที่ด้วยชื่อผู้ใช้งานที่กรอกมา
แปลงไฟล์ Slide เป็น PDF
ลบไฟล์ Slide สำเนาทิ้งเพื่อไม่ให้รก Drive
แปลงไฟล์ PDF เป็น Base64 String เพื่อส่งกลับไปให้หน้า Frontend สร้างปุ่มดาวน์โหลด
ขอโค้ดที่สมบูรณ์ สะอาด จัดระเบียบอย่างดี และมีคอมเมนต์อธิบายการทำงานที่สำคัญ รวมถึงขั้นตอนสั้นๆ ในการเตรียม Sheet, Slide และวิธีการ Deploy ด้วย
บทบาท (Role): คุณคือผู้เชี่ยวชาญด้าน Full Stack Web Development และ Google Apps Script
คำสั่ง (Task):
โปรดเขียนโค้ดสร้าง "ระบบจัดคิวอัตโนมัติ (Queue Management System)" โดยใช้ Google Apps Script ทำหน้าที่เป็น Backend API และใช้ Google Sheets เป็นฐานข้อมูล (Database) ส่วน Frontend ให้เป็น Web App แบบ Single Page Application (SPA) ที่รวมทุกหน้าจอไว้ในไฟล์ HTML เดียว
รายละเอียดความต้องการ (Requirements):
โครงสร้างฐานข้อมูล (Google Sheets):
บันทึกข้อมูลรายวันลงใน Sheet ชื่อ "Data"
คอลัมน์ประกอบด้วย: วันที่, เวลาที่กดรับคิว, หมายเลขคิว, สถานะ (Waiting / Called), เวลาที่เรียกคิว
หมายเลขคิวต้องรันใหม่ทุกวัน โดยเริ่มจาก A001, A002, A003 ไปเรื่อยๆ ตรวจสอบจากวันที่ปัจจุบัน
Backend (Google Apps Script - Code.gs):
doGet() สำหรับเรนเดอร์หน้า HTML Web App
ฟังก์ชันสร้างคิวใหม่ (Generate Queue) และบันทึกลง Sheet
ฟังก์ชันเรียกคิวถัดไป (Call Next Queue) โดยหาคิวที่สถานะเป็น "Waiting" ที่เก่าที่สุด (FIFO) แล้วเปลี่ยนสถานะเป็น "Called"
ฟังก์ชันดึงข้อมูลสำหรับจอแสดงผล (Get Display Data) ส่งคืนข้อมูล: คิวที่กำลังเรียกปัจจุบัน, จำนวนคิวที่รอทั้งหมด, และรายการหมายเลขคิวที่กำลังรอ (จำกัด 5 คิวถัดไป)
Frontend (UI/UX - Index.html):
ใช้ Tailwind CSS ผ่าน CDN สำหรับการออกแบบ UI ให้ดูทันสมัยและสะอาดตา
ใช้ฟอนต์ภาษาไทย (เช่น Kanit)
สร้าง Navigation Bar ด้านบนสำหรับสลับหน้าจอ (ซ่อน/แสดง div) แบ่งเป็น 3 โหมด:
3.1 โหมดจุดรับคิว (Kiosk - สำหรับลูกค้า):
มีปุ่มขนาดใหญ่ "รับคิว"
เมื่อกดแล้ว ให้แสดงหมายเลขคิวที่ได้ตัวใหญ่ๆ บนหน้าจอเป็นเวลา 5 วินาที แล้วซ่อนไป
3.2 โหมดจุดเรียกคิว (Staff - สำหรับพนักงาน):
แสดงหมายเลขคิวที่เรียกล่าสุด
มีปุ่ม "เรียกคิวถัดไป" เมื่อกดแล้วให้ไปดึงคิวที่รออยู่มาแสดง ถ้าไม่มีให้แจ้งเตือนว่า "ไม่มีคิวรอ"
3.3 โหมดจอแสดงผล (Display - สำหรับทีวีส่วนกลาง):
แบ่งหน้าจอเป็น 2 ฝั่ง (ซ้าย: คิวปัจจุบันตัวใหญ่มาก / ขวา: รายการคิวรอ 5 คิวและจำนวนคิวรอทั้งหมด)
มีระบบ Auto-refresh ดึงข้อมูลทุกๆ 3 วินาที
ระบบเสียง (Text-to-Speech): เมื่อมีคิวใหม่ถูกเรียก ให้เบราว์เซอร์อ่านออกเสียงภาษาไทย เช่น "ขอเชิญหมายเลขคิว [A 0 0 1] ที่ช่องบริการค่ะ"
มีตัวหนังสือกระพริบเมื่อเรียกคิวใหม่
ข้อบังคับ: ต้องมีหน้าต่าง Overlay ปุ่ม "เริ่มจอแสดงผล" ให้กดก่อน 1 ครั้ง เพื่อปลดล็อคข้อจำกัด Autoplay ของเบราว์เซอร์ในการเล่นเสียง
เงื่อนไขเพิ่มเติม (Constraints):
โค้ดฝั่ง Frontend ต้องอยู่ในไฟล์ Index.html เพียงไฟล์เดียว (รวม CSS และ JS ไว้ในนั้น)
โค้ดฝั่ง Backend ต้องอยู่ในไฟล์ Code.gs
โค้ดต้องพร้อมนำไป Deploy ใช้งานได้ทันที มีการจัดการ Error พื้นฐาน และมีคอมเมนต์อธิบายโค้ดภาษาไทยที่ชัดเจน
บทบาท (Role): คุณคือผู้เชี่ยวชาญด้าน Full Stack Web Development และ Google Apps Script
คำสั่ง (Task):
โปรดเขียนโค้ดสร้าง "ระบบจัดคิวอัตโนมัติ (Queue Management System)" โดยใช้ Google Apps Script ทำหน้าที่เป็น Backend API และใช้ Google Sheets เป็นฐานข้อมูล (Database) ส่วน Frontend ให้เป็น Web App แบบ Single Page Application (SPA) ที่รวมทุกหน้าจอไว้ในไฟล์ HTML เดียว
รายละเอียดความต้องการ (Requirements):
โครงสร้างฐานข้อมูล (Google Sheets):
บันทึกข้อมูลรายวันลงใน Sheet ชื่อ "Data"
คอลัมน์ประกอบด้วย: วันที่, เวลาที่กดรับคิว, หมายเลขคิว, สถานะ (Waiting / Called), เวลาที่เรียกคิว
หมายเลขคิวต้องรันใหม่ทุกวัน โดยเริ่มจาก A001, A002, A003 ไปเรื่อยๆ ตรวจสอบจากวันที่ปัจจุบัน
Backend (Google Apps Script - Code.gs):
doGet() สำหรับเรนเดอร์หน้า HTML Web App
ฟังก์ชันสร้างคิวใหม่ (Generate Queue) และบันทึกลง Sheet
ฟังก์ชันเรียกคิวถัดไป (Call Next Queue) โดยหาคิวที่สถานะเป็น "Waiting" ที่เก่าที่สุด (FIFO) แล้วเปลี่ยนสถานะเป็น "Called"
ฟังก์ชันดึงข้อมูลสำหรับจอแสดงผล (Get Display Data) ส่งคืนข้อมูล: คิวที่กำลังเรียกปัจจุบัน, จำนวนคิวที่รอทั้งหมด, และรายการหมายเลขคิวที่กำลังรอ (จำกัด 5 คิวถัดไป)
Frontend (UI/UX - Index.html):
ใช้ Tailwind CSS ผ่าน CDN สำหรับการออกแบบ UI ให้ดูทันสมัยและสะอาดตา
ใช้ฟอนต์ภาษาไทย (เช่น Kanit)
สร้าง Navigation Bar ด้านบนสำหรับสลับหน้าจอ (ซ่อน/แสดง div) แบ่งเป็น 3 โหมด:
3.1 โหมดจุดรับคิว (Kiosk - สำหรับลูกค้า):
มีปุ่มขนาดใหญ่ "รับคิว"
เมื่อกดแล้ว ให้แสดงหมายเลขคิวที่ได้ตัวใหญ่ๆ บนหน้าจอเป็นเวลา 5 วินาที แล้วซ่อนไป
3.2 โหมดจุดเรียกคิว (Staff - สำหรับพนักงาน):
แสดงหมายเลขคิวที่เรียกล่าสุด
มีปุ่ม "เรียกคิวถัดไป" เมื่อกดแล้วให้ไปดึงคิวที่รออยู่มาแสดง ถ้าไม่มีให้แจ้งเตือนว่า "ไม่มีคิวรอ"
3.3 โหมดจอแสดงผล (Display - สำหรับทีวีส่วนกลาง):
แบ่งหน้าจอเป็น 2 ฝั่ง (ซ้าย: คิวปัจจุบันตัวใหญ่มาก / ขวา: รายการคิวรอ 5 คิวและจำนวนคิวรอทั้งหมด)
มีระบบ Auto-refresh ดึงข้อมูลทุกๆ 3 วินาที
ระบบเสียง (Text-to-Speech): เมื่อมีคิวใหม่ถูกเรียก ให้เบราว์เซอร์อ่านออกเสียงภาษาไทย เช่น "ขอเชิญหมายเลขคิว [A 0 0 1] ที่ช่องบริการค่ะ"
มีตัวหนังสือกระพริบเมื่อเรียกคิวใหม่
ข้อบังคับ: ต้องมีหน้าต่าง Overlay ปุ่ม "เริ่มจอแสดงผล" ให้กดก่อน 1 ครั้ง เพื่อปลดล็อคข้อจำกัด Autoplay ของเบราว์เซอร์ในการเล่นเสียง
เงื่อนไขเพิ่มเติม (Constraints):
โค้ดฝั่ง Frontend ต้องอยู่ในไฟล์ Index.html เพียงไฟล์เดียว (รวม CSS และ JS ไว้ในนั้น)
โค้ดฝั่ง Backend ต้องอยู่ในไฟล์ Code.gs
โค้ดต้องพร้อมนำไป Deploy ใช้งานได้ทันที มีการจัดการ Error พื้นฐาน และมีคอมเมนต์อธิบายโค้ดภาษาไทยที่ชัดเจน
"ทำหน้าที่เป็น Full-stack Developer ที่เชี่ยวชาญด้าน Google Apps Script, HTML, JavaScript และ Tailwind CSS
กรุณาเขียนโค้ดสำหรับสร้าง 'ระบบขอแลกเวรออนไลน์' (Web App) โดยทำงานร่วมกับ Google Sheets โดยมีรายละเอียดและข้อกำหนดดังนี้:
1. ส่วนหน้าบ้าน (Frontend - index.html):
สร้างหน้าฟอร์มที่สวยงาม ดูสะอาดตา และรองรับมือถือ (Responsive) โดยใช้ Tailwind CSS
มีช่องรับข้อมูลดังนี้:
ชื่อ-นามสกุลผู้ขอ (Text)
เวรเดิม: แยกเป็น 2 ช่องคือ ช่องเลือกวันที่ (Date picker) และช่องเลือกกะ (Dropdown: เช้า, บ่าย, ดึก)
เวรใหม่: แยกเป็น 2 ช่องคือ ช่องเลือกวันที่ (Date picker) และช่องเลือกกะ (Dropdown: เช้า, บ่าย, ดึก)
เหตุผลการขอแลก (Textarea)
อีเมลของหัวหน้า/ผู้อนุมัติ (Email)
มีระบบป้องกันการกดปุ่ม Submit ซ้ำ โดยเปลี่ยนข้อความปุ่มเป็น 'กำลังส่งข้อมูล...' และทำปุ่มจางลงขณะรอการประมวลผล
มีการแปลงรูปแบบวันที่ (Date format) จาก YYYY-MM-DD เป็น DD/MM/YYYY ก่อนส่งข้อมูลไปหลังบ้าน
2. ส่วนหลังบ้าน (Backend - Code.gs):
รับข้อมูลจากหน้าเว็บและบันทึกลง Google Sheet ชื่อแผ่นงาน 'Data'
โครงสร้างคอลัมน์ใน Sheet มี 9 คอลัมน์: Timestamp, ชื่อ-สกุล, วันที่เวรเดิม, กะเวรเดิม, วันที่เวรใหม่, กะเวรใหม่, เหตุผล, อีเมลผู้อนุมัติ, สถานะ (เริ่มต้นให้บันทึกเป็น 'รออนุมัติ')
หลังจากบันทึกข้อมูลเสร็จ ให้ดึงหมายเลขแถว (Row ID) และส่งอีเมลแจ้งเตือนอัตโนมัติไปยังอีเมลของหัวหน้าที่กรอกไว้
3. ส่วนระบบอนุมัติผ่านอีเมล (Email Approval):
ในเนื้อหาอีเมล (HTML Body) ให้สรุปข้อมูลการขอแลกเวรทั้งหมดให้อ่านง่าย
สร้างปุ่ม (หรือลิงก์ที่มีสไตล์คล้ายปุ่ม) 2 ปุ่มคือ '✅ อนุมัติ' และ '❌ ไม่อนุมัติ'
เมื่อหัวหน้าคลิกปุ่มใดปุ่มหนึ่ง ระบบจะเรียกฟังก์ชัน doGet(e) พร้อมพารามิเตอร์ action และ row
ตรวจสอบสถานะปัจจุบันใน Sheet ก่อน หากไม่ใช่ 'รออนุมัติ' ให้แสดงหน้าเว็บแจ้งเตือนว่าทำรายการไปแล้ว เพื่อป้องกันการกดซ้ำ
หากยังไม่ทำรายการ ให้อัปเดตสถานะใน Sheet เป็น 'อนุมัติแล้ว' หรือ 'ไม่อนุมัติ' ตามที่กด และแสดงหน้าเว็บยืนยันผลการดำเนินการ
กรุณาแยกไฟล์เป็น Code.gs และ index.html พร้อมอธิบายขั้นตอนการติดตั้งและการเตรียม Google Sheet ให้ครบถ้วน"
"ทำหน้าที่เป็น Full-stack Developer ที่เชี่ยวชาญด้าน Google Apps Script, HTML, JavaScript และ Tailwind CSS
กรุณาเขียนโค้ดสำหรับสร้าง 'ระบบขอแลกเวรออนไลน์' (Web App) โดยทำงานร่วมกับ Google Sheets โดยมีรายละเอียดและข้อกำหนดดังนี้:
1. ส่วนหน้าบ้าน (Frontend - index.html):
สร้างหน้าฟอร์มที่สวยงาม ดูสะอาดตา และรองรับมือถือ (Responsive) โดยใช้ Tailwind CSS
มีช่องรับข้อมูลดังนี้:
ชื่อ-นามสกุลผู้ขอ (Text)
เวรเดิม: แยกเป็น 2 ช่องคือ ช่องเลือกวันที่ (Date picker) และช่องเลือกกะ (Dropdown: เช้า, บ่าย, ดึก)
เวรใหม่: แยกเป็น 2 ช่องคือ ช่องเลือกวันที่ (Date picker) และช่องเลือกกะ (Dropdown: เช้า, บ่าย, ดึก)
เหตุผลการขอแลก (Textarea)
อีเมลของหัวหน้า/ผู้อนุมัติ (Email)
มีระบบป้องกันการกดปุ่ม Submit ซ้ำ โดยเปลี่ยนข้อความปุ่มเป็น 'กำลังส่งข้อมูล...' และทำปุ่มจางลงขณะรอการประมวลผล
มีการแปลงรูปแบบวันที่ (Date format) จาก YYYY-MM-DD เป็น DD/MM/YYYY ก่อนส่งข้อมูลไปหลังบ้าน
2. ส่วนหลังบ้าน (Backend - Code.gs):
รับข้อมูลจากหน้าเว็บและบันทึกลง Google Sheet ชื่อแผ่นงาน 'Data'
โครงสร้างคอลัมน์ใน Sheet มี 9 คอลัมน์: Timestamp, ชื่อ-สกุล, วันที่เวรเดิม, กะเวรเดิม, วันที่เวรใหม่, กะเวรใหม่, เหตุผล, อีเมลผู้อนุมัติ, สถานะ (เริ่มต้นให้บันทึกเป็น 'รออนุมัติ')
หลังจากบันทึกข้อมูลเสร็จ ให้ดึงหมายเลขแถว (Row ID) และส่งอีเมลแจ้งเตือนอัตโนมัติไปยังอีเมลของหัวหน้าที่กรอกไว้
3. ส่วนระบบอนุมัติผ่านอีเมล (Email Approval):
ในเนื้อหาอีเมล (HTML Body) ให้สรุปข้อมูลการขอแลกเวรทั้งหมดให้อ่านง่าย
สร้างปุ่ม (หรือลิงก์ที่มีสไตล์คล้ายปุ่ม) 2 ปุ่มคือ '✅ อนุมัติ' และ '❌ ไม่อนุมัติ'
เมื่อหัวหน้าคลิกปุ่มใดปุ่มหนึ่ง ระบบจะเรียกฟังก์ชัน doGet(e) พร้อมพารามิเตอร์ action และ row
ตรวจสอบสถานะปัจจุบันใน Sheet ก่อน หากไม่ใช่ 'รออนุมัติ' ให้แสดงหน้าเว็บแจ้งเตือนว่าทำรายการไปแล้ว เพื่อป้องกันการกดซ้ำ
หากยังไม่ทำรายการ ให้อัปเดตสถานะใน Sheet เป็น 'อนุมัติแล้ว' หรือ 'ไม่อนุมัติ' ตามที่กด และแสดงหน้าเว็บยืนยันผลการดำเนินการ
กรุณาแยกไฟล์เป็น Code.gs และ index.html พร้อมอธิบายขั้นตอนการติดตั้งและการเตรียม Google Sheet ให้ครบถ้วน"
"ช่วยสร้างระบบบันทึกข้อมูล Home Health Care (การเยี่ยมบ้าน) โดยแบ่งเป็น 2 ส่วน คือ Frontend (HTML/JS) และ Backend (Google Apps Script) ให้หน่อยครับ
ความต้องการระบบ:
Frontend (index.html):
เป็นหน้าเว็บแอปพลิเคชันแบบหน้าเดียว (Single Page Application)
ออกแบบ UI ให้ดูทันสมัย สะอาดตา ใช้งานง่ายบนมือถือ (Responsive) โดยใช้ Tailwind CSS
ใช้ SweetAlert2 สำหรับแสดงกล่องข้อความแจ้งเตือน (Success, Error, Warning)
ฟอนต์ภาษาไทย ขอให้ใช้ฟอนต์ Prompt จาก Google Fonts
มีฟอร์มสำหรับกรอกข้อมูลดังนี้:
วันที่เยี่ยม (Type: date, ค่าเริ่มต้นคือวันปัจจุบัน)
HN / เลขบัตรประชาชน (Text)
ชื่อ-สกุล ผู้ป่วย (Text)
สัญญาณชีพ (Vital Signs) แบ่งเป็น: ความดันโลหิต (Text), ชีพจร (Number), อุณหภูมิ (Number แบบทศนิยม 1 ตำแหน่ง)
อาการ / การประเมิน (Textarea)
การพยาบาล / คำแนะนำ (Textarea)
ชื่อผู้เยี่ยม / ผู้บันทึก (Text)
มีปุ่ม "บันทึกข้อมูล" พร้อมแสดง Loading Spinner และเปลี่ยนข้อความเป็น 'กำลังส่งข้อมูลไป Google Sheet...' ขณะกำลังส่งข้อมูล
การทำงานเมื่อกดบันทึก (Hybrid System):
ส่งข้อมูล (POST) ไปยัง Google Apps Script (Web App URL) แบบอัตโนมัติ (ให้ใส่ตัวแปร const SCRIPT_URL = 'ใส่_URL_WEB_APP_ของคุณที่นี่'; เผื่อไว้ให้ผู้ใช้ใส่ URL เองภายหลัง)
นำข้อมูลไปบันทึกไว้ใน Local Storage ของเบราว์เซอร์ด้วย เพื่อใช้แสดงผล
หากยังไม่ได้ใส่ SCRIPT_URL ให้แสดงแจ้งเตือนว่ายังไม่ได้เชื่อมต่อ แต่ยังคงบันทึกลง Local Storage ตามปกติ
ส่วนแสดงผล (ตาราง):
ด้านล่างฟอร์ม ให้มีตารางแสดงประวัติการเยี่ยมบ้านที่ดึงข้อมูลมาจาก Local Storage เรียงจากล่าสุดขึ้นก่อน
มีปุ่ม "ลบ" ข้อมูลรายบรรทัด (มีแจ้งเตือนยืนยัน และลบเฉพาะใน Local Storage)
มีปุ่ม "ล้างหน้าจอ" (ล้างข้อมูลทั้งหมดใน Local Storage)
มีปุ่ม "ส่งออกไฟล์ CSV สำรอง" เพื่อดาวน์โหลดข้อมูลใน Local Storage เป็นไฟล์ .csv (รองรับภาษาไทย)
Backend (Code.gs สำหรับ Google Apps Script):
สร้างฟังก์ชัน doPost(e) สำหรับรับข้อมูล JSON จากหน้า HTML
นำข้อมูลที่ได้รับ ไปเขียนต่อท้ายแถวใหม่ (appendRow) ใน Google Sheet ที่ผูกกับสคริปต์
โครงสร้างคอลัมน์ใน Sheet: Timestamp, วันที่เยี่ยม, HN/CID, ชื่อ-สกุล, ความดัน, ชีพจร, อุณหภูมิ, อาการ/ประเมิน, การพยาบาล/คำแนะนำ, ผู้เยี่ยม
เขียนโค้ดให้ครอบคลุมการจัดการ Error (try...catch) และ Return กลับเป็น JSON
รบกวนเขียนโค้ดแยกเป็น 2 ไฟล์ให้ชัดเจน และใส่คอมเมนต์อธิบายการทำงานที่สำคัญๆ เป็นภาษาไทยให้ด้วย"
"ช่วยสร้างระบบบันทึกข้อมูล Home Health Care (การเยี่ยมบ้าน) โดยแบ่งเป็น 2 ส่วน คือ Frontend (HTML/JS) และ Backend (Google Apps Script) ให้หน่อยครับ
ความต้องการระบบ:
Frontend (index.html):
เป็นหน้าเว็บแอปพลิเคชันแบบหน้าเดียว (Single Page Application)
ออกแบบ UI ให้ดูทันสมัย สะอาดตา ใช้งานง่ายบนมือถือ (Responsive) โดยใช้ Tailwind CSS
ใช้ SweetAlert2 สำหรับแสดงกล่องข้อความแจ้งเตือน (Success, Error, Warning)
ฟอนต์ภาษาไทย ขอให้ใช้ฟอนต์ Prompt จาก Google Fonts
มีฟอร์มสำหรับกรอกข้อมูลดังนี้:
วันที่เยี่ยม (Type: date, ค่าเริ่มต้นคือวันปัจจุบัน)
HN / เลขบัตรประชาชน (Text)
ชื่อ-สกุล ผู้ป่วย (Text)
สัญญาณชีพ (Vital Signs) แบ่งเป็น: ความดันโลหิต (Text), ชีพจร (Number), อุณหภูมิ (Number แบบทศนิยม 1 ตำแหน่ง)
อาการ / การประเมิน (Textarea)
การพยาบาล / คำแนะนำ (Textarea)
ชื่อผู้เยี่ยม / ผู้บันทึก (Text)
มีปุ่ม "บันทึกข้อมูล" พร้อมแสดง Loading Spinner และเปลี่ยนข้อความเป็น 'กำลังส่งข้อมูลไป Google Sheet...' ขณะกำลังส่งข้อมูล
การทำงานเมื่อกดบันทึก (Hybrid System):
ส่งข้อมูล (POST) ไปยัง Google Apps Script (Web App URL) แบบอัตโนมัติ (ให้ใส่ตัวแปร const SCRIPT_URL = 'ใส่_URL_WEB_APP_ของคุณที่นี่'; เผื่อไว้ให้ผู้ใช้ใส่ URL เองภายหลัง)
นำข้อมูลไปบันทึกไว้ใน Local Storage ของเบราว์เซอร์ด้วย เพื่อใช้แสดงผล
หากยังไม่ได้ใส่ SCRIPT_URL ให้แสดงแจ้งเตือนว่ายังไม่ได้เชื่อมต่อ แต่ยังคงบันทึกลง Local Storage ตามปกติ
ส่วนแสดงผล (ตาราง):
ด้านล่างฟอร์ม ให้มีตารางแสดงประวัติการเยี่ยมบ้านที่ดึงข้อมูลมาจาก Local Storage เรียงจากล่าสุดขึ้นก่อน
มีปุ่ม "ลบ" ข้อมูลรายบรรทัด (มีแจ้งเตือนยืนยัน และลบเฉพาะใน Local Storage)
มีปุ่ม "ล้างหน้าจอ" (ล้างข้อมูลทั้งหมดใน Local Storage)
มีปุ่ม "ส่งออกไฟล์ CSV สำรอง" เพื่อดาวน์โหลดข้อมูลใน Local Storage เป็นไฟล์ .csv (รองรับภาษาไทย)
Backend (Code.gs สำหรับ Google Apps Script):
สร้างฟังก์ชัน doPost(e) สำหรับรับข้อมูล JSON จากหน้า HTML
นำข้อมูลที่ได้รับ ไปเขียนต่อท้ายแถวใหม่ (appendRow) ใน Google Sheet ที่ผูกกับสคริปต์
โครงสร้างคอลัมน์ใน Sheet: Timestamp, วันที่เยี่ยม, HN/CID, ชื่อ-สกุล, ความดัน, ชีพจร, อุณหภูมิ, อาการ/ประเมิน, การพยาบาล/คำแนะนำ, ผู้เยี่ยม
เขียนโค้ดให้ครอบคลุมการจัดการ Error (try...catch) และ Return กลับเป็น JSON
รบกวนเขียนโค้ดแยกเป็น 2 ไฟล์ให้ชัดเจน และใส่คอมเมนต์อธิบายการทำงานที่สำคัญๆ เป็นภาษาไทยให้ด้วย"