portedcheese / base-settings
Templates and settings for start project
Installs: 1 705
Dependents: 22
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- guzzlehttp/guzzle: ^7.0.1
- intervention/image: ^2.0
- laravel/framework: ^9.0|^10.0
- laravel/ui: ^4.0.0
- dev-master
- v5.0.4
- v5.0.3
- v5.0.2
- v5.0.1
- v5.0.0
- v4.2.4
- v4.2.3
- v4.2.2
- v4.2.1
- v4.2.0
- v4.1.6
- v4.1.5
- v4.1.4
- v4.1.3
- v4.1.2
- v4.1.1
- v4.1.0
- v4.0.4
- v4.0.3
- v4.0.2
- v4.0.1
- v4.0.0
- v3.1.4
- v3.1.3
- v3.1.2
- v3.1.1
- v3.1.0
- v3.0.6
- v3.0.5
- v3.0.4
- v3.0.3
- v3.0.2
- v3.0.1
- v3.0.0
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.0
- v1.7.15
- v1.7.14
- v1.7.13
- v1.7.12
- v1.7.11
- v1.7.10
- v1.7.9
- v1.7.8
- v1.7.7
- v1.7.6
- v1.7.5
- v1.7.4
- v1.7.3
- v1.7.2
- v1.7.1
- v1.7.0
- v1.6.4
- v1.6.3
- v1.6.2
- v1.6.1
- v1.6.0
- v1.5.2
- v1.5.1
- v1.5.0
- v1.4.29
- v1.4.28
- v1.4.27
- v1.4.26
- v1.4.25
- v1.4.24
- v1.4.23
- v1.4.22
- v1.4.21
- v1.4.20
- v1.4.19
- v1.4.18
- v1.4.17
- v1.4.16
- v1.4.15
- v1.4.14
- v1.4.13
- v1.4.12
- v1.4.11
- v1.4.10
- v1.4.9
- v1.4.8
- v1.4.7
- v1.4.6
- v1.4.5
- v1.4.4
- v1.4.3
- v1.4.2
- v1.4.1
- v1.4.0
- v1.3.10
- v1.3.9
- v1.3.8
- v1.3.7
- v1.3.6
- v1.3.5
- v1.3.4.6
- v1.3.4.5
- v1.3.4.4
- v1.3.4.3
- v1.3.4.2
- v1.3.4.1
- v1.3.4.0
- v1.3.3.12
- v1.3.3.11
- v1.3.3.10
- v1.3.3.9
- v1.3.3.8
- v1.3.3.7
- v1.3.3.6
- v1.3.3.5
- v1.3.3.4
- v1.3.3.3
- v1.3.3.2
- v1.3.3.1
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.13
- v1.2.12.5
- v1.2.12.4
- v1.2.12.3
- v1.2.12.2
- v1.2.12.1
- v1.2.12
- v1.2.11.5
- v1.2.11.4
- v1.2.11.3
- v1.2.11.2
- v1.2.11.1
- v1.2.11
- v1.2.10
- v1.2.9
- v1.2.8
- v1.2.7
- v1.2.6
- v1.2.5
- v1.2.4
- v1.2.3
- v1.2.2
- v1.2.1
- v1.2.0
- v1.1.9
- v1.1.8
- v1.1.7
- v1.1.6
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.13
- v1.0.12
- v1.0.11
- v1.0.10
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
This package is auto-updated.
Last update: 2025-01-11 14:11:10 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
Middleware
- role: доступ по наличию роли
- management: доступ в административную часть сайта.
- super: пропускает админа
- editor: пропускает редактора
Gates
- пользователи с ролью admin имею доступ ко всему
- 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
Components
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: Отмена
Includes
@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",
])
Вывод тега picture
Lazy:
@picLazy([
"image" => (object) ["file_name" => "example.jpg", "name" => "example"],
"template" => "small",
"grid" => [
"example-grid" => 768,
],
"imgClass" => "example-class",
])
Вывод изображения Lazy с lightbox
:
@imgLazy([
"image" => (object) ["file_name" => "example.jpg", "name" => "example", "id" => "unique"], (id требуется если lightbox не указан)
"template" => "small",
"lightbox" => "lightGroupExample",
"imgClass" => "example-class",
"grid" => [
"example-grid" => 768,
],
])
Вывод галереии Lazy с lightbox
:
@imagesLazy([
"gallery" => [(object) ..., (object) ...],
"lightbox" => "lightExampleGroup",
"template" => "sm-grid-6",
"grid" => [
"lg-grid-3" => 992,
"md-grid-6" => 768,
],
"imgClass" => "img-fluid",
])