* @created 2022-07-20 15:35:59 * @modified 2022-07-20 15:35:59 */ namespace Plugin\LatestProducts; class Bootstrap { /** * 去除注释后可以观察网站头部以及产品详情页页面变化 */ public function boot() { $this->addLatestProducts(); // $this->modifyHeader(); // $this->modifyProductDetail(); // $this->modifyAdminProductEdit(); } /** * 在前台网页头部添加二级菜单链接 */ private function addLatestProducts() { add_hook_filter('menu.content', function ($data) { $data[] = [ 'name' => trans('LatestProducts::header.latest_products'), "link" => shop_route('latest_products'), ]; return $data; }, 0); } /** * 修改前台全局 header 模板演示 */ private function modifyHeader() { add_hook_blade('header.top.currency', function ($callback, $output, $data) { return '货币前' . $output; }); add_hook_blade('header.top.language', function ($callback, $output, $data) { return $output . '语言后'; }); add_hook_blade('header.top.telephone', function ($callback, $output, $data) { return '电话前' . $output; }); add_hook_blade('header.menu.logo', function ($callback, $output, $data) { return $output . 'Logo后'; }); add_hook_blade('header.menu.icon', function ($callback, $output, $data) { $view = view('LatestProducts::shop.header_icon')->render(); return $output . $view; }); } /** * 修改产品详情页演示 * 1. 在产品名称上面添加 Hot 标签 * 2. 品牌下面添加信息 * 3. 立即购买后添加按钮 */ private function modifyProductDetail() { add_hook_blade('product.detail.name', function ($callback, $output, $data) { $badge = 'Hot'; return $badge . $output; }); add_hook_blade('product.detail.brand', function ($callback, $output, $data) { return $output . '
Brand 2:品牌 2
'; }); add_hook_blade('product.detail.buy.after', function ($callback, $output, $data) { $view = view('LatestProducts::shop.product_button')->render(); return $output . $view; }); } /** * 后台产品编辑页添加自定义字段演示 */ private function modifyAdminProductEdit() { add_hook_blade('admin.product.edit.extra', function ($callback, $output, $data) { $view = view('LatestProducts::admin.product.edit_extra_field', $data)->render(); return $output . $view; }, 1); } }