habitica-self-host/website/client
2018-07-30 16:10:01 +02:00
..
assets Merge branch 'develop' into release 2018-07-26 18:15:33 +00:00
components Merge branch 'thefifthisa-clickout' into develop 2018-07-30 16:10:01 +02:00
directives Fix difficult to edit checklists in Firefox (#9525) 2017-11-27 19:43:24 -06:00
filters improves rounding for boss hp and player pending damage - partial fix for #8368 (#9749) 2018-03-31 12:57:37 +02:00
libs Remember equipment drawer tab (#10458) 2018-06-27 19:08:21 +02:00
mixins Separated out modal components (#10545) 2018-07-30 14:38:29 +08:00
store Group Tasks Shared Completion (#10515) 2018-07-20 12:29:44 -05:00
.babelrc Client: Header & Menu & Icons (#8770) 2017-06-08 12:04:19 -07:00
.eslintrc Client: i18n (#8972) 2017-08-22 18:26:53 +02:00
app.vue Fix Modal Stack - reopening modals (#10493) 2018-07-20 15:50:40 -05:00
index.html Client: use api v4 (#10457) 2018-06-21 21:25:27 +02:00
main.js Merge branch 'release' into develop 2017-12-13 22:16:30 +00:00
README.md adjust README file for recent changes in wiki Blacksmith pages 2018-06-30 15:05:05 +10:00
router.js Logout Changes #9915 (#10022) 2018-07-12 15:07:08 -05:00

Running

For information about installing and running Habitica locally, see Setting up Habitica Locally.

Preparation Reading

  • Vue 2 (https://vuejs.org)

  • Webpack (https://webpack.github.io/) is the build system and it includes plugins for code transformation, right now we have: BabelJS for ES6 transpilation, eslint for code style, less and postcss for css compilation. The code comes from https://github.com/vuejs-templates/webpack which is a Webpack template for Vue, with some small modifications to adapt it to our use case. Docs http://vuejs-templates.github.io/webpack/

  • We're using .vue files that make it possible to have HTML, JS and CSS for each component together in a single location. They're implemented as a webpack plugin and the docs can be found here http://vue-loader.vuejs.org/en/

  • SemanticUI is the UI framework http://semantic-ui.com/. So far I've only used the CSS part, it also has JS plugins but I've yet to use them. It supports theming so if it's not too difficult we'll want to customize the base theme with our own styles instead of writing CSS rules to override the original styling.

The code is in /website/client. We're using something very similar to Vuex (equivalent of React's Redux) for state management http://vuex.vuejs.org/en/index.html

The API is almost the same except that we don't use mutations but only actions because it would make it difficult to work with common code

The project is developed directly in the develop branch as long as we'll be able to avoid splitting it into a different branch.

So far most of the work has been on the template, so there's no complex logic to understand. The only thing I would suggest you to read about is Vuex for data management: it's basically a Flux implementation: there's a central store that hold the data for the entire app, and every change to the data must happen through an action, the data cannot be mutated directly.

For further resources, see Guidance for Blacksmiths, and in particular the "Website Technology Stack" section.