\"feat(#6): Crear plan de desarrollo para solicitudes de laboratorio\"

This commit is contained in:
Luis Ernesto Portillo Zaldivar 2025-07-14 00:42:47 -06:00
parent 0dbf546908
commit 053eb59657

View File

@ -0,0 +1,51 @@
# Plan de Desarrollo: Issue #6 - Solicitudes de Laboratorio
## Análisis
El objetivo de este issue es implementar la funcionalidad para que un recepcionista pueda registrar una **"Solicitud de Laboratorio"**. Esta solicitud debe estar vinculada a un paciente, a un médico remitente (opcional) y debe contener los análisis clínicos que se realizarán.
Basándose en los documentos de diseño (`ToBeDesing.md`) y los requerimientos, la estrategia principal es **reutilizar el modelo de Órdenes de Venta (`sale.order`) de Odoo** para representar las solicitudes de laboratorio. Esta decisión es clave porque aprovecha el flujo de facturación y contabilidad ya existente en Odoo, evitando desarrollar una lógica de cobro paralela y asegurando una integración nativa.
El trabajo realizado en el **Issue #5** ya nos proporciona el "Catálogo de Análisis Clínicos" como productos de tipo servicio, que serán los elementos que se añadirán a estas solicitudes.
Por lo tanto, el plan se centrará en adaptar y extender el modelo `sale.order` para que se comporte y se presente al usuario como una "Solicitud de Laboratorio".
---
## Plan de Actividades
- **1. Extender el Modelo `sale.order`:**
- [ ] Crear el archivo `lims_management/models/sale_order.py`.
- [ ] Heredar del modelo `sale.order` para añadir los siguientes campos:
- `is_lab_request` (Booleano): Un campo técnico para identificar que la orden de venta es una solicitud de laboratorio. Será invisible en la interfaz y se usará para filtrar y aplicar lógica específica.
- `doctor_id` (Many2one a `res.partner`): Para seleccionar al médico que remite la solicitud. Se debe aplicar un dominio para que solo muestre los contactos que estén marcados como doctores (`is_doctor = True`).
- [ ] Añadir el nuevo archivo `sale_order.py` al `__init__.py` de la carpeta `models`.
- **2. Crear Vistas para Solicitudes de Laboratorio:**
- [ ] Crear el archivo de vistas `lims_management/views/sale_order_views.xml`.
- [ ] **Heredar la vista de formulario de `sale.order`** para:
- Añadir el campo `doctor_id` cerca del campo del paciente.
- Cambiar la etiqueta (string) del campo `partner_id` de "Cliente" a "Paciente".
- En las líneas de la orden (`order_line`), aplicar un dominio al campo `product_id` para que **solo permita seleccionar productos que sean análisis clínicos** (`is_analysis = True`).
- [ ] **Heredar la vista de lista (tree/list) de `sale.order`** para:
- Añadir la columna "Médico Remitente" (`doctor_id`).
- **3. Crear Men<65><6E> y Acción de Ventana:**
- [ ] Modificar el archivo `lims_management/views/menus.xml`.
- [ ] Crear una nueva **Acción de Ventana** (`ir.actions.act_window`) para las solicitudes de laboratorio:
- `name`: "Solicitudes de Laboratorio".
- `res_model`: `sale.order`.
- `view_mode`: `list,form`.
- `domain`: `[('is_lab_request', '=', True)]` para mostrar solo las solicitudes de laboratorio.
- `context`: `{'default_is_lab_request': True}` para que las nuevas solicitudes se marquen correctamente por defecto.
- [ ] Crear un nuevo `menuitem` llamado "Solicitudes de Laboratorio" bajo el menú principal de "Laboratorio", que dispare la acción anterior.
- **4. Actualizar Manifiesto y Seguridad:**
- [ ] Añadir el nuevo archivo de vistas `sale_order_views.xml` a la lista `data` en `__manifest__.py`.
- [ ] Asegurar que los grupos de usuarios del laboratorio (ej. Recepcionista) tengan los permisos adecuados para crear y modificar órdenes de venta (`sale.order`).
- **5. Verificación Final:**
- [ ] Reiniciar la instancia de Odoo para aplicar los cambios.
- [ ] Verificar en la interfaz que el nuevo menú "Solicitudes de Laboratorio" aparece y funciona.
- [ ] Comprobar que al crear una nueva solicitud, solo se puedan añadir análisis del catálogo y que se pueda seleccionar un médico remitente.
- [ ] Revisar los logs para asegurar que no haya errores.