🚧 Normaliza versiones a las últimas publicaciones

Revisa y completa la documentación general.
This commit is contained in:
Manuel Cillero 2025-08-03 18:00:02 +02:00
parent fe81ed1cd7
commit 605675af1a
10 changed files with 80 additions and 14 deletions

4
Cargo.lock generated
View file

@ -1600,7 +1600,7 @@ dependencies = [
[[package]]
name = "pagetop-build"
version = "0.0.1"
version = "0.0.16"
dependencies = [
"grass",
"static-files",
@ -1608,7 +1608,7 @@ dependencies = [
[[package]]
name = "pagetop-macros"
version = "0.0.5"
version = "0.0.18"
dependencies = [
"proc-macro2",
"proc-macro2-diagnostics",

View file

@ -3,8 +3,8 @@ name = "pagetop"
version = "0.0.61"
edition = "2021"
description = """\
Un entorno de desarrollo para crear soluciones web modulares, extensibles y configurables.\
description = """
Un entorno de desarrollo para crear soluciones web modulares, extensibles y configurables.
"""
categories = ["web-programming", "gui", "development-tools", "asynchronous"]
keywords = ["pagetop", "web", "framework", "frontend", "ssr"]

View file

@ -41,8 +41,8 @@ async fn main() -> std::io::Result<()> {
}
```
Sólo con esto, este código sirve por defecto una página web de bienvenida accesible desde un
navegador en la dirección `http://localhost:8080` con la configuración predeterminada.
Este código arranca el servidor de `PageTop` que, con la configuración por defecto, muestra una
página de bienvenida accesible desde un navegador local en `http://localhost:8080`.
Para personalizar el servicio, se puede crear una extensión de `PageTop` de la siguiente manera:

View file

@ -1,11 +1,11 @@
[package]
name = "pagetop-build"
version = "0.0.1"
version = "0.0.16"
edition = "2021"
description = """\
Prepara un conjunto de archivos estáticos o archivos SCSS compilados para ser incluidos en el \
binario de un proyecto PageTop.\
description = """
Prepara un conjunto de archivos estáticos o archivos SCSS compilados para ser incluidos en el
binario de un proyecto PageTop.
"""
categories = ["development-tools::build-utils", "web-programming"]
keywords = ["pagetop", "build", "assets", "resources", "static"]

View file

@ -5,6 +5,9 @@
<p>Prepara un conjunto de archivos estáticos o archivos SCSS compilados para ser incluidos en el binario de un proyecto <strong>PageTop</strong>.</p>
[![Licencia](https://img.shields.io/badge/license-MIT%2FApache-blue.svg?label=Licencia&style=for-the-badge)](#-license)
[![Doc API](https://img.shields.io/docsrs/pagetop-build?label=Doc%20API&style=for-the-badge&logo=Docs.rs)](https://docs.rs/pagetop-build)
[![Crates.io](https://img.shields.io/crates/v/pagetop-build.svg?style=for-the-badge&logo=ipfs)](https://crates.io/crates/pagetop-build)
[![Descargas](https://img.shields.io/crates/d/pagetop-build.svg?label=Descargas&style=for-the-badge&logo=transmission)](https://crates.io/crates/pagetop-build)
</div>

View file

@ -5,6 +5,9 @@
//! <p>Prepara un conjunto de archivos estáticos o archivos SCSS compilados para ser incluidos en el binario de un proyecto <strong>PageTop</strong>.</p>
//!
//! [![Licencia](https://img.shields.io/badge/license-MIT%2FApache-blue.svg?label=Licencia&style=for-the-badge)](#-license)
//! [![Doc API](https://img.shields.io/docsrs/pagetop-build?label=Doc%20API&style=for-the-badge&logo=Docs.rs)](https://docs.rs/pagetop-build)
//! [![Crates.io](https://img.shields.io/crates/v/pagetop-build.svg?style=for-the-badge&logo=ipfs)](https://crates.io/crates/pagetop-build)
//! [![Descargas](https://img.shields.io/crates/d/pagetop-build.svg?label=Descargas&style=for-the-badge&logo=transmission)](https://crates.io/crates/pagetop-build)
//!
//! </div>
//!

View file

@ -1,10 +1,10 @@
[package]
name = "pagetop-macros"
version = "0.0.5"
version = "0.0.18"
edition = "2021"
description = """\
Una colección de macros que mejoran la experiencia de desarrollo con PageTop.\
description = """
Una colección de macros que mejoran la experiencia de desarrollo con PageTop.
"""
categories = ["development-tools::procedural-macro-helpers", "web-programming"]
keywords = ["pagetop", "macros", "proc-macros", "codegen"]

View file

@ -5,6 +5,9 @@
<p>Una colección de macros que mejoran la experiencia de desarrollo con <strong>PageTop</strong>.</p>
[![Licencia](https://img.shields.io/badge/license-MIT%2FApache-blue.svg?label=Licencia&style=for-the-badge)](#-license)
[![Doc API](https://img.shields.io/docsrs/pagetop-macros?label=Doc%20API&style=for-the-badge&logo=Docs.rs)](https://docs.rs/pagetop-macros)
[![Crates.io](https://img.shields.io/crates/v/pagetop-macros.svg?style=for-the-badge&logo=ipfs)](https://crates.io/crates/pagetop-macros)
[![Descargas](https://img.shields.io/crates/d/pagetop-macros.svg?label=Descargas&style=for-the-badge&logo=transmission)](https://crates.io/crates/pagetop-macros)
</div>

View file

@ -5,6 +5,9 @@
//! <p>Una colección de macros que mejoran la experiencia de desarrollo con <strong>PageTop</strong>.</p>
//!
//! [![Licencia](https://img.shields.io/badge/license-MIT%2FApache-blue.svg?label=Licencia&style=for-the-badge)](#-license)
//! [![Doc API](https://img.shields.io/docsrs/pagetop-macros?label=Doc%20API&style=for-the-badge&logo=Docs.rs)](https://docs.rs/pagetop-macros)
//! [![Crates.io](https://img.shields.io/crates/v/pagetop-macros.svg?style=for-the-badge&logo=ipfs)](https://crates.io/crates/pagetop-macros)
//! [![Descargas](https://img.shields.io/crates/d/pagetop-macros.svg?label=Descargas&style=for-the-badge&logo=transmission)](https://crates.io/crates/pagetop-macros)
//!
//! </div>
//!

View file

@ -7,13 +7,26 @@
//! <p>Un entorno de desarrollo para crear soluciones web modulares, extensibles y configurables.</p>
//!
//! [![Licencia](https://img.shields.io/badge/license-MIT%2FApache-blue.svg?label=Licencia&style=for-the-badge)](#-license)
//! [![Doc API](https://img.shields.io/docsrs/pagetop?label=Doc%20API&style=for-the-badge&logo=Docs.rs)](https://docs.rs/pagetop)
//! [![Crates.io](https://img.shields.io/crates/v/pagetop.svg?style=for-the-badge&logo=ipfs)](https://crates.io/crates/pagetop)
//! [![Descargas](https://img.shields.io/crates/d/pagetop.svg?label=Descargas&style=for-the-badge&logo=transmission)](https://crates.io/crates/pagetop)
//!
//! <br>
//! </div>
//!
//! `PageTop` reivindica la esencia de la web clásica usando [Rust](https://www.rust-lang.org/es)
//! para la creación de soluciones web SSR (*renderizadas en el servidor*) basadas en HTML, CSS y
//! JavaScript.
//! JavaScript. Ofrece un conjunto de herramientas que los desarrolladores pueden implementar,
//! extender o adaptar según las necesidades de cada proyecto, incluyendo:
//!
//! * **Acciones** (*actions*): alteran la lógica interna de una funcionalidad interceptando su
//! flujo de ejecución.
//! * **Componentes** (*components*): encapsulan HTML, CSS y JavaScript en unidades funcionales,
//! configurables y reutilizables.
//! * **Extensiones** (*extensions*): añaden, extienden o personalizan funcionalidades usando las
//! APIs de `PageTop` o de terceros.
//! * **Temas** (*themes*): son extensiones que permiten modificar la apariencia de páginas y
//! componentes sin comprometer su funcionalidad.
//!
//! # ⚡️ Guía rápida
//!
@ -27,6 +40,47 @@
//! Application::new().run()?.await
//! }
//! ```
//!
//! Este código arranca el servidor de `PageTop` que, con la
//! [configuración por defecto](crate::global::SETTINGS), muestra una página de bienvenida accesible
//! desde un navegador local en `http://localhost:8080`.
//!
//! Para personalizar el servicio, se puede crear una extensión de `PageTop` de la siguiente manera:
//!
//! ```rust,no_run
//! use pagetop::prelude::*;
//!
//! struct HelloWorld;
//!
//! impl Extension for HelloWorld {
//! fn configure_service(&self, scfg: &mut service::web::ServiceConfig) {
//! scfg.route("/", service::web::get().to(hello_world));
//! }
//! }
//!
//! async fn hello_world(request: HttpRequest) -> ResultPage<Markup, ErrorPage> {
//! Page::new(Some(request))
//! .with_component(Html::with(move |_| html! { h1 { "Hello world!" } }))
//! .render()
//! }
//!
//! #[pagetop::main]
//! async fn main() -> std::io::Result<()> {
//! Application::prepare(&HelloWorld).run()?.await
//! }
//! ```
//!
//! Este programa implementa una extensión llamada `HelloWorld` que sirve una página web en la ruta
//! raíz (`/`) mostrando el texto "Hello world!" dentro de un elemento HTML `<h1>`.
//!
//! # 🧩 Gestión de Dependencias
//!
//! Los proyectos que utilizan `PageTop` gestionan las dependencias con `cargo`, como cualquier otro
//! proyecto en Rust.
//!
//! Sin embargo, es fundamental que cada extensión declare explícitamente sus
//! [dependencias](core::extension::Extension::dependencies), si las tiene, para que `PageTop` pueda
//! estructurar e inicializar la aplicación de forma modular.
#![cfg_attr(docsrs, feature(doc_cfg))]
#![doc(