@use-pattern/grid-layout

1.0.21 • Public • Published

Material Grid

use-pattern angular npm github

@use-pattern/grid-layout

Grid-Layout contém estilos css para desenvolvimento de layouts responsivos seguindo os padrões do Material Design adapta-se ao tamanho e orientação da tela, garantindo a consistência nos layouts.

Inspirado orinalmente em material-responsive-grid.

Conteúdo

  1. Instalar
  2. Utilizar
  3. Aprender
  4. Contribuir

Instalar

Instale a partir do npm:

npm install @use-pattern/grid-layout --save

Utilizar

Aprender

src/styles.scss

Inclua o arquivo styles.css em seu arquivo de estilo sass

@import "~@use-pattern/grid-layout/styles.css";

Sistema de Grid

Existem três elementos básicos que compõem um sistema de grid: grids, rows, e columns.

  • As linhas (rows) devem ser inseridas dentro de uma grid.
  • As colunas (columens) devem ser inseridas dentro de uma linha (row).

Breakpoints

Este sistema de grid suporta seis tamanhos de tela:

Classe Tela Colunas Breakpoint Margins Gutters*
xs xsmall 12 0 ~ 359 16
xsm xsmall medium 12 360 ~ 399 16
xsb xsmall big 12 400 ~ 599 16
sm small 12 600 ~ 839 16
smm small medium 12 840 ~ 959 24
smb small big 12 960 ~ 1023 24
md medium 12 1024 ~ 1279 24
mdm medium medium 12 1280 ~ 1439 24
lg large 12 1440 ~ 1599 24
lgm large medium 12 1600 ~ 1919 24
xl xlarge 12 1920 + 24

-* As margens e gutters são flexíveis e não precisam ser do mesmo tamanho.

Isso segue a recomendação do Google para breakpoints de interrupção responsivos da interface do usuário :

  • Com exceção dos três primeiros, os tamanhos de tela têm 12 colunas.
  • O espaço entre as colunas (gutter) é 16px ou 24px. Um espaço (gutter) de 24px é aplicada quando as duas dimensões da tela são maiores ou iguais a 600 px.
  • As grids preencherão a viewport até 1600 px. Nesse ponto, a grid pode: continuar a preencher a janela de visualização ou permanecer com 1600 pixels de largura (alinhado à esquerda ou centralizado).

Grids

As grids têm as seguintes classes:

  • .use-grid - O elemento principal que contém linhas. Ele tem uma margem aplicada que absorverá as margens esquerda e direita negativas da linha.
  • .marginless - Elimina o preenchimento externo que impede que o conteúdo de uma linha seja estendido de um lado a outro.
  • .fixed-left - A partir de 1600px, a grid terá largura fixa e será alinhada à esquerda na viewport.
  • .fixed-center - A partir de 1600px, a grid terá largura fixa e será centralizada horizontalmente na viewport.

O comportamento padrão de uma grid será preencher a viewport e preservar o preenchimento externo nas colunas adjacentes à borda.

Linhas (Rows)

As linhas devem estar dentro de uma grid e ter as seguintes classes:

{size} = xs, xsm, xsb, sm, smm, smb, md, mdm, lg, lgm, xl

  • .use-row - O elemento que contém colunas. Ele usa uma margem negativa que nega a calha externa da primeira e da última colunas.
  • .reverse - Inverte a direção desta linha.
  • .start-{size} - Justifica o conteúdo para o início para os tamanhos especificados (com base na direção).
  • .center-{size} - Centraliza o conteúdo nessa linha para os tamanhos especificados.
  • .end-{size} - Justifique o conteúdo até o final para os tamanhos especificados (com base na direção).
  • .top-{size} - Alinhar verticalmente o conteúdo ao topo para os tamanhos especificados.
  • .middle-{size} - Alinhe verticalmente o conteúdo ao meio para os tamanhos especificados.
  • .bottom-{size} - Alinhe verticalmente o conteúdo ao fundo para os tamanhos especificados.
  • .around-{size} - distribuir uniformemente o espaço não utilizado em torno das colunas para os tamanhos especificados.
  • .between-{size} - distribui uniformemente o espaço não utilizado entre colunas para os tamanhos especificados.

Colunas (Columns)

As colunas devem estar dentro de uma linha (Row) e ter as seguintes classes:

