Skip to content

This is an entry task for a junior position at a certain company. The task involves loading topics from a JSON file and manipulating the font size and color of each topic based on its metadata. Technologies used: JavaScript/React.

Notifications You must be signed in to change notification settings

bujakkristijan/challenge

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 

Repository files navigation

Project is implemented using React library and some additional libraries such as Bootstrap (table, modal, button), Moment (date format) and few more.

How to run application:

  • Open the command prompt or Terminal and navigate to React project directory.
  • Run the following command to install all the necessary dependencies: npm install
  • Once the installation is complete, run the following command to start the development server: npm start

How application works:

  • When application starts, topics (topic.label value) are loaded from topics.json file and presented in a table on the left side

  • There are 6 different font sizes of topics depending on volume

  • Topic with sentiment score > 60 is displayed in green color

  • Topic with sentiment score < 40 is displayed in red color

  • Other topics are grey

  • When a topic is not clicked yet, there will be a message that inform user to select the topic from the table

  • When a topic is clicked, metadata about the topic are displayed (total volume, and how that breaks down into positive, neutral and negative sentiment) in the component from the right side

  • Positive sentiment value has green and negative has red color

  • If some sentiment property does not exist in topic object, it will have default value 0

  • When the user clicks on 'Volume by days' button next to a topic (topic.label) in the table, modal will pop up

  • Modal shows topic searches (date and volume) sorted by date (ascending)

  • Date values in modal are parsed into "YYYY-MM-DD" format

Application UI preview

preview1

preview2

preview3

About

This is an entry task for a junior position at a certain company. The task involves loading topics from a JSON file and manipulating the font size and color of each topic based on its metadata. Technologies used: JavaScript/React.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published