codecamp

Laravel Nova 工具

概览

当你想用 Nova 还没有提供的功能时,你可以向 Nova 的侧边栏添加自定义工具。Nova 工具的定制性极强,因为他们主要都是由 Vue 的单文件组件构成。在 Vue 组件里,你可以向应用中任意的控制器发送 HTTP 请求。

定义工具

自定义工具可以通过 nova:tool 命令生成。所有生成的工具都默认放在应用的 nova-components 目录中。当使用 nova:tool 命令生成工具时,工具的名称必须遵循 Composer 的 vendor/package 格式。比如我们要生成一个价格跟踪工具,我们可以执行如下命令:

artisan nova:tool acme/price-tracker

当生成工具时,Nova 会提示你安装工具的 NPM 依赖,编译资源,并且更新应用的 composer.json 文件。所有自定义的工具都会作为 Composer 的「path」注册到你的应用中。

Nova 生成工具时已经包含了所有必要的东西。每个工具都有自己的 composer.json 文件,他们随时可以在 Github 或其他源码管理网站上分享。

注册工具

Nova 工具要在应用的 NovaServiceProvider 中注册。服务提供者里包含一个 tools 方法,该方法返回一个工具数组。只要把你的工具添加到工具列表中即可完成注册。假如你创建了一个名为 acme/price-tracker 的 Nova 工具,你可以像下面这样来注册:

use Acme\PriceTracker\PriceTracker;

/**
 * 获取展示在 Nova 侧边栏中的卡片。
 *
 * @return array
 */
public function tools()
{
    return [
        new PriceTracker,
    ];
}

构建工具

每个 Nova 生成的工具都包含有各自的服务提供者和「tool」类。以 price-tracker 工具为例,该工具的类文件位于 src/PriceTracker.php 。像上文提到的那样,该工具类必须在 NovaServiceProvider 中注册。

工具的服务提供者位于工具的 src 目录,并且已经注册进了工具的 composer.json 文件中,因此 Laravel 框架会自动加载该工具类。

授权

如果你只想把工具暴露给特定的用户,你可以在工具注册时链式调用 canSee 方法。canSee 方法接收一个返回值为 true 或 false 的闭包函数。该闭包函数的参数为 HTTP 请求:

use Acme\PriceTracker\PriceTracker;

/**
 * 获取展示在 Nova 侧边栏里的卡片。
 *
 * @return array
 */
public function tools()
{
    return [
        (new PriceTracker)->canSee(function ($request) {
            return false;
        }),
    ];
}

路由

通常,你需要定义工具调用的 Laravel 路由。Nova 生成工具时会创建一个 routes/api.php 的路由文件。你可以使用它定义任何工具所需要的路由。

它所有路由都是通过工具的 ToolServiceProvider 自动定义在路由组里面。路由组指定所有组内路由接收一个 /nova-vendor/tool-name 前缀,tool-name 是工具 "kebab-case" 的名字 。举例: /nova-vendor/price-tracker 。你可以自由定义这个路由组,但是请注意要确保你的 Nova 工具和其他 Nova 包兼容。

路由授权

你的 Nova 工具会生成一个 Authorize 中间件。它在执行任意的请求到达路由组之前,就自动判断授权用户是否可见此工具。另外,你可以按需自由修改这个中间件。

导航

Nova 工具类包含一个 renderNavigation 方法。该方法返回一个渲染工具侧边栏链接的视图。当然,工具生成时就已经创建好了一个默认的导航。如果需要的话你可以自定义该视图:

/**
 * 构建工具的导航链接视图。
 *
 * @return \Illuminate\View\View
 */
public function renderNavigation()
{
    return view('price-tracker::navigation');
}

资源

Nova 生成工具时,resources/js 和 resources/sass 目录也一并创建了。这些目录包含了工具的 JavaScript 脚本和 Sass 样式,其中的主要文件是:resources/js/components/Tool.vue 和 resources/sass/tool.scss

Tool.vue 是一个 Vue 单文件组件,你可以在里面做任意修改。在工具里你可以通过全局的 Axios 发送 HTTP 请求。此外,moment.js 和 underscore.js 库也是全局可访问的。

注册资源

Nova 工具类包含了一个 boot 方法,当工具存在或者注册后,这个方法会被执行。默认情况下,该方法会把你的工具已编译的资源都注册上,因此在 Nova 的前端就可以使用了。

/**
 *  工具注册时需要执行的任务
 * 
 * @return void
 */
public function boot()
{
    Nova::script('price-tracker', __DIR__.'/../dist/js/tool.js');
    Nova::style('price-tracker', __DIR__.'/../dist/css/tool.css');
}

JavaScript Bootstrap & 路由

你的组件会被引导启动并且前端路由注册在 resources/js/tool.js 文件中。你可以按需求自由地修改这个文件或者注册额外的组件。

编译资源

Nova 在创建工具时也创建了一个 webpack.mix.js 文件。你可以使用 NPM dev 和 prod 命令构建工具:

// 为本地开发环境编译资源...
npm run dev

// 编译并压缩资源...
npm run prod

此外,你可以执行 NPM watch 命令来实现资源文件修改后的自动编译:

npm run watch


Laravel Nova 本地化
Laravel Nova 资源工具
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }