diff --git a/app/Helper/Common.php b/app/Helper/Common.php new file mode 100644 index 0000000..89c4f6c --- /dev/null +++ b/app/Helper/Common.php @@ -0,0 +1,29 @@ + 'nullable|array', + "$key.*" => ['nullable', 'string', Rule::in(['asc', 'desc'])], + ]; + } + public static function getSearchValidation() { return 'nullable|string'; } + } +?> \ No newline at end of file diff --git a/app/Helper/Traits/Models/CanMultiOrderBy.php b/app/Helper/Traits/Models/CanMultiOrderBy.php new file mode 100644 index 0000000..c192e6b --- /dev/null +++ b/app/Helper/Traits/Models/CanMultiOrderBy.php @@ -0,0 +1,18 @@ + $direction) { + $queryBuilder->orderBy($column, $direction); + } + } else if($defaultOrderBy) { + $queryBuilder->orderByRaw($defaultOrderBy); + } + } +} diff --git a/app/Helper/Traits/Models/CanMultiSearch.php b/app/Helper/Traits/Models/CanMultiSearch.php new file mode 100644 index 0000000..365db91 --- /dev/null +++ b/app/Helper/Traits/Models/CanMultiSearch.php @@ -0,0 +1,20 @@ +where(function($q) use($search, $searchColumns) { + foreach($searchColumns as $column) { + $q->orWhere($column, 'ilike', "%$search%"); + } + }); + } +}