-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: Guia de contribuição, assets e página inicial
- Loading branch information
1 parent
1fd1f7d
commit 7a2d039
Showing
14 changed files
with
693 additions
and
3 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
document.addEventListener("DOMContentLoaded", function() { | ||
removeCredits(); | ||
}); | ||
|
||
function removeCredits(){ | ||
document.querySelectorAll('.md-footer')[0].getElementsByClassName("md-footer-meta")[0].remove(); | ||
document.querySelectorAll('.md-footer-meta')[0].childNodes[1].remove(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,264 @@ | ||
/** | ||
* termynal.js | ||
* A lightweight, modern and extensible animated terminal window, using | ||
* async/await. | ||
* | ||
* @author Ines Montani <[email protected]> | ||
* @version 0.0.1 | ||
* @license MIT | ||
*/ | ||
|
||
'use strict'; | ||
|
||
/** Generate a terminal widget. */ | ||
class Termynal { | ||
/** | ||
* Construct the widget's settings. | ||
* @param {(string|Node)=} container - Query selector or container element. | ||
* @param {Object=} options - Custom settings. | ||
* @param {string} options.prefix - Prefix to use for data attributes. | ||
* @param {number} options.startDelay - Delay before animation, in ms. | ||
* @param {number} options.typeDelay - Delay between each typed character, in ms. | ||
* @param {number} options.lineDelay - Delay between each line, in ms. | ||
* @param {number} options.progressLength - Number of characters displayed as progress bar. | ||
* @param {string} options.progressChar – Character to use for progress bar, defaults to █. | ||
* @param {number} options.progressPercent - Max percent of progress. | ||
* @param {string} options.cursor – Character to use for cursor, defaults to ▋. | ||
* @param {Object[]} lineData - Dynamically loaded line data objects. | ||
* @param {boolean} options.noInit - Don't initialise the animation. | ||
*/ | ||
constructor(container = '#termynal', options = {}) { | ||
this.container = (typeof container === 'string') ? document.querySelector(container) : container; | ||
this.pfx = `data-${options.prefix || 'ty'}`; | ||
this.originalStartDelay = this.startDelay = options.startDelay | ||
|| parseFloat(this.container.getAttribute(`${this.pfx}-startDelay`)) || 600; | ||
this.originalTypeDelay = this.typeDelay = options.typeDelay | ||
|| parseFloat(this.container.getAttribute(`${this.pfx}-typeDelay`)) || 90; | ||
this.originalLineDelay = this.lineDelay = options.lineDelay | ||
|| parseFloat(this.container.getAttribute(`${this.pfx}-lineDelay`)) || 1500; | ||
this.progressLength = options.progressLength | ||
|| parseFloat(this.container.getAttribute(`${this.pfx}-progressLength`)) || 40; | ||
this.progressChar = options.progressChar | ||
|| this.container.getAttribute(`${this.pfx}-progressChar`) || '█'; | ||
this.progressPercent = options.progressPercent | ||
|| parseFloat(this.container.getAttribute(`${this.pfx}-progressPercent`)) || 100; | ||
this.cursor = options.cursor | ||
|| this.container.getAttribute(`${this.pfx}-cursor`) || '▋'; | ||
this.lineData = this.lineDataToElements(options.lineData || []); | ||
this.loadLines() | ||
if (!options.noInit) this.init() | ||
} | ||
|
||
loadLines() { | ||
// Load all the lines and create the container so that the size is fixed | ||
// Otherwise it would be changing and the user viewport would be constantly | ||
// moving as she/he scrolls | ||
const finish = this.generateFinish() | ||
finish.style.visibility = 'hidden' | ||
this.container.appendChild(finish) | ||
// Appends dynamically loaded lines to existing line elements. | ||
this.lines = [...this.container.querySelectorAll(`[${this.pfx}]`)].concat(this.lineData); | ||
for (let line of this.lines) { | ||
line.style.visibility = 'hidden' | ||
this.container.appendChild(line) | ||
} | ||
const restart = this.generateRestart() | ||
restart.style.visibility = 'hidden' | ||
this.container.appendChild(restart) | ||
this.container.setAttribute('data-termynal', ''); | ||
} | ||
|
||
/** | ||
* Initialise the widget, get lines, clear container and start animation. | ||
*/ | ||
init() { | ||
/** | ||
* Calculates width and height of Termynal container. | ||
* If container is empty and lines are dynamically loaded, defaults to browser `auto` or CSS. | ||
*/ | ||
const containerStyle = getComputedStyle(this.container); | ||
this.container.style.width = containerStyle.width !== '0px' ? | ||
containerStyle.width : undefined; | ||
this.container.style.minHeight = containerStyle.height !== '0px' ? | ||
containerStyle.height : undefined; | ||
|
||
this.container.setAttribute('data-termynal', ''); | ||
this.container.innerHTML = ''; | ||
for (let line of this.lines) { | ||
line.style.visibility = 'visible' | ||
} | ||
this.start(); | ||
} | ||
|
||
/** | ||
* Start the animation and rener the lines depending on their data attributes. | ||
*/ | ||
async start() { | ||
this.addFinish() | ||
await this._wait(this.startDelay); | ||
|
||
for (let line of this.lines) { | ||
const type = line.getAttribute(this.pfx); | ||
const delay = line.getAttribute(`${this.pfx}-delay`) || this.lineDelay; | ||
|
||
if (type == 'input') { | ||
line.setAttribute(`${this.pfx}-cursor`, this.cursor); | ||
await this.type(line); | ||
await this._wait(delay); | ||
} | ||
|
||
else if (type == 'progress') { | ||
await this.progress(line); | ||
await this._wait(delay); | ||
} | ||
|
||
else { | ||
this.container.appendChild(line); | ||
await this._wait(delay); | ||
} | ||
|
||
line.removeAttribute(`${this.pfx}-cursor`); | ||
} | ||
this.addRestart() | ||
this.finishElement.style.visibility = 'hidden' | ||
this.lineDelay = this.originalLineDelay | ||
this.typeDelay = this.originalTypeDelay | ||
this.startDelay = this.originalStartDelay | ||
} | ||
|
||
generateRestart() { | ||
const restart = document.createElement('a') | ||
restart.onclick = (e) => { | ||
e.preventDefault() | ||
this.container.innerHTML = '' | ||
this.init() | ||
} | ||
restart.href = '#' | ||
restart.setAttribute('data-terminal-control', '') | ||
restart.innerHTML = "restart ↻" | ||
return restart | ||
} | ||
|
||
generateFinish() { | ||
const finish = document.createElement('a') | ||
finish.onclick = (e) => { | ||
e.preventDefault() | ||
this.lineDelay = 0 | ||
this.typeDelay = 0 | ||
this.startDelay = 0 | ||
} | ||
finish.href = '#' | ||
finish.setAttribute('data-terminal-control', '') | ||
finish.innerHTML = "fast →" | ||
this.finishElement = finish | ||
return finish | ||
} | ||
|
||
addRestart() { | ||
const restart = this.generateRestart() | ||
this.container.appendChild(restart) | ||
} | ||
|
||
addFinish() { | ||
const finish = this.generateFinish() | ||
this.container.appendChild(finish) | ||
} | ||
|
||
/** | ||
* Animate a typed line. | ||
* @param {Node} line - The line element to render. | ||
*/ | ||
async type(line) { | ||
const chars = [...line.textContent]; | ||
line.textContent = ''; | ||
this.container.appendChild(line); | ||
|
||
for (let char of chars) { | ||
const delay = line.getAttribute(`${this.pfx}-typeDelay`) || this.typeDelay; | ||
await this._wait(delay); | ||
line.textContent += char; | ||
} | ||
} | ||
|
||
/** | ||
* Animate a progress bar. | ||
* @param {Node} line - The line element to render. | ||
*/ | ||
async progress(line) { | ||
const progressLength = line.getAttribute(`${this.pfx}-progressLength`) | ||
|| this.progressLength; | ||
const progressChar = line.getAttribute(`${this.pfx}-progressChar`) | ||
|| this.progressChar; | ||
const chars = progressChar.repeat(progressLength); | ||
const progressPercent = line.getAttribute(`${this.pfx}-progressPercent`) | ||
|| this.progressPercent; | ||
line.textContent = ''; | ||
this.container.appendChild(line); | ||
|
||
for (let i = 1; i < chars.length + 1; i++) { | ||
await this._wait(this.typeDelay); | ||
const percent = Math.round(i / chars.length * 100); | ||
line.textContent = `${chars.slice(0, i)} ${percent}%`; | ||
if (percent > progressPercent) { | ||
break; | ||
} | ||
} | ||
} | ||
|
||
/** | ||
* Helper function for animation delays, called with `await`. | ||
* @param {number} time - Timeout, in ms. | ||
*/ | ||
_wait(time) { | ||
return new Promise(resolve => setTimeout(resolve, time)); | ||
} | ||
|
||
/** | ||
* Converts line data objects into line elements. | ||
* | ||
* @param {Object[]} lineData - Dynamically loaded lines. | ||
* @param {Object} line - Line data object. | ||
* @returns {Element[]} - Array of line elements. | ||
*/ | ||
lineDataToElements(lineData) { | ||
return lineData.map(line => { | ||
let div = document.createElement('div'); | ||
div.innerHTML = `<span ${this._attributes(line)}>${line.value || ''}</span>`; | ||
|
||
return div.firstElementChild; | ||
}); | ||
} | ||
|
||
/** | ||
* Helper function for generating attributes string. | ||
* | ||
* @param {Object} line - Line data object. | ||
* @returns {string} - String of attributes. | ||
*/ | ||
_attributes(line) { | ||
let attrs = ''; | ||
for (let prop in line) { | ||
// Custom add class | ||
if (prop === 'class') { | ||
attrs += ` class=${line[prop]} ` | ||
continue | ||
} | ||
if (prop === 'type') { | ||
attrs += `${this.pfx}="${line[prop]}" ` | ||
} else if (prop !== 'value') { | ||
attrs += `${this.pfx}-${prop}="${line[prop]}" ` | ||
} | ||
} | ||
|
||
return attrs; | ||
} | ||
} | ||
|
||
/** | ||
* HTML API: If current script has container(s) specified, initialise Termynal. | ||
*/ | ||
if (document.currentScript.hasAttribute('data-termynal-container')) { | ||
const containers = document.currentScript.getAttribute('data-termynal-container'); | ||
containers.split('|') | ||
.forEach(container => new Termynal(container)) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
|
||
# Código de Conduta de Colaboração | ||
|
||
## Nossa promessa | ||
|
||
Como pessoas participantes, colaboradoras e líderes, nós nos comprometemos a fazer com que a participação em nossa comunidade seja uma experiência livre de assédio para todas as pessoas, independentemente de idade, tamanho do corpo, deficiência aparente ou não aparente, etnia, características sexuais, identidade ou expressão de gênero, nível de experiência, educação, situação sócio-econômica, nacionalidade, aparência pessoal, raça, religião ou identidade e orientação sexuais. | ||
|
||
Comprometemo-nos a agir e interagir de maneiras que contribuam para uma comunidade aberta, acolhedora, diversificada, inclusiva e saudável. | ||
|
||
## Nossos padrões | ||
|
||
Exemplos de comportamentos que contribuem para criar um ambiente positivo para a nossa comunidade incluem: | ||
|
||
* Demonstrar empatia e bondade com as outras pessoas | ||
* Respeitar opiniões, pontos de vista e experiências contrárias | ||
* Dar e receber feedbacks construtivos de maneira respeitosa | ||
* Assumir responsabilidade, pedir desculpas às pessoas afetadas por nossos erros e aprender com a experiência | ||
* Focar no que é melhor não só para nós individualmente, mas para a comunidade em geral | ||
|
||
Exemplos de comportamentos inaceitáveis incluem: | ||
|
||
* Uso de linguagem ou imagens sexualizadas, bem como o assédio sexual ou de qualquer natureza | ||
* Comentários insultuosos/depreciativos e ataques pessoais ou políticos (*Trolling*) | ||
* Assédio público ou privado | ||
* Publicar informações particulares de outras pessoas, como um endereço de e-mail ou endereço físico, sem a permissão explícita delas | ||
* Outras condutas que são normalmente consideradas inapropriadas em um ambiente profissional | ||
|
||
## Aplicação das nossas responsabilidades | ||
|
||
A liderança da comunidade é responsável por esclarecer e aplicar nossos padrões de comportamento aceitáveis e tomará ações corretivas apropriadas e justas em resposta a qualquer comportamento que considerar impróprio, ameaçador, ofensivo ou problemático. | ||
|
||
A liderança da comunidade tem o direito e a responsabilidade de remover, editar ou rejeitar comentários, commits, códigos, edições na wiki, erros e outras contribuições que não estão alinhadas com este Código de Conduta e irá comunicar as razões por trás das decisões da moderação quando for apropriado. | ||
|
||
## Escopo | ||
|
||
Este Código de Conduta se aplica dentro de todos os espaços da comunidade e também se aplica quando uma pessoa estiver representando oficialmente a comunidade em espaços públicos. | ||
Exemplos de representação da nossa comunidade incluem usar um endereço de e-mail oficial, postar em contas oficiais de mídias sociais ou atuar como uma pessoa indicada como representante em um evento online ou offline. | ||
|
||
## Aplicação | ||
|
||
Ocorrências de comportamentos abusivos, de assédio ou que sejam inaceitáveis por qualquer outro motivo poderão ser reportadas para a liderança da comunidade, responsável pela aplicação, via contato [INSERIR MÉTODO DE CONTATO]. | ||
|
||
Todas as reclamações serão revisadas e investigadas imediatamente e de maneira justa. | ||
|
||
A liderança da comunidade tem a obrigação de respeitar a privacidade e a segurança de quem reportar qualquer incidente. | ||
|
||
## Diretrizes de aplicação | ||
|
||
A liderança da comunidade seguirá estas Diretrizes de Impacto na Comunidade para determinar as consequências de qualquer ação que considerar violadora deste Código de Conduta: | ||
|
||
### 1. Ação Corretiva | ||
|
||
**Impacto na comunidade**: Uso de linguagem imprópria ou outro comportamento considerado anti-profissional ou repudiado pela comunidade. | ||
|
||
**Consequência**: Aviso escrito e privado da liderança da comunidade, esclarecendo a natureza da violação e com a explicação do motivo pelo qual o comportamento era impróprio. Um pedido de desculpas público poderá ser solicitado. | ||
|
||
### 2. Advertência | ||
|
||
**Impacto na comunidade**: Violação por meio de um incidente único ou atitudes repetidas. | ||
|
||
**Consequência**: Advertência com consequências para comportamento repetido. Não poderá haver interações com as pessoas envolvidas, incluindo interações não solicitadas com as pessoas que estiverem aplicando o Código de Conduta, por um período determinado. Isto inclui evitar interações em espaços da comunidade, bem como canais externos como as mídias sociais. A violação destes termos pode levar a um banimento temporário ou permanente. | ||
|
||
### 3. Banimento Temporário | ||
|
||
**Impacto na comunidade**: Violação grave dos padrões da comunidade, incluindo a persistência do comportamento impróprio. | ||
|
||
**Consequência**: Banimento temporário de qualquer tipo de interação ou comunicação pública com a comunidade por um determinado período. Estarão proibidas as interações públicas ou privadas com as pessoas envolvidas, incluindo interações não solicitadas com as pessoas que estiverem aplicando o Código de Conduta. A violação destes termos pode resultar em um banimento permanente. | ||
|
||
### 4. Banimento Permanente | ||
|
||
**Impacto na comunidade**: Demonstrar um padrão na violação das normas da comunidade, incluindo a persistência do comportamento impróprio, assédio a uma pessoa ou agressão ou depreciação a classes de pessoas. | ||
|
||
**Consequência**: Banimento permanente de qualquer tipo de interação pública dentro da comunidade. | ||
|
||
## Atribuição | ||
|
||
Este Código de Conduta é adaptado do [Contributor Covenant][homepage], | ||
versão 2.0, disponível em | ||
https://www.contributor-covenant.org/version/2/0/code_of_conduct.html. | ||
|
||
As Diretrizes de Impacto na Comunidade foram inspiradas pela [Aplicação do código de conduta Mozilla](https://github.com/mozilla/diversity). | ||
|
||
[homepage]: https://www.contributor-covenant.org | ||
|
||
Para obter respostas a perguntas comuns sobre este código de conduta, veja a página de Perguntas Frequentes (*FAQ*) em | ||
https://www.contributor-covenant.org/faq. Traduções estão disponíveis em | ||
https://www.contributor-covenant.org/translations. |
Oops, something went wrong.