https://github.com/FriendsOfFlarum/links
Manage Flarum primary navigation links
https://github.com/FriendsOfFlarum/links
flarum friendsofflarum hacktoberfest
Last synced: 28 days ago
JSON representation
Manage Flarum primary navigation links
- Host: GitHub
- URL: https://github.com/FriendsOfFlarum/links
- Owner: FriendsOfFlarum
- License: mit
- Created: 2019-01-06T16:56:04.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-14T13:19:55.000Z (6 months ago)
- Last Synced: 2024-10-29T22:37:24.316Z (6 months ago)
- Topics: flarum, friendsofflarum, hacktoberfest
- Language: PHP
- Size: 1000 KB
- Stars: 37
- Watchers: 8
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-flarum - FoF Links - Manage Flarum primary navigation links. (Extensions / Forum Appearance ([:top:](#table-of-contents)))
README
# FoF Links
 [](https://packagist.org/packages/fof/links) [](https://packagist.org/packages/fof/links)
A [Flarum](http://flarum.org) extension that allows you to add links to your forum's navigation.
## Features
- Add links to your forum's navigation menu
- Support for both internal and external links
- Control link visibility based on user groups
- Guest-only links
- Hierarchical links (dropdown menus)
- Programmatic link definition via PHP## Installation
Install with composer:
```bash
composer require fof/links
```## Updating
```bash
composer update fof/links
php flarum cache:clear
```## Usage
### Admin Interface
Links can be managed through the admin interface under the "Links" tab.
### Programmatic Link Definition
This extension provides a way to define links programmatically through PHP code. This can be useful in situations where there are multiple environments (ie dev, staging, production) and you want to define a set of links only once (in code), and not have to re-enter or define them via the admin interface.
#### Basic Usage
```php
use FoF\Links\Extend\LinksOverride;
use FoF\Links\LinkDefinition;return [
// Other extenders...
(new LinksOverride())
->addLinks([
LinkDefinition::make()
->withId(1)
->withTranslationKey('my-extension.link')
->withUrl('/my-page')
->withIcon('fas fa-link')
->withIsInternal(true)
])
];
```#### Hierarchical Links
You can create dropdown menus by adding child links:
```php
use FoF\Links\Extend\LinksOverride;
use FoF\Links\LinkDefinition;$parent = LinkDefinition::make()
->withId(1)
->withTranslationKey('my-extension.parent')
->withUrl('/parent');$child1 = LinkDefinition::make()
->withId(2)
->withTranslationKey('my-extension.child1')
->withUrl('/child1');$child2 = LinkDefinition::make()
->withId(3)
->withTranslationKey('my-extension.child2')
->withUrl('/child2');$parent->addChild($child1);
$parent->addChild($child2);return [
// Other extenders...
(new LinksOverride())
->addLinks([$parent])
];
```#### Using a Provider Class
For more complex scenarios, you can use a provider class:
```php
use FoF\Links\Extend\LinksOverride;
use FoF\Links\LinkDefinition;class MyLinksProvider
{
public function __invoke()
{
return [
LinkDefinition::make()
->withId(1)
->withTranslationKey('my-extension.link')
->withUrl('/my-page')
];
}
}return [
// Other extenders...
(new LinksOverride())
->addLinks(MyLinksProvider::class)
];
```### LinkDefinition API
The `LinkDefinition` class provides a fluent interface for defining links:
| Method | Description |
|--------|-------------|
| `withId(int $id)` | Set the link ID |
| `withTranslationKey(string $key)` | Set the translation key for the link title |
| `withUrl(string $url)` | Set the link URL |
| `withIcon(string $icon)` | Set the link icon (FontAwesome class) |
| `withIsInternal(bool $isInternal)` | Set whether the link is internal |
| `withIsNewtab(bool $isNewtab)` | Set whether the link should open in a new tab |
| `withUseRelme(bool $useRelme)` | Set whether to use rel="me" attribute |
| `withGuestOnly(bool $guestOnly)` | Set whether the link is only visible to guests |
| `withParentId(?int $parentId)` | Set the parent link ID |
| `withPosition(int $position)` | Set the link position |
| `addChild(LinkDefinition $child)` | Add a child link |## Links
- [Packagist](https://packagist.org/packages/fof/links)
- [GitHub](https://github.com/FriendsOfFlarum/links)
- [Discuss](https://discuss.flarum.org/d/18335)An extension by [FriendsOfFlarum](https://github.com/FriendsOfFlarum).