2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

baserCMSAdvent Calendar 2023

Day 25

baserCMS BurgerEditorプラグインのオリジナルブロックを再帰的に利用する方法

Posted at

BurgerEditorとは

BurgerEditorとは、baserCMSのコンテンツ編集エリアを積み上げ式のブロック編集型に変更できるプラグインです。
デフォルトでレスポンシブデザインにも対応しているため、グリッドデザインのページなどが管理画面から簡単に生成できるエディターです。
image.png

こちらのBurgerEditorの有償版は、オリジナルブロックを追加する機能がついており、
サイトに合った専用ブロックや、何度も使うような特定リンクボタンなどをオリジナルブロックにして編集エリアに呼び出すことが可能になります。

ただ、app/Plugin/BurgerEditor/ フォルダ配下に直接オリジナルブロックを追加してしまうと、BurgerEditor本体のセキュリティアップデートを行ったときに、誤って消してしまったりするおそれがあります。
また、他のサイトで同じブロックを使いたいときにも、該当ファイルを選んでコピーする必要があり、結構面倒です。

実はあまり知られていないのですが、
2020年夏頃から、外部プラグインから Addon の参照先を追加できるような機能が追加されました。
こちらの機能を使うことで、BurgerEditorとオリジナルブロックを切り離すことができるようになり、BurgerEditor本体のアップデートなどを行った際にまるごと入れ替えてアップデートしたり、オリジナルブロックを他のサイトのBurgerEditorで使用することがより簡単になりました。
(一部 Config.setting(_customize).phpの記述だけは必要になります)

README.md には

外部プラグインでブロックやタイプを追加する

外部プラグインを作成し、直下に BurgerAddon をいう名称でフォルダを作ると、BurgerEditor のアドオン用のディレクトリとして認識させることができます。
追加したブロックを、 /BurgerAddon/block/category.php に定義するとエディタで読み込むことができます。

といった記述が追加されておりますが、ちょっとわかりにくいかもしれないので、実際にやってみました。

1,案件専用プラグインなどを作成

app/Plugin/ 配下にBurgerEditorオリジナルブロック用のプラグインを作成します。
今回の場合、わかりやすいようにBurgerAddon という名前の新規プラグインを作成しています。
image.png

※後でなんのプラグインか分からなくならないようにconfig.phpに機能の説明も書いておくと良いかと思います。
image.png

config.php
<?php
/**
 * [BurgerAddon] config
 *
 */
$title = 'BurgerEditor案件専用オリジナルブロック';
$description = 'BurgerEditor案件専用オリジナルブロックを管理するプラグインです。';
$author = '';
$url = '';

2,下記の様にディレクトリを作成

/app/Plugin/BurgerAddon/BurgerAddon/block/
/app/Plugin/BurgerAddon/BurgerAddon/type/ (オリジナルtypeを使わない場合不要)

image.png

3,category.phpの作成

記述内容

/app/Plugin/BurgerAddon/BurgerAddon/block/category.php
<?php 
$bgCategory = array(
	'オリジナルカテゴリー' => array(
		'{追加したいブロックのname}' => '{追加したいブロックの表示名}',
	),
);

4,オリジナルブロックの追加

/app/Plugin/BurgerAddon/BurgerAddon/block/{追加したいブロックのname}/

の中に

panel.svg
index.php
style.css

を配置

5,setting_customize.phpのenableAddonPluginの設定

/app/Plugin/BurgerEditor/Config/setting_customize.php

の下の方の

'enableAddonPlugin' => array()

'enableAddonPlugin' => array('BurgerAddon')

に修正

注意
このファイルだけは、アップデートしたりするときに再設定が必要になることがあります。

6,管理画面よりプラグインを有効化

image.png

以上で完成となります。

完成形

block.jpg

因みに、追加されたカテゴリーやブロックは、一番最後(下)に追加されます。

2
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?