1. Go to this page and download the library: Download bumpcore/editor.php library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
bumpcore / editor.php example snippets
use BumpCore\EditorPhp\EditorPhp;
// Passing Editor.js's output directly to the `make`.
// This will render blocks into html.
echo EditorPhp::make($json)->render();
use BumpCore\EditorPhp\EditorPhp;
// Using the `new` syntax.
$editor = new EditorPhp($json);
// Using the `make` syntax.
$editor = EditorPhp::make($json);
use BumpCore\EditorPhp\EditorPhp;
use BumpCore\EditorPhp\Block\Block;
use BumpCore\EditorPhp\Blocks\Paragraph;
$editor = EditorPhp::make($json);
// Stripping all tags from paragraph block's text.
$editor->blocks->transform(function(Block $block)
{
if($block instanceof Paragraph)
{
$block->set('text', strip_tags($block->get('text')));
}
return $block;
});
use BumpCore\EditorPhp\EditorPhp;
$editor = EditorPhp::make($json);
// Using the `render` function.
echo $editor->render();
// Using the `toHtml` function.
echo $editor->toHtml();
// Or by casting to a string.
echo $editor;
use BumpCore\EditorPhp\EditorPhp;
// Using tailwind.
EditorPhp::useTailwind();
// Using Bootstrap.
EditorPhp::useBootstrapFive();
use BumpCore\EditorPhp\EditorPhp;
// This will return a generated fake JSON.
$fake = EditorPhp::fake();
// If we pass first argument true, it will return new `EditorPhp` instance with fake data.
$fakeEditor = EditorPhp::fake(true);
// You can also pass min lenght and max lenght of blocks.
// Below code will generate blocks between 1 and 3.
$fakeEditor = EditorPhp::fake(true, 1, 3);
echo $fakeEditor->render();
use BumpCore\EditorPhp\EditorPhp;
$editor = EditorPhp::make($json);
// This will return ['time' => ..., 'blocks' => [...], 'version' => '...']
$array = $editor->toArray();
use BumpCore\EditorPhp\EditorPhp;
$editor = EditorPhp::make($json);
// This will return encoded JSON.
$json = $editor->toJson(JSON_PRETTY_PRINT);
use BumpCore\EditorPhp\EditorPhp;
$editor = EditorPhp::make($json);
$editor->time;
$editor->version;
use BumpCore\EditorPhp\EditorPhp;
// Registering new macro.
EditorPhp::macro(
'getParagraphs',
fn () => $this->blocks->filter(fn (Block $block) => $block instanceof Paragraph)
);
$editor = EditorPhp::make($json);
// This will return a collection that only contains paragraphs.
$paragraphs = $editor->getParagraphs();
use BumpCore\EditorPhp\EditorPhp;
// This will merge without erasing already registered blocks. Other blocks will still remain with the recently registered `image` and `paragraph` blocks.
EditorPhp::register([
'image' => \Blocks\MyCustomImageBlock::class,
'paragraph' => \Blocks\MyCustomParagraphBlock::class,
]);
// This will override already registered blocks. We now only have `image` and `paragraph` blocks.
EditorPhp::register([
'image' => \Blocks\MyCustomImageBlock::class,
'paragraph' => \Blocks\MyCustomParagraphBlock::class,
], true);
use BumpCore\EditorPhp\Blocks\Image;
class MyImageBlock extends Image
{
public static function uploadTemp(string $fileName = 'image'): array
{
// ...
// Temporary upload logic.
return [
'success' => ...,
'file' => [
'url' => ...,
],
];
}
public function upload(): void
{
$file = $this->get('file.url');
// Your logic.
// ...
// Altering the current block's data.
$this->set('file.url', ...);
}
}
// ...
// Registering customized block.
EditorPhp::register([
'image' => MyImageBlock::class
]);
use BumpCore\EditorPhp\EditorPhp;
use Blocks\MyImageBlock;
$editor = EditorPhp::make($json);
$editor->blocks->each(function(Block $block)
{
if ($block instanceof MyImageBlock)
{
$block->upload();
}
});
return $editor->toJson();
use BumpCore\EditorPhp\Block\Block;
class MyCustomBlock extends Block
{
public function render(): string
{
return view('blocks.my-custom-block', ['data' => $this->data]);
}
}
public function render(): string
{
// ...
// Method 1: Accessing through the data object.
$data = $this->data;
$data->get('custom.data');
$data->set('custom.data', 'Hello World!');
// Method 2: Accessing by invoking the data object.
$data('custom.data'); // Hello World!
// Method 3: Using shortcuts.
$this->get('custom.data');
$this->set('custom.data', 'Nice!');
// ...
}
$data->has('custom.data');
// or
$this->has('custom.data');
use BumpCore\EditorPhp\Block\Block;
class MyCustomBlock extends Block
{
// ...
public function rules(): array
{
return [
'text' => ';
}
// ...
}
use BumpCore\EditorPhp\Block\Block;
class MyCustomBlock extends Block
{
// ...
public function allow(): array|string
{
// Specifying one by one.
return [
'text' => [
'a:href,target,title', // Will allow `a` tag and href, target, and title attributes.
'b', // Will only allow `b` tag with no attributes.
],
'items.*.name' => 'b:*', // Will allow `b` tag with all attributes.
'items.*.html' => '*', // Will allow every tag and every attribute.
];
// Or just allowing all attributes and tags for all data.
return '*';
}
// ...
}
use BumpCore\EditorPhp\Block\Block;
class MyCustomBlock extends Block
{
// ...
public static function fake(\Faker\Generator $faker): array
{
$items = [];
foreach (range(0, $faker->numberBetween(0, 10)) as $index)
{
$items[] = [
'name' => fake()->name(),
'html' => $faker->randomHtml(),
];
}
return [
'text' => fake()->text(255),
'items' => $items,
];
}
// ...
}
use BumpCore\EditorPhp\Casts\EditorPhpCast;
use Illuminate\Database\Eloquent\Model;
class Post extends Model
{
protected $casts = [
'content' => EditorPhpCast::class,
];
}
// ...
$post = Post::find(1);
// Content is `EditorPhp` instance in here.
echo $post->content->render();
use BumpCore\EditorPhp\Block\Block;
use App\Models\Post;
class MyBlock extends Block
{
// ...
public static function render(): string
{
if($this->root->model instanceof Post)
{
// Do the other thing.
}
}
// ...
}
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use App\Models\Post;
class ShowPostController extends Controller
{
public function __invoke(Post $post)
{
// Depending on the request it will return json or rendered html.
return $post->content;
}
}