پکیج لاراول مخصوص توسعه دهندگان ایرانی
من همیشه یه سری کد داشتم که هر بار پروژه جدید ایجاد میکردم هر بار از اول کپی میکردم تو پروژه جدیده.بعد تصمیم گرفتم این رو به صورت یه پکیج در بیارم تا هم خودم و هم همکارام به راحتی بتونیم ازشون استفاده کنیم. حالا اگه شما هم فکر میکنین این پکیج میتونه روند توسعه نرم افزار هاتون رو سریع کنه شما هم استفاده کنین. اگه فکر میکنین چیز خاصی هست که مخصوص توسعه دهنده های ایرانی هست اما در این پکیج موجود نیست حتما یه
forkو pull request
مهمون کنین 😁.
امکانات:
- ذخیره و بازیابی تاریخ شمسی در الوکوئنت
- شرط گذاری روی کوئری با تاریخ شمسی
- میدلویر برای تعمیر حروف ک و ی عربی و اعداد فارسی و عربی
- تابع تهیه اسلاگ فارسی
- ولیدیتور شماره همراه و شماره تماس ثابت
- دیتابیس شهر ها و استان های ایران به همراه روت بایندینگ ها
- پیدا کردن بانک از روی شماره کارت
- نصب
- کانفیگ
- ذخیره و بازیابی تاریخ شمسی
- کوئری بیلدر تاریخ شمسی
- میدلویر
- ولیدیشن
- فیکر
- استان ها و شهرها
- اسلاگ
- پیداکردن بانک از روی شماره کارت
- ساخته شده با کمک
برای نصب شما به لاراول نسخه 6 یا بالاتر نیاز دارید. با استفاده از کومپوزر در پروژه لاراولی خود این پکیج رو نصب کنید.
composer require sanjabteam/baloot
بعد هم با این کامند فایل کانفیگ رو بسازین.
php artisan vendor:publish --provider=Baloot\\BalootServiceProvider
در فایل
config/baloot.php
میتونین کانفیگ رو تغییر بدین.
geo
:
اگه نمیخاین از قابلیت استان و شهر استفاده کنین مقدار این قسمت رو برابر
false
قرار بدید تا جداولش ایجاد نشه.
این پکیج این امکان رو به شما میده تا به راحتی تاریخ های موجود در مدل لاراول رو به راحتی به کلاس ورتا تبدیل کنید. برای شروع
trait
Baloot\EloquentHelper
رو به مدلی که میخاین اضافه کنین.
use Baloot\EloquentHelper;
class User extends Model
{
use EloquentHelper; // trait
}
بعد به راحتی میتونین به صورت شمسی به مشخصات دسترسی داشته باشین. فقط کافیه به فیلد مورد نظرتون پسوند
_fa
اضافه کنید.
$user = User::where(...)->first();
$user->created_at_fa // به صورت کلاس Hekmatinasser\Verta\Verta
$user->created_at_fa_f // 1390/1/1
$user->created_at_fa_ft // 1390/1/1 12:00
$user->created_at_fa_ftt // 1390/1/1 12:00:00
$user->updated_at_fa->format("%B %d %Y") // فروردین 01 1390
برای مدیریت بهتر میتونین به مستندات ورتا .مراجعه کنین همچنین با تنظیم کردن تاریخ هم از همین روش استفاده کنین.
$user->created_at_fa = Verta::createJalaliDate(1390, 1, 1);
dd($user->created_at); // Illuminate\Support\Carbon { date: 2011-03-21 }
$user->created_at_fa = "1392/1/1";
dd($user->created_at); // Illuminate\Support\Carbon { date: 2013-03-21 }
$user->created_at_fa = "1395/1/1 14:22:11";
dd($user->created_at); // Illuminate\Support\Carbon { date: 2016-03-20 14:22:11 }
اگه میخاین یه فیلد دلخواه به جز
created_at, updated_at
داشته باشین که از همین قابلیت پشتیبانی کنه کافیه اون رو به تاریخ کست کنین.
use Baloot\EloquentHelper;
class User extends Model
{
use EloquentHelper;
protected $casts = [
'birth_date' => 'date',
// یا
'released_at' => 'datetime'
];
}
و بازم هم به همون روش میتونین بهش دسترسی داشته باشین.
$user->birth_date_fa; // Hekmatinasser\Verta\Verta
این دستورات کمک میکنن بر روی ستون های از نوع date/datetime شرط با تاریخ شمسی بذارین.
شرط با یک تاریخ و زمان به خصوص شمسی
User::whereJalali('created_at', '1399/01/15 14:00:00')->get();
// یا
User::whereJalali('created_at', Verta::createJalali(1399,01,15, 14, 0, 0))->get();
// شرط با عملگر
User::whereJalali('created_at', '>', '1399/01/15 14:00:00')->get();
شرط با یک تاریخ به خصوص شمسی
User::whereDateJalali('created_at', '1399/01/15')->get();
// یا
User::whereDateJalali('created_at', Verta::createJalaliDate(1399,01,15))->get();
// شرط با عملگر
User::whereDateJalali('created_at', '>', '1399/01/15')->get();
شرط یک ماه خاص شمسی در یک سال
User::whereInMonthJalali('created_at', 3)->get(); // فقط کاربران ایجاد شده در خرداد ماه سال جاری
User::whereInMonthJalali('created_at', 3, 1397)->get(); // فقط کاربران ایجاد شده در خرداد ماه سال 1397
شرط یک سال خاص شمسی
User::whereInYearJalali('created_at')->get(); // فقط کاربران ایجاد شده در سال جاری
User::whereInYearJalali('created_at', 1397)->get(); //فقط کاربران ایجاد شده در سال 1397
شرط بین دو تاریخ مشخص شمسی
User::whereBetweenJalali('created_at', ['1400/03/26 12:00:00', '1400/05/26 12:00:00'])->get(); // فقط کاربران ایجاد شده بین دو تاریخ مشخص شده
// یا
User::whereBetweenJalali('created_at', [Verta::createJalali(1400,01,15, 14, 0, 0), Verta::createJalali(1399,01,15, 14, 0, 0)])->get();
// شرط با Not
User::whereNotBetweenJalali('created_at', ['1400/03/26 12:00:00', '1400/05/26 12:00:00'])->get(); // همه کاربران به جز کاربران ایجاد شده در تاریخ مشخص
یکی از مشکلاتی که تو پروژه ها سر و کله میزنم باهاشون یکی اعداد فارسی هست. مثلا طرف میاد موقع ثبت نام رمز عبورش رو با عدد فارسی میزنه بعد موقع ورود با عدد انگلیسی بعد این وسط میگه رمز عبورش اشتباهه درصورتی که اینطوری نیست. مشکل دوم اینه که مثلا ادمین یه چیزی با ک و ی فارسی وارد میکنه اما یه کاربری تو سایت کیبوردش عربی و با ك,ي عربی سرچ میکنه و این وسط موقع سرچ چیزی پیدا نمیکنه در صورتی که اینطور نیستش. برای حل این مشکل کافیه در فایل
app/Http/Kernel.php
کلاس
\Baloot\Middleware\FixRequestInputs
به آرایه
middleware
اضافه کنین
protected $middleware = [
...
\Baloot\Middleware\FixRequestInputs::class,
];
به همین راحتی برای همیشه هم با مشکل اعداد فارسی و هم مشکل حروف عربی خداحافظی کنین.
iran_phone: برای وارد کردن شماره های ثابت ایرانی
iran_mobile: برای ولیدیشن شماره موبایل های ایرانی
در صورتی که میخواید شماره هایی که بدون صفر هم وارد میشن رو بپذیره, به این صورت وارد کنید : iran_mobile:true در غیر این صورت اگر صفر وارد نشه شماره تایید نمیشه.
برای استفاده:
public function test(Request $request)
{
$request->validate([
'mobile1' => 'required|iran_mobile',
'phone' => 'required|iran_phone',
'mobile2' => 'required|iran_mobile:true', // وارد کردن صفر در اول شماره اختیاری
]);
}
این قسمت نیاز به بهبود دارد
iran_national_code: ولیدیشن کد ملی
برای فیکر یه سری بهبود ها انجام شده برای مثال paragraph فارسی سازی شده.
CustomImage:
customImage($path, $width, $height, $prefix)
این فیکر عکس از سایت
براتون فراهم میکنه.
$path: پوشه محل ذخیره $width: طول عکس $height: عرض عکس $prefix: به طور پیشفرض فقط نام عکس بهتون داده میشه با کمک این میتونین یه پیشوند به اسم عکس اضافه کنین
نمونه:
'image' => $faker->customImage(public_path('uploads/fake'), 640, 480, 'fake/')
همچنین اگه میخاین یه آرایه از عکس داشته باشین
$faker->customImages(public_path('uploads/fake'), 640, 480, $faker->numberBetween(1, 3), 'fake/')
چهارمین پارامتر تعداد عکس هایی که لازم دارین رو ازتون دریافت میکنه.
iranMobile:
یه شماره موبایل ایرانی براتون میسازه
$faker->iranMobile
iranPhone:
یه شماره ثابت ایرانی براتون میسازه
$faker->iranPhone
برای شروع در
DatabaseSeeder.php
این قسمت رو اضافه کنید.
public function run()
{
$this->call(\Baloot\Database\CitiesTableSeeder::class); // سیدر شهر ها و استان ها
}
سپس بعد از میگریت سید رو انجام بدین.
php artisan migrate --seed
حالا جداول شما از شهر ها و استان ها پر شده برای استفاده از دو مدل پایین میتونین استفاده کنین.
مدل استان:
Baloot\Models\Province
مدل شهر:
Baloot\Models\City
نمونه:
use Baloot\Models\City;
City::where('name', 'آمل')->first()
اگه میخاین از استان و شهر در آدرس ها استفاده کنین از این روش استفاده کنین.
use Baloot\Models\Province;
use Baloot\Models\City;
Route::get('test/{province}/{city}', function (Province $province, City $city) {
abort_if($city->province_id != $province->id, 404);
// ...
});
و سپس آدرس زیر رو باز کنید.
/test/27/1068
حالا به استان و شهر دسترسی دارین.
اگه میخاین آدرستون
seo freindly
باشه از
slug
موجود در شهر ها و استان ها استفاده کنین. این اسلاگ ها به کمک
تهیه شدن. بنابراین آدرس رو به این شکل باز کنین.
/test/مازندران/آمل
.
اگه فقط میخاین با آی دی باز باشه یا فقط اسلاگ و هر دو حالت رو قبول نکنه در اون صورت از این ها به جای
province
, city
استفاده کنین.
city_by_id
: شهر با آی دی
city_by_slug
: شهر با اسلاگ
province_by_id
: استان با آی دی
province_by_slug
: استان با اسلاگ
استان: Province
شهر: City
همونطور که میدونین در لاراول با تابع
Str::slug('test test')
میشه یه اسلاگ برای آدرس دهی درست کرد اما اگه فارسی به این تابع بدین
Str::slug('خونه ی مادربزرگه')
خروجی
"khonh-i-madrbzrgh"
میده که یه جورایی سعی کرده به فینگلیش تبدیلش کنه اما با تابع
str_to_slug
این پکیج به راحتی حروف فارسی رو هم مدیریت میکنه
str_to_slug('خونه ی مادربزرگه')
"خونه-ی-مادربزرگه"
کافیه در فایل
config/sluggable.php
قسمت
method
رو این شکلی بنویسین.
'method' => 'str_to_slug',
برای پیدا کردن بانک از روی شماره کارت از این تابع استفاده کنین.
find_bank_by_card_number("6037697531")
خروجی:
[
"class" => "bsi",
"name" => "بانک صادرات ایران",
"card_prefix" => "603769",
]
کلاس, نام کلاس بر اساس این پکیج هست.