gstreamer0.10-ffmpeg
gstreamer0.10-plugins-good
packages.
Acabamos de sustituir por completo nuestra página de inicio por un diseño dinámico. Pero, eso no es realmente tan interesante. Lo que realmente quiero es poder utilizar mi plantilla de página de inicio existente y todo este buen contenido que he preparado:
{% extends nglayouts.layoutTemplate %} | |
{% block body %} | |
<div class="hero-wrapper"> | |
<h1 class="header">Bark & Bake</h1> | |
<p class="text-center">Doggone Good Treat & Meal Recipes</p> | |
<div class="d-flex justify-content-center"> | |
<img src="{{ asset('images/dog-bone.png') }}" width="auto" height="50" alt="dog bone icon"> | |
</div> | |
</div> | |
... lines 11 - 58 | |
{% endblock %} |
pero luego retocarla añadiendo pequeños fragmentos de contenido dinámico aquí y allá... o incluso reorganizar las cosas. Para ello, en el diseño, debajo de los bloques, en la parte inferior, añade uno especial llamado "Bloque Twig"... y pongámoslo justo debajo del título. Fíjate en que puedes poner tantos bloques como quieras dentro de una misma zona. En realidad, estas zonas no acaban siendo tan importantes.
De todas formas, cuando hagas clic en un bloque, en la parte derecha verás las opciones de ese bloque, que tiene una importante llamada "Nombre del bloque Twig". Introduce body
para que coincida con el{% block body %}
que tenemos en la plantilla:
{% extends nglayouts.layoutTemplate %} | |
{% block body %} | |
... lines 4 - 58 | |
{% endblock %} |
Vale, dale a "publicar y continuar editando"... luego ve a actualizar la página de inicio. ¡Santo hombre murciélago del contenido! Nuestro contenido Twig vive ahora dentro de esta página dinámica. ¡Es increíble! Y todo sigue funcionando: incluso el elegante "componente vivo" del centro de la página.
Vale, esto es genial... pero sigue siendo sólo un montón de contenido dinámico en la parte superior... y luego contenido de plantilla Twig en la parte inferior: realmente no podemos mezclar nada en el centro de nuestra página.
A menos que... añadamos más bloques a nuestra plantilla. Por ejemplo, mantener el block body
... sólo para que la página siga funcionando aunque no mapeemos un diseño... pero luego añadir un{% block hero %}
alrededor de la sección superior, un bloque llamado, qué tal, latest_recipes
,{% endblock %}
, otro llamado subscribe_newsletter
, {% endblock %}
y uno final llamado featured_skills
, {% endblock %}
:
... lines 1 - 2 | |
{% block body %} | |
{% block hero %} | |
<div class="hero-wrapper"> | |
... lines 7 - 11 | |
</div> | |
{% endblock %} | |
{% block latest_recipes %} | |
<div class="container"> | |
... lines 17 - 31 | |
</div> | |
{% endblock %} | |
{% block subscribe_newsletter %} | |
<div class="text-center pt-4 pb-5 my-4" style="background-color: #fdedf0;"> | |
... lines 37 - 40 | |
</div> | |
{% endblock %} | |
{% block featured_skills %} | |
<div class="container py-4 my-5"> | |
... lines 46 - 65 | |
</div> | |
{% endblock %} | |
{% endblock %} |
Si nos detuviéramos ahora, esto no supondría ninguna diferencia para nuestra app: seguimos renderizando el bloque body
aquí abajo... que incluye todos esos. Pero acabamos de darnos un montón de poder nuevo.
Compruébalo: cambia el nombre del bloque body
por hero
. Y luego vamos a añadir unos cuantos bloques Twig más. Renderiza latest_recipes
para éste. Por cierto, las "etiquetas" de los bloques son sólo para nosotros en el área de administración: sólo para mayor claridad. Si introduzco "Últimas recetas", aparecerá encima del bloque. Totalmente opcional.
Añade dos bloques más: uno que muestre subscribe_newsletter
y, por último, uno para featured_skills
. Luego, aquí arriba, voy a eliminar por ahora el bloque title
.
Por cierto, estoy utilizando la palabra "bloque" para referirme a dos cosas distintas a la vez. Los bloques son las "cosas" que añadimos a nuestro diseño, como un título, un mapa de Google o una lista de elementos. Pero los bloques también se refieren a los bloques Twig de nuestras plantillas. Y, por supuesto, uno de los tipos de bloques que podemos añadir... es uno que renderiza... bloques Twig. Bloques Twig. Un poco confuso, pero no puede ser peor.
De todos modos, di "Publicar y continuar editando"... y luego ve a actualizar el frontend. Y... ¡genial! Nuestra página funciona. Lo sé, tiene exactamente el mismo aspecto que hace un minuto, pero ahora está siendo renderizada por layouts... ¡y podemos reorganizar las piezas!
Observa: Moveré el subscribe_newsletter
hacia abajo, le daré a "Publicar y continuar editando", actualizaré y... ¡boom! Esa parte estática de la página se ha movido mágicamente a la parte inferior. Es genial.
O podríamos volver a subirla... y luego añadir algún contenido dinámico, como texto, entre uno de los otros bloques.
A continuación, vamos a ser aún más agresivos y flexibles permitiendo que la navegación superior y el pie de página inferior sean opcionales, pero fáciles de añadir, dentro del Diseño.
"Houston: no signs of life"
Start the conversation!
// composer.json
{
"require": {
"php": ">=8.1.0",
"ext-ctype": "*",
"ext-iconv": "*",
"babdev/pagerfanta-bundle": "^3.7", // v3.7.0
"doctrine/doctrine-bundle": "^2.7", // 2.7.0
"doctrine/doctrine-migrations-bundle": "^3.2", // 3.2.2
"doctrine/orm": "^2.13", // 2.13.3
"easycorp/easyadmin-bundle": "^4.4", // v4.4.1
"netgen/layouts-contentful": "^1.3", // 1.3.2
"netgen/layouts-standard": "^1.3", // 1.3.1
"pagerfanta/doctrine-orm-adapter": "^3.6",
"sensio/framework-extra-bundle": "^6.2", // v6.2.8
"stof/doctrine-extensions-bundle": "^1.7", // v1.7.0
"symfony/console": "5.4.*", // v5.4.14
"symfony/dotenv": "5.4.*", // v5.4.5
"symfony/flex": "^1.17|^2", // v2.2.3
"symfony/framework-bundle": "5.4.*", // v5.4.14
"symfony/monolog-bundle": "^3.0", // v3.8.0
"symfony/proxy-manager-bridge": "5.4.*", // v5.4.6
"symfony/runtime": "5.4.*", // v5.4.11
"symfony/security-bundle": "5.4.*", // v5.4.11
"symfony/twig-bundle": "5.4.*", // v5.4.8
"symfony/ux-live-component": "^2.x-dev", // 2.x-dev
"symfony/ux-twig-component": "^2.x-dev", // 2.x-dev
"symfony/validator": "5.4.*", // v5.4.14
"symfony/webpack-encore-bundle": "^1.15", // v1.16.0
"symfony/yaml": "5.4.*", // v5.4.14
"twig/extra-bundle": "^2.12|^3.0", // v3.4.0
"twig/twig": "^2.12|^3.0" // v3.4.3
},
"require-dev": {
"doctrine/doctrine-fixtures-bundle": "^3.4", // 3.4.2
"symfony/debug-bundle": "5.4.*", // v5.4.11
"symfony/maker-bundle": "^1.47", // v1.47.0
"symfony/stopwatch": "5.4.*", // v5.4.13
"symfony/web-profiler-bundle": "5.4.*", // v5.4.14
"zenstruck/foundry": "^1.22" // v1.22.1
}
}