Package Data | |
---|---|
Maintainer Username: | Te7a-Houdini |
Maintainer Contact: | ahmedabdelftah95165@gmail.com (Ahmed Abd El Ftah) |
Package Create Date: | 2019-10-26 |
Package Last Update: | 2024-03-13 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-24 15:03:02 |
Package Statistics | |
---|---|
Total Downloads: | 121,139 |
Monthly Downloads: | 3,207 |
Daily Downloads: | 31 |
Total Stars: | 524 |
Total Watchers: | 10 |
Total Forks: | 53 |
Total Open Issues: | 32 |
inspired by Rails Action Text
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>
let's assume we have Post model
& want to add trix editor.
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>
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'),
]);
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') !!}
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')
]);
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'])
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'] ])
| configuration | type | values | description
|-----------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------
| hideToolbar | Boolean | True or False | hides the the toolbar
| hideTools | Array | ['text-tools', 'block-tools', 'file-tools', 'history-tools'] | hides group of buttons
| hideButtonIcons | Array | ['attach', 'bold', 'italic', 'strike', 'link', 'heading-1', 'quote', 'code', 'bullet-list', 'number-list', 'decrease-nesting-level', 'increase-nesting-level'] | hides a single button
| disk | String | 'local' or 's3' or 'any-disk' | sets the attachment storage per field
| id | String | 'any-value-you-want' | the id of input which renders trix. check this link . current id follows this convention (model lowered class name)-field-modelId
like post-content-1
or post-content-new-model
| containerElement | String | valid html tag like span
or div
| default container tag is set to span
you can change it as you want
composer test
Please see CHANGELOG for more information what has changed recently.
If you discover any security related issues, please email ahmedabdelftah95165@gmail.com instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.