AppLayout
El componente AppLayout te proporciona una estructura de página lista con un encabezado y un pie de página fijos, un cajón que se desliza hacia dentro y hacia afuera, y un área de contenido desplazable. Juntos, estas secciones cubren las necesidades de diseño de paneles de control, paneles de administración y la mayoría de las interfaces de múltiples secciones.
Características
El App Layout de webforJ es un componente que permite construir diseños de aplicaciones comunes.
- Fácil de usar y personalizar
- Diseño responsivo
- Múltiples opciones de diseño
- Funciona con el Modo Oscuro de webforJ
Proporciona un encabezado, pie de página, cajón y sección de contenido, todo integrado en un componente responsivo que se puede personalizar fácilmente para construir rápidamente diseños comunes de aplicaciones como un panel de control. El encabezado y el pie de página son fijos, el cajón se desliza dentro y fuera de la vista, y el contenido es desplazable.
Cada parte del diseño es un Div, que puede contener cualquier control válido de webforJ. Para obtener los mejores resultados, la aplicación debe incluir una etiqueta meta de viewport que contenga viewport-fit=cover. La etiqueta meta hace que el viewport se escale para llenar la pantalla del dispositivo.
@AppMeta(name = "viewport", content = "width=device-width, initial-scale=1.0, viewport-fit=cover, user-scalable=no")
Descripción general
El siguiente ejemplo de código resultará en una aplicación con una barra lateral colapsable que contiene un logotipo y pestañas para varias opciones de contenido y un encabezado. La demostración utiliza el componente web dwc-icon-button para crear un botón de conmutación del cajón. El botón tiene el atributo data-drawer-toggle que instruye a DwcAppLayout a escuchar los eventos de clic que provienen de ese componente para alternar el estado del cajón.
Mostrar Código
- AppLayoutView.java
- DrawerLogo.java
- AbstractContentView.java
- applayout.css
Barra de navegación de ancho completo
Por defecto, el AppLayout renderiza el encabezado y el pie de página en modo fuera de pantalla. El modo fuera de pantalla significa que la posición del encabezado y del pie de página se desplazará para ajustarse al lado del cajón abierto. Desactivar este modo hará que el encabezado y el pie de página ocupen el espacio disponible completo y que el cajón se desplace hacia arriba y hacia abajo para ajustarse al encabezado y al pie de página.
AppLayout myApp = new AppLayout();
myApp.setHeaderOffscreen(false);
myApp.setFooterOffscreen(false);
Mostrar Código
- AppLayoutFullNavbarView.java
- AppLayoutFullNavbarContentView.java
- AbstractContentView.java
- applayout.css
Múltiples barras de herramientas
La barra de navegación no tiene límite en el número de barras de herramientas que puedes agregar. Una Toolbar es un contenedor horizontal que alberga un conjunto de botones de acción, íconos u otros controles. Para agregar una barra de herramientas adicional, simplemente usa el método addToHeader() para agregar otro componente Toolbar.
La siguiente demostración muestra cómo usar dos barras de herramientas. La primera alberga el botón de conmutación del cajón y el título de la aplicación. La segunda barra alberga un menú de navegación secundario.
Mostrar Código
- AppLayoutMultipleHeadersView.java
- DrawerLogo.java
- AppLayoutMultipleHeaderContentView.java
- AbstractContentView.java
- applayout.css
Barras de herramientas adhesivas
Una barra de herramientas adhesiva es una barra de herramientas que permanece visible en la parte superior de la página cuando el usuario se desplaza hacia abajo, pero la altura de la barra de navegación se colapsa para liberar más espacio para el contenido de la página. Normalmente, este tipo de barra de herramientas contiene un menú de navegación fijo que es relevante para la página actual.
Es posible crear barras de herramientas adhesivas utilizando la propiedad CSS personalizada --dwc-app-layout-header-collapse-height y la opción AppLayout.setHeaderReveal().
Cuando se llama a AppLayout.setHeaderReveal(true), el encabezado será visible en el primer renderizado y luego se ocultará cuando el usuario comience a desplazarse hacia abajo. Una vez que el usuario comience a desplazarse hacia arriba nuevamente, el encabezado será revelado.
Con la ayuda de la propiedad CSS personalizada --dwc-app-layout-header-collapse-height, es posible controlar cuánto de la barra de navegación del encabezado será ocultado.
Mostrar Código
- AppLayoutStickyToolbarView.java
- DrawerLogo.java
- AppLayoutStickyToolbarContentView.java
- AbstractContentView.java
- applayout.css
Diseño de navegación móvil
La barra de navegación inferior puede usarse para proporcionar una versión diferente de la navegación en la parte inferior de la aplicación. Este tipo de navegación es especialmente popular en aplicaciones móviles.
Observa cómo el cajón está oculto en la siguiente demostración. El widget AppLayout admite tres posiciones del cajón: DrawerPlacement.LEFT, DrawerPlacement.RIGHT y DrawerPlacement.HIDDEN.
Al igual que con AppLayout.setHeaderReveal(), se admite AppLayout.setFooterReveal(). Cuando se llama a AppLayout.setFooterReveal(true), el pie de página será visible en el primer renderizado y luego se ocultará cuando el usuario comience a desplazarse hacia arriba. Una vez que el usuario comience a desplazarse hacia abajo nuevamente, el pie de página será revelado.
Por defecto, cuando el ancho de la pantalla es de 800px o menos, el cajón se cambiará a modo popover. Esto se llama el breakpoint. El modo popover significa que el cajón aparecerá sobre el área de contenido con una superposición. Es posible configurar el breakpoint utilizando el método setDrawerBreakpoint() y el breakpoint debe ser una consulta de medios válida media query.
Mostrar Código
- AppLayoutMobileDrawerView.java
- DrawerLogo.java
- AppLayoutMobileDrawerContentView.java
- AbstractContentView.java
- applayout.css
Utilidades del cajón
Las utilidades del cajón AppLayout están diseñadas para la navegación integrada y menús contextuales dentro del diseño principal de la aplicación, mientras que los componentes de Drawer independientes ofrecen paneles deslizantes flexibles e independientes que se pueden usar en cualquier parte de tu aplicación para contenido adicional, filtros o notificaciones. Esta sección se centra en las características y utilidades del cajón integradas proporcionadas por AppLayout.
Punto de interrupción del cajón
Por defecto, cuando el ancho de la pantalla es de 800px o menos, el cajón se cambiará a modo popover. Esto se llama el breakpoint. El modo popover significa que el cajón aparecerá sobre el área de contenido con una superposición. Es posible configurar el breakpoint utilizando el método setDrawerBreakpoint() y el breakpoint debe ser una consulta de medios válida.
Por ejemplo, en el siguiente ejemplo, el breakpoint del cajón se configura para ser de 500px o menos.
AppLayout demo = new AppLayout();
demo.setDrawerBreakpoint("(max-width:500px)");
Título del cajón
El componente AppLayout proporciona un método addToDrawerTitle() para definir un título personalizado que se mostrará en el encabezado del cajón.
layout.addToDrawerTitle(new Div("Menú"));
Acciones del cajón
El componente AppLayout te permite colocar componentes personalizados como botones o íconos en el área de acciones del encabezado del cajón utilizando el método addToDrawerHeaderActions().
layout.addToDrawerHeaderActions(
new IconButton(TablerIcon.create("bell")),
);
Es posible pasar múltiples componentes como argumentos:
layout.addToDrawerHeaderActions(
new IconButton(TablerIcon.create("bell")),
new Button("Perfil")
);
Las acciones del cajón aparecen en la sección alineada a la derecha del encabezado del cajón.
Mostrar Código
- AppLayoutDrawerUtilityView.java
- DrawerLogo.java
- AppLayoutDrawerUtilityContentView.java
- AbstractContentView.java
- applayout.css
AppDrawerToggle 24.12
El componente AppDrawerToggle es una clase de webforJ del lado del servidor que representa un botón utilizado para alternar la visibilidad de un cajón de navegación en un AppLayout. Se mapea al elemento del lado del cliente <dwc-app-drawer-toggle> y está diseñado por defecto para comportarse como un icono de menú de hamburguesa tradicional, este comportamiento se puede personalizar.
Descripción general
El AppDrawerToggle extiende IconButton y utiliza el icono "menu-2" del conjunto de íconos Tabler por defecto. Aplica automáticamente el atributo data-drawer-toggle para integrarse con el comportamiento del cajón del lado del cliente.
// No se requiere registro de eventos:
AppLayout layout = new AppLayout();
layout.addToHeader(new AppDrawerToggle());
// El conmutador del cajón funcionará directamente—no se necesitan oyentes de eventos manuales.