Files
lcbp3/specs/01-requirements/01-03-modules/01-03-05-shop-drawing.md
T
admin 4cd0952482
CI / CD Pipeline / build (push) Failing after 1m52s
CI / CD Pipeline / deploy (push) Has been skipped
260324:1349 Refactor RFA #01
2026-03-24 13:49:30 +07:00

135 lines
6.6 KiB
Markdown

# 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 สำหรับ sorting
- `revision_label`: A, B, C, ... — แสดงใน UI
- `is_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"