Files
lcbp3/specs/01-requirements/01-03-modules/01-03-04-contract-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

106 lines
5.7 KiB
Markdown

# 3.4 Contract Drawing Management (การจัดการแบบคู่สัญญา)
---
title: 'Functional Requirements: Contract 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-05-shop-drawing.md
- specs/03-Data-and-Storage/03-01-data-dictionary.md
- specs/01-requirements/01-02-business-rules/01-02-01-rbac-matrix.md
---
## 3.4.1. วัตถุประสงค์
แบบคู่สัญญา (Contract Drawing) คือแบบที่ได้รับจากสัญญาก่อสร้าง ใช้เป็น **เอกสารอ้างอิงหลัก** สำหรับ Shop Drawing และ As-Built Drawing ภายในโครงการ ไม่มี Revision Model — แต่ละแบบเป็นเอกสาร Master คงที่
> **หมายเหตุการพัฒนา:** ข้อมูล Contract Drawing มาจาก **Seed Data** (นำเข้าจากข้อมูลสัญญาที่มีอยู่แล้ว) ไม่ได้สร้างใหม่ผ่าน UI ระบบอัปโหลดไฟล์ PDF อยู่**ระหว่างการพัฒนา** — ปัจจุบัน record มีอยู่ในระบบแต่ไฟล์แนบยังไม่สมบูรณ์
---
## 3.4.2. โครงสร้างข้อมูล (Database Tables)
| Table | บทบาท |
|---|---|
| `contract_drawings` | ข้อมูล Master แบบคู่สัญญา: เลขแบบ, ชื่อ, หมวดหมู่, เล่ม |
| `contract_drawing_attachments` | ไฟล์แนบ (M:N กับ `attachments`) รองรับหลายไฟล์ต่อแบบ |
| `contract_drawing_volumes` | Master: เล่มของแบบ (ผูกกับ Project) |
| `contract_drawing_cats` | Master: หมวดหมู่หลัก (ผูกกับ Project) |
| `contract_drawing_sub_cats` | Master: หมวดหมู่ย่อย (ผูกกับ Project) |
| `contract_drawing_subcat_cat_maps` | M:N ระหว่าง หมวดหมู่หลัก ↔ หมวดหมู่ย่อย (ผูกกับ Project) |
**ข้อสำคัญ:** `condwg_no` ต้อง UNIQUE ภายใน Project เดียวกัน (`ux_condwg_no_project`)
---
## 3.4.3. Fields ที่ต้องกรอกเมื่อสร้าง Contract Drawing
| Field | Required | หมายเหตุ |
|---|---|---|
| Project | ✅ | UUID — ผูกกับ `projects` |
| Drawing Number (`condwg_no`) | ✅ | VARCHAR(255) — unique per project |
| Title | ✅ | VARCHAR(255) |
| Category (`map_cat_id`) | ❌ | FK → `contract_drawing_subcat_cat_maps` |
| Volume (`volume_id`) | ❌ | FK → `contract_drawing_volumes` |
| Volume Page (`volume_page`) | ❌ | INT |
| Attachments | ❌ | PDF / DWG / SOURCE / OTHER — ผ่าน ClamAV scan (**อยู่ระหว่างพัฒนาระบบนำเข้า PDF**) |
---
## 3.4.4. ไฟล์แนบ (contract_drawing_attachments)
รองรับหลายไฟล์ต่อ 1 Contract Drawing:
| file_type | ความหมาย |
|---|---|
| `PDF` | ไฟล์ PDF แบบดิจิทัล |
| `DWG` | ไฟล์ AutoCAD |
| `SOURCE` | ไฟล์ต้นฉบับอื่นๆ |
| `OTHER` | ประเภทอื่น |
- `is_main_document = TRUE` ระบุไฟล์หลัก (แสดงเป็น Default สำหรับ Preview)
> **สถานะ:** ข้อมูล `contract_drawings` ถูก Seed เข้าระบบแล้ว แต่ `contract_drawing_attachments` ยังว่างอยู่ระหว่างรอระบบ PDF Import
---
## 3.4.5. โครงสร้างหมวดหมู่ (Category Structure)
หมวดหมู่ผูกกับ **Project** (ไม่ใช่ Global) — จัดการโดย Project Manager:
```
contract_drawing_volumes (เล่ม — Volume)
contract_drawing_cats (หมวดหมู่หลัก — Main Category)
contract_drawing_sub_cats (หมวดหมู่ย่อย — Sub Category)
contract_drawing_subcat_cat_maps (M:N: Sub Category ↔ Main Category)
```
- `contract_drawings.map_cat_id` FK → `contract_drawing_subcat_cat_maps`
- 1 Sub Category สามารถอยู่ใน Main Category ได้หลายหมวด (M:N)
---
## 3.4.6. การสร้างและสิทธิ์ (RBAC)
| การกระทำ | Role ที่อนุญาต | Scope |
|---|---|---|
| สร้าง / แก้ไข Contract Drawing | Project Manager, Org Admin, Superadmin | Project |
| ลบ Contract Drawing | Org Admin, Superadmin | Project |
| จัดการ Volume / Category (Master) | Project Manager | Project |
| ดู Contract Drawing | ทุกคนที่มีสิทธิ์ใน Project | Project |
---
## 3.4.7. ความสัมพันธ์กับ Module อื่น
- **Shop Drawing** (`shop_drawings`) อ้างอิง `contract_drawing_id` → ใช้ Contract Drawing เป็นแบบต้นฉบับ
- Contract Drawing **ไม่มี Revision Model** — ต่างจาก Shop Drawing ที่มี `shop_drawing_revisions`
- ไม่มีความสัมพันธ์โดยตรงกับ RFA — RFA อ้างอิง `shop_drawing_revisions` ไม่ใช่ Contract Drawing