adalessa / laravel-workflow
将 Symfony Workflow 组件集成到 Laravel 中。
3.0.0
2020-09-08 19:25 UTC
Requires
- php: >=7.3.0
- illuminate/console: ^8.0
- illuminate/support: ^8.0
- symfony/event-dispatcher: ^5.0
- symfony/process: ^5.0
- symfony/workflow: ^5.0
Requires (Dev)
- mockery/mockery: ^1.0
- phpunit/phpunit: ^6.0 || ~7.0 || ^8.0
README
是 Brexis 包的分支,我只是将其更新到了 laravel 7 和 symfony 5
在 Laravel 中使用 Symfony Workflow 组件
安装
composer require adalessa/laravel-workflow
对于 laravel <= 5.4
将 ServiceProvider 添加到你的 config/app.php
中的 providers 数组
<?php 'providers' => [ ... Brexis\LaravelWorkflow\WorkflowServiceProvider::class, ]
将 Workflow
门面添加到你的 facades 数组
<?php ... 'Workflow' => Brexis\LaravelWorkflow\Facades\WorkflowFacade::class,
配置
发布配置文件
php artisan vendor:publish --provider="Brexis\LaravelWorkflow\WorkflowServiceProvider"
在 config/workflow.php
中配置你的工作流程
<?php return [ 'straight' => [ 'type' => 'workflow', // or 'state_machine' 'marking_store' => [ 'type' => 'multiple_state', 'arguments' => ['currentPlace'] ], 'supports' => ['App\BlogPost'], 'places' => ['draft', 'review', 'rejected', 'published'], 'transitions' => [ 'to_review' => [ 'from' => 'draft', 'to' => 'review' ], 'publish' => [ 'from' => 'review', 'to' => 'published' ], 'reject' => [ 'from' => 'review', 'to' => 'rejected' ] ], ] ];
在支持的类中使用 WorkflowTrait
<?php namespace App; use Illuminate\Database\Eloquent\Model; use Brexis\LaravelWorkflow\Traits\WorkflowTrait; class BlogPost extends Model { use WorkflowTrait; }
用法
<?php use App\BlogPost; use Workflow; $post = BlogPost::find(1); $workflow = Workflow::get($post); // if more than one workflow is defined for the BlogPost class $workflow = Workflow::get($post, $workflowName); $workflow->can($post, 'publish'); // False $workflow->can($post, 'to_review'); // True $transitions = $workflow->getEnabledTransitions($post); // Apply a transition $workflow->apply($post, 'to_review'); $post->save(); // Don't forget to persist the state // Using the WorkflowTrait $post->workflowCan('publish'); // True $post->workflowCan('to_review'); // False // Get the post transitions foreach ($post->workflow_transitions() as $transition) { echo $transition->getName(); } // if more than one workflow is defined for the BlogPost class foreach ($post->workflow_transitions($workflowName) as $transition) { echo $transition->getName(); } // Apply a transition $post->workflowApply('publish'); $post->save();
使用事件
此包提供了一系列在转换期间触发的事件
Brexis\LaravelWorkflow\Events\Guard Brexis\LaravelWorkflow\Events\Leave Brexis\LaravelWorkflow\Events\Transition Brexis\LaravelWorkflow\Events\Enter Brexis\LaravelWorkflow\Events\Entered
你可以订阅一个事件
<?php namespace App\Listeners; use Brexis\LaravelWorkflow\Events\GuardEvent; class BlogPostWorkflowSubscriber { /** * Handle workflow guard events. */ public function onGuard(GuardEvent $event) { /** Symfony\Component\Workflow\Event\GuardEvent */ $originalEvent = $event->getOriginalEvent(); /** @var App\BlogPost $post */ $post = $originalEvent->getSubject(); $title = $post->title; if (empty($title)) { // Posts with no title should not be allowed $originalEvent->setBlocked(true); } } /** * Handle workflow leave event. */ public function onLeave($event) {} /** * Handle workflow transition event. */ public function onTransition($event) {} /** * Handle workflow enter event. */ public function onEnter($event) {} /** * Handle workflow entered event. */ public function onEntered($event) {} /** * Register the listeners for the subscriber. * * @param Illuminate\Events\Dispatcher $events */ public function subscribe($events) { $events->listen( 'Brexis\LaravelWorkflow\Events\GuardEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onGuard' ); $events->listen( 'Brexis\LaravelWorkflow\Events\LeaveEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onLeave' ); $events->listen( 'Brexis\LaravelWorkflow\Events\TransitionEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onTransition' ); $events->listen( 'Brexis\LaravelWorkflow\Events\EnterEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onEnter' ); $events->listen( 'Brexis\LaravelWorkflow\Events\EnteredEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onEntered' ); } }
转储工作流程
Symfony 工作流程使用 GraphvizDumper 创建工作流程图像。你可能需要安装Graphviz 的 dot
命令。
php artisan workflow:dump workflow_name --class App\\BlogPost
你可以使用 --format
选项更改图像格式。默认格式是 png。
php artisan workflow:dump workflow_name --format=jpg