wangta69 / laravel-board
BBS bulletin board system
Installs: 63
Dependents: 2
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 1
pkg:composer/wangta69/laravel-board
Requires
- php: >=7.0.0
- wangta69/laravel-auth: ^8.12
- wangta69/laravel-components: *
- wangta69/laravel-editor: *
- wangta69/laravel-meta: ^8.12
- wangta69/laravel-pondol: ^8.12
- wangta69/php-thumbnail: ^1
README
A Korean-style Bulletin Board System (BBS) package for Laravel.
한국형 계층형 게시판(BBS)을 라라벨에서 쉽고 빠르게 구축하기 위한 패키지입니다.
💡 Overview
This library is designed to implement the hierarchical board structure (List, View, Write, Reply, Comment) commonly used in Korea within the Laravel environment. It supports Bootstrap 5 by default.
이 라이브러리는 길라(Gilra) (Online Fortune Service)의 커뮤니티 및 공지사항 기능을 구축하는 데 실제로 사용되었습니다.
- Demo: Live Demo Link
- Official Docs: Documentation
🚀 Features
- Korean Style BBS: Hierarchical posts (Reply), Comments, Secret posts.
- Admin Panel: Built-in controller and views for board management.
- Thumbnails: Real-time thumbnail generator helper.
- Widgets: Latest posts widget helper.
- Comments Component: Easily add comment functionality to any model.
📦 Installation
Requirements
- PHP >= 7.4
- Laravel >= 8.x (Tested on 8.x ~ 11.x)
- Bootstrap 5.x
- jQuery 3.6.x
1. Require the package via Composer
composer require wangta69/laravel-board
2. Install Assets & Config
Run the installation command to publish assets and migration files.
php artisan pondol:install-bbs
🛠 Configuration & Usage
1. Admin Security Setup
After installation, you should secure the Admin Controller.
Go to App/Http/Controllers/Bbs/Admin/BbsController.php (or similar admin controllers) and set up the middleware or permission check in the __construct method.
public function __construct() { $this->middleware('auth'); // Example: Check for administrator role // if (!Auth::user()->hasRole('administrator')) { // abort(403, 'Unauthorized action.'); // } }
2. Create a Board
- Access the admin panel:
http://YourDomain/bbs/admin - Create a new board configuration (e.g., table name:
notice). - (Optional) If you need a role management system:
php artisan make:model Role -m
3. Access the Board
- Admin URL:
http://YourDomain/bbs/admin/tbl/{table_name} - User URL:
http://YourDomain/bbs/{table_name}
🎨 Helpers & Components
Real-time Thumbnail
Generate thumbnails on the fly.
<!-- usage: bbs_get_thumb($image_path, $width, $height) --> <img src="{{ bbs_get_thumb($article->image, 205, 205) }}" alt="{{ $article->title }}" />
Latest Posts Widget
Display the latest posts from a specific board.
public function index() { // usage: bbs_get_latest(['table' => 'table_name', 'cnt' => count]) $notices = bbs_get_latest(['table' => 'notice', 'cnt' => 5]); return view('welcome', compact('notices')); }
Forum (Comment) Component
You can attach a comment section to any arbitrary model or page, not just the BBS.
<x-item-comments item="story" :itemId="$story->id" skin="default" />
- skin: Skin name (currently 'default' is available).
- item: Target category or model name (string).
- itemId: Unique ID of the target content.
📂 Customization
To customize the templates, look into the resources/views/bbs/templates directory. You can duplicate an existing template and modify it to create your own skin.
📜 License
The MIT License (MIT). Please see License File for more information.