mirror of https://github.com/abpframework/abp.git
committed by
GitHub
2 changed files with 50 additions and 0 deletions
@ -0,0 +1,46 @@ |
|||
# Sorting Navigation Elements |
|||
This documentation describes how the navigation elements are sorted and how to change this default behaviour. |
|||
|
|||
When you want to add the `Navigation Element` you can use the `RoutesService`. For more details, see the [document](https://docs.abp.io/en/abp/latest/UI/Angular/Modifying-the-Menu#how-to-add-a-navigation-element). |
|||
However, in this documentation, we will talk more about how to sort the navigation elements with the `order` attribute from the `Routes Service`. |
|||
|
|||
|
|||
### Order Property |
|||
- This parameter is optional and is used for sorting purposes. |
|||
- If you define this property it will be sorted by the default sorting function. |
|||
- You can edit this function. |
|||
|
|||
**Default Compare Function;** |
|||
``compare-func.token.ts`` |
|||
```ts |
|||
export const SORT_COMPARE_FUNC = new InjectionToken<0 | 1 | -1>('SORT_COMPARE_FUNC'); |
|||
|
|||
export function compareFuncFactory() { |
|||
const localizationService = inject(LocalizationService); |
|||
const fn = (a,b) => { |
|||
const aName = localizationService.instant(a.name); |
|||
const bName = localizationService.instant(b.name); |
|||
|
|||
const aNumber = a.order; |
|||
const bNumber = b.order; |
|||
|
|||
if (!Number.isInteger(aNumber)) return 1; |
|||
if (!Number.isInteger(bNumber)) return -1; |
|||
|
|||
if (aNumber > bNumber) return 1 |
|||
if (aNumber < bNumber) return -1 |
|||
|
|||
if (aName > bName ) return 1; |
|||
if (aName < bName ) return -1; |
|||
|
|||
return 0 |
|||
} |
|||
return fn; |
|||
} |
|||
``` |
|||
**What does this function do?** |
|||
- if the order property is defined, then it will be sorted by the order value. |
|||
- if both of the navigation elements have the same order value then it will be sorted by the name. |
|||
- If the order property is not defined, it will be the last element and the unordered navs will be sorted by name. |
|||
|
|||
You can edit this sorting function behaviour as you wish. |
|||
Loading…
Reference in new issue