--- name: pdf_add_page kind: function lang: py domain: infra version: "1.0.0" purity: impure signature: "def pdf_add_page(doc, orientation, width, height) -> PDFDoc" description: "Añade una pagina nueva al documento PDF con orientacion y tamaño configurables. Sin dimensiones personalizadas usa A4 con la orientacion indicada." tags: [pdf, page, layout, builder, infra, pendiente-usar] uses_functions: [] uses_types: [pdf_doc_py_infra] returns: [pdf_doc_py_infra] returns_optional: false error_type: "error_go_core" imports: [] params: - name: doc desc: "PDFDoc inicializado con pdf_create" - name: orientation desc: "orientacion de la pagina: 'portrait' (vertical) o 'landscape' (horizontal)" - name: width desc: "ancho personalizado en mm; None usa A4 (210 mm)" - name: height desc: "alto personalizado en mm; None usa A4 (297 mm)" output: "PDFDoc con la nueva pagina añadida; metadata de la pagina en doc.pages" tested: true tests: ["añadir pagina portrait A4", "añadir pagina landscape", "pagina con dimensiones personalizadas"] test_file_path: "python/functions/infra/pdf_add_page_test.py" file_path: "python/functions/infra/pdf_add_page.py" --- ## Ejemplo ```python doc = pdf_create(title="Demo") doc = pdf_add_page(doc) # A4 portrait doc = pdf_add_page(doc, orientation="landscape") # A4 landscape doc = pdf_add_page(doc, width=148, height=210) # A5 portrait ``` ## Notas Llama a `fpdf.add_page()` con el formato adecuado. El header/footer configurado en `pdf_add_header_footer` se aplica automaticamente en cada pagina nueva (via subclase FPDF). Las dimensiones reales post-add se registran en `doc.pages` con las medidas internas de fpdf2 (que incluye los margenes).