Giter Site home page Giter Site logo

site's Introduction

Sources do site do PHP.rio

Descritivo dessa treta

TL;DR: aqui fica o source, os statics ficam no phprio.github.io.

Este repositório contém os sources do php.rio. O site é hospedado pelo próprio GitHub Pages. Para tanto, tínhamos duas opções:

  1. Fazer o site com Jekyll e forçar a galera a se virar com Ruby e similares 😷, mas tendo a build sendo gerada automaticamente
  2. Fazer o site com um primo PHP do Jekyll, o Sculpin, que não faz build automática mas é PHPRio-friendly.

Obviamente, fomos pela segunda opção. Para tanto, é necessário que o site seja publicado na raiz de um repositório com o nome correto e, pra não misturar os statics com todo o source do site, dividimos o projeto em dois repositórios.
Assim, o conteúdo final do site gerado fica em /output_prod, que é um submódulo desse aqui.

Disclaimer: esse projeto foi baseado no exemplo de Blog Skeleton que tem no Get Started deles.

Instalação

muidifício.

  1. Clonar o repositório: git clone [email protected]:PHPRio/site.git phprio-site
  2. Entre na pasta, e prepare o submódulo: git submodule init; git submodule update
  3. Dependências: composer install (espero que você tenha o Composer instalado, né? Senão, veja a seguir)
  4. [opcional] Se você for mexer no layout, você vai precisar do node-sass ou algum outro compilador de SASS. Instale-o pelo NPM ou Yarn: npm install --global node-sass ou yarn global add node-sass.

Não tente seguir as instruções do site do Sculpin. Elas estão bem desatualizadas (mandando usar um phar, por exemplo).

Composer

Método prático pra instalar o Composer globalmente no seu PC: curl -sS https://getcomposer.org/installer | sudo php -- --filename=composer --install-dir=/usr/local/bin

Compilação do site

Desenvolvimento

  • Para testar o site durante o desenvolvimento você pode executar composer watch e acessar em localhost:8000.
  • Para compilar ele uma única vez e servir, composer serve.
  • Há também como compilar estaticamente e só, com o composer generate.
  • Para o layout, nós usamos SASS. Se você for mexer nisso, é importante subir também o watcher de SASS: composer sass-watch. Se quiser compilar uma única vez, composer sass.

Produção

  1. Para fazer a compilação, use composer prod. Isso limpa a pasta, re-gera o SASS, e compila com configurações de produção.
  2. Para fazer o deploy, composer deploy entra na pasta de produção, faz o commit para o submódulo e faz o push.
  3. Se você quiser fazer os dois passos de uma vez, use composer prod-deploy 😏

Não esqueça de, ao finalizar tudo, fazer um commit que inclua a pasta output_prod!
A dica é fazer o deploy antes do commit final da última modificação, assim a gente não polui o histórico do repositório de source com commits "atualizando build do site" 😉

site's People

Contributors

igorsantos07 avatar raphaeldealmeida avatar vitormattos avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.