Also updated breadcrumb view composer to current standards.
Closes #4553
*/
protected function limiter(): RateLimiter
{
- return app(RateLimiter::class);
+ return app()->make(RateLimiter::class);
}
/**
}
if ($homepageOption === 'bookshelves') {
- $shelves = app(BookshelfRepo::class)->getAllPaginated(18, $commonData['listOptions']->getSort(), $commonData['listOptions']->getOrder());
+ $shelves = app()->make(BookshelfRepo::class)->getAllPaginated(18, $commonData['listOptions']->getSort(), $commonData['listOptions']->getOrder());
$data = array_merge($commonData, ['shelves' => $shelves]);
return view('home.shelves', $data);
}
if ($homepageOption === 'books') {
- $books = app(BookRepo::class)->getAllPaginated(18, $commonData['listOptions']->getSort(), $commonData['listOptions']->getOrder());
+ $books = app()->make(BookRepo::class)->getAllPaginated(18, $commonData['listOptions']->getSort(), $commonData['listOptions']->getOrder());
$data = array_merge($commonData, ['books' => $books]);
return view('home.books', $data);
// Custom blade view directives
Blade::directive('icon', function ($expression) {
- return "<?php echo icon($expression); ?>";
+ return "<?php echo (new \BookStack\Util\SvgIcon($expression))->toHtml(); ?>";
});
}
}
}
// Check permission on ownable item
- $permissions = app(PermissionApplicator::class);
+ $permissions = app()->make(PermissionApplicator::class);
return $permissions->checkOwnableUserAccess($ownable, $permission);
}
*/
function userCanOnAny(string $action, string $entityClass = ''): bool
{
- $permissions = app(PermissionApplicator::class);
+ $permissions = app()->make(PermissionApplicator::class);
return $permissions->checkUserHasEntityPermissionOnAny($action, $entityClass);
}
*/
function setting(string $key = null, $default = null)
{
- $settingService = resolve(SettingService::class);
+ $settingService = app()->make(SettingService::class);
if (is_null($key)) {
return $settingService;
return base_path('themes/' . $theme . ($path ? DIRECTORY_SEPARATOR . $path : $path));
}
-/**
- * Get fetch an SVG icon as a string.
- * Checks for icons defined within a custom theme before defaulting back
- * to the 'resources/assets/icons' folder.
- *
- * Returns an empty string if icon file not found.
- */
-function icon(string $name, array $attrs = []): string
-{
- $attrs = array_merge([
- 'class' => 'svg-icon',
- 'data-icon' => $name,
- 'role' => 'presentation',
- ], $attrs);
- $attrString = ' ';
- foreach ($attrs as $attrName => $attr) {
- $attrString .= $attrName . '="' . $attr . '" ';
- }
-
- $iconPath = resource_path('icons/' . $name . '.svg');
- $themeIconPath = theme_path('icons/' . $name . '.svg');
-
- if ($themeIconPath && file_exists($themeIconPath)) {
- $iconPath = $themeIconPath;
- } elseif (!file_exists($iconPath)) {
- return '';
- }
-
- $fileContents = file_get_contents($iconPath);
-
- return str_replace('<svg', '<svg' . $attrString, $fileContents);
-}
-
/**
* Generate a URL with multiple parameters for sorting purposes.
* Works out the logic to set the correct sorting direction
class BreadcrumbsViewComposer
{
- protected $entityContextManager;
-
- /**
- * BreadcrumbsViewComposer constructor.
- *
- * @param ShelfContext $entityContextManager
- */
- public function __construct(ShelfContext $entityContextManager)
- {
- $this->entityContextManager = $entityContextManager;
+ public function __construct(
+ protected ShelfContext $shelfContext
+ ) {
}
/**
* Modify data when the view is composed.
- *
- * @param View $view
*/
- public function compose(View $view)
+ public function compose(View $view): void
{
$crumbs = $view->getData()['crumbs'];
$firstCrumb = $crumbs[0] ?? null;
+
if ($firstCrumb instanceof Book) {
- $shelf = $this->entityContextManager->getContextualShelfForBook($firstCrumb);
+ $shelf = $this->shelfContext->getContextualShelfForBook($firstCrumb);
if ($shelf) {
array_unshift($crumbs, $shelf);
$view->with('crumbs', $crumbs);
$page->allRevisions()->delete();
// Delete Attached Files
- $attachmentService = app(AttachmentService::class);
+ $attachmentService = app()->make(AttachmentService::class);
foreach ($page->attachments as $attachment) {
$attachmentService->deleteFile($attachment);
}
*/
public function refreshSlug(): string
{
- $this->slug = app(SlugGenerator::class)->generate($this);
+ $this->slug = app()->make(SlugGenerator::class)->generate($this);
return $this->slug;
}
--- /dev/null
+<?php
+
+namespace BookStack\Util;
+
+class SvgIcon
+{
+ public function __construct(
+ protected string $name,
+ protected array $attrs = []
+ ) {
+ }
+
+ public function toHtml(): string
+ {
+ $attrs = array_merge([
+ 'class' => 'svg-icon',
+ 'data-icon' => $this->name,
+ 'role' => 'presentation',
+ ], $this->attrs);
+
+ $attrString = ' ';
+ foreach ($attrs as $attrName => $attr) {
+ $attrString .= $attrName . '="' . $attr . '" ';
+ }
+
+ $iconPath = resource_path('icons/' . $this->name . '.svg');
+ $themeIconPath = theme_path('icons/' . $this->name . '.svg');
+
+ if ($themeIconPath && file_exists($themeIconPath)) {
+ $iconPath = $themeIconPath;
+ } elseif (!file_exists($iconPath)) {
+ return '';
+ }
+
+ $fileContents = file_get_contents($iconPath);
+
+ return str_replace('<svg', '<svg' . $attrString, $fileContents);
+ }
+}