Giter Site home page Giter Site logo

lebrancconvas / promise-tracker Goto Github PK

View Code? Open in Web Editor NEW

This project forked from wevisdemo/promise-tracker

1.0 2.0 0.0 18.95 MB

Thai politicians and parties promise tracker

Home Page: https://wevisdemo.github.io/promise-tracker/

License: MIT License

Shell 0.10% JavaScript 0.98% TypeScript 39.63% CSS 0.18% Vue 59.11%

promise-tracker's Introduction

๐Ÿคž WeVis Promise Tracker

Thai politicians and parties promise tracker

๐ŸŒŽ Environment

๐Ÿ’ป Tech stack

โšฝ Working style

  • We use Github issue to track the progress.
    • Please assign yourself to the issue you are working on.
    • I don't want to force "HOW" to implement the issue and we can discuss everything on the issue.
    • Communication language doesn't matter. Feel free to use Thai or English.
  • We use Trunk-based development.
    • No braches, we all push to main branch.
    • If the commit is related to a specific issue, add issue id in the commit message eg. #21 Add button components
    • Pull rebase git pull --rebase often. Before you start coding and pushing.
    • Continuous integration: don't leave your code without pushing overnight, push as much as you can without breaking the build.
    • Linter and formater will be run on commit, while test and build will be run on push so you can't push if it fail.
  • Encourage to write component test with TDD (Test driven development) but it's not mandatory.
  • Each time the code is pushed to main, Github Action will build and deploy to the staging environment.
  • Use asynchonous communication. Let's try not to have meeting if not necessary.
    • For issue related discussion, please use Github issue
    • Other discussion can be done in slack

๐Ÿ“‚ Directory structure

Use pascal-case for every file name since Linux (eg. Github Action runner) is not case-incensitive, in contrary to Mac and Windows.

  • /components Vue components
    • Put on the root if it's shared between pages
    • Put in the /components/<page>/ if it's only used in that page
    • If components is too big or getting duplicated, you should split into several component which can also be group in sub-folder
  • /data JSON promises and related data, including example one before fetching script is implemented.
  • /models Data types (interface, enum, etc.) sharing across the project
  • /pages Represent Nuxt routing
  • /static Static assets such as images
    • Before adding new assets, check first if it's already exist here.
    • $config.path.base can be used to reference static path (or base path)
    • $config.path.images can be used to reference static/images path
      <img :src="`${$config.path.images}/status/nodata.png`"
    • For SVG that can change the color (eg. button icon on hover), recommend in use inline svg with currentColor and Tailwind color preset
  • /tests Test file
    • Recommend to mimick project structure eg. /tests/components/component-name.test.ts

๐Ÿ’… Styling and design system

  • We used WeVis Design System which provide
    • Utility classes for typography
    • Vue component
  • For other styling customization beyond WeVis design system, use Tailwindcss
    • Color is defined in tailwind.config.css which naming should be related to Figma
    • Configuration is also available on http://localhost:3000/\_tailwind/ when dev server is running

THANK YOU FOR ALL THE CONTRIBUTION โค๏ธ

promise-tracker's People

Contributors

th1nkk1d avatar palminister avatar mixth avatar nathakits avatar dependabot[bot] avatar

Stargazers

Yami An avatar

Watchers

James Cloos 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.