-
-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Attaching Media form spate media library #42
Comments
Hi @OliverZiegler, The problem here is that Spatie's library requires a model in order to link the media to it. By default, this package does not use models (data is stored in JSON files). Therefore, you should switch to database storage. This will however probably not work with the current version of nova-flexible-content, since the model is difficult to fetch from inside a Flexible content. I'm working on a fix for a similar issue (the one you linked in your post) as we speak, I'll try to find a solution that also fixes this one. |
…or nova-flexible-content (HasMediaLibrary issue) compatibility. References #42
Hi @OliverZiegler, Could you update both packages (using Here's how I got it working (you should probably re-publish the package's configuration file):
namespace App;
use Whitecube\NovaPage\Sources\StaticPage;
use Spatie\MediaLibrary\HasMedia\HasMedia;
use Spatie\MediaLibrary\HasMedia\HasMediaTrait;
class Page extends StaticPage implements HasMedia
{
use HasMediaTrait;
}
|
Thanks for the fast response!! So with the still missing PR from advanced-nova-media-library I got it working with nova-flexible-content but with some limitations...
One more issue (not related to nova-flexible-content) is adding Images to the page directly. Make the template implement Furthermore adding: protected function getMediaModel() : HasMedia
{
$model = $this->getSource()->getOriginal($this);
\Log::info($model);
if(is_null($model) || !($model instanceof HasMedia)) {
throw new \Exception('Origin HasMedia model not found.');
}
return $model;
}
public function getMedia(string $collectionName = 'default', $filters = [])
{
return app(MediaRepository::class)->getCollection($this->getMediaModel(), $collectionName, $filters);
}
public function addMedia($file)
{
return app(FileAdderFactory::class)
->create($this->getMediaModel(), $file)
->preservingOriginal();
} |
Hey guys, When running:
Pressing save won't do anything 😕 UpdateMy fault, ignore me :) |
does it world? |
We are currently using this package, and in combination with nova-flexible-content this is a winner 🎉
As nova-flexible-content now resolved the issue with advanced-nova-media-library field, it would be great to use this also with nova-page.
In the issue you state:
Is there any idea how to get this working?
Would be nice to define the media collections in the template files and use advanced-nova-media-library field 🤔
The text was updated successfully, but these errors were encountered: