0.7.0 • Published 6 years ago

filesquash-widget v0.7.0

Weekly downloads
2
License
MIT
Repository
github
Last release
6 years ago

Componentes do Filesquash

Este é um conjunto de web componentes criados para interagir com a API do Filesquash.

Instalação

Via tag

  • Adicione o seguinte código antes de fechar a tag <body> de seu site:
<script type="application/javascript">
  var filesquashConfig = {
    projectId: '[seu projectId]',
    token: '[seu token]'
  }
</script>
<script src='https://unpkg.com/filesquash-widget@0.7.0/dist/filesquash.js'></script>
  • Pronto. Agora você já pode usar os componentes em qualquer lugar no seu template, jsx, html, etc.

NPM

  • Rode npm install filesquash-widget --save
  • Adicione um código similar ao a seguir antes de fechar a tag <body> de seu site:
<script type="application/javascript">
  var filesquashConfig = {
    projectId: '[seu projectId]',
    token: '[seu token]'
  }
</script>
<script src='node_modules/filesquash-widget/dist/filesquash.js'></script>
  • Pronto. Agora você já pode usar os componentes em qualquer lugar no seu template, jsx, html, etc.

Widget de imagens

O widget de imagens do Filesquash permite que você tenha imagens automaticamente responsivas em seu site com o mínimo de esforço possível. Além disso, também é possível aplicar uma grande quantidade de efeitos efeitos, como blur, grayscale, watermark, etc..

Exemplo:

  <img
    data-fs-src="https://mysite.com/images/image.jpg"
    src=""
  />

Opções

AtributoValor padrãoValores possíveisDescrição
data-fs-srcEste atributo define o endereço URL da imagem ou identificador único de imagem no Filesquash. Esse atributo é obrigatório.
data-fs-size"w_auto""default", "h_auto", "w_auto" e maisEste atributo especifica o tamanho desejado da imagem.
data-fs-filtersMais informaçõesEste atributo define os filtros que serão aplicados a imagem.
data-fs-progressivetruetrue ou falseEste atributo define se a imagem será carregada de forma progressiva usando placeholder de baixa resolução (LQIP).
data-fs-auto-webpfalsetrue ou falseEste atributo define se a imagem será carregada no formato webp quando o navegador apresentar suporte. A conversão para webp pode resultar em perda de qualidad das imagens.

Widget de imagens em background

O widget de imagens do Filesquash também permite que você tenha imagens em background automaticamente responsivas.

Exemplo:

  <div
    data-fs-bg="https://mysite.com/images/image.jpg"
    style="width:100%; height: 500px;"
  ></div>

Opções

AtributoValor padrãoValores possíveisDescrição
data-fs-bgEste atributo define o endereço URL da imagem ou identificador único de imagem no Filesquash. Esse atributo é obrigatório.
data-fs-size"w_auto""default", "h_auto", "w_auto" e maisEste atributo especifica o tamanho desejado da imagem.
data-fs-filtersMais informaçõesEste atributo define os filtros que serão aplicados a imagem.
data-fs-progressivetruetrue ou falseEste atributo define se a imagem será carregada de forma progressiva usando placeholder de baixa resolução (LQIP).
data-fs-auto-webpfalsetrue ou falseEste atributo define se a imagem será carregada no formato webp quando o navegador apresentar suporte. A conversão para webp pode resultar em perda de qualidad das imagens.

Widget de Upload

Javascript (vanilla):

  <filesquash-widget id="widget"></filesquash-widget>

Para receber a URL de seu arquivo após o upload você deverá criar um listener para o evento uploadCompleted:

  const widget = document.querySelector('widget');
  widget.addEventListener(
    'uploadCompleted',
    data => console.log(data)
  )

Alternativamente você também pode escutar pelo evento filesquash:uploadStarted no document

document.addEventListener('filesquash:uploadCompleted', () => {
	console.log('filesquash:uploadStarted')
});

Caso queira acionar programaticamente o widget de upload do Filesquash, utilize o <filesquash-modal> e chame o método toggleModal() para exibir ou esconder o widget.

<button onclick="showModal()">Exibir modal</button>
<filesquash-modal token="YOUR_TOKEN" id="modal"></filesquash-modal>

<script>
  const modalElm = document.querySelector('#modal');

  function showModal() {
    modalElm.componentOnReady()
      .then(() => {
        modalElm.toggleModal();
      });
  }
</script>

Opções

AtributoValor padrãoDescrição
multiplefalseEste atributo define se o usuário pode selecionar mais de um arquivo de forma simultânea.
button-text"Selecionar arquivos"Este atributo define o texto do botão de abertura do modal do widget.
label-text"Arraste/solte seu arquivo aqui."Este atributo define o texto da caixa de seleção de arquivos do widget.
upload-button-text"Enviar"Este atributo define o texto do botão que realiza o upload dos arquivos do widget.

Utilizando o widget de upload com o React:

Para usar o widget de upload no React você precisará criar um wrapper como o apresentado a seguir.

import React, { Component } from 'react'
import kebabCase from 'lodash/kebabCase'

export class UploadWidget extends Component {
  constructor(props) {
    super(props)

    this.onUploadComplete = this.onUploadComplete.bind(this)
  }

  componentDidMount () {
    this.component.addEventListener('uploadCompleted', this.onUploadComplete)
  }

  componentWillUnmount () {
    this.component.removeEventListener('uploadCompleted', this.onUploadComplete)
  }

  onUploadComplete (data) {
    this.props.onComplete(data)
  }

  _handleRef = (component) => {
    this.component = component
  };

  render () {
    const newProps = {
      ...Object.keys(this.props).reduce((accumulator, key) => ({
        ...accumulator,
        [kebabCase(key)]: this.props[key]
      }), {})
    }

    return (
      <filesquash-widget
        {...newProps}
        ref={this._handleRef}
      />
    )
  }
}

Usando o wrapper:

  <UploadWidget
    token={this.state.info.api_token}
    onComplete={(data) => console.log(data)}
    buttonText='Upload new files'
  />

ps.: Em breve disponibilizaremos esse wrapper como um pacote no NPM.

0.7.0

6 years ago

0.6.4

6 years ago

0.6.3

6 years ago

0.6.2

6 years ago

0.6.1

6 years ago

0.6.0

6 years ago

0.5.5

6 years ago

0.5.4

6 years ago

0.5.3

6 years ago

0.5.2

6 years ago

0.5.1

6 years ago

0.5.0

6 years ago

0.4.6

6 years ago

0.4.5

6 years ago

0.4.4

6 years ago

0.4.3

6 years ago

0.4.2

6 years ago

0.4.1

6 years ago

0.4.0

6 years ago

0.3.2

6 years ago

0.3.1

6 years ago

0.3.0

6 years ago

0.2.4

6 years ago

0.2.3

6 years ago

0.2.2

6 years ago

0.2.1

6 years ago

0.2.0

6 years ago

0.1.6

6 years ago

0.1.5

6 years ago

0.1.4

6 years ago

0.1.3

6 years ago

0.1.2

6 years ago

0.1.1

6 years ago

0.1.0

6 years ago

0.0.6

6 years ago

0.0.5

6 years ago

0.0.4

6 years ago

0.0.3

6 years ago

0.0.2

6 years ago

0.0.1

6 years ago