承接 hammerstone/refine-nova 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

hammerstone/refine-nova

最新稳定版本:v0.2.4

Composer 安装命令:

composer require hammerstone/refine-nova

包简介

A Laravel Nova integration for the Refine query builder.

README 文档

README

Refine is a powerful, visual query builder for Laravel Nova 3 and 4. Refine is a paid package, which you can purchase at hammerstone.dev.

We also have libraries for Laravel (without Nova) and Ruby on Rails at hammerstone.dev.

Refine lets you define filterable conditions per resource, and then your users can mix and match them in any way they want to find exactly what they're looking for.

// Create a filter called "UserFilter"
class UserFilter extends Filter
{
    public function conditions()
    {
        return [
            // Number condition on the ID column
            NumericCondition::make('id', 'ID'),
            
            // Text condition on the name column
            TextCondition::make('name', 'Name'),
            
            // Boolean condition on the is_subscriber column
            BooleanCondition::make('is_subscriber', 'Subscriber'),
            
            // Option condition on the referral column
            OptionCondition::make('referral', 'Referral Source')
                ->options([
                    'twitter' => 'Twitter',
                    'linkedin' => 'LinkedIn',
                    'fb' => 'Facebook'
                ]),
                
            // Date condition on the created_at column
            DateWithTimeCondition::make('created_at', 'Created At'),
        ];
    }
}

Refine Nova 4 Refine for Laravel Nova 4

Refine Nova 3 Refine for Laravel Nova 3

Installation

To use Refine with Nova, you must first require the package composer require hammerstone/refine-nova. This will install hammerstone/refine-laravel as well. Since refine-laravel is a paid package, you will need to make sure your credentials are available to composer in the auth.json file.

Integration

Create a UserFilter class in your app\Filters directory.

namespace App\Filters;

use Hammerstone\Refine\Conditions\NumericCondition;
use Hammerstone\Refine\Filter;

class UserFilter extends Filter
{
    public function conditions()
    {
        return [
            NumericCondition::make('id', 'ID'),
            
            // @TODO: Add more conditions
        ];
    }
}

In your app\Nova\User file, you'll need to add the RefinesModels trait and reference your newly created filter.

use App\Filters\UserFilter;
use Hammerstone\Refine\Nova\RefinesModels;

class User extends Resource
{
    use RefinesModels;
    
    // ...
    
    public static $filter = UserFilter::class;
}

Finally, to show the query builder on the frontend, you'll need to add the Refine card:

public function cards(Request $request)
{
    return [
        static::refineCard()
    ];
}

That's it! You should see the Refine query builder on the Users page in Nova. You can read further documentation about building filters in the Refine documentation.

统计信息

  • 总下载量: 56.47k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 33
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 33
  • Watchers: 3
  • Forks: 4
  • 开发语言: Vue

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-01-30