Test Job

Create a time attendance application. After completion, you need to upload the project to any open GIT repository.

This application should be able to:

  1. Show the user the current tasks in the context of projects and dates
  2. Calculate the amount of time spent on a task
  3. Be able to create tasks and projects

For implementation, you need to use:

  1. ะก#. ASP.NET.Core Mvc. Entity Framework.
  2. JavaScript/TypeScript. ReactJS/Angular or any other JS framework
  3. SCSS/CSS. Bootstrap or any other Framework

The application must have a layered architecture:

  1. DAL
  2. Buisness
  3. UI.

User Interface

  1. The task table should display all the necessary information for the user and have the following columns
    • Number in order
    • Project name
    • The amount of time spent on a task in hours and minutes. Format 00:00
    • Task name (Link to edit page)
    • Start time
    • End time
  2. On the page with the table of tasks, you need to display the total time spent on tasks from the table.
  3. Above the table, you need to display the DatePicker to filter tasks by date, as well as display a drop-down list of projects, to filter by project.
  4. To create a task, you must use the pop-up dialog with the form. After saving the data, the page should not be reloaded and the table data should be updated. Fields:
    • Task name (required parameter)
    • Project (required parameter, drop-down list)
    • Start time and end time. Start time cannot be greater than End time
    • Description of the task. It can be either a file or just a text field, provide for switching.
  5. The task is edited on a separate page. The displayed fields are the same as when creating (item 2). On this page to provide the ability to display, add and delete sets of Descriptions of the current task.
  6. On the page with the table of tasks, you need to display the total time spent on tasks from the table
table_image

Time counting

The column "The amount of time spent on the task" is dynamic and is calculated by the formula:

"Amount of time spent on the task" = "End time" - "Start time"

If the Start time is specified and the End Time is not specified, then the task is considered to be in progress and the end time is considered from the current time. DateTime.Now. Time counting must be implemented on the server.

Database structure

Provide filling of all tables in the database with test data when updating migrations.

db_image

About the company:

Our company is quick growing team with several clients in US and Europe with more than 10 years contracts. There are a lot of work and we hope you join to work and grow with us. Please send your CV to job@itpdevelopment.ru and we will arrange an interview.