Web Components Descripción general del banner
El componente Ignite UI for Web Components Banner proporciona una manera de mostrar fácilmente un mensaje destacado a los usuarios de la aplicación de una manera que es menos transitoria que una barra de aperitivos y menos intrusiva que un cuadro de diálogo. También puede indicar las acciones que se deben realizar en función del contexto del mensaje.
Ignite UI for Web Components Banner Example
Usage
Primero, debe instalar la Ignite UI for Web Components ejecutando el siguiente comando:
npm install igniteui-webcomponents
A continuación, tendrás que importar el IgcBannerComponent
CSS necesario y registrar su módulo, de la siguiente manera:
import { defineComponents, IgcBannerComponent } from "igniteui-webcomponents";
import 'igniteui-webcomponents/themes/light/bootstrap.css';
defineComponents(IgcBannerComponent);
Para obtener una introducción completa a Ignite UI for Web Components, lea el tema Introducción.
Show Banner
Para mostrar el componente de banner, utilice su show
método y llámelo con un clic de botón. El banner aparece en relación con el lugar donde se insertó el elemento en la plantilla de página, moviendo todo el resto del contenido. Por lo general, muestra contenido no intrusivo que requiere una interacción mínima del usuario para ser descartado.
<igc-button onclick="banner.show()">Show Banner</igc-button>
<igc-banner id="banner">
You are currently offline.
</igc-banner>
[!NOTE] The
IgcBannerComponent
includes a default action buttonOK
, which closes the banner.
Examples
El IgcBannerComponent
componente permite crear plantillas de su contenido sin dejar de ceñirse lo más posible a las directrices del banner de diseño de materiales.
Changing the banner message
Configurar el mensaje que se muestra en el banner es fácil: simplemente cambie el contenido que está pasando a la igc-banner
etiqueta. El texto se mostrará en el área del banner especificada y el banner utilizará su plantilla predeterminada al mostrarlo. A continuación, cambiaremos el contenido de nuestro banner de muestra para que sea un poco más descriptivo:
<igc-banner id="banner">
You have lost connection to the internet. This app is offline.
</igc-banner>
Adding an icon
An IgcIconComponent
se puede mostrar en el banner utilizando la ranura del prefix
banner. El icono siempre se colocará al principio del mensaje de banner.
[!NOTE] If several
IgcIconComponent
elements are inserted, the banner will try to position all of them at the beginning. It is strongly advised to pass only oneIgcIconComponent
directly to the banner.
Para pasar un IgcIconComponent
a tu banner, usa la prefix
ranura:
<igc-banner id="banner">
<igc-icon slot="prefix" name="signal_wifi_off"></igc-icon>
You have lost connection to the internet. This app is offline.
</igc-banner>
Si desea utilizar un IgcIconComponent
mensaje en su banner, simplemente insértelo en el contenido del banner:
<igc-banner id="banner">
You have lost connection to the internet. This app is offline.
<igc-icon name="signal_wifi_off"></igc-icon>
</igc-banner>
Changing the banner button
Expone IgcBannerComponent
la actions
ranura para crear plantillas de los botones de banner. Esto le permite anular el botón de banner predeterminado (OK
) y agregar acciones personalizadas definidas por el usuario.
<igc-banner id="banner">
<igc-icon slot="prefix" name="signal_wifi_off"></igc-icon>
You have lost connection to the internet. This app is offline.
<div slot="actions">
<igc-button onclick="banner.toggle()">
<igc-ripple></igc-ripple>
Toggle Banner
</igc-button>
</div>
</igc-banner>
Binding to events
El componente de banner emite los igcClosing
eventos y igcClosed
cuando se cierra. El igcClosing
evento es cancelable: utiliza la CustomEvent
interfaz y el objeto emitido tiene su cancelable
propiedad establecida en true. Si cancelamos el evento, la acción final y el igcClosing
evento correspondientes no se activarán: el banner no se cerrará y el igcClosed
evento no se emitirá.
To cancel the closing event, call the preventDefault
method.
<igc-banner id="banner">
...
</igc-banner>
const banner = document.getElementById('banner') as IgcBannerComponent;
banner.addEventListener('igcClosing', (event) => {
event.preventDefault();
});
[!NOTE] If the changes above are applied, the banner will never close, as the closing event is always cancelled.
Advanced Example
Vamos a crear un banner con dos botones personalizados: uno para descartar la notificación y otro para activar la conexión. Podemos pasar controladores de acciones personalizados usando la actions
ranura:
<igc-banner id="banner">
<igc-icon slot="prefix" name="signal_wifi_off"></igc-icon>
You have lost connection to the internet. This app is offline.
<div slot="actions">
<igc-button onclick="banner.hide()">
<igc-ripple></igc-ripple>
Continue Offline
</igc-button>
<igc-button id="button">
<igc-ripple></igc-ripple>
Turn On Wifi
</igc-button>
</div>
</igc-banner>
De acuerdo con las directrices de diseño de materiales de Google, un banner debe tener un máximo de 2 botones presentes. No
IgcBannerComponent
limita explícitamente el número de elementos debajo de laactions
ranura, pero se recomienda encarecidamente usar hasta 2 si desea cumplir con las pautas de diseño de materiales.
La opción dismiss (Continuar sin conexión) no necesita más lógica, por lo que puede llamar simplemente hide
al método. La acción de confirmación (Activar Wifi), sin embargo, requiere alguna lógica adicional, por lo que tenemos que definirla en el componente. Luego, agregaremos un detector de eventos para el click
evento. El último paso es llamar refreshBanner()
al método en cada cambio, que alternará el banner en función de la wifiState
.
La barra de navegación tendrá un icono de Wifi y también agregaremos un oyente de eventos para su click
evento. A medida que se llama al refreshBanner()
método en cada cambio, el icono no solo alternará el banner, sino que cambiará según el estado de la conexión:
<igc-navbar>
<h1>Gallery</h1>
<igc-icon id="icon" slot="end" name="signal_wifi_off"></igc-icon>
</igc-navbar>
<igc-banner id="banner">
...
<div slot="actions">
...
<igc-button id="button">
<igc-ripple></igc-ripple>
Turn On Wifi
</igc-button>
</div>
</igc-banner>
private banner: IgcBannerComponent;
private icon: IgcIconComponent;
private button: IgcButtonComponent;
private wifiState: boolean = false;
constructor() {
this.banner = document.getElementById('banner') as IgcBannerComponent;
this.icon = document.getElementById('icon') as IgcIconComponent;
this.button = document.getElementById('button') as IgcButtonComponent;
this.icon.addEventListener('click', () => this.refreshBanner());
this.button.addEventListener('click', () => this.refreshBanner());
}
public refreshBanner() {
if (!this.wifiState) {
this.icon.name = 'signal_wifi_4_bar';
this.banner.hide();
} else {
this.icon.name = 'signal_wifi_off';
this.banner.show();
}
this.wifiState = !this.wifiState;
}
Finalmente, agregaremos un IgcToastComponent
, mostrando un mensaje sobre el estado de WiFi. Los resultados del banner con plantilla se pueden ver en la demostración a continuación:
Styling
El componente banner expone varias partes CSS (base
, spacer
, message
, illustration
,, content
y actions
) para darle control total sobre su estilo.
igc-banner::part(spacer) {
background: #dedede;
}
igc-banner::part(illustration) {
color: #666666;
}
igc-banner::part(content) {
color: #151515;
}
API References
IgcBannerComponent
IgcCardComponent
IgcIconComponent
IgcNavbarComponent
IgcToastComponent
IgcRippleComponent