Đăng bởi:
Nguyễn Viết HiếuĐăng ngày:
Mar 30, 2021Đăng ở:
Kiến Thức Cơ BảnTại phần 2, chúng ta đã tìm hiểu được cách tạo Package với đầy đủ các thành phần cơ bản như Route và cấu trúc MVC. Tại phần 3 này chúng ta sẽ tiếp tục với các thành phần cơ bản và quan trọng khác mà một Package cần có.
Mình sẽ lại tiếp tục đặt cấu trúc thư mục dưới đây để mọi người có thể hình dung lại cấu trúc của package đã được tạo từ 2 phần trước:
packages
├── demo
│ ├── configs
│ │ └── demo.php
│ ├── helpers
│ │ └── functions.php
│ ├── migrations
│ ├── resources
│ │ └── assets
│ │ └── lang
│ │ └── views
│ ├── routes
│ │ └── routes.php
│ ├── src
│ │ └── Commands
│ │ └── Http
│ │ | └── Controllers
│ │ | | └── DemoController.php
│ │ | └── Middlewares
│ │ └── Models
│ │ | └── Demo.php
│ │ └── Providers
│ │ | └── DemoServiceProvider.php
│ ├── composer.json
│ ├── Readme.md
├── demo2
│ ├── ...
Config tại package được dùng để cấu hình và định nghĩa các giá trị có sử dụng tại Package. Tính năng và công dụng của file Config tại Package giống với các file Config mặc định. Và để khai báo chúng ta sẽ khai báo tại hàm Boot ở DemoServiceProvider:
// /packages/demo/src/Providers/DemoServiceProvider.php
...
public function boot()
{
$modulePath = __DIR__.'/../../';
$moduleName = 'Demo';
...
// boot route
if (File::exists($modulePath."routes/routes.php")) {
$this->loadRoutesFrom($modulePath."/routes/routes.php");
}
...
}
...
Ngày nay, đa phần các website đều sử dụng đa ngôn ngữ để có thể dễ dàng tiếp cận và đáp ứng nhiều nhu cầu của nhiều loại khách hàng. Như chúng ta đã biết thì các vấn đề về đa ngôn ngữ trong Laravel được hỗ trợ và giải quyết cực kỳ dễ dàng.
Để có thể sử dụng đa ngôn ngữ tại package thì chúng ta có thể khai báo theo 2 dạng:
Chúng ta sẽ tạo 2 file php theo ngôn ngữ với cấu trúc và nội dung dung sau:
// Khai báo đa ngôn ngữ với bản tiếng anh
// packages/demo/resources/lang/en/demo.php
<?php
return [
'name' => 'Demo',
];
// Khai báo đa ngôn ngữ với bản tiếng việt
// packages/demo/resources/lang/vi/demo.php
<?php
return [
'name' => 'Ví dụ',
];
Tiếp đến chúng ta sẽ khai báo tại DemoServiceProvider:
// /packages/demo/src/Providers/DemoServiceProvider.php
...
public function boot()
{
$modulePath = __DIR__.'/../../';
$moduleName = 'Demo';
...
// boot languages
if (File::exists($modulePath . "resources/lang")) {
$this->loadTranslationsFrom($modulePath . "resources/lang", $moduleName);
}
...
}
...
Vậy là xong, để sử dụng thì chúng ta chỉ cần gọi trans('Demo::demo.name') hoặc __('Demo::demo.name') với Demo chính là $moduleName.
Chúng ta sẽ tạo file json theo ngôn ngữ với cấu trúc và nội dung dung sau:
// Khai báo đa ngôn ngữ với bản tiếng anh
// packages/demo/resources/lang/en.json
{
"Đây là Demo 1": "This is Demo 1",
"Đây là Demo 2": "This is Demo 2"
}
Tiếp đến chúng ta sẽ khai báo tại DemoServiceProvider:
// /packages/demo/src/Providers/DemoServiceProvider.php
...
public function boot()
{
$modulePath = __DIR__.'/../../';
$moduleName = 'Demo';
...
// boot languages
if (File::exists($modulePath . "resources/lang")) {
$this->loadJSONTranslationsFrom($modulePath . 'resources/lang');
}
...
}
...
Để sử dụng thì chúng ta chỉ cần gọi trans('Đây là Demo 1') hoặc __('Đây là Demo 1').
Để có thể đa dạng phương thức nhập ngôn ngữ chúng ta có thể sử dụng cả 2 dạng trên bằng cách khai báo như sau:
// /packages/demo/src/Providers/DemoServiceProvider.php
...
public function boot()
{
$modulePath = __DIR__.'/../../';
$moduleName = 'Demo';
...
// boot languages
if (File::exists($modulePath . "resources/lang")) {
$this->loadTranslationsFrom($modulePath . "resources/lang", $moduleName);
$this->loadJSONTranslationsFrom($modulePath . 'resources/lang');
}
...
}
...
Chúng ta có thể tự định nghĩa các Helper của riêng mình tại "packages/demo/helpers/functions.php". Lưu ý tên file không nhất thiết phải là functions.php nhé.
Chúng ta sẽ khai báo Helpers tại hàm Boot:
// /packages/demo/src/Providers/DemoServiceProvider.php
...
public function boot()
{
$modulePath = __DIR__.'/../../';
$moduleName = 'Demo';
...
// boot all helpers
if (File::exists($modulePath . "helpers")) {
// Lây thông tin file tại thư mục helpers
$helper_dir = File::allFiles($modulePath . "helpers");
// Khai báo helpers
foreach ($helper_dir as $key => $value) {
$file = $value->getPathName();
require $file;
}
}
...
}
...
Như vậy là chúng ta đã có thể sử dụng Helper do chính mình định nghĩa rồi.
Hẳn chúng ta không còn xa lạ gì mới migrations rồi. Để có thể tạo 1 file migrations tại packages chúng ta có thể sử dụng command sau:
php artisan make:migration create_demo_table --path=packages/demo/migrations
Cuối cùng để khai báo migrations tại package chúng ta sẽ tiếp tục khai báo tại hàm boot của DemoServiceProvider:
// /packages/demo/src/Providers/DemoServiceProvider.php
...
public function boot()
{
$modulePath = __DIR__.'/../../';
$moduleName = 'Demo';
...
// boot migration
if (File::exists($modulePath . "migrations")) {
$this->loadMigrationsFrom($modulePath . "migrations");
}
...
}
...
Lúc này chúng ta có thể sử dụng command "php artisan migrate" để có thể chạy các migrations chúng ta đã định nghĩa rồi.
Như vậy là chúng ta đã cùng nhau tìm hiểu được các thành phần cơ bản của một package, với các thành phần này chúng ta đã có thể tạo ra những package phục vụ cho các dự án sau này rồi. Có cơ bản thì sẽ có nâng cao, ở bài viết sau chúng ta sẽ tiếp tục cùng nhau tìm hiểu một vài kiến thức nâng cao khi xây dựng một package. Cụ thể ở bài viết sau chúng ta sẽ cùng tìm hiểu về: Commands, Middlewares và Publish. Mình hi vọng bài viết này giúp ích được cho mọi người.
Nguyễn Viết Hiếu
Bài viết liên quan
Bình luận
Để lại bình luận
Email và số điện thoại sẽ không được công khai. Những trường bắt buộc được đánh dấu *