应用插件运行机制

创建于 2022-05-26 / 最近更新于 2022-05-26 / 934
字体: [默认] [大] [更大]

预设事件

学习应用目录结构一章后,我们接下来认识应用插件运行机制。

PESCMS系列软件的应用插件运行机制是基于事件绑定进行调用 。因此,您想通过插件实现某个功能,需要先查阅软件的文档,确认有提供符合您想法的的事件绑定。

(简单的运行流程图)

以PESCMS Ticket为例,我们调用了通用的事件绑定:

例如,我要在PESCMS Ticket后台某个列表的工具栏添加一个新按钮来触发我的邮件模板修改插件,那么我就调用toolEvent事件绑定。如下图所示:

图片

自定义事件

除了预设事件,某些情况下我们需要自定义事件实现更加丰富的功能。相比起预设事件,自定义事件更具可扩性,但是调用不灵活,需要使用者手动编辑指定程序文件,进行埋点操作。下来以一个PESCMS Ticket例子来说明:

假定现在自定义一个名为 testEvent 事件绑定,在前台登录页中显示一个按钮(plugin.ini中,GROUP声明了Form的支持) 。首先我们需要在插件注册此事件。

/**
 * 启用插件
 * @return mixed|void
 */
public function enabled() {
 
    $config = $this->loadConfig($this);
    $config['plugin']['status'] = 'enabled';
 
    (new \Core\Plugin\Plugin())->updateConfig($this, $config)->register("\\Plugin\\MailTemplate\\Form\\Index", [
        'testEvent' => [
            'index' => 'Form-Login-index',
        ],
    ]);
    $this->success('插件启用成功');
}

完成注册事件后,我们用编辑器打开登录页的模板:Public\Theme\Form\Default\Login\Login_index.php。在指定位置填写如下代码进行事件埋点。

<div class="am-cf login-options am-text-sm">
    <div class="am-fl">
        还没<?= $system['siteTitle'] ?>账号?<a href="<?= $label->url('Login-signup') ?>" class="login-signup-link" >立即注册!</a>
    </div>
    <div class="am-fr">
        <a href="<?= $label->url('Login-findpw') ?>">忘记密码?</a>
    </div>
</div>
 
<input type="hidden" name="back_url" value="<?= $_GET['back_url'] ?>">
 
<button type="submit" class="am-btn am-btn-primary am-radius am-btn-sm am-margin-top-sm am-btn-block">登录</button>
 
<?= (new \Core\Plugin\Plugin())->event('testEvent', NULL); //自定义事件埋点 ?>

图片

部署完毕后,到 本地应用 中,启用本插件,观看效果。如下图所示:

图片

1 人点赞过