-
-/**
- * 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
- * Discards empty parameters and allows overriding.
- */
-function sortUrl(string $path, array $data, array $overrideData = []): string
-{
- $queryStringSections = [];
- $queryData = array_merge($data, $overrideData);
-
- // Change sorting direction is already sorted on current attribute
- if (isset($overrideData['sort']) && $overrideData['sort'] === $data['sort']) {
- $queryData['order'] = ($data['order'] === 'asc') ? 'desc' : 'asc';
- } elseif (isset($overrideData['sort'])) {
- $queryData['order'] = 'asc';
- }
-
- foreach ($queryData as $name => $value) {
- $trimmedVal = trim($value);
- if ($trimmedVal === '') {
- continue;
- }
- $queryStringSections[] = urlencode($name) . '=' . urlencode($trimmedVal);
- }
-
- if (count($queryStringSections) === 0) {
- return url($path);
- }
-
- return url($path . '?' . implode('&', $queryStringSections));
-}