codecamp

Laravel Nova 卡片

概述

卡片类似于资源工具,但却是一种更小、更微型的工具,它们可以被放置在仪表盘中,用来显示或提示各类资源的简要信息或明细信息。事实上,如果你已经使用过 Nova metrics 的话,说明你已经尝试过卡片。同时,可以通过自定义卡片来创建属于你自己的资源工具。

定义卡片

卡片可以使用 Artisan 命令 nova:card 来创建。默认情况下,所有新创建的卡片都将被保持在你应用根目录下的 nova-components 文件夹中。当使用 Artisan 命令 nova:card 创建卡片时,所传递的卡片名称因遵从 Composer  vendor/package 格式。因此,如果我们要创建一个叫『流量分析』的卡片时,我们应该运行如下命令:

artisan nova:card acme/analytics

生成卡片时,Nova 讲提示你去安装卡片所需要的 npm 依赖包,编译资源,和更新项目的 composer.json 文件。所有的自定义卡片都会通过 Composer "path" 仓库注册到你的应用。

Nova 卡包括构建卡所需的所有脚手架。每张卡甚至都包含其自己 composer.json 文件,并可以在 GitHub 或您选择的源代码控制提供商上与世界共享。

注册卡片

Nova 卡片可以在你的 Resource 类中的 cards 方法中注册。此方法返回资源可用的卡片数组。将你的卡片添加到由这个方法返回的卡片数组中,对卡片进行注册:

use Acme\Analytics\Analytics;

/**
 * 获取可用的资源卡片.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return array
 */
public function cards(Request $request)
{
    return [new Analytics];
}

卡片选项

通常,您需要允许您卡片的消费者自定义卡上的运行时配置选项。您可以通过在您的 card 类中公开方法来实现这一点。这些方法可能会调用卡片的底层 withMeta 方法来添加信息到卡片的元数据中,这些元数据将应用在您的 Card.vue 的组件。withMeta 方法接受一个 键 / 值 选项数组:

<?php

namespace Acme\Analytics;

use Laravel\Nova\Card;

class Analytics extends Card
{
    /**
     * 卡片的宽度(1/3, 1/2, or full)。
     *
     * @var string
     */
    public $width = '1/3';

    /**
     * 指示分析应该显示当前的访问者。
     *
     * @return $this
     */
    public function currentVisitors()
    {
        return $this->withMeta(['currentVisitors' => true]);
    }

    /**
     * 获取卡片的组件名称。
     *
     * @return string
     */
    public function component()
    {
        return 'analytics';
    }
}

构建卡片

Nova 生成的每张卡片都包含自己的服务提供商和 “卡片” 类,以使用 analytics 卡片为例,卡片类位于 src/Analytics.php

卡片的服务提供者也位于卡片的 src 目录中,并在卡片的 composer.json 文件中注册,以便 Laravel 框架自动加载。

授权

如果您只想向特定用户公开指定的卡片,可以将 canSee 方法链到您指定的卡片上。canSee 方法接受一个闭包,该闭包应该返回 true 或 false。闭包将接收传入的 HTTP 请求:

use Acme\Analytics\Analytics;

/**
 * 获得可用的资源卡片.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return array
 */
public function cards(Request $request)
{
    return [
        (new Analytics)->canSee(function ($request) {
            return false;
        }),
    ];
}

路由

通常,您需要定义卡片调用的 Laravel 路由。当 Nova 生成您的卡片时,它会创建一个 routes/api.php 路由文件。如果需要,您可以使用此文件来定义您卡片所需的任何路由。

此文件中的所有路由都由您卡片的 CardServiceProvider 在路由组内自动定义。路由组指定组内所有路由都应接收 /nova-vendor/card-name 前缀,其中 card-name 是您卡片的「kebab-case」名称。例如,/nova-vendor/analytics。您可以自由的修改此路由组的定义, 但请务必确保您的 Nova 卡片与其他 Nova 包共存。

路由授权

当为您的卡片创建路由时,您应该 始终 使用 Laravel 的 gates 或 policies 为这些路由添加授权。

Assets

当 Nova 生成卡片时,会为您生成 resources/js 和 resources/sass 目录。这些目录包含您的卡片的 JavaScript 和 Sass 样式表。这些目录中最感兴趣的文件主要是:resources/js/components/Card.vue 和 resources/sass/card.scss

Card.vue 文件是一个包含卡片前端的单文件 Vue 组件。从这文件中,您可以随意构建你想要的卡片。您的卡片可以使用 Axios 发起 HTTP 请求,它是全局可用的。此外,moment.js 和 underscore.js 库也是全局可用。

卡片属性

您卡片的 Card.vue 组件接收一个 卡片 Vue prop。此属性提供对任何可用卡片 选项 的访问:

const issuesRefunds = this.card.issuesRefunds;

注册 Assets

Nova 卡片的服务提供注册您卡片编译的 assets,以便 Nova 前端可以使用它们:

/**
 * 引导任何应用程序服务。
 *
 * @return void
 */
public function boot()
{
    $this->app->booted(function () {
        $this->routes();
    });

    Nova::serving(function (ServingNova $event) {
        Nova::script('{{ component }}', __DIR__.'/../dist/js/card.js');
        Nova::style('{{ component }}', __DIR__.'/../dist/css/card.css');
    });
}

JavaScript 引导 & 路由

您组件在 resources/js/card.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; }