承接 dynamikasolucoesweb/laravel-adaptive-menu 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

dynamikasolucoesweb/laravel-adaptive-menu

最新稳定版本:v1.0.0

Composer 安装命令:

composer require dynamikasolucoesweb/laravel-adaptive-menu

包简介

Complex, adaptable, responsive and self-correcting menu for Laravel.

README 文档

README

php version pkg version license quality build

O Laravel Adaptive Menu é um componente Blade que transforma arrays complexos em menus responsivos e auto-ajustáveis. Ele redistribui sub-itens automaticamente para manter o equilíbrio visual do layout.

Instalação

A maneira preferida de instalar esta extensão é através do [composer] composer.

Ou corre

$ composer require dynamikasolucoesweb/laravel-adaptive-menu "*"

ou adicione

"dynamikasolucoesweb/laravel-adaptive-menu": "*"

à seção require do seu arquivo composer.json.

Assets & Customização

Por padrão, a biblioteca injeta automaticamente o CSS e JS necessários.

Caso deseje customizar os estilos ou scripts, você pode publicá-los em sua pasta pública:

$ php artisan vendor:publish --tag=adaptive-menu-assets

Isso copiará os arquivos para public/vendor/dynamikasolucoesweb/adaptive-menu. A biblioteca passará a usar esses arquivos automaticamente, melhorando a performance.

⚠️ Requisito do Layout

Para que os estilos e scripts sejam injetados automaticamente, seu arquivo de layout base precisa conter a diretiva @adaptiveMenuAssets:

<head>
    {{-- Injeta automaticamente o CSS e JS do Menu --}}
    @adaptiveMenuAssets
    
    @stack('css')
</head>
<body>
    <x-adaptive-menu :items="$menuTree" :max-items="5" id="main-navigation" />
    
    @stack('scripts')
</body>

Uso

Certifique-se de que seu layout principal possua a diretiva @adaptiveMenuAssets. Basta chamar o componente e passar o seu array de itens. Também é possível informar a quantidade máxima de itens por menu através da variável max-items. O componente gerencia o cache e a normalização dos dados automaticamente.

<x-adaptive-menu :items="$menuTree" :max-items="5" id="main-navigation" />

Estrutura do Array

O componente aceita uma estrutura de árvore. Abaixo, um exemplo de como formatar os dados (seja via Model ou Array estático):

$menuTree = [
    [
        'label' => 'Institucional',
        'url' => '/quem-somos',
        'target' => '_self',
        'items' => [
            [
                'label' => 'Nossa História',
                'url' => '/historia',
                'target' => '_self',
                'items' => []
            ],
            [
                'label' => 'Equipe',
                'url' => '/equipe',
                'target' => '_self',
                'items' => []
            ],
        ]
    ],
    [
        'label' => 'Serviços',
        'url' => '/#',
        'target' => '_self',
        'content' => '<p>Texto customizado ou HTML</p>', // Conteúdo opcional
        'items' => [
            [
                'label' => 'Desenvolvimento Web',
                'url' => '/dev',
                'target' => '_blank',
                'content' => '<p>Texto customizado ou HTML</p>', // Conteúdo opcional
                'items' => []
            ],
            [
                'label' => 'Design',
                'url' => '/design',
                'target' => '_self',
                'items' => []
            ],
        ]
    ]
];

⚡ Performance & Cache

O componente utiliza uma camada de cache inteligente que se adapta ao ambiente:

  • Production: Cache automático de 24h. O cache é invalidado automaticamente se os itens do menu forem alterados ou se o arquivo da biblioteca for atualizado.
  • Development: Se APP_DEBUG=true, o cache é ignorado para refletir mudanças instantâneas.

Features

Auto-Correction: Quando um grupo de itens excede o limite definido em max-items, a biblioteca cria novos grupos (_auto) para evitar quebras de layout.

Smart Caching: Em ambientes de produção (APP_DEBUG=false), o componente gera um hash único e armazena o HTML renderizado no cache por 24 horas.

Slug Generation: Gera automaticamente slugs para os IDs dos menus a partir dos labels.

Flexible Content: Suporte nativo para campos de content (HTML) dentro dos sub-menus.

Authors

Giordani da Silveira dos Santos - giordani@dynamika.com.br

dynamika soluções web This project is under BSD-3-Clause license.

统计信息

  • 总下载量: 9
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2026-02-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固