Файловый менеджер - Редактировать - /home/c7lekhnath/silverray.com.au/Modules/Language/database/seeders/68334/Tax.tar
Назад
lang/.gitkeep 0000644 00000000000 15012230607 0007100 0 ustar 00 module.json 0000644 00000000316 15012230607 0006720 0 ustar 00 { "name": "Tax", "alias": "tax", "description": "", "keywords": [], "priority": 0, "providers": [ "Modules\\Tax\\app\\Providers\\TaxServiceProvider" ], "files": [] } tests/Unit/.gitkeep 0000644 00000000000 15012230607 0010240 0 ustar 00 tests/Feature/.gitkeep 0000644 00000000000 15012230607 0010714 0 ustar 00 vite.config.js 0000644 00000001274 15012230607 0007315 0 ustar 00 import { defineConfig } from 'vite'; import laravel from 'laravel-vite-plugin'; export default defineConfig({ build: { outDir: '../../public/build-tax', emptyOutDir: true, manifest: true, }, plugins: [ laravel({ publicDirectory: '../../public', buildDirectory: 'build-tax', input: [ __dirname + '/resources/assets/sass/app.scss', __dirname + '/resources/assets/js/app.js' ], refresh: true, }), ], }); //export const paths = [ // 'Modules/$STUDLY_NAME$/resources/assets/sass/app.scss', // 'Modules/$STUDLY_NAME$/resources/assets/js/app.js', //]; routes/.gitkeep 0000644 00000000000 15012230607 0007500 0 ustar 00 routes/error_log 0000644 00000001060 15012230607 0007773 0 ustar 00 [12-May-2025 09:40:07 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Support\Facades\Route" not found in /home/lekhnath/silverray.com.au/Modules/Tax/routes/api.php:5 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/routes/api.php on line 5 [12-May-2025 10:44:50 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Support\Facades\Route" not found in /home/lekhnath/silverray.com.au/Modules/Tax/routes/web.php:6 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/routes/web.php on line 6 routes/web.php 0000644 00000000612 15012230607 0007346 0 ustar 00 <?php use Illuminate\Support\Facades\Route; use Modules\Tax\app\Http\Controllers\TaxController; Route::middleware(['auth:admin', 'translation'])->name('admin.')->prefix('admin')->group(function () { Route::resource('tax', TaxController::class)->names('tax')->except('show'); Route::put('/tax/status-update/{id}', [TaxController::class, 'statusUpdate'])->name('tax.status-update'); }); routes/api.php 0000644 00000000206 15012230607 0007341 0 ustar 00 <?php use Illuminate\Support\Facades\Route; Route::middleware(['auth:sanctum'])->prefix('v1')->name('api.')->group(function () {}); composer.json 0000644 00000001245 15012230607 0007264 0 ustar 00 { "name": "nwidart/tax", "description": "", "authors": [ { "name": "Nicolas Widart", "email": "n.widart@gmail.com" } ], "extra": { "laravel": { "providers": [], "aliases": { } } }, "autoload": { "psr-4": { "Modules\\Tax\\": "", "Modules\\Tax\\App\\": "app/", "Modules\\Tax\\Database\\Factories\\": "database/factories/", "Modules\\Tax\\Database\\Seeders\\": "database/seeders/" } }, "autoload-dev": { "psr-4": { "Modules\\Tax\\Tests\\": "tests/" } } } config/config.php 0000644 00000000050 15012230607 0007756 0 ustar 00 <?php return [ 'name' => 'Tax', ]; config/.gitkeep 0000644 00000000000 15012230607 0007424 0 ustar 00 package.json 0000644 00000000410 15012230607 0007021 0 ustar 00 { "private": true, "type": "module", "scripts": { "dev": "vite", "build": "vite build" }, "devDependencies": { "axios": "^1.1.2", "laravel-vite-plugin": "^0.7.5", "sass": "^1.69.5", "postcss": "^8.3.7", "vite": "^4.0.0" } } app/Http/Controllers/TaxController.php 0000644 00000006305 15012230607 0014062 0 ustar 00 <?php namespace Modules\Tax\app\Http\Controllers; use App\Enums\RedirectType; use Modules\Tax\app\Models\Tax; use App\Traits\RedirectHelperTrait; use App\Http\Controllers\Controller; use Illuminate\Pagination\Paginator; use Illuminate\Http\RedirectResponse; use Modules\Language\app\Models\Language; use Modules\Tax\app\Http\Requests\TaxRequest; use Modules\Language\app\Enums\TranslationModels; use Modules\Language\app\Traits\GenerateTranslationTrait; class TaxController extends Controller { use GenerateTranslationTrait, RedirectHelperTrait; public function index() { checkAdminHasPermissionAndThrowException('tax.view'); Paginator::useBootstrap(); $taxes = Tax::paginate(15); return view('tax::index', ['taxes' => $taxes]); } public function create() { checkAdminHasPermissionAndThrowException('tax.create'); return view('tax::create'); } public function store(TaxRequest $request): RedirectResponse { checkAdminHasPermissionAndThrowException('tax.store'); $tax = Tax::create($request->validated()); $languages = Language::all(); $this->generateTranslations( TranslationModels::Tax, $tax, 'tax_id', $request, ); return $this->redirectWithMessage(RedirectType::CREATE->value, 'admin.tax.edit', ['tax' => $tax->id, 'code' => $languages->first()->code]); } /** * Show the form for editing the specified resource. */ public function edit($id) { checkAdminHasPermissionAndThrowException('tax.edit'); $code = request('code') ?? getSessionLanguage(); if (! Language::where('code', $code)->exists()) { abort(404); } $tax = Tax::findOrFail($id); $languages = allLanguages(); return view('tax::edit', compact('tax', 'code', 'languages')); } public function update(TaxRequest $request, Tax $tax) { checkAdminHasPermissionAndThrowException('tax.update'); $validatedData = $request->validated(); $tax->update($validatedData); $this->updateTranslations( $tax, $request, $validatedData, ); return $this->redirectWithMessage(RedirectType::UPDATE->value, 'admin.tax.edit', ['tax' => $tax->id, 'code' => $request->code]); } /** * Remove the specified resource from storage. */ public function destroy(Tax $tax) { checkAdminHasPermissionAndThrowException('tax.delete'); $tax->translations()->each(function ($translation) { $translation->tax()->dissociate(); $translation->delete(); }); $tax->delete(); return $this->redirectWithMessage(RedirectType::DELETE->value, 'admin.tax.index'); } public function statusUpdate($id) { checkAdminHasPermissionAndThrowException('tax.update'); $tax = Tax::find($id); $status = $tax->status == 1 ? 0 : 1; $tax->update(['status' => $status]); $notification = __('Updated Successfully'); return response()->json([ 'success' => true, 'message' => $notification, ]); } } app/Http/Controllers/.gitkeep 0000644 00000000000 15012230607 0012164 0 ustar 00 app/Http/Controllers/error_log 0000644 00000000511 15012230607 0012457 0 ustar 00 [13-May-2025 07:34:10 UTC] PHP Fatal error: Uncaught Error: Class "App\Http\Controllers\Controller" not found in /home/lekhnath/silverray.com.au/Modules/Tax/app/Http/Controllers/TaxController.php:16 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/app/Http/Controllers/TaxController.php on line 16 app/Http/Requests/.gitkeep 0000644 00000000000 15012230607 0011471 0 ustar 00 app/Http/Requests/TaxRequest.php 0000644 00000002366 15012230607 0012677 0 ustar 00 <?php namespace Modules\Tax\app\Http\Requests; use Illuminate\Support\Facades\Auth; use Illuminate\Foundation\Http\FormRequest; class TaxRequest extends FormRequest { /** * Get the validation rules that apply to the request. */ public function authorize(): bool { return Auth::guard('admin')->check() ? true : false; } public function rules(): array { $rules = [ 'title' => 'required|string|max:255', 'percentage' => 'required|numeric', ]; if ($this->isMethod('put')) { $rules['code'] = 'required|string'; $rules['slug'] = 'sometimes|string|max:255'; } if ($this->isMethod('post')) { $rules['slug'] = 'required|string|max:255'; } return $rules; } public function messages(): array { return [ 'title.required' => __('Title must be unique.'), 'title.max' => __('Title must be string with a maximum length of 255 characters.'), 'slug.required' => __('Slug is required.'), 'slug.max' => __('Slug must be string with a maximum length of 255 characters.'), 'percentage.required' => __('Percentage is required'), ]; } } app/Http/Middleware/.gitkeep 0000644 00000000000 15012230607 0011733 0 ustar 00 app/Models/Tax.php 0000644 00000001636 15012230607 0010016 0 ustar 00 <?php namespace Modules\Tax\app\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\HasOne; use Illuminate\Database\Eloquent\Relations\HasMany; use Illuminate\Database\Eloquent\Factories\HasFactory; class Tax extends Model { use HasFactory; protected $fillable = ['slug','percentage', 'status']; // make a accessor for translation public function getTitleAttribute(): ?string { return $this->translation->title; } public function translation(): ?HasOne { return $this->hasOne(TaxTranslation::class)->where('lang_code', getSessionLanguage()); } public function getTranslation($code): ?TaxTranslation { return $this->hasOne(TaxTranslation::class)->where('lang_code', $code)->first(); } public function translations(): ?HasMany { return $this->hasMany(TaxTranslation::class, 'tax_id'); } } app/Models/.gitkeep 0000644 00000000000 15012230607 0010162 0 ustar 00 app/Models/error_log 0000644 00000001134 15012230607 0010457 0 ustar 00 [08-May-2025 10:52:45 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Database\Eloquent\Model" not found in /home/lekhnath/silverray.com.au/Modules/Tax/app/Models/TaxTranslation.php:9 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/app/Models/TaxTranslation.php on line 9 [08-May-2025 15:05:58 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Database\Eloquent\Model" not found in /home/lekhnath/silverray.com.au/Modules/Tax/app/Models/Tax.php:10 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/app/Models/Tax.php on line 10 app/Models/TaxTranslation.php 0000644 00000001001 15012230607 0012217 0 ustar 00 <?php namespace Modules\Tax\app\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\BelongsTo; use Illuminate\Database\Eloquent\Factories\HasFactory; class TaxTranslation extends Model { use HasFactory; /** * The attributes that are mass assignable. */ protected $fillable = [ 'blog_id', 'lang_code', 'title', ]; public function tax(): ?BelongsTo { return $this->belongsTo(Tax::class, 'tax_id'); } } app/Providers/RouteServiceProvider.php 0000644 00000002643 15012230607 0014145 0 ustar 00 <?php namespace Modules\Tax\app\Providers; use Illuminate\Support\Facades\Route; use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; class RouteServiceProvider extends ServiceProvider { /** * The module namespace to assume when generating URLs to actions. */ protected string $moduleNamespace = 'Modules\Tax\app\Http\Controllers'; /** * Called before routes are registered. * * Register any model bindings or pattern based filters. */ public function boot(): void { parent::boot(); } /** * Define the routes for the application. */ public function map(): void { $this->mapApiRoutes(); $this->mapWebRoutes(); } /** * Define the "web" routes for the application. * * These routes all receive session state, CSRF protection, etc. */ protected function mapWebRoutes(): void { Route::middleware('web') ->namespace($this->moduleNamespace) ->group(module_path('Tax', '/routes/web.php')); } /** * Define the "api" routes for the application. * * These routes are typically stateless. */ protected function mapApiRoutes(): void { Route::prefix('api') ->middleware('api') ->namespace($this->moduleNamespace) ->group(module_path('Tax', '/routes/api.php')); } } app/Providers/TaxServiceProvider.php 0000644 00000006422 15012230607 0013602 0 ustar 00 <?php namespace Modules\Tax\app\Providers; use Illuminate\Support\Facades\Blade; use Illuminate\Support\ServiceProvider; class TaxServiceProvider extends ServiceProvider { protected string $moduleName = 'Tax'; protected string $moduleNameLower = 'tax'; /** * Boot the application events. */ public function boot(): void { $this->registerCommands(); $this->registerCommandSchedules(); $this->registerTranslations(); $this->registerConfig(); $this->registerViews(); $this->loadMigrationsFrom(module_path($this->moduleName, 'database/migrations')); } /** * Register the service provider. */ public function register(): void { $this->app->register(RouteServiceProvider::class); } /** * Register commands in the format of Command::class */ protected function registerCommands(): void { // $this->commands([]); } /** * Register command Schedules. */ protected function registerCommandSchedules(): void { // $this->app->booted(function () { // $schedule = $this->app->make(Schedule::class); // $schedule->command('inspire')->hourly(); // }); } /** * Register translations. */ public function registerTranslations(): void { $langPath = resource_path('lang/modules/'.$this->moduleNameLower); if (is_dir($langPath)) { $this->loadTranslationsFrom($langPath, $this->moduleNameLower); $this->loadJsonTranslationsFrom($langPath); } else { $this->loadTranslationsFrom(module_path($this->moduleName, 'lang'), $this->moduleNameLower); $this->loadJsonTranslationsFrom(module_path($this->moduleName, 'lang')); } } /** * Register config. */ protected function registerConfig(): void { $this->publishes([module_path($this->moduleName, 'config/config.php') => config_path($this->moduleNameLower.'.php')], 'config'); $this->mergeConfigFrom(module_path($this->moduleName, 'config/config.php'), $this->moduleNameLower); } /** * Register views. */ public function registerViews(): void { $viewPath = resource_path('views/modules/'.$this->moduleNameLower); $sourcePath = module_path($this->moduleName, 'resources/views'); $this->publishes([$sourcePath => $viewPath], ['views', $this->moduleNameLower.'-module-views']); $this->loadViewsFrom(array_merge($this->getPublishableViewPaths(), [$sourcePath]), $this->moduleNameLower); $componentNamespace = str_replace('/', '\\', config('modules.namespace').'\\'.$this->moduleName.'\\'.config('modules.paths.generator.component-class.path')); Blade::componentNamespace($componentNamespace, $this->moduleNameLower); } /** * Get the services provided by the provider. */ public function provides(): array { return []; } private function getPublishableViewPaths(): array { $paths = []; foreach (config('view.paths') as $path) { if (is_dir($path.'/modules/'.$this->moduleNameLower)) { $paths[] = $path.'/modules/'.$this->moduleNameLower; } } return $paths; } } app/Providers/.gitkeep 0000644 00000000000 15012230607 0010714 0 ustar 00 app/Providers/error_log 0000644 00000001262 15012230607 0011213 0 ustar 00 [14-May-2025 17:19:47 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Foundation\Support\Providers\RouteServiceProvider" not found in /home/c7lekhnath/silverray.com.au/Modules/Tax/app/Providers/RouteServiceProvider.php:8 Stack trace: #0 {main} thrown in /home/c7lekhnath/silverray.com.au/Modules/Tax/app/Providers/RouteServiceProvider.php on line 8 [14-May-2025 18:13:42 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Support\ServiceProvider" not found in /home/c7lekhnath/silverray.com.au/Modules/Tax/app/Providers/TaxServiceProvider.php:8 Stack trace: #0 {main} thrown in /home/c7lekhnath/silverray.com.au/Modules/Tax/app/Providers/TaxServiceProvider.php on line 8 database/factories/.gitkeep 0000644 00000000000 15012230607 0011702 0 ustar 00 database/migrations/2024_07_10_122445_create_tax_translations_table.php 0000644 00000001327 15012230607 0021361 0 ustar 00 <?php use Modules\Tax\app\Models\Tax; use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; return new class extends Migration { /** * Run the migrations. */ public function up(): void { Schema::create('tax_translations', function (Blueprint $table) { $table->id(); $table->foreignIdFor(Tax::class)->constrained('taxes'); $table->string('lang_code'); $table->string('title'); $table->timestamps(); }); } /** * Reverse the migrations. */ public function down(): void { Schema::dropIfExists('tax_translations'); } }; database/migrations/.gitkeep 0000644 00000000000 15012230607 0012077 0 ustar 00 database/migrations/error_log 0000644 00000001422 15012230607 0012374 0 ustar 00 [14-May-2025 11:29:56 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Database\Migrations\Migration" not found in /home/lekhnath/silverray.com.au/Modules/Tax/database/migrations/2024_07_10_122445_create_tax_translations_table.php:8 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/database/migrations/2024_07_10_122445_create_tax_translations_table.php on line 8 [14-May-2025 15:50:24 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Database\Migrations\Migration" not found in /home/c7lekhnath/silverray.com.au/Modules/Tax/database/migrations/2024_07_10_122236_create_taxes_table.php:7 Stack trace: #0 {main} thrown in /home/c7lekhnath/silverray.com.au/Modules/Tax/database/migrations/2024_07_10_122236_create_taxes_table.php on line 7 database/migrations/2024_07_10_122236_create_taxes_table.php 0000644 00000001232 15012230607 0017101 0 ustar 00 <?php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; return new class extends Migration { /** * Run the migrations. */ public function up(): void { Schema::create('taxes', function (Blueprint $table) { $table->id(); $table->string('slug'); $table->decimal('percentage', 8, 2); $table->boolean('status')->default(true); $table->timestamps(); }); } /** * Reverse the migrations. */ public function down(): void { Schema::dropIfExists('taxes'); } }; database/seeders/.gitkeep 0000644 00000000000 15012230607 0011355 0 ustar 00 database/seeders/error_log 0000644 00000000502 15012230607 0011650 0 ustar 00 [13-May-2025 17:46:16 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Database\Seeder" not found in /home/lekhnath/silverray.com.au/Modules/Tax/database/seeders/TaxDatabaseSeeder.php:7 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Tax/database/seeders/TaxDatabaseSeeder.php on line 7 database/seeders/TaxDatabaseSeeder.php 0000644 00000000363 15012230607 0013762 0 ustar 00 <?php namespace Modules\Tax\database\seeders; use Illuminate\Database\Seeder; class TaxDatabaseSeeder extends Seeder { /** * Run the database seeds. */ public function run(): void { // $this->call([]); } } resources/assets/.gitkeep 0000644 00000000000 15012230607 0011473 0 ustar 00 resources/assets/js/app.js 0000644 00000000000 15012230607 0011574 0 ustar 00 resources/assets/sass/app.scss 0000644 00000000000 15012230607 0012470 0 ustar 00 resources/views/sidebar.blade.php 0000644 00000000443 15012230607 0013100 0 ustar 00 @if (Module::isEnabled('Tax') && Route::has('admin.tax.index')) <li class="{{ isRoute('admin.tax.*', 'active') }}"> <a class="nav-link" href="{{ route('admin.tax.index') }}"> <i class="fas fa-percentage"></i> <span>{{ __('Tax') }}</span> </a> </li> @endif resources/views/edit.blade.php 0000644 00000026171 15012230607 0012422 0 ustar 00 @extends('admin.master_layout') @section('title') <title>{{ __('Tax List') }}</title> @endsection @section('admin-content') <div class="main-content"> <section class="section"> {{-- Breadcrumb --}} <x-admin.breadcrumb title="{{ __('Edit Tax') }}" :list="[ __('Dashboard') => route('admin.dashboard'), __('Tax List') => route('admin.tax.index'), __('Edit Tax') => '#', ]" /> <div class="section-body row"> <div class="col-12"> <div class="card"> <div class="card-header gap-3 justify-content-between align-items-center"> <h5 class="m-0 service_card">{{ __('Available Translations') }}</h5> @adminCan('tax.translate') @if ($code !== $languages->first()->code) <x-admin.button id="translate-btn" :text="__('Translate')" /> @endif @endadminCan </div> <div class="card-body"> <div class="lang_list_top"> <ul class="lang_list"> @foreach ($languages as $language) <li><a id="{{ request('code') == $language->code ? 'selected-language' : '' }}" href="{{ route('admin.tax.edit', ['tax' => $tax->id, 'code' => $language->code]) }}"><i class="fas {{ request('code') == $language->code ? 'fa-eye' : 'fa-edit' }}"></i> {{ $language->name }}</a></li> @endforeach </ul> </div> <div class="mt-2 alert alert-danger" role="alert"> @php $current_language = $languages->where('code', request()->get('code'))->first(); @endphp <p>{{ __('Your editing mode') }} : <b>{{ $current_language?->name }}</b> </p> </div> </div> </div> </div> </div> <div class="section-body"> <div class="mt-4 row"> <div class="col-12"> <div class="card"> <div class="card-header d-flex justify-content-between"> <x-admin.form-title :text="__('Edit Tax')" /> <div> <x-admin.back-button :href="route('admin.tax.index')" /> </div> </div> <div class="card-body"> <form action="{{ route('admin.tax.update', ['tax' => $tax->id, 'code' => $code]) }}" method="post"> @csrf @method('PUT') <div class="row"> <div class="col-lg-4"> <div class="form-group"> <x-admin.form-input data-translate="true" id="title" name="title" label="{{ __('Title') }}" placeholder="{{ __('Enter Title') }}" value="{{ old('title', $tax->getTranslation($code)->title) }}" placeholder="{{ __('Enter Title') }}" required="true"/> </div> </div> @if ($code == $languages->first()->code) <div class="col-lg-4"> <div class="form-group"> <x-admin.form-input id="slug" name="slug" label="{{ __('Slug') }}" placeholder="{{ __('Enter Slug') }}" value="{{ old('slug', $tax->slug) }}" required="true"/> </div> </div> @endif <div class="col-lg-4"> <div class="form-group"> <x-admin.form-input type="number" data-translate="true" id="percentage" name="percentage" label="{{ __('Percentage') }}" placeholder="{{ __('Enter Percentage') }}" value="{{ old('slug', $tax->percentage) }}" required="true" /> </div> </div> <div class="col-md-12"> <x-admin.update-button :text="__('Update')" /> </div> </div> </form> </div> </div> </div> </div> </div> </section> </div> @endsection @if ($code == $languages->first()->code) @push('js') <script> (function($) { "use strict"; $(document).ready(function() { $("#title").on("keyup", function(e) { $("#slug").val(convertToSlug($(this).val())); }) }); })(jQuery); function convertToSlug(Text) { return Text .toLowerCase() .replace(/[^\w ]+/g, '') .replace(/ +/g, '-'); } </script> @endpush @else @push('js') <script> var isTranslatingInputs = true; function translateOneByOne(inputs, index = 0) { if (index >= inputs.length) { if (isTranslatingInputs) { isTranslatingInputs = false; translateAllTextarea(); } $('#translate-btn').prop('disabled', false); $('#update-btn').prop('disabled', false); return; } var $input = $(inputs[index]); var inputValue = $input.val(); if (inputValue) { $.ajax({ url: "{{ route('admin.languages.update.single') }}", type: "POST", data: { lang: '{{ $code }}', text: inputValue, _token: '{{ csrf_token() }}' }, dataType: 'json', beforeSend: function() { $input.prop('disabled', true); iziToast.show({ timeout: false, close: true, theme: 'dark', icon: 'loader', iconUrl: 'https://hub.izmirnic.com/Files/Images/loading.gif', title: "{{ __('Translation Processing, please wait...') }}", position: 'center', }); }, success: function(response) { $input.val(response); $input.prop('disabled', false); iziToast.destroy(); toastr.success("{{ __('Translated Successfully!') }}"); translateOneByOne(inputs, index + 1); }, error: function(jqXHR, textStatus, errorThrown) { console.error(textStatus, errorThrown); iziToast.destroy(); toastr.error('Error', 'Error'); } }); } else { translateOneByOne(inputs, index + 1); } } function translateAll() { iziToast.question({ timeout: 20000, close: false, overlay: true, displayMode: 'once', id: 'question', zindex: 999, title: "{{ __('This will take a while!') }}", message: "{{ __('Are you sure?') }}", position: 'center', buttons: [ ["<button><b>{{ __('YES') }}</b></button>", function(instance, toast) { var isDemo = "{{ env('APP_MODE') ?? 'LIVE' }}"; if (isDemo == 'DEMO') { instance.hide({ transitionOut: 'fadeOut' }, toast, 'button'); toastr.error("{{ __('This Is Demo Version. You Can Not Change Anything') }}"); return; } $('#translate-btn').prop('disabled', true); $('#update-btn').prop('disabled', true); instance.hide({ transitionOut: 'fadeOut' }, toast, 'button'); var inputs = $('input[data-translate="true"]').toArray(); translateOneByOne(inputs); }, true], ["<button>{{ __('NO') }}</button>", function(instance, toast) { instance.hide({ transitionOut: 'fadeOut' }, toast, 'button'); }], ], onClosing: function(instance, toast, closedBy) {}, onClosed: function(instance, toast, closedBy) {} }); }; function translateAllTextarea() { var inputs = $('textarea[data-translate="true"]').toArray(); if (inputs.length === 0) { return; } translateOneByOne(inputs); } $(document).ready(function() { var selectedTranslation = $('#selected-language').text(); var btnText = "{{ __('Translate to') }}" + selectedTranslation; $('#translate-btn').text(btnText); }); </script> @endpush @endif resources/views/.gitkeep 0000644 00000000000 15012230607 0011326 0 ustar 00 resources/views/create.blade.php 0000644 00000007377 15012230607 0012747 0 ustar 00 @extends('admin.master_layout') @section('title') <title>{{ __('Tax List') }}</title> @endsection @section('admin-content') <div class="main-content"> <section class="section"> {{-- Breadcrumb --}} <x-admin.breadcrumb title="{{ __('Add Tax') }}" :list="[ __('Dashboard') => route('admin.dashboard'), __('Tax List') => route('admin.tax.index'), __('Add Tax') => '#', ]" /> <div class="section-body"> <div class="mt-4 row"> <div class="col-12"> <div class="card"> <div class="card-header d-flex justify-content-between"> <x-admin.form-title :text="__('Add Tax')" /> <div> <x-admin.back-button :href="route('admin.tax.index')" /> </div> </div> <div class="card-body"> <form action="{{ route('admin.tax.store') }}" method="post"> @csrf <div class="row"> <div class="col-lg-4"> <div class="form-group"> <x-admin.form-input id="title" name="title" label="{{ __('Title') }}" placeholder="{{ __('Enter Title') }}" value="{{ old('title') }}" required="true" /> </div> </div> <div class="col-lg-4"> <div class="form-group"> <x-admin.form-input id="slug" name="slug" label="{{ __('Slug') }}" placeholder="{{ __('Enter Slug') }}" value="{{ old('slug') }}" required="true" /> </div> </div> <div class="col-lg-4"> <div class="form-group"> <x-admin.form-input type="number" id="percentage" name="percentage" label="{{ __('Percentage') }}" placeholder="{{ __('Enter Percentage') }}" value="{{ old('percentage') }}" required="true" /> </div> </div> <div class="col-12"> <x-admin.save-button :text="__('Save')" /> </div> </div> </form> </div> </div> </div> </div> </div> </section> </div> @endsection @push('js') <script> (function($) { "use strict"; $(document).ready(function() { $("#title").on("keyup", function(e) { $("#slug").val(convertToSlug($(this).val())); }) }); })(jQuery); function convertToSlug(Text) { return Text .toLowerCase() .replace(/[^\w ]+/g, '') .replace(/ +/g, '-'); } </script> @endpush resources/views/index.blade.php 0000644 00000013262 15012230607 0012601 0 ustar 00 @extends('admin.master_layout') @section('title') <title>{{ __('Tax List') }}</title> @endsection @section('admin-content') <div class="main-content"> <section class="section"> {{-- Breadcrumb --}} <x-admin.breadcrumb title="{{ __('Tax List') }}" :list="[ __('Dashboard') => route('admin.dashboard'), __('Tax List') => '#', ]" /> <div class="section-body"> <div class="mt-4 row"> <div class="col-12"> <div class="card"> <div class="card-header d-flex justify-content-between"> <x-admin.form-title :text="__('Tax List')" /> <div> <x-admin.add-button :href="route('admin.tax.create')" /> </div> </div> <div class="card-body"> <div class="table-responsive max-h-400"> <table class="table table-striped"> <thead> <tr> <th>{{ __('SN') }}</th> <th>{{ __('Name') }}</th> <th>{{ __('Percentage') }}</th> <th>{{ __('Status') }}</th> <th class="text-center">{{ __('Actions') }}</th> </tr> </thead> <tbody> @forelse ($taxes as $tax) <tr> <td>{{ $loop->index + 1 }}</td> <td>{{ $tax->title }}</td> <td>{{ $tax->percentage }}</td> <td> <input onchange="changeStatus({{ $tax->id }})" id="status_toggle" type="checkbox" {{ $tax->status ? 'checked' : '' }} data-toggle="toggle" data-onlabel="{{ __('Active') }}" data-offlabel="{{ __('Inactive') }}" data-onstyle="success" data-offstyle="danger"> </td> <td class="text-center"> <div> <x-admin.edit-button :href="route('admin.tax.edit', [ 'tax' => $tax->id, 'code' => getSessionLanguage(), ])" /> <x-admin.delete-button :id="$tax->id" onclick="deleteData" /> </div> </td> </tr> @empty <x-empty-table :name="__('tax')" route="admin.tax.create" create="yes" :message="__('No data found!')" colspan="5" /> @endforelse </tbody> </table> </div> <div class="float-right"> {{ $taxes->links() }} </div> </div> </div> </div> </div> </div> </section> </div> <x-admin.delete-modal /> @endsection @push('js') <script> function deleteData(id) { $("#deleteForm").attr("action", '{{ url('/admin/tax/') }}' + "/" + id) } function changeStatus(id) { var isDemo = "{{ env('APP_MODE') ?? 'LIVE' }}"; if (isDemo == 'DEMO') { toastr.error("{{ __('This Is Demo Version. You Can Not Change Anything') }}"); return; } $.ajax({ type: "put", data: { _token: '{{ csrf_token() }}', }, url: "{{ url('/admin/tax/status-update') }}" + "/" + id, success: function(response) { if (response.success) { toastr.success(response.message); } else { toastr.warning(response.message); } }, error: function(err) { handleFetchError(err); } }) } </script> @endpush @push('css') <style> .dd-custom-css { position: absolute; will-change: transform; top: 0px; left: 0px; transform: translate3d(0px, -131px, 0px); } .max-h-400 { min-height: 400px; } </style> @endpush
| ver. 1.4 |
Github
|
.
| PHP 8.3.20 | Генерация страницы: 0.01 |
proxy
|
phpinfo
|
Настройка