Файловый менеджер - Редактировать - /home/c7lekhnath/silverray.com.au/Modules/Language/database/seeders/68334/Counter.tar
Назад
lang/.gitkeep 0000644 00000000000 15012236406 0007103 0 ustar 00 module.json 0000644 00000000336 15012236406 0006725 0 ustar 00 { "name": "Counter", "alias": "counter", "description": "", "keywords": [], "priority": 0, "providers": [ "Modules\\Counter\\app\\Providers\\CounterServiceProvider" ], "files": [] } tests/Unit/.gitkeep 0000644 00000000000 15012236406 0010243 0 ustar 00 tests/Feature/.gitkeep 0000644 00000000000 15012236406 0010717 0 ustar 00 vite.config.js 0000644 00000001304 15012236406 0007312 0 ustar 00 import { defineConfig } from 'vite'; import laravel from 'laravel-vite-plugin'; export default defineConfig({ build: { outDir: '../../public/build-counter', emptyOutDir: true, manifest: true, }, plugins: [ laravel({ publicDirectory: '../../public', buildDirectory: 'build-counter', 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 15012236406 0007503 0 ustar 00 routes/error_log 0000644 00000001102 15012236406 0007773 0 ustar 00 [08-May-2025 22:07:29 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Support\Facades\Route" not found in /home/lekhnath/silverray.com.au/Modules/Counter/routes/api.php:17 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Counter/routes/api.php on line 17 [08-May-2025 22:13:20 UTC] PHP Fatal error: Uncaught Error: Class "Illuminate\Support\Facades\Route" not found in /home/lekhnath/silverray.com.au/Modules/Counter/routes/web.php:6 Stack trace: #0 {main} thrown in /home/lekhnath/silverray.com.au/Modules/Counter/routes/web.php on line 6 routes/web.php 0000644 00000000636 15012236406 0007357 0 ustar 00 <?php use Illuminate\Support\Facades\Route; use Modules\Counter\app\Http\Controllers\CounterController; Route::middleware(['auth:admin', 'translation']) ->name('admin.') ->prefix('admin') ->group( function () { Route::get('counter', [CounterController::class, 'index'])->name('counter'); Route::put('counter-update', [CounterController::class, 'update'])->name('counter-update'); }); routes/api.php 0000644 00000001233 15012236406 0007345 0 ustar 00 <?php use Illuminate\Http\Request; use Illuminate\Support\Facades\Route; /* |-------------------------------------------------------------------------- | API Routes |-------------------------------------------------------------------------- | | Here is where you can register API routes for your application. These | routes are loaded by the RouteServiceProvider within a group which | is assigned the "api" middleware group. Enjoy building your API! | */ Route::middleware(['auth:sanctum'])->prefix('v1')->name('api.')->group(function () { Route::get('counter', fn (Request $request) => $request->user())->name('counter'); }); composer.json 0000644 00000001275 15012236406 0007272 0 ustar 00 { "name": "nwidart/counter", "description": "", "authors": [ { "name": "Nicolas Widart", "email": "n.widart@gmail.com" } ], "extra": { "laravel": { "providers": [], "aliases": { } } }, "autoload": { "psr-4": { "Modules\\Counter\\": "", "Modules\\Counter\\App\\": "app/", "Modules\\Counter\\Database\\Factories\\": "database/factories/", "Modules\\Counter\\Database\\Seeders\\": "database/seeders/" } }, "autoload-dev": { "psr-4": { "Modules\\Counter\\Tests\\": "tests/" } } } config/config.php 0000644 00000000054 15012236406 0007765 0 ustar 00 <?php return [ 'name' => 'Counter', ]; config/.gitkeep 0000644 00000000000 15012236406 0007427 0 ustar 00 package.json 0000644 00000000410 15012236406 0007024 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/.gitkeep 0000644 00000000000 15012236406 0012167 0 ustar 00 app/Http/Controllers/CounterController.php 0000644 00000004600 15012236406 0014744 0 ustar 00 <?php namespace Modules\Counter\app\Http\Controllers; use App\Enums\RedirectType; use Illuminate\Http\Request; use Illuminate\Http\Response; use App\Traits\RedirectHelperTrait; use App\Http\Controllers\Controller; use Illuminate\Http\RedirectResponse; use Modules\Counter\app\Models\Counter; use Modules\Language\app\Models\Language; use Modules\Counter\app\Models\CounterTranslation; use Modules\Language\app\Traits\GenerateTranslationTrait; class CounterController extends Controller { use RedirectHelperTrait, GenerateTranslationTrait; public function index(Request $request) { checkAdminHasPermissionAndThrowException('counter.view'); $counters = Counter::all(); $code = request('code') ?? getSessionLanguage(); if (!Language::where('code', $code)->exists()) { abort(404); } $languages = allLanguages(); return view('counter::index', compact('counters','code','languages')); } public function update(Request $request) { checkAdminHasPermissionAndThrowException('counter.update'); // if($request->code == 'en'){ // foreach($request->ids as $index => $request_item){ // $counter = Counter::find($request->ids[$index]); // if ($request->hasFile('icon_'.$request->ids[$index])) { // $req_file_name = 'icon_'.$request->ids[$index]; // $file_name = file_upload($request->$req_file_name, 'uploads/website-images/', $counter->icon); // $counter->icon = $file_name; // } // $counter->qty = $request->qtys[$index]; // $counter->save(); // } // } if($request->code == 'en'){ foreach($request->ids as $index => $request_item){ $counter = Counter::find($request->ids[$index]); $counter->icon = $request->icons[$index]; $counter->qty = $request->qtys[$index]; $counter->save(); } } foreach($request->titles as $index => $title){ $translate = CounterTranslation::find($request->trans_ids[$index]); $translate->title = $request->titles[$index]; $translate->save(); } return $this->redirectWithMessage(RedirectType::UPDATE->value, 'admin.counter', ['code' => $request->code]); } } app/Http/Requests/.gitkeep 0000644 00000000000 15012236406 0011474 0 ustar 00 app/Http/Middleware/.gitkeep 0000644 00000000000 15012236406 0011736 0 ustar 00 app/Models/CounterTranslation.php 0000644 00000000770 15012236406 0013121 0 ustar 00 <?php namespace Modules\Counter\app\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Factories\HasFactory; use Modules\Counter\Database\factories\CounterTranslationFactory; class CounterTranslation extends Model { use HasFactory; /** * The attributes that are mass assignable. */ protected $fillable = []; protected static function newFactory(): CounterTranslationFactory { //return CounterTranslationFactory::new(); } } app/Models/.gitkeep 0000644 00000000000 15012236406 0010165 0 ustar 00 app/Models/Counter.php 0000644 00000001600 15012236406 0010673 0 ustar 00 <?php namespace Modules\Counter\app\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\HasOne; use Modules\Counter\app\Models\CounterTranslation; use Illuminate\Database\Eloquent\Factories\HasFactory; use Modules\Counter\Database\factories\CounterFactory; class Counter extends Model { use HasFactory; /** * The attributes that are mass assignable. */ protected $fillable = []; protected static function newFactory(): CounterFactory { //return CounterFactory::new(); } public function getTranslation($code): ?CounterTranslation { return $this->hasOne(CounterTranslation::class)->where('lang_code', $code)->first(); } public function translation(): ?HasOne { return $this->hasOne(CounterTranslation::class, 'counter_id')->where('lang_code', getSessionLanguage()); } } app/Providers/RouteServiceProvider.php 0000644 00000002663 15012236406 0014152 0 ustar 00 <?php namespace Modules\Counter\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\Counter\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('Counter', '/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('Counter', '/routes/api.php')); } } app/Providers/.gitkeep 0000644 00000000000 15012236406 0010717 0 ustar 00 app/Providers/CounterServiceProvider.php 0000644 00000006442 15012236406 0014472 0 ustar 00 <?php namespace Modules\Counter\app\Providers; use Illuminate\Support\Facades\Blade; use Illuminate\Support\ServiceProvider; class CounterServiceProvider extends ServiceProvider { protected string $moduleName = 'Counter'; protected string $moduleNameLower = 'counter'; /** * 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; } } database/factories/.gitkeep 0000644 00000000000 15012236406 0011705 0 ustar 00 database/migrations/.gitkeep 0000644 00000000000 15012236406 0012102 0 ustar 00 database/migrations/2023_12_10_061124_create_counters_table.php 0000644 00000001164 15012236406 0017617 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('counters', function (Blueprint $table) { $table->id(); $table->string('icon')->nullable(); $table->string('qty')->nullable(); $table->timestamps(); }); } /** * Reverse the migrations. */ public function down(): void { Schema::dropIfExists('counters'); } }; database/migrations/2023_12_10_061138_create_counter_translations_table.php 0000644 00000001262 15012236406 0022241 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('counter_translations', function (Blueprint $table) { $table->id(); $table->integer('counter_id'); $table->string('lang_code'); $table->string('title')->nullable(); $table->timestamps(); }); } /** * Reverse the migrations. */ public function down(): void { Schema::dropIfExists('counter_translations'); } }; database/seeders/.gitkeep 0000644 00000000000 15012236406 0011360 0 ustar 00 database/seeders/CounterDatabaseSeeder.php 0000644 00000001771 15012236406 0014654 0 ustar 00 <?php namespace Modules\Counter\database\seeders; use Illuminate\Database\Seeder; use Modules\Counter\app\Models\Counter; use Modules\Counter\app\Models\CounterTranslation; class CounterDatabaseSeeder extends Seeder { /** * Run the database seeds. */ public function run(): void { $quantity = 100; $icon = 'counter.png'; for ($i = 1; $i <= 4; $i++) { $counter = new Counter(); $counter->icon = $icon; $counter->qty = $quantity; $counter->save(); } $counters = Counter::all(); foreach($counters as $counter){ $languages = allLanguages(); foreach($languages as $language){ $translation = new CounterTranslation(); $translation->counter_id = $counter->id; $translation->lang_code = $language->code; $translation->title = 'Winning Award'; $translation->save(); } } } } database/seeders/CounterPermissionSeeder.php 0000644 00000002226 15012236406 0015274 0 ustar 00 <?php namespace Modules\Counter\database\seeders; use Illuminate\Database\Seeder; use Spatie\Permission\Models\Role; use Spatie\Permission\Models\Permission; class CounterPermissionSeeder extends Seeder { /** * Run the database seeds. */ public function run(): void { $roleSuperAdmin = Role::where(['guard_name' => 'admin'])->first(); $permissions = [ [ 'group_name' => 'counter', 'permissions' => [ 'counter.view', 'counter.update', 'counter.translate' ] ] ]; for ($i = 0; $i < count($permissions); $i++) { $permissionGroup = $permissions[$i]['group_name']; for ($j = 0; $j < count($permissions[$i]['permissions']); $j++) { $permission = Permission::create([ 'name' => $permissions[$i]['permissions'][$j], 'group_name' => $permissionGroup, 'guard_name' => 'admin' ]); $roleSuperAdmin->givePermissionTo($permission); } } } } resources/assets/.gitkeep 0000644 00000000000 15012236406 0011476 0 ustar 00 resources/assets/js/app.js 0000644 00000000000 15012236406 0011577 0 ustar 00 resources/assets/sass/app.scss 0000644 00000000000 15012236406 0012473 0 ustar 00 resources/views/sidebar.blade.php 0000644 00000000325 15012236406 0013102 0 ustar 00 <li class="{{ Route::is('admin.counter') ? 'active' : '' }}"> <a class="nav-link" href="{{ route('admin.counter', ['code' => getSessionLanguage()]) }}"> <span>{{ __('Counter') }}</span> </a> </li> resources/views/.gitkeep 0000644 00000000000 15012236406 0011331 0 ustar 00 resources/views/index.blade.php 0000644 00000025366 15012236406 0012614 0 ustar 00 @extends('admin.master_layout') @section('title') <title>{{ __('Counter') }}</title> @endsection @section('admin-content') <!-- Main Content --> <div class="main-content"> <section class="section"> <div class="section-header"> <h1>{{ __('Counter') }}</h1> </div> <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('counter.translate') @if ($code !== $languages->first()->code) <x-admin.button onclick="translateAll()" id="translate-btn" :text="__('Translate')" /> @endif @endadminCan </div> <div class="card-body"> <div class="lang_list_top"> <ul class="lang_list"> @foreach ($languages = allLanguages() as $language) <li><a id="{{ request('code') == $language->code ? 'selected-language' : '' }}" href="{{ route('admin.counter', ['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="row"> <div class="col-12"> <div class="card"> <div class="card-body"> <form action="{{ route('admin.counter-update') }}" method="POST" enctype="multipart/form-data"> @csrf @method('PUT') <div class="row"> @php($i=1) @foreach ($counters as $index => $counter) <div class="col-md-6"> <input type="hidden" name="ids[]" value="{{ $counter->id }}"> <input type="hidden" name="code" value="{{ $code }}"> @if ($code == $languages->first()->code) {{-- <div class="form-group"> <label >{{ __('Existing icon') }} {{ $i }}</label> <div> <img src="{{ asset($counter->icon) }}" alt="" width="80"> </div> </div> <div class="form-group"> <label class="w-100">{{ __('New icon') }} </label> <input type="file" name="icon_{{ $counter->id }}" class="form-control-file"> </div> --}} <div class="form-group"> <label class="w-100">{{ __('Icon') }} </label> <input type="text" class="form-control custom-icon-picker" value="{{ $counter->icon }}" name="icons[]" required> </div> <div class="form-group"> <label >{{ __('Quantity') }} {{ $i }}</label> <input type="number" step="any" name="qtys[]" value="{{ $counter->qty }}" class="form-control" required> </div> @endif <div class="form-group"> <label >{{ __('Title') }} {{ $i }}</label> <input data-translate="true" type="text" name="titles[]" value="{{ $counter->getTranslation($code)->title }}" class="form-control" required> <input type="hidden" name="trans_ids[]" value="{{ $counter->getTranslation($code)->id }}"> </div> </div> @php($i++) @endforeach </div> @adminCan('counter.update') <x-admin.save-button :text="__('Update')"> </x-admin.save-button> @endadminCan </form> </div> </div> </div> </div> </div> </section> </div> @endsection @if ($code != $languages->first()->code) @push('js') <script> "use strict"; 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
| ver. 1.4 |
Github
|
.
| PHP 8.3.20 | Генерация страницы: 0.02 |
proxy
|
phpinfo
|
Настройка