greekasoft / plan_cooking_calendar
Laravel пакет для планирования блюд по календарю
Package info
github.com/GreekIgor/packade-book-recipe
Language:Vue
pkg:composer/greekasoft/plan_cooking_calendar
Requires
- php: ^8.2
- illuminate/database: ^11.0|^12.0
- illuminate/http: ^11.0|^12.0
- illuminate/routing: ^11.0|^12.0
- illuminate/support: ^11.0|^12.0
Requires (Dev)
- orchestra/testbench: ^10.0|^11.0
- phpunit/phpunit: ^11.0
This package is not auto-updated.
Last update: 2026-03-24 07:11:48 UTC
README
Laravel пакет для планирования блюд по календарю. Позволяет пользователям создавать планы готовки на определенные даты, связывая их с рецептами из вашей кулинарной книги.
Требования
- PHP >= 8.2
- Laravel >= 11.0 или >= 12.0
- Vue.js 3 (для использования Vue компонента)
Установка
Через Composer
composer require greekasoft/plan_cooking_calendar
Публикация миграций
php artisan vendor:publish --tag=plan-cooking-calendar-migrations
Публикация конфигурации (опционально)
php artisan vendor:publish --tag=plan-cooking-calendar-config
Публикация Vue компонентов (опционально)
php artisan vendor:publish --tag=plan-cooking-calendar-assets
Выполнение миграций
php artisan migrate
Конфигурация
После публикации конфигурации, вы можете настроить пакет в файле config/plan-cooking-calendar.php:
return [ 'route_prefix' => 'api/cooking-calendar', 'middleware' => ['web', 'auth'], 'recipe_model' => 'App\Models\Recipe', 'user_model' => 'App\Models\User', ];
Использование
API Endpoints
Пакет автоматически регистрирует следующие маршруты:
GET /api/cooking-calendar- Получить список планов (поддерживает параметрыstart_date,end_date,month,year)GET /api/cooking-calendar/date/{date}- Получить планы на конкретную датуPOST /api/cooking-calendar- Создать новый планGET /api/cooking-calendar/{id}- Получить конкретный планPUT /api/cooking-calendar/{id}- Обновить планDELETE /api/cooking-calendar/{id}- Удалить планPATCH /api/cooking-calendar/{id}/toggle-complete- Переключить статус выполнения
Использование модели
use Greekasoft\PlanCookingCalendar\Models\CookingPlan; // Создать план $plan = CookingPlan::create([ 'user_id' => auth()->id(), 'recipe_id' => 1, 'planned_date' => '2024-01-15', 'planned_time' => '18:00', 'servings' => 4, 'notes' => 'Ужин для семьи', ]); // Получить планы на дату $plans = CookingPlan::forDate('2024-01-15')->get(); // Получить планы за период $plans = CookingPlan::forDateRange('2024-01-01', '2024-01-31')->get(); // Получить только выполненные планы $completed = CookingPlan::completed()->get(); // Получить только невыполненные планы $pending = CookingPlan::pending()->get();
Использование Vue компонента
После публикации Vue компонента, импортируйте его в ваше приложение:
import CookingCalendar from './vendor/plan-cooking-calendar/CookingCalendar.vue'; // В вашем компоненте или app.js app.component('CookingCalendar', CookingCalendar);
Затем используйте в шаблоне:
<template> <div> <CookingCalendar /> </div> </template>
Или в Blade шаблоне:
<div id="cooking-calendar"> <cooking-calendar></cooking-calendar> </div> @vite(['resources/js/app.js'])
Важно: Убедитесь, что у вас настроен API endpoint для получения списка рецептов. Компонент ожидает ответ от /api/recipes или /recipe-list. При необходимости измените метод loadRecipes() в компоненте.
Структура базы данных
Пакет создает таблицу cooking_plans со следующими полями:
id- ID планаuser_id- ID пользователя (связь с таблицей users)recipe_id- ID рецепта (связь с таблицей recipes)planned_date- Запланированная датаplanned_time- Запланированное время (опционально)servings- Количество порцийnotes- Заметкиis_completed- Статус выполненияcreated_at,updated_at- Временные метки
Минимальные требования
Пакет требует следующие зависимости:
php >= 8.2illuminate/support ^11.0|^12.0illuminate/database ^11.0|^12.0illuminate/routing ^11.0|^12.0illuminate/http ^11.0|^12.0
Публикация на Packagist
- Создайте репозиторий на GitHub
- Добавьте теги версий (например,
v1.0.0) - Зарегистрируйте пакет на packagist.org
- Укажите URL вашего репозитория
Лицензия
MIT
Автор
Igor Morozov (GreekIgor87@gmail.com)