Tạ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 │ ├── ...
1. Config
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"); } ... } ...
2. Translation
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:
2.1 Khai báo file có đuôi là php
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.
2.2 Khai báo file có đuôi là json
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’).
2.3 Khai báo cả 2 dạng
Để 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'); } ... } ...
3. Helpers
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.
4. Migrations
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.
Tổng Kết
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
Nguồn : https://sudo.vn