Skip to content

Latest commit

 

History

History
84 lines (52 loc) · 3 KB

README.md

File metadata and controls

84 lines (52 loc) · 3 KB

Elm Exercise: Dial

Project to learn basic Elm by doing a simple project (see also Learning Elm section below for information about the language).

NOTE: Make sure you read the Elm Guide first before attempting this exercise.

Goal

The idea is to create a dial that represents graphically a value within a range.

It should look something like this:

You are free to adjust the design (colors and shapes), but the overall idea should be the same.

Features

The current dial doesn't do anything other than increasing a value without limits, you need to implement the following features:

  • Reset button. Restores the value to the default value (of your choosing)
  • Add a decrease button. Reduces the value by 1
  • Add a max and min values (0 and 20 for example)
  • Add a "step" that changes how the value changes when the + or - buttons are used
    • 1 -> The value changes by 1
    • 1/2 -> The value changes in steps of .5
    • 1/4 -> The value changes in steps of .25
  • The rotation of the dial has to be in synch with the value (in relation to its min and max values)

Bonus

  • The + and - buttons are disabled when it max and min values are reached respectively
  • Use an icon instead of text for the + and - buttons
  • Super bonus Allow users to click on the dial and then drag (left and right) changing the value by a fix amount depending on the horizontal distance from the click.

Notes

  • The value is a float value
  • The angular reference is: 0deg is North, 90deg is East
  • Use inline SVG if you want to add more images

Development

The project provides all the necessary packages. Running npm install should be enough to set up the project.

To run the project, just run npm run start.

Learning Elm

Official Docs

The Elm Architecture

Books

Other

Tools

Editor

Use VSCode for a better developer experience.

Elm extension

Warning: The one that shows a wrench made of pieces, not the one that uses the Elm logo.

This tool provides inline error reporting, auto-import and automatic formatting.