te7a-houdini / laravel-trix
trix editor for laravel inspired by ActionText for rails
Installs: 127 461
Dependents: 2
Suggesters: 0
Security: 0
Stars: 526
Watchers: 10
Forks: 53
Open Issues: 33
Requires
- php: ^7.1|^8.0
- laravel/framework: ~5.8.0|~6.0|~7.0|~8.0|~9.0|^10.0|^11.0
Requires (Dev)
- orchestra/testbench: ^3.5|~4.0|~5.0|~6.0|^8.0|^9.0
README
Configurable Basecamp Trix Editor delivered to your laravel application
inspired by Rails Action Text
Installation
You can install the package via composer:
composer require te7a-houdini/laravel-trix
Then publish the configurations and migrations:
php artisan vendor:publish --provider="Te7aHoudini\LaravelTrix\LaravelTrixServiceProvider"
After the migration has been published then run the migrations to create required tables:
php artisan migrate
then add @trixassets
directive at the head tag of your html
<html> <head> @trixassets </head> </html>
Usage
let's assume we have Post model
& want to add trix editor.
Using @trix($model, $field, $config = [])
you can use @trix directive inside any view to render trix editor.
<html> <head> @trixassets </head> <body> <!-- notice that content field isn't presented in Post model --> @trix(\App\Post::class, 'content') </body> </html>
Storing Rich Text Fields
now lets try to store content
rich text field when hitting submit button.
<html> <head> @trixassets </head> <body> <form method="POST" action="{{ route('posts.store') }}"> @csrf @trix(\App\Post::class, 'content') <input type="submit"> </form> </body> </html>
first add HasTrixRichText
trait to your model
namespace App; use Illuminate\Database\Eloquent\Model; use Te7aHoudini\LaravelTrix\Traits\HasTrixRichText; class Post extends Model { use HasTrixRichText; protected $guarded = []; }
then you can easily store any rich text fields by multiple ways:
Post::create(request()->all()); //storing must follow this convention (model lowered class name)-trixFields Post::create([ 'post-trixFields' => request('post-trixFields'), ]);
Render Trix For Existing Model
there's multiple ways to render trix for already existing model
<!-- inside view blade file --> @trix($post, 'content') {!! $post->trix('content') !!} //must use HasTrixRichText trait in order for $model->trix() method work {!! app('laravel-trix')->make($post, 'content') !!}
Render Html For Existing Model
You can render the html content for already existing model
<!-- inside view blade file --> {!! $post->trixRender('content') !!} //must use HasTrixRichText trait in order for $model->trixRender() method work
Storing Attachment
when uploading a file to trix editor. an ajax request is sent to store_attachment_action
in laravel-trix
config file. which uses Laravel Storage and then this action returns url
if upload is success according to Basecamp Trix api .
the uploaded file will be stored in trix_attachments
table as pending
attachment.
once model is saved . all pending
attachments will have is_pending
column = 0
so in order to make storing attachment very easy make sure to use HasTrixRichText
trait in your model.
Post::create(request()->all()); //storing must follow this convention (model lowered class name)-trixFields //and for attachment must follow attachment-(model lowered class name)-trixFields Post::create([ 'post-trixFields' => request('post-trixFields'), 'attachment-post-trixFields' => request('attachment-post-trixFields') ]);
Changing Storage Disk
you can change attachment storage disk from laravel-trix
config file .
return [ 'storage_disk' => env('LARAVEL_TRIX_STORAGE_DISK', 'public'), 'store_attachment_action' => Te7aHoudini\LaravelTrix\Http\Controllers\TrixAttachmentController::class . '@store', 'destroy_attachment_action' => Te7aHoudini\LaravelTrix\Http\Controllers\TrixAttachmentController::class . '@destroy', ];
or if you want to change the storage disk for specific rich text field you can do that
@trix($post, 'content', ['disk' => 'local'])
Deleting Rich Text Field and Attachments
you can remove related rich text fields and attachments on a model deleting:
class Post extends Model { use HasTrixRichText; protected $guarded = []; protected static function boot() { parent::boot(); static::deleted(function ($post) { $post->trixRichText->each->delete(); $post->trixAttachments->each->purge(); }); } }
Configuration Table
if you want to hide buttons or toolbar you can do this. for more configuration refer to the table below.
@trix($post, 'content', [ 'hideButtonIcons' => ['attach', 'bold'] ]) @trix($post, 'content', [ 'hideTools' => ['text-tools'] ])
Testing
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
Security
If you discover any security related issues, please email ahmedabdelftah95165@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.