承接 proside/file-manager 相关项目开发

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

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

proside/file-manager

Composer 安装命令:

composer require proside/file-manager

包简介

File Manager reutilizável para Laravel, construído em Livewire v4 (substitui o File Manager Next.js da Proside).

README 文档

README

Gestor de ficheiros reutilizável para Laravel 10/11/12 construído integralmente em Livewire v4. Substitui o antigo File Manager em Next.js/React, mantendo paridade funcional e melhorando a arquitetura: sem iframe, sem JWT, sem serviço externo — corre dentro da própria aplicação Laravel e usa a autenticação/sessão existente.

Compatível com Laravel 10.49 e PHP 8.1+. Requer Livewire ^4.0.

Funcionalidades

  • Árvore de diretórios lateral com lazy-load e expandir/colapsar
  • Vistas em grelha e lista
  • Filtros (Tudo / Pastas / Imagens / Vídeos) e ordenação (A–Z / Z–A)
  • Breadcrumbs de navegação
  • Seleção simples e múltipla (Shift)
  • Menu de contexto: criar subpasta, renomear, eliminar, visualizar, descarregar, escolher
  • Upload por botão flutuante (FAB) e por arrastar ficheiros do sistema
  • Mover por drag & drop (incluindo múltiplos itens) para pastas ou para a árvore
  • Lixo (apagados) com retenção configurável e expiração automática
  • Restaurar itens do lixo (novo) e eliminação definitiva
  • Pré-visualização (lightbox) de imagens e vídeos
  • Pesquisa funcional por nome (o FM antigo não pesquisava)
  • Pronto para picker de ficheiros em formulários (<x-file-manager::picker>)
  • Multi-disco (local/public, S3, …) via Filesystem do Laravel
  • Traduções PT/EN, totalmente publicáveis

Instalação

composer require proside/file-manager

O Service Provider, rotas, componente Livewire e componentes Blade são registados automaticamente (package discovery).

1. Garantir o disco e o symlink

Por omissão usa o disco public. Crie o symlink uma vez:

php artisan storage:link

2. (Opcional) Publicar recursos

php artisan vendor:publish --tag=file-manager-config    # config/file-manager.php
php artisan vendor:publish --tag=file-manager-views     # resources/views/vendor/file-manager
php artisan vendor:publish --tag=file-manager-lang      # lang/vendor/file-manager
php artisan vendor:publish --tag=file-manager-assets    # public/vendor/file-manager/file-manager.css

3. Tailwind (importante)

O package usa classes utilitárias Tailwind (paleta teal, equivalente ao antigo proximo). Se a sua app compila Tailwind, adicione o caminho das vistas do package ao content do tailwind.config.js para que as classes sejam geradas:

content: [
    // ...
    './vendor/proside/file-manager/resources/views/**/*.blade.php',
],

4. Agendar a limpeza do lixo

Em app/Console/Kernel.php:

$schedule->command('file-manager:prune-trash')->daily();

Utilização

Página inteira

Já existe a rota GET /file-manager (configurável). Ou embeba o componente onde quiser:

<div style="height: 80vh">
    <livewire:file-manager />
</div>

Picker em formulários (drop-in)

Substitui o antigo <x-file-manager-modal> com a mesma API de props:

{{-- Um ficheiro --}}
<x-file-manager::picker input-name="gfqueue_image" :value="$queue->image ?? ''" />

{{-- Vários ficheiros --}}
<x-file-manager::picker input-name="imagens[]" :value="$existing" multiple />

{{-- Forçar apenas imagens (ou 'videos') --}}
<x-file-manager::picker input-name="icon" filter="images" />

O ficheiro escolhido fica num <input type="hidden" name="..."> — o submit do formulário funciona exatamente como antes. Ao escolher, o componente emite o evento Livewire file-manager-selected ({ paths: [...] }).

Configuração (config/file-manager.php)

Chave Omissão Descrição
disk public Disco do Filesystem
root conteudos Pasta base navegável
trash apagados Pasta do lixo
trash_retention_days 30 Dias até eliminação definitiva
uploads.max_size 51200 (KB) Tamanho máximo por ficheiro
uploads.mimes null Mimes aceites (null = todos)
media_url auto auto / route / storage
route.* Prefixo, middleware e rota full-page

Variáveis .env: FILE_MANAGER_DISK, FILE_MANAGER_ROOT, FILE_MANAGER_TRASH, FILE_MANAGER_TRASH_DAYS, FILE_MANAGER_MAX_UPLOAD, FILE_MANAGER_MEDIA_URL, FILE_MANAGER_ROUTE, FILE_MANAGER_ROUTE_PREFIX.

Correspondência Next.js → Livewire

Antigo (Next.js/React) Novo (Livewire v4)
FileManagerContext.js (estado global React) Propriedades públicas + #[Computed] em FileManager.php
FileManager.jsx (layout) resources/views/livewire/file-manager.blade.php
Files.jsx (grid/lista) partials/grid-item.blade.php, partials/list-item.blade.php
NavItem.jsx (árvore) partials/tree-node.blade.php + tree() computed
ContextMenu.jsx partials/context-menu.blade.php (Alpine)
Modal.jsx partials/modal.blade.php (Alpine)
ShowFile.jsx (lightbox) partials/lightbox.blade.php
Filters.jsx, BreadCrumbs.js toolbar na view principal + breadcrumbs()
AddFile.jsx (FAB + upload) FAB na view + wire:model="uploads" + updatedUploads()
api/files, api/files/tree FileManagerService::listing() / tree()
api/folders, api/rename, api/move createFolder() / rename() / move()
api/delete, api/delete/cleanup trash() + file-manager:prune-trash
api/upload, image/route.js upload() + MediaController (rota file-manager.media)
verify-token, TokenListener.jsx (JWT) eliminado — usa auth/sessão do Laravel
iframe + postMessage(SELECTED_FILE) <x-file-manager::picker> + evento file-manager-selected

Melhorias face à versão anterior

  • Sem serviço externo: deixa de ser preciso FILE_MANAGER_URL, proxy HTTP, JWT RS256 e chaves .pem.
  • Segurança: auth nativa do Laravel + PathGuard contra path traversal.
  • Retenção do lixo correta: era 60s no código (texto dizia 30 dias); agora é configurável (30 por omissão).
  • Restaurar itens do lixo (não existia).
  • Pesquisa funcional (não existia).
  • Multi-disco via Filesystem (S3-ready), em vez de fs direto no public/.
  • Navegação preservada ao filtrar por imagens/vídeos (pastas continuam visíveis).
  • Limpeza do lixo por comando agendado em vez de polling no cliente.

Integração no Backoffice Proside: ver docs/BACKOFFICE-INTEGRATION.md.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-06-17

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固