menuMDUIDocs
color_lens
El nuevo mdui 2 basado en Material Design 3 y Web Components ya está disponible. Consulta la documentación de mdui 2 ahora.

Panel de expansión

Modo de uso

  1. Se puede invocar mediante atributos personalizados (si el componente se genera dinámicamente, es necesario llamar a mdui.mutation() para inicializarlo)
  2. Llamada vía JavaScript

Estilo

Estructura HTML completa

Este ejemplo incluye todos los elementos HTML que se pueden incluir.

Ejemplo
<div class="mdui-panel" mdui-panel>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">
      <div class="mdui-panel-item-title">Trip name</div>
      <div class="mdui-panel-item-summary">Carribean cruise</div>
      <i class="mdui-panel-item-arrow mdui-icon material-icons">keyboard_arrow_down</i>
    </div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <div class="mdui-panel-item-actions">
        <button class="mdui-btn mdui-ripple" mdui-panel-item-close>cancel</button>
        <button class="mdui-btn mdui-ripple">save</button>
      </div>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">
      <div class="mdui-panel-item-title">Location</div>
      <i class="mdui-panel-item-arrow mdui-icon material-icons">keyboard_arrow_down</i>
    </div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <div class="mdui-panel-item-actions">
        <button class="mdui-btn mdui-ripple" mdui-panel-item-close>cancel</button>
        <button class="mdui-btn mdui-ripple">save</button>
      </div>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">
      <div class="mdui-panel-item-title">Start and end dates</div>
      <div class="mdui-panel-item-summary">Start date: Feb 29, 2016</div>
      <div class="mdui-panel-item-summary">End date: Not set</div>
      <i class="mdui-panel-item-arrow mdui-icon material-icons">keyboard_arrow_down</i>
    </div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <div class="mdui-panel-item-actions">
        <button class="mdui-btn mdui-ripple" mdui-panel-item-close>cancel</button>
        <button class="mdui-btn mdui-ripple">save</button>
      </div>
    </div>
  </div>

</div>

Estructura HTML mínima

Algunos elementos del ejemplo anterior no son obligatorios; el siguiente ejemplo solo incluye los elementos HTML obligatorios.

Ejemplo
<div class="mdui-panel" mdui-panel>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">First</div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Second</div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Third</div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
    </div>
  </div>

</div>

Elemento del panel abierto por defecto

Añade la clase .mdui-panel-item-open al elemento <div class="mdui-panel-item"></div> para que este elemento del panel se abra por defecto.

Ejemplo
<div class="mdui-panel" mdui-panel>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">First</div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
    </div>
  </div>

  <div class="mdui-panel-item mdui-panel-item-open">
    <div class="mdui-panel-item-header">Second</div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Third</div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
    </div>
  </div>

</div>

Eliminar el espaciado entre paneles

Añade la clase .mdui-panel-gapless al elemento <div class="mdui-panel"></div> para eliminar el espacio entre el panel abierto y los demás.

Ejemplo
<div class="mdui-panel mdui-panel-gapless" mdui-panel>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">First</div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Second</div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Third</div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
    </div>
  </div>

</div>

Panel emergente

Añade la clase .mdui-panel-popout al elemento <div class="mdui-panel"></div> para dar un efecto emergente al panel abierto.

Ejemplo
<div class="mdui-panel mdui-panel-popout" mdui-panel>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">First</div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Second</div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
    </div>
  </div>

  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Third</div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
    </div>
  </div>

</div>

Anidación de paneles

Los paneles de expansión pueden anidarse entre sí.

Ejemplo
<div class="mdui-panel" mdui-panel>
  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">First</div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>

      <!-- Primer panel de expansión anidado -->
      <div class="mdui-panel" mdui-panel>
        <div class="mdui-panel-item">
          <div class="mdui-panel-item-header">First</div>
          <div class="mdui-panel-item-body">
            <p>First content</p>
            <p>First content</p>
            <p>First content</p>

            <!-- Segundo panel de expansión anidado -->
            <div class="mdui-panel" mdui-panel>
              <div class="mdui-panel-item">
                <div class="mdui-panel-item-header">First</div>
                <div class="mdui-panel-item-body">
                  <p>First content</p>
                  <p>First content</p>
                  <p>First content</p>
                </div>
              </div>
              <div class="mdui-panel-item">
                <div class="mdui-panel-item-header">Second</div>
                <div class="mdui-panel-item-body">
                  <p>Second content</p>
                  <p>Second content</p>
                  <p>Second content</p>
                </div>
              </div>
            </div>

          </div>
        </div>
        <div class="mdui-panel-item">
          <div class="mdui-panel-item-header">Second</div>
          <div class="mdui-panel-item-body">
            <p>Second content</p>
            <p>Second content</p>
            <p>Second content</p>
          </div>
        </div>
      </div>

    </div>
  </div>
  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Second</div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
    </div>
  </div>
  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Third</div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
    </div>
  </div>
</div>

Modo de uso

Llamada vía atributos

Con este método no necesitas escribir código JavaScript. Solo añade el atributo mdui-panel="options" al elemento <div class="mdui-panel"></div> para activar el complemento.

Si el componente se genera dinámicamente, es necesario llamar a mdui.mutation() para inicializarlo.

Ejemplo
<div class="mdui-panel" mdui-panel="{accordion: true}">
  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">First</div>
    <div class="mdui-panel-item-body">
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
      <p>First content</p>
    </div>
  </div>
  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Second</div>
    <div class="mdui-panel-item-body">
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
      <p>Second content</p>
    </div>
  </div>
  <div class="mdui-panel-item">
    <div class="mdui-panel-item-header">Third</div>
    <div class="mdui-panel-item-body">
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
      <p>Third content</p>
    </div>
  </div>
</div>

Se pueden añadir algunos atributos a los elementos dentro del panel de expansión para enlazar eventos. Estos atributos también pueden usarse al invocarlo mediante JavaScript.

AtributoDescripción
mdui-panel-item-closeHacer clic en este elemento disparará el evento close.mdui.panel y cerrará el elemento del panel en el que se encuentra.

Llamada vía JavaScript

Instanciar el componente:

// selector es el selector CSS o el elemento DOM del elemento .mdui-panel
// options son los parámetros del complemento; consulta la lista de parámetros a continuación
var inst = new mdui.Panel(selector, options);
Ejecutar

Parámetro

NombreTipoValor por defectoDescripción
accordionbooleanfalseIndica si se activa el efecto de acordeón.
  • Si es true, solo puede haber un elemento de panel abierto a la vez; al abrir un elemento de panel, se cerrarán los demás.
  • Si es false, varios elementos de panel pueden abrirse simultáneamente.

Método

Nombre del métodoDescripción
open(item)Abre un elemento de panel.
  • item: número de índice del elemento del panel, o elemento DOM, o selector CSS.
close(item)Cierra un elemento de panel.
  • item: número de índice del elemento del panel, o elemento DOM, o selector CSS.
toggle(item)Alterna el estado de un elemento de panel.
  • item: número de índice del elemento del panel, o elemento DOM, o selector CSS.
openAll()Abre todos los elementos del panel. Este método solo es válido cuando accordion es false.
closeAll()Cierra todos los elementos del panel.

Evento

Nombre del eventoDescripciónObjetivoParámetros
open.mdui.panelSe disparará cuando un elemento del panel empiece la animación de apertura.<div class="mdui-panel-item"></div>event._detail.inst: instancia
opened.mdui.panelSe disparará cuando un elemento del panel termine la animación de apertura.
close.mdui.panelSe disparará cuando un elemento del panel empiece la animación de cierre.
closed.mdui.panelSe disparará cuando un elemento del panel termine la animación de cierre.

Lista de clases CSS

Nombre de claseDescripción
.mdui-panelDefine un panel de expansión.
.mdui-panel-gaplessElimina el espacio entre el panel abierto y los demás paneles.
.mdui-panel-popoutDa un efecto emergente al panel abierto.
.mdui-panel-itemDefine un elemento de panel dentro de un panel de expansión.
.mdui-panel-item-openHace que el elemento del panel se abra por defecto.
.mdui-panel-item-headerDefine la cabecera de un elemento del panel.
.mdui-panel-item-titleDefine el título de la cabecera de un elemento del panel.
.mdui-panel-item-summaryDefine el resumen de la cabecera de un elemento del panel.
.mdui-panel-item-arrowDefine el icono de expandir/contraer del elemento del panel.
.mdui-panel-item-bodyDefine el contenido del elemento del panel.
.mdui-panel-item-actionsDefine la barra de acciones del elemento del panel.