{size} = xs, xsm, xsb, sm, smm, smb, md, mdm, lg, lgm, xl

  • .col-quarter-row - Consome um quarto de linha para todos os tamanhos de tela
  • .col-half-row - Consome metade de uma linha para todos os tamanhos de tela
  • .col-three-quarter-row - Consome três quartos de uma linha para todos os tamanhos de tela
  • .col-full-row - Consome a linha completa para todos os tamanhos de tela
  • .col-{size}-{integer, 1-max column count} - Número de colunas a serem consumidas para um determinado tamanho de tela
  • .col-{size}-offset-{integer, 0-max column count-1} - Número de colunas para compensar essa coluna para um tamanho de tela específico
  • .first-{size} - Apresenta esta coluna primeiro para um tamanho de tela específico (com base na direção da linha)
  • .last-{size} - Apresentar esta coluna por um tamanho de tela específico (com base na direção da linha)
  • .hidden-{size}-only - Esta coluna ficará oculta para um tamanho de tela específico
  • .hidden-{size}-down - Esta coluna ficará oculta para telas tão largas quanto ou mais estreitas que um tamanho de tela específico
  • .hidden-{size}-up - Esta coluna ficará oculta para telas tão largas quanto ou maiores que um tamanho de tela específico

src/app/app.template.html

<div class="use-grid">
   <div class="use-row">
      <div class="col-xs-4 col-lg-6">
         <p>Esta coluna consome toda a linha para telas extra-pequenas,
            pequenas e médias. Para telas grandes e extragrandes, preenche metade da linha.</p>
      </div>
      <div class="hidden-md-down col-half-row">
         <p>Esta coluna não é visível para telas estra-pequenas, pequenas
            e telas médias, mas é visível para telas grandes 
            e telas extra-grandes. Preenche metade da linha.
      </div>
      <div class="hidden-sm-down hidden-up-xl col-md-12">
         <p>Esta coluna é visível apenas para telas médias e telas grandes.</p>
      </div>
      <div class="hidden-sm-only hidden-smm-only hidden-smb-only hidden-lg-only col-full-row">
         <p>Esta coluna está escondida para telas pequenas e telas grandes
            e preenche toda a linha.</p>
      </div>
   </div>
</div>

Contribuir

Contibuições são sempre muito bem vindas! As contribuições não precisam serem somente através de desenvolvimentos de códigos, qualquer ajuda com ideias, sugestões, melhorias na documentação ou doações para os desenvolvedores são sempre muito apreciadas!

Participe da comunidade Projeto que Vale e colabore da forma que achar melhor.

Licença

MIT License

Copyright (c) 2018 PROJETO QUE VALE

É concedida permissão, gratuitamente, a qualquer pessoa que obtenha uma cópia deste software e dos arquivos de documentação associados (o "Software"), para negociar o Software sem restrições, incluindo, sem limitação, os direitos de uso, cópia, modificação e fusão , publicar, distribuir, sublicenciar e / ou vender cópias do Software, e permitir que as pessoas a quem o Software é fornecido o façam, sujeitas às seguintes condições:

O aviso de copyright acima e este aviso de permissão devem ser incluídos em todas as cópias ou partes substanciais do Software.

O SOFTWARE É FORNECIDO "NO ESTADO EM QUE SE ENCONTRA", SEM NENHUM TIPO DE GARANTIA, EXPRESSA OU IMPLÍCITA, INCLUINDO, MAS NÃO SE LIMITANDO ÀS GARANTIAS DE COMERCIALIZAÇÃO, ADEQUAÇÃO A UM FIM ESPECÍFICO E NÃO VIOLAÇÃO. EM NENHUMA CIRCUNSTÂNCIA, OS AUTORES OU PROPRIETÁRIOS DE DIREITOS DE AUTOR PODERÃO SER RESPONSABILIZADOS POR QUAISQUER REIVINDICAÇÕES, DANOS OU OUTRAS RESPONSABILIDADES, QUER EM ACÇÃO DE CONTRATO, DELITO OU DE OUTRA FORMA, DECORRENTES DE, OU EM CONEXÃO COM O SOFTWARE OU O USO OU OUTRAS NEGOCIAÇÕES NO PROGRAMAS.

Dependents (1)

Package Sidebar

Install

npm i @use-pattern/grid-layout

Weekly Downloads

23

Version

1.0.21

License

MIT

Unpacked Size

53.6 kB

Total Files

4

Last publish

Collaborators

  • use-pattern