diff --git a/documents/plans/ISSUE6_PLAN.md b/documents/plans/ISSUE6_PLAN.md new file mode 100644 index 0000000..15863d3 --- /dev/null +++ b/documents/plans/ISSUE6_PLAN.md @@ -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�� 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.