dnadesign/silverstripe-setmenu

A SilverStripe module for managing configurable and sortable menu sets.

Installs: 1

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 6

Forks: 1

Open Issues: 0

Type:silverstripe-vendormodule

2.0.0 2023-10-29 22:24 UTC

This package is auto-updated.

Last update: 2024-05-01 22:11:18 UTC


README

A Silverstripe module to define menu sets for different purposes.

Credit

This module was inspired by the following modules, but modified for our tastes:

Requirements

This module is baked for Silverstripe 4 and Php 8

Installation

This module is not yet published on packagist, so install the module by including it in your composer.json with a repository definition.

    "require": {
        "dnadesign/silverstripe-setmenu": "dev-master"
    },
    "repositories": [
        {
            "type": "vcs",
            "url": "https://github.com/dnadesign/silverstripe-setmenu.git"
        }
    ],

Configuration

Define the MenuSets and the group they belong to in .yml configuration by setting default_sets.

  • Key: Initial name of the MenuSet.
  • Value: Group the MenuSet belongs to.
DNADesign\SetMenu\Model\MenuSet:
  default_sets:
    Main nav: Main
    Main footer: Footer
    Secondary footer: Footer
    Auxilliary Footer: Footer

On /dev/build they will be created automatically.

Migration from MenuManager

The classes in this module are namespaced, and the table names are plural, so this module is able to be installed without removing MenuManager first.

The intent for this is to allow a migration from MenuManager to Set Menu other by first deploying the module, creating the menus in the production environment, then later, deploying the template changes.

This avoids a state where the content must be hurriedly created after deployment.

Usage

Use the $MenuType('Name') template function to retrieve the MenuSet DataList:

<% loop $MenuType('Footer') %>
    <p>$Name</p>
    <% loop $MenuItems %>
        <a href="{$Link}" class="{$LinkingMode}"
            <% if $NewWindow %>
                target="_blank"
                rel="noopener"
            <% end_if %>
        >
            {$Title}
        </a>
    <% end_loop %>
<% end_loop %>

Permissions

In /admin/security/, add the Access to 'Menus' section and Manage Menus permissions to a group to view and edit the menu objects.

Subsites

This module is configured to operate with or without the Subsites module.

Tasks

The module comes with a task to truncate the MenuSets, which may be helpful for development purposes. This can be enabled on PROD if required.

DNADesign\SetMenu\Model\MenuSet:
  prod_truncate_permission: true

TODO

  • Currently, when using Subsites, the same MenuSets will be created for each subsite.
    • Update the configuration documentation and requireDefaultRecords() functionality in MenuSetSubsiteExtension to allow different configuration per Subsite.