The task is to implement a 2 step UI wizard to create a user account. There is no UX or UI constraints, this is up to you to decide.
The User information that we need to collect is described in the User type:
interface User {
name: string
age: number
email: string
newsletter: 'daily' | 'weekly' | 'monthly'
}
You can, for example collect the name and age in the first step and then email and newsletter in the second step. You may use a routing library such that every step is a separate route but this is completely optional and not required.
There is a dummy sdk
package(implemented in the /sdk folder) which exports a createUser
function. This function returns a Promise
.
Use it to simulate a request that creates a user account.
Ex:
import { createUser } from 'sdk'
const details = {...}
createUser(details).then( ... )
The focus should be on code style and the way you approach the problem implementation wise. Feel free to use any other helper library although ideally the more code you write yourself the better.
- use either vanilla Javascript or one of the frameworks we use at Sheypoor(React / Knockout.js) or whatever you like
- use npm to manage dependencies, there is pre-initialized package.json included in this repo
- Fork the repo
- Implement your solution
- Create a PR against this repo
Optional: build the project and deploy (ie make it available as a static project) on Github Pages, otherwise please provide detailed instructions on how to start the project locally.
Any questions please contact us via email (jobs AT sheypoor.com) :)
- Clone the repo
- Install required packages using npm. (run
npm install
ornpm i
in the root directory of project ) - Start development version of project. (run
npm start
in the root directory of project) or you can build the production version. (runnpm run build
in the root directory of project)