6.6 KiB
6.6 KiB
3.5 Shop Drawing Management (การจัดการแบบก่อสร้าง)
title: 'Functional Requirements: Shop Drawing Management' version: 1.8.1 status: updated owner: Nattanin Peancharoen last_updated: 2026-03-24 related:
- specs/01-requirements/01-01-objectives.md
- specs/01-requirements/01-03-modules/01-03-00-index.md
- specs/01-requirements/01-03-modules/01-03-03-rfa.md
- specs/01-requirements/01-03-modules/01-03-04-contract-drawing.md
- specs/01-requirements/01-06-edge-cases-and-rules.md (EC-RFA-001, EC-RFA-003)
- specs/03-Data-and-Storage/03-01-data-dictionary.md
- specs/01-requirements/01-02-business-rules/01-02-01-rbac-matrix.md
3.5.1. วัตถุประสงค์
แบบก่อสร้าง (Shop Drawing) คือแบบที่ Contractor จัดทำขึ้นเพื่อขออนุมัติจากผู้ว่าจ้างหรือที่ปรึกษา โดยส่งผ่าน RFA (Request for Approval) — มี Revision Model (Rev.A, Rev.B, ...) และอ้างอิง Contract Drawing ที่เป็นต้นฉบับได้
3.5.2. โครงสร้างข้อมูล (Database Tables)
| Table | บทบาท |
|---|---|
shop_drawings |
ข้อมูล Master: เลขแบบ, หมวดหมู่หลัก, หมวดหมู่ย่อย, project |
shop_drawing_revisions |
ประวัติแต่ละ Revision: title, revision_label, is_current, revision_date |
shop_drawing_revision_contract_refs |
M:N: Revision ↔ Contract Drawing ที่อ้างอิง |
shop_drawing_revision_attachments |
ไฟล์แนบต่อ Revision (M:N กับ attachments) |
shop_drawing_main_categories |
Master: หมวดหมู่หลัก (ผูกกับ Project) |
shop_drawing_sub_categories |
Master: หมวดหมู่ย่อย (ผูกกับ Project) |
ข้อสำคัญ:
drawing_numberต้อง UNIQUE ภายใน Project (ux_shop_dwg_no_project)is_current = TRUEมีได้เพียง 1 แถวต่อ Shop Drawing (uq_sd_current)
3.5.3. Fields ที่ต้องกรอกเมื่อสร้าง Shop Drawing
Master (shop_drawings)
| Field | Required | หมายเหตุ |
|---|---|---|
| Project | ✅ | UUID |
| Drawing Number | ✅ | VARCHAR(100) — unique per project |
| Main Category | ✅ | INT id — FK → shop_drawing_main_categories |
| Sub Category | ✅ | INT id — FK → shop_drawing_sub_categories |
Revision (shop_drawing_revisions)
| Field | Required | หมายเหตุ |
|---|---|---|
| Title | ✅ | VARCHAR(500) — ชื่อแบบใน Revision นี้ |
| Revision Label | ❌ | VARCHAR(10) เช่น A, B, 1.1 |
| Revision Date | ❌ | DATE |
| Description | ❌ | คำอธิบายการแก้ไข |
| Legacy Drawing Number | ❌ | VARCHAR(100) — เลขแบบเดิม (สำหรับข้อมูล Migration) |
| Contract Drawing Refs | ❌ | UUID[] — อ้างอิง Contract Drawing ต้นฉบับ |
| Attachments | ❌ | PDF / DWG / SOURCE / OTHER — ผ่าน ClamAV scan |
3.5.4. ไฟล์แนบ (shop_drawing_revision_attachments)
ไฟล์แนบผูกกับ Revision ไม่ใช่ Master — รองรับหลายไฟล์ต่อ 1 Revision:
| file_type | ความหมาย |
|---|---|
PDF |
ไฟล์ PDF แบบดิจิทัล |
DWG |
ไฟล์ AutoCAD |
SOURCE |
ไฟล์ต้นฉบับอื่นๆ |
OTHER |
ประเภทอื่น |
is_main_document = TRUEระบุไฟล์หลักของ Revision นั้น
3.5.5. โครงสร้างหมวดหมู่ (Category Structure)
หมวดหมู่ผูกกับ Project — จัดการโดย Project Manager:
shop_drawing_main_categories (หมวดหมู่หลัก เช่น ARCH, STR, MEP)
shop_drawing_sub_categories (หมวดหมู่ย่อย เช่น STR-COLUMN, STR-BEAM)
- ต่างจาก Contract Drawing ที่ Main ↔ Sub เป็น M:N — Shop Drawing เป็น direct FK:
shop_drawings.main_category_idและshop_drawings.sub_category_id(1 แบบ = 1 Main + 1 Sub)
3.5.6. Revision Model
- 1 Shop Drawing Master → หลาย Revision (1:N)
revision_number: 0-based integer สำหรับ sortingrevision_label: A, B, C, ... — แสดงใน UIis_current = TRUEมีได้เพียง 1 แถว (NULL สำหรับที่ไม่ใช่ปัจจุบัน — ต่างจาก BOOLEAN เพื่อให้ UNIQUE constraint ทำงาน)
3.5.7. การสร้างและสิทธิ์ (RBAC)
| การกระทำ | Role ที่อนุญาต | Scope |
|---|---|---|
| สร้าง Shop Drawing + Revision | Document Control, Org Admin, Superadmin | Project |
| แก้ไข Shop Drawing | Document Control, Org Admin, Superadmin | Project |
| ลบ Shop Drawing | Org Admin, Superadmin | Project |
| จัดการ Main/Sub Category (Master) | Project Manager | Project |
| ดู Shop Drawing | ทุกคนที่มีสิทธิ์ใน Project | Project |
3.5.8. ความสัมพันธ์กับ Module อื่น
- RFA (
rfa_items) อ้างอิงshop_drawing_revision_id→ 1 Revision มี Active RFA ได้สูงสุด 1 ฉบับ (EC-RFA-001) - Contract Drawing (
shop_drawing_revision_contract_refs) — แต่ละ Revision สามารถอ้างอิง Contract Drawing ต้นฉบับได้หลายฉบับ (M:N) - As-Built Drawing — ไม่มีความสัมพันธ์โดยตรง (คนละ module)
3.5.9. Business Rules และ Edge Cases
| รหัส | กฎ | Severity |
|---|---|---|
| EC-RFA-001 | 1 Shop Drawing Revision มี Active RFA ได้สูงสุด 1 ฉบับ (ยกเว้น REJECTED/CANCELLED แล้ว) | 🔴 Critical |
| EC-RFA-003 | Discipline และ Category ต้องเลือกก่อน Upload — ไม่มี Auto-detection (Phase 3) | 🟡 Medium |
ดูรายละเอียดครบที่ 01-06-edge-cases-and-rules.md หมวด "Module 4: RFA & Drawing Edge Cases"