Widgets

Filesquash widget is our major tool for web integrations. It’s provided as a typical Javascript library and can be easily embedded in your site. The widget is highly customizable to fit your needs.

Instalação

Via tag <script>

  • 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.4.4/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 de uso

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

Opções

Atributo

Valor padrão

Valores possíveis

Descrição

data-fs-src

Este atributo define o endereço URL da imagem ou identificador único de imagem no Filesquash. Esse atributo é obrigatório.

data-fs-size

"auto"

"default", "auto" e mais

Este atributo especifica o tamanho desejado da imagem.

data-fs-filters

Mais informações

Este atributo define os filtros que serão aplicados a imagem.

data-fs-progressive

true

true ou false

Este atributo define se a imagem será carregada de forma progressiva usando placeholder de baixa resolução (LQIP).

data-fs-auto-webp

false

true ou false

Este 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 de uso

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

Opções

Atributo

Valor padrão

Valores possíveis

Descrição

data-fs-bg

Este 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 mais

Este atributo especifica o tamanho desejado da imagem.

data-fs-filters

Mais informações

Este atributo define os filtros que serão aplicados a imagem.

data-fs-progressive

true

true ou false

Este atributo define se a imagem será carregada de forma progressiva usando placeholder de baixa resolução (LQIP).

data-fs-auto-webp

false

true ou false

Este 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

Atributo

Valor padrão

Descrição

multiple

false

Este 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.