An open API service indexing awesome lists of open source software.

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

Awesome Lists containing this project

README

        

# FoF Links

![License](https://img.shields.io/badge/license-MIT-blue.svg) [![Latest Stable Version](https://img.shields.io/packagist/v/fof/links.svg)](https://packagist.org/packages/fof/links) [![Total Downloads](https://img.shields.io/packagist/dt/fof/links.svg)](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).