Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/sokoloff-rv/task-force

Онлайн-сервис для поиска исполнителей и заказчиков по типу YouDo. Проект разработан на фреймворке Yii2. Методология ООП, паттерн MVC. Используются внешние API.
https://github.com/sokoloff-rv/task-force

api composer mvc oop php yii2

Last synced: about 1 month ago
JSON representation

Онлайн-сервис для поиска исполнителей и заказчиков по типу YouDo. Проект разработан на фреймворке Yii2. Методология ООП, паттерн MVC. Используются внешние API.

Awesome Lists containing this project

README

        

# Taskforce
![PHP Version](https://img.shields.io/badge/php-%5E7.4-7A86B8)
![MySQL Version](https://img.shields.io/badge/mysql-%5E5.6-F29221)
![Yii2 Version](https://img.shields.io/badge/Yii2-%5E2.0.45-83C933)
![PHPUnit Version](https://img.shields.io/badge/phpunit-%5E9.5-3A97D0)

## О проекте

«TaskForce» — это онлайн площадка для поиска исполнителей на разовые задачи. Сайт функционирует как биржа объявлений, где заказчики — физические лица публикуют задания. Исполнители могут откликаться на эти задания, предлагая свои услуги и стоимость работ. Проект разработан на базе фреймворка Yii2, использует методологию ООП и паттерн MVC. Также используется внешний API Яндекс.Карт и Вконтакте.

Демонстрационная версия доступна по адресу https://taskforce.sokoloff-rv.ru/.

Для входа в **демо-аккаунт заказчика** используйте следующие данные:

- Логин: [email protected]
- Пароль: democustomer

Для входа в **демо-аккаунт исполнителя** используйте следующие данные:

- Логин: [email protected]
- Пароль: demoexecutor

## Функциональность

Основные возможности, реализованные в проекте:

- Регистрация на сайте;
- Авторизация;
- Регистрация и авторизация через социальную сеть VK;
- Профиль пользователя, отображаемый на отдельной странице:
- аватар,
- город,
- возраст,
- информация о пользователе,
- блок с контактами,
- специализации (для исполнителей),
- отзывы заказчиков (для исполнителей),
- статистика выполненных заказов (для исполнителей),
- дата регистрации (для исполнителей),
- место в общем рейтинге (для исполнителей),
- статус (для исполнителей);
- Редактирование профиля пользователя:
- аватар,
- электронная почта,
- день рождения,
- номер телефона,
- telegram,
- информация о себе,
- пароль (с подтверждением старого);
- Вывод списка заданий с пагинацией (каждый пользователь видит только задания из своего города, а также задания в формате удаленной работы);
- Фильтрация заданий по категориям, времени размещения, наличию откликов и формату работы (удаленная работа или обычная);
- Вывод карточки задания;
- Статусы заданий (в зависимости от того, есть ли на задание отклики, находится ли задание в работе, выполнено оно или провалено);
- Отображение локации задания на Яндекс.Карте через внешний API;
- Возможность оставить отклик на задание (для исполнителей);
- Просмотр откликов на задания (для заказчиков);
- Раздел “Мои задания” для заказчиков:
- список заданий, находящихся в процессе,
- список просроченных заданий,
- список завершенных заданий;
- Раздел “Мои задания” для исполнителей:
- список новых заданий, по которым ещё не выбран исполнитель,
- список заданий, над которыми работают исполнители,
- список завершенных заданий;
- Страница с формой добавления нового задания (для заказчиков), включающая в себя следующие поля:
- заголовок,
- описание задания,
- категория задания,
- локация,
- бюджет,
- срок исполнения,
- файлы задания;
- Размещение откликов на задания (для исполнителей);
- Выбор исполнителя на задание (для заказчиков);
- Размещение отзывов на исполнителей (для заказчиков);
- Система рейтинга исполнителей;
- Валидация всех форм;
- Возврат страницы с ошибкой 404, если пользователь пытается открыть страницу с несуществующим пользователем или заданием.

## Обзор проекта

[![Видео](https://sokoloff-rv.ru/share/github/taskforce.webp?ver_1)](https://youtu.be/mDWVi3cPgNI)

## Начало работы

Чтобы развернуть проект локально или на хостинге, выполните последовательно несколько действий:

1. Клонируйте репозиторий:

```bash
git clone https://github.com/sokoloff-rv/task-force.git taskforce
```

2. Перейдите в директорию проекта:

```bash
cd taskforce
```

3. Установите зависимости, выполнив команду:

```bash
composer install
```

4. Настройте веб-сервер таким образом, чтобы корневая директория указывала на папку web внутри проекта. Например, в случае с размещением проекта в директории `public_html` это можно сделать с помощью команды:

```bash
ln -s web public_html
```

5. Создайте базу данных для проекта, используя схему из файла `schema.sql`:

```sql
CREATE DATABASE taskforce
DEFAULT CHARACTER SET utf8
DEFAULT COLLATE utf8_general_ci;

USE taskforce;

/* Города */
CREATE TABLE cities (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100) NOT NULL,
latitude DECIMAL(11, 8) NOT NULL,
longitude DECIMAL(11, 8) NOT NULL
);

/* Пользователи */
CREATE TABLE users (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(150) NOT NULL,
email VARCHAR(100) NOT NULL UNIQUE,
password VARCHAR(100) NOT NULL,
birthday DATETIME,
phone VARCHAR(100),
telegram VARCHAR(100),
information TEXT,
specializations VARCHAR(255),
avatar VARCHAR(255),
register_date DATETIME DEFAULT CURRENT_TIMESTAMP,
role ENUM ('customer', 'executor') NOT NULL,
succesful_tasks INT,
failed_tasks INT,
city_id INT,
vk_id INT,
hidden_contacts INT DEFAULT 0 NOT NULL,
total_score FLOAT DEFAULT 0 NOT NULL,
FOREIGN KEY (city_id) REFERENCES cities(id)
);

/* Категории заданий */
CREATE TABLE categories (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100) NOT NULL,
alias VARCHAR(100) NOT NULL
);

/* Задания */
CREATE TABLE tasks (
id INT AUTO_INCREMENT PRIMARY KEY,
customer_id INT NOT NULL,
title VARCHAR(255) NOT NULL,
description TEXT,
category_id INT NOT NULL,
city_id INT,
budget VARCHAR(100),
deadline DATETIME,
location VARCHAR(255),
latitude DECIMAL(11, 8),
longitude DECIMAL(11, 8),
creation_date DATETIME DEFAULT CURRENT_TIMESTAMP,
status VARCHAR(50) DEFAULT 'new' NOT NULL,
executor_id INT,
FOREIGN KEY (category_id) REFERENCES categories(id),
FOREIGN KEY (customer_id) REFERENCES users(id),
FOREIGN KEY (executor_id) REFERENCES users(id),
FOREIGN KEY (city_id) REFERENCES cities(id)
);

/* Файлы */
CREATE TABLE files (
id INT AUTO_INCREMENT PRIMARY KEY,
link VARCHAR(255) NOT NULL UNIQUE,
task_id INT NOT NULL,
FOREIGN KEY (task_id) REFERENCES tasks(id)
);

/* Отклики */
CREATE TABLE responses (
id INT AUTO_INCREMENT PRIMARY KEY,
executor_id INT NOT NULL,
task_id INT NOT NULL,
comment TEXT,
price INT,
creation_date DATETIME DEFAULT CURRENT_TIMESTAMP,
status VARCHAR(50) DEFAULT 'new' NOT NULL,
FOREIGN KEY (executor_id) REFERENCES users(id),
FOREIGN KEY (task_id) REFERENCES tasks(id)
);

/* Отзывы */
CREATE TABLE reviews (
id INT AUTO_INCREMENT PRIMARY KEY,
customer_id INT NOT NULL,
executor_id INT NOT NULL,
task_id INT NOT NULL,
comment TEXT,
grade INT,
creation_date DATETIME DEFAULT CURRENT_TIMESTAMP,
FOREIGN KEY (customer_id) REFERENCES users(id),
FOREIGN KEY (executor_id) REFERENCES users(id),
FOREIGN KEY (task_id) REFERENCES tasks(id)
);

CREATE FULLTEXT INDEX task_title_search ON tasks(title);
CREATE FULLTEXT INDEX task_description_search ON tasks(description);
```

6. Настройте подключение к базе данных в файле `config\db.php`, указав в нем параметры своего окружения. Например, это может выглядеть так:

```php
'yii\db\Connection',
'dsn' => 'mysql:host=127.0.0.1;dbname=taskforce',
'username' => 'root',
'password' => 'root',
'charset' => 'utf8',
];
```

## Техническое задание

[Посмотреть техническое задание проекта](https://sokoloff-rv.notion.site/Taskforce-a703517be86f4dd2b0562c0602bad50e?pvs=4)