work-timer/README.md

140 lines
3.2 KiB
Markdown
Raw Normal View History

2023-06-22 13:33:33 +02:00
# WorkTimer
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
<img src="./public/logo.png" width="100" height="100" alt="WorkTimer" />
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
Time tracking app built with Remix, supports authentication, projects management, and monthly or custom reports.
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
Built for self-hosting: host it anywhere you want, and use it for free. Your time, your data.
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
## Table of contents
- [Features](#features)
- [Pre-built Docker image](#pre-built-docker-image)
- [Docker compose](#docker-compose)
- [Custom deployments or development](#custom-deployment-or-development)
- [Tech stack](#tech-stack)
- [Running locally](#running-locally)
- [Running with Docker](#running-with-docker)
- [Screenshots](#screenshots)
- [License](#license)
## Features
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
- Time entries management
- Authentication
- Multi-user support, with admin role
- Projects management
- Monthly or custom reports
- Import/Export to CSV
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
[Screenshots](#screenshots)
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
## Pre-built Docker Image
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
```bash
docker pull nzambello/work-timer
2023-02-11 03:14:14 +01:00
```
2023-06-22 13:33:33 +02:00
If you want to use the pre-built Docker image, you can run it with:
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
```bash
docker run -d -p 8080:8080 -v /path/to/data:/data/data.db nzambello/work-timer
2023-02-11 03:14:14 +01:00
```
2023-06-22 13:33:33 +02:00
If you want to use different defaults, you can build your own image. See [Running with docker](#running-with-docker)
### Docker compose
Example of docker-compose.yml with [Traefik](https://traefik.io/) as reverse proxy:
```yaml
uptime-kuma:
depends_on:
- watchtower
image: nzambello/work-timer
container_name: work-timer
restart: always
volumes:
- /dockerData/work-timer:/data # Path to data for DB persistence
labels:
- 'com.centurylinklabs.watchtower.enable=true'
- 'traefik.enable=true'
- 'traefik.http.routers.work-timer.rule=Host(`timer.YOURDOMAIN.com`)'
- 'traefik.http.routers.work-timer.entrypoints=websecure'
- 'traefik.http.routers.work-timer.tls.certresolver=letsencrypt'
- 'traefik.http.routers.work-timer.service=work-timer-service'
- 'traefik.http.services.work-timer-service.loadbalancer.server.port=8080'
```
## Custom deployment or development
### Tech Stack
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
- [Remix](https://remix.run)
- [Prisma](https://prisma.io)
- [SQLite](https://sqlite.org)
- [Mantine](https://mantine.dev)
- [Docker](https://docker.com)
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
### Running Locally
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
```bash
# Clone the repo
git clone https://github.com/nzambello/work-timer.git
cd work-timer
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
# Install dependencies
yarn install
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
# Setup .env
cp .env.example .env
vim .env
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
# Start the app
yarn dev
```
### Running with Docker
```bash
# Clone the repo
git clone https://github.com/nzambello/work-timer.git
cd work-timer
2023-02-11 03:14:14 +01:00
2023-06-22 13:33:33 +02:00
# Setup .env
cp .env.example .env
vim .env
# Build the image
docker built -t work-timer .
# Start the app
docker run -p 127.0.0.1:8080:8080 work-timer
2023-02-11 03:14:14 +01:00
```
2023-06-22 13:33:33 +02:00
## Screenshots
### Light / Dark mode
<img width="300" src="./public/images/00-time-entries-light.png" />
<img width="300" src="./public/images/01-time-entries-dark.png" />
### Time tracking
<img width="500" src="./public/images/02-new-time-entry.png" />
### Projects
<img width="300" src="./public/images/03-projects.png" />
<img width="300" src="./public/images/04-new-project.png" />
### Reports
<img width="500" src="./public/images/05-reports.png" />
## License
[Nicola Zambello](https://github.com/nzambello) © 2023
[GNU GPLv3](./LICENSE)