fof / links
Manage Flarum primary navbar menu links
Fund package maintenance!
Website
Installs: 79 166
Dependents: 3
Suggesters: 0
Security: 0
Stars: 38
Watchers: 7
Forks: 12
Open Issues: 0
Type:flarum-extension
Requires
- php: ^8.0
- flarum/core: ^1.8.6
Requires (Dev)
- flarum/phpstan: *
- flarum/tags: *
- flarum/testing: ^1.0.0
Replaces
This package is auto-updated.
Last update: 2025-03-21 06:54:23 UTC
README
A Flarum 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:
composer require fof/links
Updating
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
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:
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:
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
An extension by FriendsOfFlarum.