Création de nouveaux modules

VérifiéSûr

Pour la création d'un nouveau module dans l'ERP 9Trip, cette compétence guide la génération des fichiers de code en respectant strictement le schéma de base de données (DBSchema.js) et les règles d'accès via DBManager. Utile lors de l'implémentation d'une nouvelle entité nécessitant une persistance et une interface utilisateur conformes aux bonnes pratiques du projet.

Spar Skills Guide Bot
DeveloppementIntermédiaire
8002/06/2026
Claude Code
#erp-development#module-creation#code-generation#database-schema

Recommandé pour

Notre avis

Génère les fichiers de code pour un nouveau module dans le système ERP 9Trip, en respectant strictement les règles de validation de schéma, d'accès aux données via DBManager et de gestion d'état.

Points forts

  • Garantit le respect d'une source unique de vérité avec DB_SCHEMA
  • Impose un accès aux données via DBManager pour éviter les appels directs à Firestore
  • Favorise la cohérence grâce aux noms et valeurs initiales définis dans le schéma
  • Réduit les erreurs avec le tri côté client et la gestion de l'historique

Limites

  • Nécessite une connaissance approfondie du framework ERP 9Trip et de l'API DBManager
  • Inutilisable en dehors du contexte spécifique de ce système ERP
  • Peut générer du code passe-partout nécessitant des ajustements manuels pour la logique métier
Quand l'utiliser

À utiliser lors de la création d'un nouveau module ou de l'ajout de nouvelles opérations CRUD à un module existant dans l'ERP 9Trip.

Quand l'éviter

Ne pas utiliser pour la génération de code général ou pour des projets en dehors de l'architecture ERP 9Trip.

Analyse de sécurité

Sûr
Score qualité75/100

The skill provides coding guidelines for data access and persistence within a specific ERP system. It does not instruct any destructive actions, data exfiltration, or execution of arbitrary commands; it is limited to internal implementation patterns.

Aucun point d'attention détecté

Exemples

Create supplier module
Create a new module for managing suppliers in the 9Trip ERP system. Follow the new module creation rules: use DB_SCHEMA for field definitions, access data only through DBManager, and ensure snake_case variable names.
Add CRUD for products
Generate the necessary files for a new 'products' module in the 9Trip ERP. Include schema validation from DB_SCHEMA, data persistence via DBManager saveRecord and deleteRecord, and proper state management with IndexedDB cache priority.
Initialize module with sample code
I need to create a new 'orders' module in our 9Trip ERP. Please generate the code skeleton including the DB_SCHEMA entries, the CRUD functions using A.DB, and the UI form generation based on schema metadata. Remember to use snake_case and initial values.

name: new description: Khi xây dựng module mới và cần tạo các file code mới. modeSlugs:

  • code
  • architect

New

Instructions

Bạn phải tuân thủ nghiêm ngặt các quy tắc dưới đây khi tương tác với dữ liệu của 9Trip ERP:

1. SINGLE SOURCE OF TRUTH (DBSchema.js)

  • Validation: Trước khi viết hàm lưu dữ liệu, phải đối chiếu với DB_SCHEMA. Ví dụ: Booking ID phải khớp pattern ^BK\d{4,}$.
  • UI Generation: Luôn sử dụng metadata từ schema (displayName, type, placeholder) để render form. Không tự ý hard-code nhãn hoặc kiểu input.
  • Initial Values: Khi tạo object mới, phải lấy giá trị từ trường initial trong schema (ví dụ: initial: 'today' hoặc initial: 1).

2. DATA ACCESS & PERSISTENCE (DBManager.js)

  • Single Point of Write: TUYỆT ĐỐI KHÔNG dùng trực tiếp db.collection().add() hay set(). Mọi thao tác ghi/xóa phải đi qua hàm firestoreCRUD(collection, action, id, data) của module DBManager bằng cách gọi qua global object của DBManager là A.DB (ví dụ gọi A.DB.tên hàm như saveRecord, batchSave, deleteRecord, getCollection...).
  • Client-Side Sorting: Khi lấy dữ liệu, KHÔNG dùng orderBy của Firestore vì sẽ bị mất document thiếu field. Luôn để DBManager xử lý postSort sau khi hydrate dữ liệu.
  • History Tracking: Lưu ý rằng các collection bookings, booking_details, transactions đã được cấu hình tự động ghi History. Khi cập nhật các bảng này, hệ thống sẽ tự động ghi vết vào bookings.history.
  • Indexing: Sử dụng INDEX_CONFIG trong DBManager để truy cập nhanh các dữ liệu nhóm (ví dụ: lấy tất cả booking_details theo booking_id).

3. STATE & CACHE MANAGEMENT

  • Cache Priority: Hiểu rằng DBManager ưu tiên IndexedDB (72h). Nếu cần dữ liệu mới nhất ngay lập tức, phải sử dụng cơ chế syncDelta hoặc loadCollections với tham số forceNew = true.
  • Variable Consistency: Luôn giữ đúng tên biến snake_case như định nghĩa trong Schema (ví dụ: customer_full_name, không được đổi thành customerFullName).

4. CRITICAL LOGIC

  • Khi thực hiện CRUD, luôn bọc trong try-catch và sử dụng log() của hệ thống để theo dõi.
  • Nếu chỉnh sửa liên quan đến tiền tệ, phải dùng hàm format từ utils.js phối hợp với trường total_amount trong Schema.
Skills similaires