Skip to content

cottonspace/time-record-system

Repository files navigation

English | 日本語

T-RECS

logo

T-RECS: Time RECord System

Web based simple Time Card system written by django. Currently this application only supports Japanese and Japan holidays.

Features

User can clock in and clock out from a smartphone or PC. Manager check users time records.

Usage

Time recording

  • Click button for "attendance at work" or "leaving work".
  • When you see a message, it indicates that time recording has been completed successfully.
  • If you click in multiple times on the same day, the work time is first click to last click.

Monthly time records

  • You can check monthly records and working hours.
  • Manager can check all user's records.

Change Password

  • Users can change own password.

Demo

id password role
demo1 demodemo1 employee
demo2 demodemo2 employee
manage manemane1 manager

Installation

Download and edit settings

  • Clone or download the application source code from repository.
  • Copy local_settings_template.txt to the same directory as local_settings.py.
  • Edit the part from % to % of the local_settings.py according to your environment.
  • You can easily create a local_settings.py file using the T-RECS easy config tool.

Install dependency libraries

  • Run the following command for install requirements libraries.
pip install -r requirements.txt
  • If you use MySQL, run following command also.
pip install mysqlclient
  • If you use PostgreSQL, run following command also.
pip install psycopg2-binary

Initialize application

  • Run the following command to prepare the database.
python manage.py migrate
  • Create a superuser with the following command.
python manage.py createsuperuser
  • Initialize the master datas with the following command. This will create default settings, so you can edit them later to create appropriate working rules.
python manage.py loaddata worktime/fixtures/standard-work-pattern.json
python manage.py loaddata worktime/fixtures/time-off-pattern.json
  • Start the server. For example, to start with Django's functions, run the following command.
python manage.py runserver

Initial setting

  • Log in as superuser in a web browser to access the administration screen.
  • First, set the working time pattern for each day of the week on the "Work Pattern" screen. Be sure to perform this setting first before starting application operation.
  • Use the following command to initialize the working hours for each day of the week and create a business day calendar.
python manage.py create_calendar
  • Register the user who will be stamping the time by adding users as appropriate from the management screen.

Adding commands to tasks

  • Register the following command to be executed at least once a month in a regular task such as crontab.
python manage.py create_calendar

Delete business day calendar

  • If you want to reconfigure the business day calendar created with create_calendar, you can use the command below to delete the business day calendar for the specified month and beyond months.
python manage.py delete_calendar year month
  • The missing month's business day calendar will be recreated by running create_calendar.
  • Business day calendars are managed on a monthly basis, so it is not possible to delete only specific days within a month.

Batch registration users

  • User registration can be from the system administration screen one by one, but many users can be registered at batch using create_users.
python manage.py create_users file
  • Input csvfile must be saved in UTF-8.
  • The order of columns is id, password, last name, first name.

Disabling a user

  • If you want to disable a user due to retirement, etc., we recommend unchecking the user's "enabled" checkbox on the administrator screen. If you delete it, you will no longer be able to view that user's past attendance history.
  • Users whose "Enabled" checkbox is unchecked will be displayed with a "*" symbol after their "Name" when displayed in a list.

License

MIT