-
-
Notifications
You must be signed in to change notification settings - Fork 59
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add improved fotorama + swatches support
- Loading branch information
1 parent
f946376
commit 83e9487
Showing
10 changed files
with
262 additions
and
55 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
<?php declare(strict_types=1); | ||
|
||
namespace Yireo\Webp2\Plugin; | ||
|
||
use Magento\ConfigurableProduct\Block\Product\View\Type\Configurable; | ||
use Magento\Framework\Serialize\SerializerInterface; | ||
use Yireo\NextGenImages\Exception\ConvertorException; | ||
use Yireo\Webp2\Convertor\Convertor; | ||
|
||
class AddWebpToConfigurableJsonConfig | ||
{ | ||
/** | ||
* @var SerializerInterface | ||
*/ | ||
private $serializer; | ||
|
||
/** | ||
* @var Convertor | ||
*/ | ||
private $convertor; | ||
|
||
/** | ||
* AddImagesToConfigurableJsonConfig constructor. | ||
* @param SerializerInterface $serializer | ||
* @param Convertor $convertor | ||
*/ | ||
public function __construct( | ||
SerializerInterface $serializer, | ||
Convertor $convertor | ||
) { | ||
$this->serializer = $serializer; | ||
$this->convertor = $convertor; | ||
} | ||
|
||
/** | ||
* @param Configurable $subject | ||
* @param string $jsonConfig | ||
* @return string | ||
* @throws ConvertorException | ||
*/ | ||
public function afterGetJsonConfig(Configurable $subject, string $jsonConfig): string | ||
{ | ||
$jsonData = $this->serializer->unserialize($jsonConfig); | ||
|
||
if (isset($jsonData['images'])) { | ||
$jsonData['images'] = $this->appendImages($jsonData['images']); | ||
} | ||
|
||
$jsonConfig = $this->serializer->serialize($jsonData); | ||
return $jsonConfig; | ||
} | ||
|
||
/** | ||
* @param array $images | ||
* @return array | ||
* @throws ConvertorException | ||
*/ | ||
private function appendImages(array $images): array | ||
{ | ||
foreach ($images as $id => $imagesData) { | ||
foreach ($imagesData as $imageDataIndex => $imageData) { | ||
$imageData['thumb_webp'] = $this->getWebpUrl($imageData['thumb']); | ||
$imageData['img_webp'] = $this->getWebpUrl($imageData['img']); | ||
$imageData['full_webp'] = $this->getWebpUrl($imageData['full']); | ||
$imagesData[$imageDataIndex] = $imageData; | ||
} | ||
|
||
$images[$id] = $imagesData; | ||
} | ||
|
||
return $images; | ||
} | ||
|
||
/** | ||
* @param string $url | ||
* @return string | ||
* @throws ConvertorException | ||
*/ | ||
private function getWebpUrl(string $url): string | ||
{ | ||
return $this->convertor->getSourceImage($url)->getUrl(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
<?php declare(strict_types=1); | ||
|
||
namespace Yireo\Webp2\Plugin; | ||
|
||
use Magento\Catalog\Block\Product\View\Gallery; | ||
use Magento\Framework\Serialize\SerializerInterface; | ||
use Yireo\NextGenImages\Exception\ConvertorException; | ||
use Yireo\Webp2\Convertor\Convertor; | ||
|
||
class AddWebpToGalleryImagesJson | ||
{ | ||
/** | ||
* @var SerializerInterface | ||
*/ | ||
private $serializer; | ||
|
||
/** | ||
* @var Convertor | ||
*/ | ||
private $convertor; | ||
|
||
/** | ||
* AddImagesToConfigurableJsonConfig constructor. | ||
* @param SerializerInterface $serializer | ||
* @param Convertor $convertor | ||
*/ | ||
public function __construct( | ||
SerializerInterface $serializer, | ||
Convertor $convertor | ||
) { | ||
$this->serializer = $serializer; | ||
$this->convertor = $convertor; | ||
} | ||
|
||
/** | ||
* @param Gallery $subject | ||
* @param string $galleryImagesJson | ||
* @return string | ||
* @throws ConvertorException | ||
*/ | ||
public function afterGetGalleryImagesJson(Gallery $subject, string $galleryImagesJson): string | ||
{ | ||
$jsonData = $this->serializer->unserialize($galleryImagesJson); | ||
$jsonData = $this->appendImages($jsonData); | ||
$jsonConfig = $this->serializer->serialize($jsonData); | ||
return $jsonConfig; | ||
} | ||
|
||
/** | ||
* @param array $images | ||
* @return array | ||
* @throws ConvertorException | ||
*/ | ||
private function appendImages(array $images): array | ||
{ | ||
foreach ($images as $id => $imageData) { | ||
$imageData['thumb_webp'] = $this->getWebpUrl($imageData['thumb']); | ||
$imageData['img_webp'] = $this->getWebpUrl($imageData['img']); | ||
$imageData['full_webp'] = $this->getWebpUrl($imageData['full']); | ||
$images[$id] = $imageData; | ||
} | ||
|
||
return $images; | ||
} | ||
|
||
/** | ||
* @param string $url | ||
* @return string | ||
* @throws ConvertorException | ||
*/ | ||
private function getWebpUrl(string $url): string | ||
{ | ||
return $this->convertor->getSourceImage($url)->getUrl(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
<?xml version="1.0"?> | ||
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||
xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd"> | ||
<type name="Magento\ConfigurableProduct\Block\Product\View\Type\Configurable"> | ||
<plugin name="Yireo_Webp2::addWebpToConfigurableJsonConfig" type="Yireo\Webp2\Plugin\AddWebpToConfigurableJsonConfig"/> | ||
</type> | ||
|
||
<type name="Magento\Catalog\Block\Product\View\Gallery"> | ||
<plugin name="Yireo_Webp2::addWebpToGalleryImagesJson" type="Yireo\Webp2\Plugin\AddWebpToGalleryImagesJson"/> | ||
</type> | ||
</config> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
define([ | ||
'jquery', | ||
'./has-webp', | ||
"domReady!" | ||
], function ($, hasWebP) { | ||
'use strict'; | ||
|
||
var mixin = { | ||
initialize: function (config, element) { | ||
if (hasWebP()) { | ||
this._replaceImageDataWithWebp(config.data); | ||
} | ||
this._super(config, element); | ||
}, | ||
|
||
_replaceImageDataWithWebp: function (imagesData) { | ||
if (_.isEmpty(imagesData)) { | ||
return; | ||
} | ||
|
||
$.each(imagesData, function (key, imageData) { | ||
imageData['full'] = imageData['full_webp']; | ||
imageData['img'] = imageData['img_webp']; | ||
imageData['thumb'] = imageData['thumb_webp']; | ||
}); | ||
} | ||
}; | ||
|
||
return function (target) { | ||
return target.extend(mixin); | ||
} | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
define([], function () { | ||
'use strict'; | ||
|
||
const createWebPImage = function () { | ||
return new Promise((resolve, reject) => { | ||
var webP = new Image(); | ||
webP.onload = () => { | ||
webP.height === 2 ? resolve() : reject() | ||
} | ||
webP.onerror = reject | ||
webP.src = ''; | ||
}); | ||
} | ||
|
||
return async function hasWebP() { | ||
return await createWebPImage(); | ||
} | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
define([ | ||
'jquery', | ||
'./has-webp', | ||
"domReady!" | ||
], function ($, hasWebP) { | ||
'use strict'; | ||
|
||
return function (widget) { | ||
$.widget('mage.SwatchRenderer', widget, { | ||
_init: function () { | ||
if (hasWebP()) { | ||
this._replaceImageDataWithWebp(); | ||
} | ||
this._super(); | ||
}, | ||
|
||
_replaceImageDataWithWebp: function () { | ||
if (_.isEmpty(this.options.jsonConfig.images)) { | ||
return; | ||
} | ||
|
||
$.each(this.options.jsonConfig.images, function (key, imagesData) { | ||
$.each(imagesData, function (key, imageData) { | ||
imageData['full'] = imageData['full_webp']; | ||
imageData['img'] = imageData['img_webp']; | ||
imageData['thumb'] = imageData['thumb_webp']; | ||
}); | ||
}); | ||
} | ||
}); | ||
|
||
return $.mage.SwatchRenderer; | ||
} | ||
}); |
This file was deleted.
Oops, something went wrong.