The goal of this test is to recreate a housing setup like we have at habx. It should take you less than 2 hours but feel free to take more time if you still have something to show us!
This repository is the template of the test, you are asked to complete it to fill all the requirements.
Fork the repo and clone it, then:
npm install
npm run start
with yarn
yarn
yarn start
When you're done you can just send us the repository link ๐จโ๐ซ
The component should be a form with 4 fields:
- Budget (price in euros)
- Surface (area in square meters)
- Typology (nb of rooms) one option possible
- Exposure (north, south, east, west) multiple options possible
The form should have a minimum of validation and be based on project properties that should be fetched from the api.
User inputs have to be saved with the upsertSetup
mutation with all
required values.
That's it ! โณ๏ธ
We ask you to use React with apollo-client to make your GraphQL API calls. ๐ฎโโ๏ธ
Pick at least one among the following
- use Typescript in strict mode (you can generate graphql types by running
npm run build:types
) ๐ค - do some animations with tools you like ๐
- test the application: you can use
jest
or evencypress
if you want ๐คนโโ๏ธ
Here are some libraries we use daily, but you can use whatever you want ! ๐
- @habx/ui-core our UI components library โจ
- styled-components ๐
- final-form ๐
You could start by editing the Setup
component. You are free to imagine the UI/UX. ๐จโ๐จ
Any thoughts about our development environment ? (create-react-app/graphql...) What tools are you using daily ?
The api is mocked client side and is described bellow
query {
project {
id
name
properties {
priceRange
surfaceRange
exposures
typologies
}
}
}
mutation($setup: SetupInput!) {
upsertSetup(setup: $setup)
}
If you have any question, don't hesitate to ask our team ๐ค
Good luck ! ๐ค