hcakir / laravel-11-media-manager
Laravel 11 için medya yönetim paketi
Requires
- php: ^8.0
- laravel/framework: ^10.0|^11.0
Requires (Dev)
- phpunit/phpunit: ^9.0|^10.0|^11.0
Suggests
- laravel/framework: Bu paket, Laravel framework ile daha iyi çalışır.
Provides
- psr/log-implementation: 1.0.0
Conflicts
- laravel/framework: <5.5
Replaces
- hcakir/laravel-10-media-manager: 1.0.0
README
Bu paket, Laravel uygulamalarında medya yönetimi için kullanılabilir.
Genel Bakış
Bu paket, Laravel projelerinde medya dosyalarını (resim ve video) yönetmek için tasarlanmıştır. İşlevselliği, ilgili modele ´MediaTrait´ sınıfını ekleyerek entegre edilebilir.
´MediaTrait´ sınıfları, model ile medya dosyaları arasında ilişkileri oluştururken aynı zamanda ´MediaHelper´ yardımıyla medya işlemlerini gerçekleştirir. Bu işlemler arasında medya dosyalarını modellerle ilişkilendirme, ekleme, çıkarma ve senkronizasyon bulunmaktadır.
Bir medya dosyası güncellendiğinde veya ilişkili model silindiğinde, veritabanından ilişki otomatik olarak kaldırılır. Ayrıca, medya dosyaları diskten silinir ve ilişkili veriler temizlenir. Bu özellikler, medya yönetimini kolay ve verimli hale getirir.
Kurulum
- Paketi Laravel projesine ekleyin:
composer require hcakir/laravel-11-media-manager
- Laravel 5.5 ve sonrası sürümler, paketin Service Provider’ını otomatik olarak tanır. Eğer Laravel 5.5 öncesi bir sürüm kullanıyorsanız, config/app.php dosyasındaki providers array’ine aşağıdaki satırı eklemeniz gerekmektedir:
Hcakir\Laravel11MediaManager\Providers\MediaManagerServiceProvider::class,
- Paketin yapılandırma dosyasını ve migration dosyalarını projenize yayınlayın:
php artisan vendor:publish --provider="Hcakir\\Laravel11MediaManager\\Providers\\MediaManagerServiceProvider"
- Bu komut, paketin yapılandırma dosyasını config/ klasörüne ve migration dosyalarını database/migrations/ klasörüne kopyalar.
- Yayınlanan migration dosyalarını çalıştırın:
php artisan migrate
- Bu komut, medya yönetim sistemi için gerekli olan veritabanı tablolarını oluşturur.
- Storage sembolik bağlantısı oluşturun:
php artisan storage:link
- İlgili modelinize MediaTrait'i ekleyin:
use Hcakir\Laravel11MediaManager\Traits\MediaTrait; class YourModel extends Model { use MediaTrait; }
Artık Laravel 11 Media Manager paketini projenizde kullanmaya başlayabilirsiniz!
Bağımlılıklar
Bu paket aşağıdaki gereksinimlere sahiptir:
- PHP 8.0 veya üstü
- Laravel 10.0 veya 11.0
- PHPUnit 9.0, 10.0 veya 11.0
- Bu gereksinimler, paketin düzgün çalışabilmesi için gereklidir. Lütfen paketi kullanmadan önce bu gereksinimleri karşıladığınızdan emin olun.
Kullanım
- Medya dosyaları ekleme ve ilişkileri oluşturma:
if ($request->hasFile('media')) { $productCategory->attachMedia($request->file('media')); }
- Medya dosyaları güncelleme:
if ($request->hasFile('media')) { $productCategory->syncMedia($request->file('media')); }
- Medya silme ve ilişkileri kaldırma:
$productCategory->detachMedia(); $productCategory->delete();
- controller json ile Medya ekleme ve ilişki oluşturma:
public function deleteMedia(Request $request, $categoryId, $mediaId) { $productCategory = ProductCategory::findOrFail($categoryId); $media = $productCategory->media()->findOrFail($mediaId); $mediaPaths = [$media->path]; MediaHelper::deleteMedia($mediaPaths); return response()->json(['success' => true]); }
- ilişkili media dosyalarını gösterme:
public function edit(string $id) { $productCategory = ProductCategory::findOrFail($id); $media = $productCategory->media()->get(); return view('backend.pages.product_category.edit', compact('productCategory', 'media')); }
Diğer Kullanım şekilleri
´MediaHelper´ sınıfı, medya dosyalarını kaydetmek ve silmek için statik metodlar sağlar.
Örnek kullanım:
use Hcakir\Laravel11MediaManager\Helpers\MediaHelper; $mediaFiles = request()->file('media'); $mediaIds = MediaHelper::storeMedia($mediaFiles);
Testler
- Paket, işlevselliğini doğrulamak için bir dizi test içerir. Testler, ´MediaTraitTest´ sınıfında bulunabilir.
- Testleri çalıştırmak için ´php artisan test´ artisan komutunu terminale yazınız
Lisans
- Bu paket MIT lisansı altında lisanslanmıştır. Daha fazla bilgi için ´LICENSE´ dosyasını inceleyebilirsiniz.
Katkıda Bulunma
- Katkılarınızı bekliyoruz! Lütfen bir hata bulduysanız veya bir özellik önermek istiyorsanız, bir sorun oluşturun veya bir çekme isteği gönderin.