We could not synchronize checks via GitHub's checks API since Scrutinizer's GitHub App is not installed for this repository.
@@ -70,13 +70,13 @@ discard block |
||
| 70 | 70 | ], |
| 71 | 71 | |
| 72 | 72 | // CSS files that are loaded in all pages, using Laravel's mix() helper |
| 73 | - 'mix_styles' => [ // file_path => manifest_directory_path |
|
| 73 | + 'mix_styles' => [// file_path => manifest_directory_path |
|
| 74 | 74 | // 'css/app.css' => '', |
| 75 | 75 | ], |
| 76 | 76 | |
| 77 | 77 | // CSS files that are loaded in all pages, using Laravel's @vite() helper |
| 78 | 78 | // Please note that support for Vite was added in Laravel 9.19. Earlier versions are not able to use this feature. |
| 79 | - 'vite_styles' => [ // resource file_path |
|
| 79 | + 'vite_styles' => [// resource file_path |
|
| 80 | 80 | // 'resources/css/app.css', |
| 81 | 81 | ], |
| 82 | 82 | |
@@ -152,12 +152,12 @@ discard block |
||
| 152 | 152 | ], |
| 153 | 153 | |
| 154 | 154 | // JS files that are loaded in all pages, using Laravel's mix() helper |
| 155 | - 'mix_scripts' => [ // file_path => manifest_directory_path |
|
| 155 | + 'mix_scripts' => [// file_path => manifest_directory_path |
|
| 156 | 156 | // 'js/app.js' => '', |
| 157 | 157 | ], |
| 158 | 158 | |
| 159 | 159 | // JS files that are loaded in all pages, using Laravel's @vite() helper |
| 160 | - 'vite_scripts' => [ // resource file_path |
|
| 160 | + 'vite_scripts' => [// resource file_path |
|
| 161 | 161 | // 'resources/js/app.js', |
| 162 | 162 | ], |
| 163 | 163 | |
@@ -83,7 +83,7 @@ discard block |
||
| 83 | 83 | |
| 84 | 84 | // Install Backpack Generators |
| 85 | 85 | $this->progressBlock('Installing Generators'); |
| 86 | - if (! file_exists('vendor/backpack/generators/composer.json')) { |
|
| 86 | + if (!file_exists('vendor/backpack/generators/composer.json')) { |
|
| 87 | 87 | // only do this if Generators aren't already required |
| 88 | 88 | $process = new Process(['composer', 'require', '--dev', 'backpack/generators']); |
| 89 | 89 | $process->setTimeout(300); |
@@ -97,7 +97,7 @@ discard block |
||
| 97 | 97 | $this->closeProgressBlock(); |
| 98 | 98 | |
| 99 | 99 | // Optional commands |
| 100 | - if (! $this->option('no-interaction')) { |
|
| 100 | + if (!$this->option('no-interaction')) { |
|
| 101 | 101 | // Themes |
| 102 | 102 | $this->installTheme(); |
| 103 | 103 | |
@@ -106,7 +106,7 @@ discard block |
||
| 106 | 106 | |
| 107 | 107 | // Addons |
| 108 | 108 | $this->installAddons(); |
| 109 | - } elseif (! $this->isAnyThemeInstalled()) { |
|
| 109 | + } elseif (!$this->isAnyThemeInstalled()) { |
|
| 110 | 110 | // Install default theme |
| 111 | 111 | $this->progressBlock('Installing default theme'); |
| 112 | 112 | $this->executeArtisanProcess('backpack:require:theme-tabler'); |
@@ -187,7 +187,7 @@ discard block |
||
| 187 | 187 | |
| 188 | 188 | $this->deleteLines(3); |
| 189 | 189 | |
| 190 | - if (! $total) { |
|
| 190 | + if (!$total) { |
|
| 191 | 191 | $this->deleteLines(); |
| 192 | 192 | $this->note('Skipping creating an admin user.'); |
| 193 | 193 | $this->newLine(); |
@@ -196,14 +196,14 @@ discard block |
||
| 196 | 196 | |
| 197 | 197 | private function isEveryAddonInstalled() |
| 198 | 198 | { |
| 199 | - return collect($this->addons)->every(function ($addon) { |
|
| 199 | + return collect($this->addons)->every(function($addon) { |
|
| 200 | 200 | return file_exists($addon->path); |
| 201 | 201 | }); |
| 202 | 202 | } |
| 203 | 203 | |
| 204 | 204 | private function updateAddonsStatus() |
| 205 | 205 | { |
| 206 | - $this->addons = $this->addons->each(function (&$addon) { |
|
| 206 | + $this->addons = $this->addons->each(function(&$addon) { |
|
| 207 | 207 | $isInstalled = file_exists($addon->path); |
| 208 | 208 | $addon->status = $isInstalled ? 'installed' : 'not installed'; |
| 209 | 209 | $addon->statusColor = $isInstalled ? 'green' : 'yellow'; |
@@ -214,7 +214,7 @@ discard block |
||
| 214 | 214 | { |
| 215 | 215 | // map the addons |
| 216 | 216 | $this->addons = collect($this->addons) |
| 217 | - ->map(function ($class) { |
|
| 217 | + ->map(function($class) { |
|
| 218 | 218 | return (object) $class::$addon; |
| 219 | 219 | }); |
| 220 | 220 | |
@@ -233,15 +233,15 @@ discard block |
||
| 233 | 233 | |
| 234 | 234 | // Calculate the printed line count |
| 235 | 235 | $printedLines = $this->addons |
| 236 | - ->map(function ($e) { |
|
| 236 | + ->map(function($e) { |
|
| 237 | 237 | return count($e->description); |
| 238 | 238 | }) |
| 239 | - ->reduce(function ($sum, $item) { |
|
| 239 | + ->reduce(function($sum, $item) { |
|
| 240 | 240 | return $sum + $item + 2; |
| 241 | 241 | }, 0); |
| 242 | 242 | |
| 243 | 243 | $total = 0; |
| 244 | - while (! $this->isEveryAddonInstalled()) { |
|
| 244 | + while (!$this->isEveryAddonInstalled()) { |
|
| 245 | 245 | $input = (int) $this->listChoice('Would you like to install a premium Backpack add-on? <fg=gray>(enter option number: 1, 2 or 3)</>', $this->addons->toArray()); |
| 246 | 246 | |
| 247 | 247 | if ($input < 1 || $input > $this->addons->count()) { |
@@ -276,14 +276,14 @@ discard block |
||
| 276 | 276 | |
| 277 | 277 | private function isEveryThemeInstalled() |
| 278 | 278 | { |
| 279 | - return $this->themes()->every(function ($theme) { |
|
| 279 | + return $this->themes()->every(function($theme) { |
|
| 280 | 280 | return $theme->status == 'installed'; |
| 281 | 281 | }); |
| 282 | 282 | } |
| 283 | 283 | |
| 284 | 284 | private function isAnyThemeInstalled() |
| 285 | 285 | { |
| 286 | - return $this->themes()->filter(function ($theme) { |
|
| 286 | + return $this->themes()->filter(function($theme) { |
|
| 287 | 287 | return $theme->status == 'installed'; |
| 288 | 288 | })->count() > 0; |
| 289 | 289 | } |
@@ -301,10 +301,10 @@ discard block |
||
| 301 | 301 | |
| 302 | 302 | // Calculate the printed line count |
| 303 | 303 | $printedLines = $this->themes() |
| 304 | - ->map(function ($e) { |
|
| 304 | + ->map(function($e) { |
|
| 305 | 305 | return count($e->description); |
| 306 | 306 | }) |
| 307 | - ->reduce(function ($sum, $item) { |
|
| 307 | + ->reduce(function($sum, $item) { |
|
| 308 | 308 | return $sum + $item + 2; |
| 309 | 309 | }, 0); |
| 310 | 310 | |
@@ -340,9 +340,9 @@ discard block |
||
| 340 | 340 | public function themes() |
| 341 | 341 | { |
| 342 | 342 | return collect($this->themes) |
| 343 | - ->map(function ($class) { |
|
| 343 | + ->map(function($class) { |
|
| 344 | 344 | return (object) $class::$addon; |
| 345 | - })->each(function (&$theme) { |
|
| 345 | + })->each(function(&$theme) { |
|
| 346 | 346 | $isInstalled = file_exists($theme->path); |
| 347 | 347 | $theme->status = $isInstalled ? 'installed' : 'not installed'; |
| 348 | 348 | $theme->statusColor = $isInstalled ? 'green' : 'yellow'; |
@@ -81,24 +81,24 @@ discard block |
||
| 81 | 81 | $this->registerBackpackErrorViews(); |
| 82 | 82 | |
| 83 | 83 | // Bind the CrudPanel object to Laravel's service container |
| 84 | - $this->app->scoped('crud', function ($app) { |
|
| 84 | + $this->app->scoped('crud', function($app) { |
|
| 85 | 85 | return new CrudPanel(); |
| 86 | 86 | }); |
| 87 | 87 | |
| 88 | - $this->app->scoped('DatabaseSchema', function ($app) { |
|
| 88 | + $this->app->scoped('DatabaseSchema', function($app) { |
|
| 89 | 89 | return new DatabaseSchema(); |
| 90 | 90 | }); |
| 91 | 91 | |
| 92 | - $this->app->singleton('BackpackViewNamespaces', function ($app) { |
|
| 92 | + $this->app->singleton('BackpackViewNamespaces', function($app) { |
|
| 93 | 93 | return new ViewNamespaces(); |
| 94 | 94 | }); |
| 95 | 95 | |
| 96 | 96 | // Bind the widgets collection object to Laravel's service container |
| 97 | - $this->app->singleton('widgets', function ($app) { |
|
| 97 | + $this->app->singleton('widgets', function($app) { |
|
| 98 | 98 | return new Collection(); |
| 99 | 99 | }); |
| 100 | 100 | |
| 101 | - $this->app->scoped('UploadersRepository', function ($app) { |
|
| 101 | + $this->app->scoped('UploadersRepository', function($app) { |
|
| 102 | 102 | return new UploadersRepository(); |
| 103 | 103 | }); |
| 104 | 104 | |
@@ -114,7 +114,7 @@ discard block |
||
| 114 | 114 | $middleware_key = config('backpack.base.middleware_key'); |
| 115 | 115 | $middleware_class = config('backpack.base.middleware_class'); |
| 116 | 116 | |
| 117 | - if (! is_array($middleware_class)) { |
|
| 117 | + if (!is_array($middleware_class)) { |
|
| 118 | 118 | $router->pushMiddlewareToGroup($middleware_key, $middleware_class); |
| 119 | 119 | |
| 120 | 120 | return; |
@@ -227,7 +227,7 @@ discard block |
||
| 227 | 227 | $configs = scandir(__DIR__."/config/backpack/$dir/"); |
| 228 | 228 | $configs = array_diff($configs, ['.', '..']); |
| 229 | 229 | |
| 230 | - if (! count($configs)) { |
|
| 230 | + if (!count($configs)) { |
|
| 231 | 231 | return; |
| 232 | 232 | } |
| 233 | 233 | |
@@ -276,8 +276,7 @@ discard block |
||
| 276 | 276 | // add the backpack_users password broker to the configuration |
| 277 | 277 | $laravelAuthPasswordBrokers = app()->config['auth.passwords']; |
| 278 | 278 | $laravelFirstPasswordBroker = is_array($laravelAuthPasswordBrokers) && current($laravelAuthPasswordBrokers) ? |
| 279 | - current($laravelAuthPasswordBrokers)['table'] : |
|
| 280 | - ''; |
|
| 279 | + current($laravelAuthPasswordBrokers)['table'] : ''; |
|
| 281 | 280 | |
| 282 | 281 | $backpackPasswordBrokerTable = config('backpack.base.password_resets_table') ?? |
| 283 | 282 | config('auth.passwords.users.table') ?? |
@@ -305,7 +304,7 @@ discard block |
||
| 305 | 304 | |
| 306 | 305 | public function loadViewComponents() |
| 307 | 306 | { |
| 308 | - $this->app->afterResolving(BladeCompiler::class, function () { |
|
| 307 | + $this->app->afterResolving(BladeCompiler::class, function() { |
|
| 309 | 308 | Blade::componentNamespace('Backpack\\CRUD\\app\\View\\Components', 'backpack'); |
| 310 | 309 | }); |
| 311 | 310 | } |
@@ -331,13 +330,13 @@ discard block |
||
| 331 | 330 | private function registerBackpackErrorViews() |
| 332 | 331 | { |
| 333 | 332 | // register the backpack error when the exception handler is resolved from the container |
| 334 | - $this->callAfterResolving(ExceptionHandler::class, function ($handler) { |
|
| 335 | - if (! Str::startsWith(request()->path(), config('backpack.base.route_prefix'))) { |
|
| 333 | + $this->callAfterResolving(ExceptionHandler::class, function($handler) { |
|
| 334 | + if (!Str::startsWith(request()->path(), config('backpack.base.route_prefix'))) { |
|
| 336 | 335 | return; |
| 337 | 336 | } |
| 338 | 337 | |
| 339 | 338 | // parse the namespaces set in config |
| 340 | - [$themeNamespace, $themeFallbackNamespace] = (function () { |
|
| 339 | + [$themeNamespace, $themeFallbackNamespace] = (function() { |
|
| 341 | 340 | $themeNamespace = config('backpack.ui.view_namespace'); |
| 342 | 341 | $themeFallbackNamespace = config('backpack.ui.view_namespace_fallback'); |
| 343 | 342 | |
@@ -354,8 +353,7 @@ discard block |
||
| 354 | 353 | // - fallback theme paths |
| 355 | 354 | // - ui path |
| 356 | 355 | $themeErrorPaths = $viewFinderHints[$themeNamespace] ?? []; |
| 357 | - $themeErrorPaths = $themeNamespace === $themeFallbackNamespace ? $themeErrorPaths : |
|
| 358 | - array_merge($viewFinderHints[$themeFallbackNamespace] ?? [], $themeErrorPaths); |
|
| 356 | + $themeErrorPaths = $themeNamespace === $themeFallbackNamespace ? $themeErrorPaths : array_merge($viewFinderHints[$themeFallbackNamespace] ?? [], $themeErrorPaths); |
|
| 359 | 357 | $uiErrorPaths = [base_path('vendor/backpack/crud/src/resources/views/ui')]; |
| 360 | 358 | $themeErrorPaths = array_merge($themeErrorPaths, $uiErrorPaths); |
| 361 | 359 | |
@@ -25,7 +25,7 @@ discard block |
||
| 25 | 25 | |
| 26 | 26 | private bool $deleteWhenEntryIsDeleted = true; |
| 27 | 27 | |
| 28 | - private bool|string $attachedToFakeField = false; |
|
| 28 | + private bool | string $attachedToFakeField = false; |
|
| 29 | 29 | |
| 30 | 30 | /** |
| 31 | 31 | * Cloud disks have the ability to generate temporary URLs to files, should we do it? |
@@ -57,7 +57,7 @@ discard block |
||
| 57 | 57 | /******************************* |
| 58 | 58 | * Static methods |
| 59 | 59 | *******************************/ |
| 60 | - public static function for(array $crudObject, array $definition): UploaderInterface |
|
| 60 | + public static function for (array $crudObject, array $definition): UploaderInterface |
|
| 61 | 61 | { |
| 62 | 62 | return new static($crudObject, $definition); |
| 63 | 63 | } |
@@ -98,7 +98,7 @@ discard block |
||
| 98 | 98 | public function deleteUploadedFiles(Model $entry): void |
| 99 | 99 | { |
| 100 | 100 | if ($this->deleteWhenEntryIsDeleted) { |
| 101 | - if (! in_array(SoftDeletes::class, class_uses_recursive($entry), true)) { |
|
| 101 | + if (!in_array(SoftDeletes::class, class_uses_recursive($entry), true)) { |
|
| 102 | 102 | $this->performFileDeletion($entry); |
| 103 | 103 | |
| 104 | 104 | return; |
@@ -169,7 +169,7 @@ discard block |
||
| 169 | 169 | |
| 170 | 170 | public function getPreviousFiles(Model $entry): mixed |
| 171 | 171 | { |
| 172 | - if (! $this->attachedToFakeField) { |
|
| 172 | + if (!$this->attachedToFakeField) { |
|
| 173 | 173 | return $this->getOriginalValue($entry); |
| 174 | 174 | } |
| 175 | 175 | |
@@ -208,7 +208,7 @@ discard block |
||
| 208 | 208 | $value = $entry->{$this->getAttributeName()}; |
| 209 | 209 | |
| 210 | 210 | if ($this->handleMultipleFiles) { |
| 211 | - if (! isset($entry->getCasts()[$this->getName()]) && is_string($value)) { |
|
| 211 | + if (!isset($entry->getCasts()[$this->getName()]) && is_string($value)) { |
|
| 212 | 212 | $entry->{$this->getAttributeName()} = json_decode($value, true); |
| 213 | 213 | } |
| 214 | 214 | |
@@ -236,7 +236,7 @@ discard block |
||
| 236 | 236 | |
| 237 | 237 | if ($this->handleMultipleFiles) { |
| 238 | 238 | // ensure we have an array of values when field is not casted in model. |
| 239 | - if (! isset($entry->getCasts()[$this->name]) && is_string($values)) { |
|
| 239 | + if (!isset($entry->getCasts()[$this->name]) && is_string($values)) { |
|
| 240 | 240 | $values = json_decode($values, true); |
| 241 | 241 | } |
| 242 | 242 | foreach ($values as $value) { |
@@ -252,7 +252,7 @@ discard block |
||
| 252 | 252 | |
| 253 | 253 | private function performFileDeletion(Model $entry) |
| 254 | 254 | { |
| 255 | - if (! $this->handleRepeatableFiles) { |
|
| 255 | + if (!$this->handleRepeatableFiles) { |
|
| 256 | 256 | $this->deleteFiles($entry); |
| 257 | 257 | |
| 258 | 258 | return; |
@@ -275,7 +275,7 @@ discard block |
||
| 275 | 275 | { |
| 276 | 276 | $previousValue = $entry->getOriginal($field ?? $this->getAttributeName()); |
| 277 | 277 | |
| 278 | - if (! $previousValue) { |
|
| 278 | + if (!$previousValue) { |
|
| 279 | 279 | return $previousValue; |
| 280 | 280 | } |
| 281 | 281 | |
@@ -23,7 +23,7 @@ discard block |
||
| 23 | 23 | return $this->getPath().$fileName; |
| 24 | 24 | } |
| 25 | 25 | |
| 26 | - if (! $value && CrudPanelFacade::getRequest()->has($this->getRepeatableContainerName() ?? $this->getName()) && $previousFile) { |
|
| 26 | + if (!$value && CrudPanelFacade::getRequest()->has($this->getRepeatableContainerName() ?? $this->getName()) && $previousFile) { |
|
| 27 | 27 | Storage::disk($this->getDisk())->delete($previousFile); |
| 28 | 28 | |
| 29 | 29 | return null; |
@@ -47,7 +47,7 @@ discard block |
||
| 47 | 47 | } |
| 48 | 48 | |
| 49 | 49 | foreach ($previousRepeatableValues as $row => $file) { |
| 50 | - if ($file && ! isset($orderedFiles[$row])) { |
|
| 50 | + if ($file && !isset($orderedFiles[$row])) { |
|
| 51 | 51 | $orderedFiles[$row] = null; |
| 52 | 52 | Storage::disk($this->getDisk())->delete($file); |
| 53 | 53 | } |
@@ -74,7 +74,7 @@ discard block |
||
| 74 | 74 | /** |
| 75 | 75 | * Add a column at the end of the CRUD object's "columns" array and return it. |
| 76 | 76 | */ |
| 77 | - public function addAndReturnColumn(array|string $column): CrudColumn |
|
| 77 | + public function addAndReturnColumn(array | string $column): CrudColumn |
|
| 78 | 78 | { |
| 79 | 79 | $column = $this->prepareAttributesAndAddColumn($column); |
| 80 | 80 | |
@@ -122,7 +122,7 @@ discard block |
||
| 122 | 122 | */ |
| 123 | 123 | public function makeFirstColumn() |
| 124 | 124 | { |
| 125 | - if (! $this->columns()) { |
|
| 125 | + if (!$this->columns()) { |
|
| 126 | 126 | return false; |
| 127 | 127 | } |
| 128 | 128 | |
@@ -166,7 +166,7 @@ discard block |
||
| 166 | 166 | */ |
| 167 | 167 | public function removeColumns($columns) |
| 168 | 168 | { |
| 169 | - if (! empty($columns)) { |
|
| 169 | + if (!empty($columns)) { |
|
| 170 | 170 | foreach ($columns as $columnKey) { |
| 171 | 171 | $this->removeColumn($columnKey); |
| 172 | 172 | } |
@@ -260,8 +260,8 @@ discard block |
||
| 260 | 260 | { |
| 261 | 261 | $columns = $this->columns(); |
| 262 | 262 | |
| 263 | - return collect($columns)->pluck('entity')->reject(function ($value, $key) { |
|
| 264 | - return ! $value; |
|
| 263 | + return collect($columns)->pluck('entity')->reject(function($value, $key) { |
|
| 264 | + return !$value; |
|
| 265 | 265 | })->toArray(); |
| 266 | 266 | } |
| 267 | 267 | |
@@ -335,7 +335,7 @@ discard block |
||
| 335 | 335 | */ |
| 336 | 336 | public function hasColumnWhere($attribute, $value) |
| 337 | 337 | { |
| 338 | - $match = Arr::first($this->columns(), function ($column, $columnKey) use ($attribute, $value) { |
|
| 338 | + $match = Arr::first($this->columns(), function($column, $columnKey) use ($attribute, $value) { |
|
| 339 | 339 | return isset($column[$attribute]) && $column[$attribute] == $value; |
| 340 | 340 | }); |
| 341 | 341 | |
@@ -351,7 +351,7 @@ discard block |
||
| 351 | 351 | */ |
| 352 | 352 | public function firstColumnWhere($attribute, $value) |
| 353 | 353 | { |
| 354 | - return Arr::first($this->columns(), function ($column, $columnKey) use ($attribute, $value) { |
|
| 354 | + return Arr::first($this->columns(), function($column, $columnKey) use ($attribute, $value) { |
|
| 355 | 355 | return isset($column[$attribute]) && $column[$attribute] == $value; |
| 356 | 356 | }); |
| 357 | 357 | } |
@@ -400,8 +400,8 @@ discard block |
||
| 400 | 400 | */ |
| 401 | 401 | public function countColumnsWithoutActions() |
| 402 | 402 | { |
| 403 | - return collect($this->columns())->filter(function ($column, $key) { |
|
| 404 | - return ! isset($column['hasActions']) || $column['hasActions'] == false; |
|
| 403 | + return collect($this->columns())->filter(function($column, $key) { |
|
| 404 | + return !isset($column['hasActions']) || $column['hasActions'] == false; |
|
| 405 | 405 | })->count(); |
| 406 | 406 | } |
| 407 | 407 | |
@@ -76,7 +76,7 @@ discard block |
||
| 76 | 76 | foreach (app('UploadersRepository')->getRepeatableUploadersFor($this->getRepeatableContainerName()) as $uploader) { |
| 77 | 77 | $uploadedValues = $uploader->uploadRepeatableFiles($values->pluck($uploader->getAttributeName())->toArray(), $this->getPreviousRepeatableValues($entry, $uploader)); |
| 78 | 78 | |
| 79 | - $values = $values->map(function ($item, $key) use ($uploadedValues, $uploader) { |
|
| 79 | + $values = $values->map(function($item, $key) use ($uploadedValues, $uploader) { |
|
| 80 | 80 | $item[$uploader->getAttributeName()] = $uploadedValues[$key] ?? null; |
| 81 | 81 | |
| 82 | 82 | return $item; |
@@ -96,7 +96,7 @@ discard block |
||
| 96 | 96 | |
| 97 | 97 | $values = $entry->{$this->getRepeatableContainerName()}; |
| 98 | 98 | $values = is_string($values) ? json_decode($values, true) : $values; |
| 99 | - $values = array_map(function ($item) use ($repeatableUploaders) { |
|
| 99 | + $values = array_map(function($item) use ($repeatableUploaders) { |
|
| 100 | 100 | foreach ($repeatableUploaders as $upload) { |
| 101 | 101 | $item[$upload->getAttributeName()] = $this->getValuesWithPathStripped($item, $upload); |
| 102 | 102 | } |
@@ -111,7 +111,7 @@ discard block |
||
| 111 | 111 | |
| 112 | 112 | private function retrieveRepeatableRelationFiles(Model $entry) |
| 113 | 113 | { |
| 114 | - switch($this->getRepeatableRelationType()) { |
|
| 114 | + switch ($this->getRepeatableRelationType()) { |
|
| 115 | 115 | case 'BelongsToMany': |
| 116 | 116 | case 'MorphToMany': |
| 117 | 117 | $pivotClass = app('crud')->getModel()->{$this->getUploaderSubfield()['baseEntity']}()->getPivotClass(); |
@@ -156,12 +156,12 @@ discard block |
||
| 156 | 156 | |
| 157 | 157 | $repeatableValues = collect($entry->{$this->getName()}); |
| 158 | 158 | foreach (app('UploadersRepository')->getRepeatableUploadersFor($this->getRepeatableContainerName()) as $upload) { |
| 159 | - if (! $upload->shouldDeleteFiles()) { |
|
| 159 | + if (!$upload->shouldDeleteFiles()) { |
|
| 160 | 160 | continue; |
| 161 | 161 | } |
| 162 | 162 | $values = $repeatableValues->pluck($upload->getName())->toArray(); |
| 163 | 163 | foreach ($values as $value) { |
| 164 | - if (! $value) { |
|
| 164 | + if (!$value) { |
|
| 165 | 165 | continue; |
| 166 | 166 | } |
| 167 | 167 | |
@@ -184,7 +184,7 @@ discard block |
||
| 184 | 184 | /** |
| 185 | 185 | * Given two multidimensional arrays/collections, merge them recursively. |
| 186 | 186 | */ |
| 187 | - protected function mergeValuesRecursive(array|Collection $array1, array|Collection $array2): array|Collection |
|
| 187 | + protected function mergeValuesRecursive(array | Collection $array1, array | Collection $array2): array | Collection |
|
| 188 | 188 | { |
| 189 | 189 | $merged = $array1; |
| 190 | 190 | foreach ($array2 as $key => &$value) { |
@@ -206,7 +206,7 @@ discard block |
||
| 206 | 206 | { |
| 207 | 207 | $items = CRUD::getRequest()->input('_order_'.$this->getRepeatableContainerName()) ?? []; |
| 208 | 208 | |
| 209 | - array_walk($items, function (&$key, $value) { |
|
| 209 | + array_walk($items, function(&$key, $value) { |
|
| 210 | 210 | $requestValue = $key[$this->getName()] ?? null; |
| 211 | 211 | $key = $this->handleMultipleFiles ? (is_string($requestValue) ? explode(',', $requestValue) : $requestValue) : $requestValue; |
| 212 | 212 | }); |
@@ -218,18 +218,18 @@ discard block |
||
| 218 | 218 | { |
| 219 | 219 | $previousValues = json_decode($entry->getOriginal($uploader->getRepeatableContainerName()), true); |
| 220 | 220 | |
| 221 | - if (! empty($previousValues)) { |
|
| 221 | + if (!empty($previousValues)) { |
|
| 222 | 222 | $previousValues = array_column($previousValues, $uploader->getName()); |
| 223 | 223 | } |
| 224 | 224 | |
| 225 | 225 | return $previousValues ?? []; |
| 226 | 226 | } |
| 227 | 227 | |
| 228 | - private function getValuesWithPathStripped(array|string|null $item, UploaderInterface $upload) |
|
| 228 | + private function getValuesWithPathStripped(array | string | null $item, UploaderInterface $upload) |
|
| 229 | 229 | { |
| 230 | 230 | $uploadedValues = $item[$upload->getName()] ?? null; |
| 231 | 231 | if (is_array($uploadedValues)) { |
| 232 | - return array_map(function ($value) use ($upload) { |
|
| 232 | + return array_map(function($value) use ($upload) { |
|
| 233 | 233 | return Str::after($value, $upload->getPath()); |
| 234 | 234 | }, $uploadedValues); |
| 235 | 235 | } |
@@ -241,19 +241,19 @@ discard block |
||
| 241 | 241 | { |
| 242 | 242 | if (in_array($this->getRepeatableRelationType(), ['BelongsToMany', 'MorphToMany'])) { |
| 243 | 243 | $pivotAttributes = $entry->getAttributes(); |
| 244 | - $connectedPivot = $entry->pivotParent->{$this->getRepeatableContainerName()}->where(function ($item) use ($pivotAttributes) { |
|
| 244 | + $connectedPivot = $entry->pivotParent->{$this->getRepeatableContainerName()}->where(function($item) use ($pivotAttributes) { |
|
| 245 | 245 | $itemPivotAttributes = $item->pivot->only(array_keys($pivotAttributes)); |
| 246 | 246 | |
| 247 | 247 | return $itemPivotAttributes === $pivotAttributes; |
| 248 | 248 | })->first(); |
| 249 | 249 | |
| 250 | - if (! $connectedPivot) { |
|
| 250 | + if (!$connectedPivot) { |
|
| 251 | 251 | return; |
| 252 | 252 | } |
| 253 | 253 | |
| 254 | 254 | $files = $connectedPivot->getOriginal()['pivot_'.$this->getAttributeName()]; |
| 255 | 255 | |
| 256 | - if (! $files) { |
|
| 256 | + if (!$files) { |
|
| 257 | 257 | return; |
| 258 | 258 | } |
| 259 | 259 | |
@@ -14,18 +14,18 @@ discard block |
||
| 14 | 14 | private string $crudObjectType; |
| 15 | 15 | |
| 16 | 16 | public function __construct( |
| 17 | - private readonly CrudField|CrudColumn $crudObject, |
|
| 17 | + private readonly CrudField | CrudColumn $crudObject, |
|
| 18 | 18 | private readonly array $uploaderConfiguration, |
| 19 | 19 | private readonly string $macro |
| 20 | 20 | ) { |
| 21 | 21 | $this->crudObjectType = is_a($crudObject, CrudField::class) ? 'field' : (is_a($crudObject, CrudColumn::class) ? 'column' : null); |
| 22 | 22 | |
| 23 | - if (! $this->crudObjectType) { |
|
| 23 | + if (!$this->crudObjectType) { |
|
| 24 | 24 | abort(500, 'Upload handlers only work for CrudField and CrudColumn classes.'); |
| 25 | 25 | } |
| 26 | 26 | } |
| 27 | 27 | |
| 28 | - public static function handle(CrudField|CrudColumn $crudObject, array $uploaderConfiguration, string $macro, ?array $subfield = null, ?bool $registerModelEvents = true): void |
|
| 28 | + public static function handle(CrudField | CrudColumn $crudObject, array $uploaderConfiguration, string $macro, ?array $subfield = null, ?bool $registerModelEvents = true): void |
|
| 29 | 29 | { |
| 30 | 30 | $instance = new self($crudObject, $uploaderConfiguration, $macro); |
| 31 | 31 | |
@@ -35,9 +35,9 @@ discard block |
||
| 35 | 35 | /******************************* |
| 36 | 36 | * Private methods - implementation |
| 37 | 37 | *******************************/ |
| 38 | - private function registerEvents(array|null $subfield = [], ?bool $registerModelEvents = true): void |
|
| 38 | + private function registerEvents(array | null $subfield = [], ?bool $registerModelEvents = true): void |
|
| 39 | 39 | { |
| 40 | - if (! empty($subfield)) { |
|
| 40 | + if (!empty($subfield)) { |
|
| 41 | 41 | $this->registerSubfieldEvent($subfield, $registerModelEvents); |
| 42 | 42 | |
| 43 | 43 | return; |
@@ -81,7 +81,7 @@ discard block |
||
| 81 | 81 | } |
| 82 | 82 | |
| 83 | 83 | $subfields = collect($this->crudObject->getAttributes()['subfields']); |
| 84 | - $subfields = $subfields->map(function ($item) use ($subfield, $uploader) { |
|
| 84 | + $subfields = $subfields->map(function($item) use ($subfield, $uploader) { |
|
| 85 | 85 | if ($item['name'] === $subfield['name']) { |
| 86 | 86 | $item['upload'] = true; |
| 87 | 87 | $item['disk'] = $uploader->getDisk(); |
@@ -111,7 +111,7 @@ discard block |
||
| 111 | 111 | } |
| 112 | 112 | |
| 113 | 113 | if ($this->crudObjectType === 'field') { |
| 114 | - $model::saving(function ($entry) use ($uploader) { |
|
| 114 | + $model::saving(function($entry) use ($uploader) { |
|
| 115 | 115 | $updatedCountKey = 'uploaded_'.($uploader->getRepeatableContainerName() ?? $uploader->getName()).'_count'; |
| 116 | 116 | |
| 117 | 117 | CRUD::set($updatedCountKey, CRUD::get($updatedCountKey) ?? 0); |
@@ -130,7 +130,7 @@ discard block |
||
| 130 | 130 | // is not called in pivot models when loading the relations. |
| 131 | 131 | $retrieveModel = $this->getModelForRetrieveEvent($model, $uploader); |
| 132 | 132 | |
| 133 | - $retrieveModel::retrieved(function ($entry) use ($uploader) { |
|
| 133 | + $retrieveModel::retrieved(function($entry) use ($uploader) { |
|
| 134 | 134 | if ($entry->translationEnabled()) { |
| 135 | 135 | $locale = request('_locale', \App::getLocale()); |
| 136 | 136 | if (in_array($locale, array_keys($entry->getAvailableLocales()))) { |
@@ -141,7 +141,7 @@ discard block |
||
| 141 | 141 | }); |
| 142 | 142 | } |
| 143 | 143 | |
| 144 | - $model::deleting(function ($entry) use ($uploader) { |
|
| 144 | + $model::deleting(function($entry) use ($uploader) { |
|
| 145 | 145 | $uploader->deleteUploadedFiles($entry); |
| 146 | 146 | }); |
| 147 | 147 | |
@@ -163,13 +163,13 @@ discard block |
||
| 163 | 163 | $customUploader = isset($uploaderConfiguration['uploader']) && class_exists($uploaderConfiguration['uploader']); |
| 164 | 164 | |
| 165 | 165 | if ($customUploader) { |
| 166 | - return $uploaderConfiguration['uploader']::for($crudObject, $uploaderConfiguration); |
|
| 166 | + return $uploaderConfiguration['uploader']::for ($crudObject, $uploaderConfiguration); |
|
| 167 | 167 | } |
| 168 | 168 | |
| 169 | 169 | $uploader = app('UploadersRepository')->hasUploadFor($crudObject['type'], $this->macro); |
| 170 | 170 | |
| 171 | 171 | if ($uploader) { |
| 172 | - return app('UploadersRepository')->getUploadFor($crudObject['type'], $this->macro)::for($crudObject, $uploaderConfiguration); |
|
| 172 | + return app('UploadersRepository')->getUploadFor($crudObject['type'], $this->macro)::for ($crudObject, $uploaderConfiguration); |
|
| 173 | 173 | } |
| 174 | 174 | |
| 175 | 175 | throw new Exception('Undefined upload type for '.$this->crudObjectType.' type: '.$crudObject['type']); |
@@ -185,7 +185,7 @@ discard block |
||
| 185 | 185 | |
| 186 | 186 | private function getSubfieldModel(array $subfield, UploaderInterface $uploader) |
| 187 | 187 | { |
| 188 | - if (! $uploader->isRelationship()) { |
|
| 188 | + if (!$uploader->isRelationship()) { |
|
| 189 | 189 | return $subfield['baseModel'] ?? get_class(app('crud')->getModel()); |
| 190 | 190 | } |
| 191 | 191 | |
@@ -198,7 +198,7 @@ discard block |
||
| 198 | 198 | |
| 199 | 199 | private function getModelForRetrieveEvent(string $model, UploaderInterface $uploader) |
| 200 | 200 | { |
| 201 | - if (! $uploader->isRelationship()) { |
|
| 201 | + if (!$uploader->isRelationship()) { |
|
| 202 | 202 | return $model; |
| 203 | 203 | } |
| 204 | 204 | |
@@ -5,7 +5,7 @@ discard block |
||
| 5 | 5 | use Illuminate\Support\Facades\Log; |
| 6 | 6 | use Illuminate\Support\Str; |
| 7 | 7 | |
| 8 | -if (! function_exists('backpack_url')) { |
|
| 8 | +if (!function_exists('backpack_url')) { |
|
| 9 | 9 | /** |
| 10 | 10 | * Appends the configured backpack prefix and returns |
| 11 | 11 | * the URL using the standard Laravel helpers. |
@@ -15,13 +15,13 @@ discard block |
||
| 15 | 15 | */ |
| 16 | 16 | function backpack_url($path = null, $parameters = [], $secure = null) |
| 17 | 17 | { |
| 18 | - $path = ! $path || (substr($path, 0, 1) == '/') ? $path : '/'.$path; |
|
| 18 | + $path = !$path || (substr($path, 0, 1) == '/') ? $path : '/'.$path; |
|
| 19 | 19 | |
| 20 | 20 | return url(config('backpack.base.route_prefix', 'admin').$path, $parameters, $secure); |
| 21 | 21 | } |
| 22 | 22 | } |
| 23 | 23 | |
| 24 | -if (! function_exists('backpack_authentication_column')) { |
|
| 24 | +if (!function_exists('backpack_authentication_column')) { |
|
| 25 | 25 | /** |
| 26 | 26 | * Return the username column name. |
| 27 | 27 | * The Laravel default (and Backpack default) is 'email'. |
@@ -34,7 +34,7 @@ discard block |
||
| 34 | 34 | } |
| 35 | 35 | } |
| 36 | 36 | |
| 37 | -if (! function_exists('backpack_email_column')) { |
|
| 37 | +if (!function_exists('backpack_email_column')) { |
|
| 38 | 38 | /** |
| 39 | 39 | * Return the email column name. |
| 40 | 40 | * The Laravel default (and Backpack default) is 'email'. |
@@ -47,7 +47,7 @@ discard block |
||
| 47 | 47 | } |
| 48 | 48 | } |
| 49 | 49 | |
| 50 | -if (! function_exists('backpack_form_input')) { |
|
| 50 | +if (!function_exists('backpack_form_input')) { |
|
| 51 | 51 | /** |
| 52 | 52 | * Parse the submitted input in request('form') to an usable array. |
| 53 | 53 | * Joins the multiple[] fields in a single key and transform the dot notation fields into arrayed ones. |
@@ -120,7 +120,7 @@ discard block |
||
| 120 | 120 | } |
| 121 | 121 | } |
| 122 | 122 | |
| 123 | -if (! function_exists('backpack_users_have_email')) { |
|
| 123 | +if (!function_exists('backpack_users_have_email')) { |
|
| 124 | 124 | /** |
| 125 | 125 | * Check if the email column is present on the user table. |
| 126 | 126 | * |
@@ -135,7 +135,7 @@ discard block |
||
| 135 | 135 | } |
| 136 | 136 | } |
| 137 | 137 | |
| 138 | -if (! function_exists('backpack_avatar_url')) { |
|
| 138 | +if (!function_exists('backpack_avatar_url')) { |
|
| 139 | 139 | /** |
| 140 | 140 | * Returns the avatar URL of a user. |
| 141 | 141 | * |
@@ -146,7 +146,7 @@ discard block |
||
| 146 | 146 | { |
| 147 | 147 | switch (config('backpack.base.avatar_type')) { |
| 148 | 148 | case 'gravatar': |
| 149 | - if (backpack_users_have_email() && ! empty($user->email)) { |
|
| 149 | + if (backpack_users_have_email() && !empty($user->email)) { |
|
| 150 | 150 | $avatarLink = Gravatar::fallback(config('backpack.base.gravatar_fallback'))->get($user->email, ['size' => 80]); |
| 151 | 151 | |
| 152 | 152 | // if we can save it locally, for safer loading, let's do it |
@@ -164,7 +164,7 @@ discard block |
||
| 164 | 164 | } |
| 165 | 165 | } |
| 166 | 166 | |
| 167 | -if (! function_exists('backpack_middleware')) { |
|
| 167 | +if (!function_exists('backpack_middleware')) { |
|
| 168 | 168 | /** |
| 169 | 169 | * Return the key of the middleware used across Backpack. |
| 170 | 170 | * That middleware checks if the visitor is an admin. |
@@ -178,7 +178,7 @@ discard block |
||
| 178 | 178 | } |
| 179 | 179 | } |
| 180 | 180 | |
| 181 | -if (! function_exists('backpack_guard_name')) { |
|
| 181 | +if (!function_exists('backpack_guard_name')) { |
|
| 182 | 182 | /* |
| 183 | 183 | * Returns the name of the guard defined |
| 184 | 184 | * by the application config |
@@ -189,7 +189,7 @@ discard block |
||
| 189 | 189 | } |
| 190 | 190 | } |
| 191 | 191 | |
| 192 | -if (! function_exists('backpack_auth')) { |
|
| 192 | +if (!function_exists('backpack_auth')) { |
|
| 193 | 193 | /* |
| 194 | 194 | * Returns the user instance if it exists |
| 195 | 195 | * of the currently authenticated admin |
@@ -201,7 +201,7 @@ discard block |
||
| 201 | 201 | } |
| 202 | 202 | } |
| 203 | 203 | |
| 204 | -if (! function_exists('backpack_user')) { |
|
| 204 | +if (!function_exists('backpack_user')) { |
|
| 205 | 205 | /* |
| 206 | 206 | * Returns back a user instance without |
| 207 | 207 | * the admin guard, however allows you |
@@ -213,7 +213,7 @@ discard block |
||
| 213 | 213 | } |
| 214 | 214 | } |
| 215 | 215 | |
| 216 | -if (! function_exists('mb_ucfirst')) { |
|
| 216 | +if (!function_exists('mb_ucfirst')) { |
|
| 217 | 217 | /** |
| 218 | 218 | * Capitalize the first letter of a string, |
| 219 | 219 | * even if that string is multi-byte (non-latin alphabet). |
@@ -234,7 +234,7 @@ discard block |
||
| 234 | 234 | } |
| 235 | 235 | } |
| 236 | 236 | |
| 237 | -if (! function_exists('backpack_view')) { |
|
| 237 | +if (!function_exists('backpack_view')) { |
|
| 238 | 238 | /** |
| 239 | 239 | * Returns a new displayable view path, based on the configured backpack view namespace. |
| 240 | 240 | * If that view doesn't exist, it falls back to the fallback namespace. |
@@ -259,8 +259,8 @@ discard block |
||
| 259 | 259 | |
| 260 | 260 | $errorMessage = 'The view: ['.$view.'] was not found in any of the following view paths: ['.implode(' ], [ ', $viewPaths).']'; |
| 261 | 261 | |
| 262 | - $errorDetails = (function () { |
|
| 263 | - if (env('APP_ENV') === 'production' || ! env('APP_DEBUG')) { |
|
| 262 | + $errorDetails = (function() { |
|
| 263 | + if (env('APP_ENV') === 'production' || !env('APP_DEBUG')) { |
|
| 264 | 264 | return ''; |
| 265 | 265 | } |
| 266 | 266 | |
@@ -276,7 +276,7 @@ discard block |
||
| 276 | 276 | } |
| 277 | 277 | } |
| 278 | 278 | |
| 279 | -if (! function_exists('backpack_theme_config')) { |
|
| 279 | +if (!function_exists('backpack_theme_config')) { |
|
| 280 | 280 | /** |
| 281 | 281 | * Returns a config value from the current theme's config file. |
| 282 | 282 | * It assumes the theme's config namespace is the same as the view namespace. |
@@ -315,7 +315,7 @@ discard block |
||
| 315 | 315 | } |
| 316 | 316 | } |
| 317 | 317 | |
| 318 | -if (! function_exists('square_brackets_to_dots')) { |
|
| 318 | +if (!function_exists('square_brackets_to_dots')) { |
|
| 319 | 319 | /** |
| 320 | 320 | * Turns a string from bracket-type array to dot-notation array. |
| 321 | 321 | * Ex: array[0][property] turns into array.0.property. |
@@ -331,7 +331,7 @@ discard block |
||
| 331 | 331 | } |
| 332 | 332 | } |
| 333 | 333 | |
| 334 | -if (! function_exists('old_empty_or_null')) { |
|
| 334 | +if (!function_exists('old_empty_or_null')) { |
|
| 335 | 335 | /** |
| 336 | 336 | * This method is an alternative to Laravel's old() helper, which mistakenly |
| 337 | 337 | * returns NULL it two cases: |
@@ -363,7 +363,7 @@ discard block |
||
| 363 | 363 | } |
| 364 | 364 | } |
| 365 | 365 | |
| 366 | -if (! function_exists('is_multidimensional_array')) { |
|
| 366 | +if (!function_exists('is_multidimensional_array')) { |
|
| 367 | 367 | /** |
| 368 | 368 | * Check if the array is multidimensional. |
| 369 | 369 | * |
@@ -372,10 +372,10 @@ discard block |
||
| 372 | 372 | function is_multidimensional_array(array $array, bool $strict = false): bool |
| 373 | 373 | { |
| 374 | 374 | foreach ($array as $item) { |
| 375 | - if ($strict && ! is_array($item)) { |
|
| 375 | + if ($strict && !is_array($item)) { |
|
| 376 | 376 | return false; |
| 377 | 377 | } |
| 378 | - if (! $strict && is_array($item)) { |
|
| 378 | + if (!$strict && is_array($item)) { |
|
| 379 | 379 | return true; |
| 380 | 380 | } |
| 381 | 381 | } |
@@ -383,7 +383,7 @@ discard block |
||
| 383 | 383 | } |
| 384 | 384 | } |
| 385 | 385 | |
| 386 | -if (! function_exists('backpack_pro')) { |
|
| 386 | +if (!function_exists('backpack_pro')) { |
|
| 387 | 387 | /** |
| 388 | 388 | * Check if the backpack/pro package is installed. |
| 389 | 389 | * |
@@ -394,7 +394,7 @@ discard block |
||
| 394 | 394 | if (app()->runningUnitTests()) { |
| 395 | 395 | return true; |
| 396 | 396 | } |
| 397 | - if (! \Composer\InstalledVersions::isInstalled('backpack/pro')) { |
|
| 397 | + if (!\Composer\InstalledVersions::isInstalled('backpack/pro')) { |
|
| 398 | 398 | return false; |
| 399 | 399 | } |
| 400 | 400 | |