لارافيل 12: كل جديد من 12.0 لـ 12.19 – دليل شامل

يوليو 20, 2025

🔧 1. لارافيل 12.0 – ستارتر كيتس وتعديلات أساسية

إصدار 12.0 جاب Starter Kits جاهزة للـ React، Vue، Livewire، وكمان دمج مع WorkOS AuthKit، وكود نوعي آمن، ودعم PHPUnit 12.

React/Vue Starter Kit

تقدر تنشئ مشروع جديد بسهولة:

composer create-project laravel/laravel my-app --prefer-dist
cd my-app
php artisan breeze:install react --typescript

# أو
php artisan breeze:install vue --typescript

WorkOS AuthKit (سوشيال لوجإن، SSO، Passkeys)

// config/workos.php
return [
  'client_id' => env('WORKOS_CLIENT_ID'),
  'api_key' => env('WORKOS_API_KEY'),
  'redirect_uri' => env('WORKOS_REDIRECT_URI'),
  'providers' => ['google'=>true,'github'=>true,'microsoft'=>true],
  'passkeys' => ['enabled'=>true,'rp_name'=>env('APP_NAME'),'rp_id'=>env('APP_DOMAIN')],
];

وفي الكنترولر:

public function callback() {
  $workos = new WorkOS(config('workos.api_key'));
  $profile = $workos->sso->getProfile(request('code'));
  $user = User::firstOrCreate(['email'=>$profile->email], [
    'name'=>$profile->firstName.' '.$profile->lastName,
    'workos_id'=>$profile->id,
  ]);
  auth()->login($user);
  return redirect()->intended('/dashboard');
}

دعم PHPUnit 12 و Type-Safe Requests

public function store(Request $req): JsonResponse {
  $user = User::create([
    'name' => $req->string('name')->value(),
    'email' => $req->string('email')->value(),
    'prefs' => $req->collect('preferences')->toArray(),
  ]);
  return response()->json($user, 201);
}

🧩 2. لارافيل 12.1 – Arr::partition() وتحسينات في HTTP

الميزة الجديدة Arr::partition() بتقسّم المصفوفة حسب شرط:

$numbers = [0,1,2,3,4,5];
[$evens, $odds] = Arr::partition($numbers, fn($n)=>$n%2===0);
// $evens = [0,2,4], $odds = [1,3,5]

وكمان تقدر تتحكم في حجم ponse body لو حصل خطأ في طلب HTTP:

Http::truncateExceptionsAt(240)
  ->post('https://example.com/api', [...]);

⚙️ 3. لارافيل 12.19 – Custom Builders & Fluent Casts وغيرها

  • @useEloquentBuilder: تربط موديل builder خاص.
  • Fluent Casts: تحول الخصائص لكائنات زي URI.
  • Fail-on-Exception Middleware: يفشل الجوب لو حصل throttle exception أوتوماتيكي.
#[useEloquentBuilder(MyBuilder::class)]
class Post extends Model {
  // دلوقتي استعلامات Model هتستخدم MyBuilder
}

📋 4. تغييرات بسيطة وراحة أفضل للمطور

  • String::doesntStartWith() و doesntEndWith().
  • إضافة JSON Serializable في URI class.
  • تحسينات في الـ queue، pagination، واللوجز.
  • تحقّق الصور ما يشتّملش SVG إلا لو بعدتها صراحة: 'photo'=>'image:allow_svg'.

💡 نصائح عملية للاستخدام في المشاريع

  • ✅ استخدم starter kits لتسريع الـ setup.
  • 🔍 استبدل تقسيم المصفوفة باستخدام Arr::partition().
  • 🛡️ استخدم truncate للتقليل من حجم الخطأ في الـ logs.
  • 🧰 لفّك استخدام custom builders و fluent casts لكود أوضح.
  • 🧪 حدّث PHPUnit و Carbon 3 عشان تختبر صح.
  • ⚠️ لو محتاج SVG خليه مسموح صراحة.

المدونة

أهم تحديثات Laravel و PHP لكتابة كود أنظف وأسرع

أغسطس 17, 2025

Laravel Global Scopes: Automatic Query Filtering Eloquent الأهمية: فرض فلترة ثابتة على جميع استعلامات الموديل (مثل Soft Deletes) دون تكرا...

React Labs: View Transitions وActivity

يونيو 17, 2025

React Labs: View Transitions وActivity المنشور اتكتب يوم 23 أبريل 2025 من Ricky Hanlon. في React Labs النهارده بيقدّموا ميزتين تجريبيّتين مودرن...

دليل للأنيميشن المتحركة بالسكّول بس بـ CSS

يونيو 26, 2025

دليل للأنيميشن المتحركة بالسكّول بـ CSS دلوقتي تقدر تربط الأنيميشن بتاعتك بـ السكّول من غير جافاسكريبت — كله CSS بحت. 1. التلات مكونات بتوع...

استكشف أقوى تقنيات Laravel الحديثة: Inertia.js، View Creators، وHLS خطوة بخطوة

يوليو 27, 2025

أدوات قوية تقدر تستخدمها لتطوير تطبيقات Laravel بشكل احترافي: Inertia.js v2، وView Creators، وحزمة Laravel HLS لبث الفيديوهات بأمان. ١. Inertia.j...

مقارنة CSS: طبقات vs BEM vs Utility Classes

يونيو 26, 2025

مقارنة CSS: Cascade Layers و BEM و Utility Classes المقالة بتتكلّم عن ٣ طرق لإدارة الـ specificity في CSS – BEM والـ utility‑first classes وك...

حلل مشروع Laravel بـ Introspect

يوليو 01, 2025

حلل كود Laravel باستخدام Laravel Introspect لو بتعمل Refactor كبير أو بتبني أدوات Dev‪، Laravel Introspect بيسمحلك تستعلم عن الكود: فيوز، مودلز، رو...