portedcheese/base-settings

启动项目的模板和设置

v5.0.2 2024-09-18 11:35 UTC

README

提供一组用于部署基本网站的类、视图和组件。

存在基本的命令,用于填充配置和模型。

安装

php artisan ui vue --auth
npm install && npm run dev
php artisan vendor:publish --provider="PortedCheese\BaseSettings\BaseSettingsServiceProvider" --tag=public --force
php artisan vendor:publish --provider="PortedCheese\BaseSettings\BaseSettingsServiceProvider" --tag=config
php artisan make:base-settings {--all : Run all}
                               {--views : Scaffold views}
                               {--force : Overwrite existing views by default}
                               {--models : Export models}
                               {--filters : Export filters}
                               {--controllers : Export controllers}
                               {--policies : Export and create rules}
                               {--only-default : Create default rules}
                               {--config : Make config}
                               {--scss : Export scss files}
                               {--vue : Export vue files}
                               {--js : Export js files}

在控制器 App\Http\Controllers\Controller 中添加构造函数

public function __construct()
{
    $this->routeName = Route::currentRouteName();
}

为图像处理配置应用程序

php artisan storage:link
FILESYSTEM_DISK=public 

中间件

  • role: 根据角色的存在提供访问权限
  • management: 访问网站的管理部分。
  • super: 允许管理员通过
  • editor: 允许编辑器通过

  • 具有管理员角色的用户可以访问所有内容
  • site-management: 允许访问管理后台。(App\Policies\BasePolicy@siteManagement)
  • settings-management: 对管理员开放。(App\Policies\BasePolicy@settingsManagement)

命令和功能

处理日期的功能

datehelper()
    {->forFilter(date, date to condition = false)}
    {->changeTz(date)}
    {->format(date, format = "d.m.Y H:i")

处理网站配置的功能

base-config()
    @method static get(string $name, $value = "", $default = null)
    @method static create(string $name, array $data, array $info, $force = false)
    @method static update(string $name, string $var, $value)

生成入口链接

php artisan generate:login-link {email} {--send=} {--get}

清除缓存密钥

php artisan cache:forget {key}

清除图像过滤器

php artisan cache:forget "image-filters:{template}-{filename}"
php artisan cache:forget "object-filters-original:{filename}"
php artisan cache:forget "object-filters-content:{template}-{filename}"

清除所有过滤器

php artisan image-filters:clear

组件

universal-priority

<universal-priority
    :elements="{{ json_encode([['name' => "name", "id" => "id"(, "url" => "url")], [..], [..]]) }}"
    url="{{ route("admin.vue.priority", ['table' => "table_name", "field" => "field_name"]) }}">
</universal-priority>

confirm-form

<confirm-form :id="'{{ "delete-form-{$model->id}" }}'">
    <template>
        <form action="{{ route('admin.model.destroy', ['model' => $model]) }}"
              id="delete-form-{{ $model->id }}"
              class="btn-group"
              method="post">
            @csrf
            @method("delete")
        </form>
    </template>
</confirm-form>
Параметры:
    - title: Вы уверены?
    - text: Это действие будет невозможно отменить!
    - confirm-text: Да, удалить!
    - cancel-text: Отмена

包含

@googleCaptcha2 - 用于表单的 Google ReCaptcha,google_captcha - 验证规则

@hiddenCaptcha - 隐藏式验证码,hidden_captcha - 验证

编辑画廊

@eGall(["id" => Auth::user()->id, "model" => "user", "noCover" => false])

输出 picture 标签

@pic([
    "image" => (object) ["file_name" => "example.jpg", "name" => "example"],
    "template" => "small",
    "grid" => [
        "example-grid" => 768,
    ],
    "imgClass" => "example-class",
])

使用 lightbox 输出图像

@img([
    "image" => (object) ["file_name" => "example.jpg", "name" => "example", "id" => "unique"], (id требуется если lightbox не указан)
    "template" => "small",
    "lightbox" => "lightGroupExample",
    "imgClass" => "example-class",
    "grid" => [
        "example-grid" => 768,
    ],
])

使用 lightbox 输出画廊

@images([
    "gallery" => [(object) ..., (object) ...],
    "lightbox" => "lightExampleGroup",
    "template" => "sm-grid-6",
    "grid" => [
        "lg-grid-3" => 992,
        "md-grid-6" => 768,
    ],
    "imgClass" => "img-fluid",
])

输出 Lazy picture 标签

@picLazy([
    "image" => (object) ["file_name" => "example.jpg", "name" => "example"],
    "template" => "small",
    "grid" => [
        "example-grid" => 768,
    ],
    "imgClass" => "example-class",
])

使用 lightbox 输出 Lazy 图像

@imgLazy([
    "image" => (object) ["file_name" => "example.jpg", "name" => "example", "id" => "unique"], (id требуется если lightbox не указан)
    "template" => "small",
    "lightbox" => "lightGroupExample",
    "imgClass" => "example-class",
    "grid" => [
        "example-grid" => 768,
    ],
])

使用 lightbox 输出 Lazy 画廊

@imagesLazy([
    "gallery" => [(object) ..., (object) ...],
    "lightbox" => "lightExampleGroup",
    "template" => "sm-grid-6",
    "grid" => [
        "lg-grid-3" => 992,
        "md-grid-6" => 768,
    ],
    "imgClass" => "img-fluid",
])