## Developing This article outlines how to get Dashy running in a development environment, and outlines the basics of the architecture. - [Setting up the Development Environment]() - [Resources for Beginners]() - [Style Guide]() - [Frontend Components]() - [Project Structure]() ### Setting up the Dev Environment #### Prerequisites You will need either the latest or LTS version of **[Node.js](https://nodejs.org/)** to build and serve the application and **[Git](https://git-scm.com/downloads)** to easily fetch the code, and push any changes. If you plan on running or deploying the container, you'll also need **[Docker](https://docs.docker.com/get-docker/)**. To avoid any unexpected issues, ensure you've got at least **[NPM](https://www.npmjs.com/get-npm)** V 7.5 or **[Yarn](https://classic.yarnpkg.com/en/docs/install/#windows-stable)** 1.22 (you may find [NVM](https://github.com/nvm-sh/nvm) helpful for switching/ managing versions). #### Running the Project 1. Get Code: `git clone git@github.com:Lissy93/dashy.git` 2. Navigate into the directory: `cd dashy` 3. Install dependencies: `yarn` 4. Start dev server: `yarn dev` Dashy should now be being served on http://localhost:8080/. Hot reload is enabled, so making changes to any of the files will trigger them to be rebuilt and the page refreshed. #### Project Commands - `yarn dev` - Starts the development server with hot reloading - `yarn build` - Builds the project for production, and outputs it into `./dist` - `yarn start` - Starts a web server, and serves up the production site from `./dist` - `yarn validate-config` - Parses and validates your `conf.yml` against Dashy's schema - `yarn lint` - Lints code to ensure it follows a consistent, neat style - `yarn test` - Runs tests, and outputs results There is also: - `yarn build-and-start` will run `yarn build` and `yarn start` - `yarn build-watch` will output contents to `./dist` and recompile when anything in `./src` is modified, you can then use either `yarn start` or your own server, to have a production environment that watches for changes. Note: - If you are using NPM, replace `yarn` with `npm run` - If you are using Docker, precede each command with `docker exec -it [container-id]`. Container ID can be found by running `docker ps` ### Resources for Beginners New to Web Development? Glad you're here! Dashy is a pretty simple app, so it should make a good candidate for your first PR. Presuming that you already have a basic knowledge of JavaScript, the following articles should point you in the right direction for getting up to speed with the technologies used in this project: - [Introduction to Vue.js](https://v3.vuejs.org/guide/introduction.html) - [Vue.js Walkthrough](https://www.taniarascia.com/getting-started-with-vue/) - [Definitive guide to SCSS](https://blog.logrocket.com/the-definitive-guide-to-scss/) - [Complete beginners guide to Docker](https://docker-curriculum.com/) - [Docker Classroom - Interactive Tutorials](https://training.play-with-docker.com/) - [Quick start TypeScript guide](https://www.freecodecamp.org/news/learn-typescript-in-5-minutes-13eda868daeb/) - [Complete TypeScript tutorial series](https://www.typescripttutorial.net/) - [Using TypeScript with Vue.js](https://blog.logrocket.com/vue-typescript-tutorial-examples/) - [Git cheat sheet](http://git-cheatsheet.com/) - [Basics of using NPM](https://www.freecodecamp.org/news/what-is-npm-a-node-package-manager-tutorial-for-beginners/) As well as Node, Git and Docker- you'll also need an IDE (e.g. [VS Code](https://code.visualstudio.com/) or [Vim](https://www.vim.org/)) and a terminal (Windows users may find [WSL](https://docs.microsoft.com/en-us/windows/wsl/) more convenient). ### Style Guide Linting is done using [ESLint](https://eslint.org/), and using the [Vue.js Styleguide](https://github.com/vuejs/eslint-config-standard), which is very similar to the [AirBnB Stylguide](https://github.com/airbnb/javascript). You can run `yarn lint` to report and fix issues. While the dev server is running, issues will be reported to the console automatically. Any lint errors will trigger the build to fail. Note that all lint checks must pass before any PR can be merged. The most significant things to note are: - Indentation should be done with two spaces - Strings should use single quotes - All statements must end in a semi-colon - The final element in all objects must be preceded with a comma - Maximum line length is 100 - There must be exactly one blank line between sections, before function names, and at the end of the file - With conditionals, put else on the same line as your if block’s closing brace - All multiline blocks must use braces - Avoid console statements in the frontend For the full styleguide, see: [github.com/airbnb/javascript](https://github.com/airbnb/javascript) ### Frontend Components All frontend code is located in the `./src` directory, which is split into 5 sub-folders: - Components - All frontend web components are located here. Each component should have a distinct, well defined and simple task, and ideally should not be too long. The components directory is organised into a series of sub-directories, representing a specific area of the application - PageStrcture - Components relating to overall page structure (nav, footer, etc) - FormElements - Reusable form elements (button, input field, etc) - LinkItems - Components relating to Dashy's sections and items (item group, item, item icon, etc) - Configuration - Components relating to Dashy's configuration forms (cloud backup, JSON editor, etc) - Views - Each view directly corresponds to a route (defined in the router), and in effectively a page. They should have minimal logic, and just contain a few components - Utils - These are helper functions, or logic that is used within the app does not include an UI elements - Styles - Any SCSS that is used globally throughout that app, and is not specific to a single component goes here. This includes variables, color themes, typography settings, CSS reset and media queries - Assets - Static assets that need to be bundled into the application, but do not require any manipulation go here. This includes interface icons and fonts The structure of the components directory is similar to that of the frontend application layout
