Thêm section "Cấu hình nâng cao" trong Designer modal (giữa Description và Steps), 3 sub-group 6 checkbox per workflow version: 1. Mode Trả lại (Approver chọn khi nhấn ← Trả lại): - Trả về 1 Cấp trước (peer review chain trong cùng Bước) - Trả về 1 Bước trước (Cấp cuối Bước trước nhận lại) - Trả về Người chỉ định (pick runtime từ list NV đã duyệt) - Trả về Người soạn thảo (default checked = backward compat S17) 2. Drafter gửi duyệt: - Cho phép Drafter gửi thẳng Cấp cuối (F2 skip mọi Bước/Cấp trung gian) 3. Approver chỉnh sửa phiếu: - Cho phép Approver chỉnh sửa Section 2 Hạng mục/NCC/Báo giá (F3, giữ Cấp) DTO types update: - DefinitionDto +6 boolean field (mirror BE AwDefinitionDto) - 6 useState cho 6 flag, default từ cloneFrom (giữ config version trước) hoặc S17 backward compat (chỉ AllowReturnToDrafter=true) - POST body extend 6 field gửi BE Styling: - Container amber-50/30 + border amber-200 (visual distinction với Steps section) - Mỗi checkbox: card border-slate-200 bg-white, hover bg-amber-50/40 - Helper text [10px] text-slate-500 dưới label giải thích mode - Headers [11px] uppercase text-slate-500 group sub-section fe-user KHÔNG mirror — ApprovalWorkflowsV2Page admin-only. PeWorkspaceCreateView chỉ filter IsUserSelectable, không cần Allow* flag lúc create phiếu. Verify: - npm run build fe-admin pass (8.72s, 0 TS6 err) - Warning chunk size pre-existing Pending Chunk D: FE eOffice (Trả lại modal dropdown + Skip submit + Edit Section 2 enable conditional theo workflow.options) mirror 2 app. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
React + TypeScript + Vite
This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
Currently, two official plugins are available:
- @vitejs/plugin-react uses Oxc
- @vitejs/plugin-react-swc uses SWC
React Compiler
The React Compiler is not enabled on this template because of its impact on dev & build performances. To add it, see this documentation.
Expanding the ESLint configuration
If you are developing a production application, we recommend updating the configuration to enable type-aware lint rules:
export default defineConfig([
globalIgnores(['dist']),
{
files: ['**/*.{ts,tsx}'],
extends: [
// Other configs...
// Remove tseslint.configs.recommended and replace with this
tseslint.configs.recommendedTypeChecked,
// Alternatively, use this for stricter rules
tseslint.configs.strictTypeChecked,
// Optionally, add this for stylistic rules
tseslint.configs.stylisticTypeChecked,
// Other configs...
],
languageOptions: {
parserOptions: {
project: ['./tsconfig.node.json', './tsconfig.app.json'],
tsconfigRootDir: import.meta.dirname,
},
// other options...
},
},
])
You can also install eslint-plugin-react-x and eslint-plugin-react-dom for React-specific lint rules:
// eslint.config.js
import reactX from 'eslint-plugin-react-x'
import reactDom from 'eslint-plugin-react-dom'
export default defineConfig([
globalIgnores(['dist']),
{
files: ['**/*.{ts,tsx}'],
extends: [
// Other configs...
// Enable lint rules for React
reactX.configs['recommended-typescript'],
// Enable lint rules for React DOM
reactDom.configs.recommended,
],
languageOptions: {
parserOptions: {
project: ['./tsconfig.node.json', './tsconfig.app.json'],
tsconfigRootDir: import.meta.dirname,
},
// other options...
},
},
])