mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-25 20:51:30 -08:00
Merge pull request #15518 from snipe/sort_by_numeric_custom_fields
Fixed #11634 - Sort by numeric columns for numeric custom fields
This commit is contained in:
commit
454796e52a
|
@ -372,7 +372,29 @@ class AssetsController extends Controller
|
||||||
$assets->OrderAssigned($order);
|
$assets->OrderAssigned($order);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
$assets->orderBy($column_sort, $order);
|
$numeric_sort = false;
|
||||||
|
|
||||||
|
// Search through the custom fields array to see if we're sorting on a custom field
|
||||||
|
if (array_search($column_sort, $all_custom_fields->pluck('db_column')->toArray()) !== false) {
|
||||||
|
|
||||||
|
// Check to see if this is a numeric field type
|
||||||
|
foreach ($all_custom_fields as $field) {
|
||||||
|
if (($field->db_column == $sort_override) && ($field->format == 'NUMERIC')) {
|
||||||
|
$numeric_sort = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// This may not work for all databases, but it works for MySQL
|
||||||
|
if ($numeric_sort) {
|
||||||
|
$assets->orderByRaw($sort_override . ' * 1 ' . $order);
|
||||||
|
} else {
|
||||||
|
$assets->orderBy($sort_override, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
$assets->orderBy($column_sort, $order);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue