-
-
Notifications
You must be signed in to change notification settings - Fork 158
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
Decouple stock data and prices from product to enable versioning of products #2331
Comments
CoreShop could introduce a stock table where the data is stored that is disregared from versioning. |
@EinShoppo Would you provide a PR? |
"CoreShop saves product's stock data directly on its DataObject. That means versioning of products is unuseable because switching to a previously scheduled version also changes the product's stock quantity." +1 |
@dpfaffenbauer: As I have already described, the versioning feature of Pimcore is currently not (safely) usable for CoreShop products. However, separating stock data and prices from products is a pretty big change in my opinion - definitely not a minimally invasive one. Therefore, I think the implementation should better be done by the core team, also because some architectural decisions have to be made here. |
@EinShoppo I honestly think it is not as big of a deal as you think ;). I would either introduce a doctrine entity to store it, or check if we can overwrite the number type and create a non versionable type. |
@EinShoppo One possible solution might be this, WDYT? <?php
declare(strict_types=1);
/*
* CoreShop
*
* This source file is available under two different licenses:
* - GNU General Public License version 3 (GPLv3)
* - CoreShop Commercial License (CCL)
* Full copyright and license information is available in
* LICENSE.md which is distributed with this source code.
*
* @copyright Copyright (c) CoreShop GmbH (https://www.coreshop.org)
* @license https://www.coreshop.org/license GPLv3 and CCL
*
*/
namespace CoreShop\Bundle\CoreBundle\EventListener;
use CoreShop\Component\Core\Model\ProductInterface;
use DeepCopy\Matcher\PropertyNameMatcher;
use Doctrine\DBAL\Connection;
use Pimcore\Event\SystemEvents;
use Pimcore\Model\DataObject\ClassDefinition\Data;
use Pimcore\Model\DataObject\Concrete;
use Pimcore\Model\Element\DeepCopy\PimcoreClassDefinitionReplaceFilter;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\EventDispatcher\GenericEvent;
class StockDeepCopyDisableListener implements EventSubscriberInterface
{
public function __construct(private Connection $connection)
{
}
public static function getSubscribedEvents(): array
{
return [
SystemEvents::SERVICE_PRE_GET_DEEP_COPY => 'addDoctrineCollectionFilter',
];
}
public function addDoctrineCollectionFilter(GenericEvent $event): void
{
$context = $event->getArgument('context');
$element = $event->getArgument('element');
$copier = $event->getArgument('copier');
if (!$element instanceof ProductInterface) {
return;
}
if (!str_starts_with($context['source'], 'Pimcore\Model\Version::')) {
return;
}
$copier->addFilter(
new PimcoreClassDefinitionReplaceFilter(
function (Concrete $object, Data $fieldDefinition, $property, $currentValue) {
$table = sprintf('object_store_'.$object->getClassId());
$result = $this->connection->fetchAssociative(
'SELECT onHand FROM '.$table.' WHERE oo_id = ?',
[$object->getId()]
);
return $result['onHand'];
}
),
new PropertyNameMatcher('onHand')
);
$copier->addFilter(
new PimcoreClassDefinitionReplaceFilter(
function (Concrete $object, Data $fieldDefinition, $property, $currentValue) {
$table = sprintf('object_store_'.$object->getClassId());
$result = $this->connection->fetchAssociative(
'SELECT onHold FROM '.$table.' WHERE oo_id = ?',
[$object->getId()]
);
return $result['onHold'];
}
),
new PropertyNameMatcher('onHold')
);
$event->setArgument('copier', $copier);
}
} |
Hi @dpfaffenbauer, i will try to look at this tomorrow and test it. until then, thank you very much! the solution is really much shorter than i had thought :-) |
Hello @dpfaffenbauer, Sorry and many greetings |
@EinShoppo Sure, no worries, I'll keep it open until I have some confirmation |
@EinShoppo Any Feedback? |
ping @EinShoppo |
1 similar comment
ping @EinShoppo |
as discussed: should still be decoupled since every order makes a save on the product that can cause heavy operations like a cache clear |
Hi!
I noticed that there are two problems regarding the product stock management in case of activated versioning of DataObjects:
-- Example:
---We have a published product with onHand = 100
---We schedule a version of the product to become published 01/01/2024
---We sell 20 pieces of the product, so the onHand value is 80.
---On 01/01/2024 the scheduled version is published with onHand = 100
What do you think about my suggestions?
Best regards
EinShoppo
The text was updated successfully, but these errors were encountered: