From b89e0b2dffb69c3b98f0b49d6a11b97746d96b36 Mon Sep 17 00:00:00 2001 From: Luke Holder Date: Tue, 12 Nov 2024 16:42:51 +0800 Subject: [PATCH 1/2] WIP --- src/events/CatalogPricingJobEvent.php | 37 +++++++++++++++++++++++++++ src/services/CatalogPricing.php | 22 +++++++++++++++- 2 files changed, 58 insertions(+), 1 deletion(-) create mode 100644 src/events/CatalogPricingJobEvent.php diff --git a/src/events/CatalogPricingJobEvent.php b/src/events/CatalogPricingJobEvent.php new file mode 100644 index 0000000000..2a3d953e09 --- /dev/null +++ b/src/events/CatalogPricingJobEvent.php @@ -0,0 +1,37 @@ + + * @since 5.3.0 + */ +class CatalogPricingJobEvent extends CancelableEvent +{ + /** + * @var int[]|null + */ + public ?array $purchasableIds = null; + + /** + * @var int[]|null + */ + public ?array $catalogPricingRuleIds = null; + + /** + * @var int[]|null + */ + public ?array $storeId = null; +} diff --git a/src/services/CatalogPricing.php b/src/services/CatalogPricing.php index 4ba3039695..2cf5d3dbbd 100755 --- a/src/services/CatalogPricing.php +++ b/src/services/CatalogPricing.php @@ -12,6 +12,7 @@ use craft\commerce\db\Table; use craft\commerce\elements\conditions\purchasables\CatalogPricingCondition; use craft\commerce\elements\conditions\purchasables\CatalogPricingCustomerConditionRule; +use craft\commerce\events\CatalogPricingJobEvent; use craft\commerce\models\CatalogPricing as CatalogPricingModel; use craft\commerce\models\CatalogPricingRule; use craft\commerce\Plugin; @@ -40,6 +41,11 @@ */ class CatalogPricing extends Component { + /** + * @since 5.3.0 + */ + const EVENT_BEFORE_CREATE_CATALOG_PRICING_JOB = 'beforeCreateCatalogPricingJob'; + /** * @var array|null */ @@ -500,7 +506,21 @@ public function createCatalogPricingJob(array $config = [], int $priority = 100) $catalogPricingRuleIds = $config['catalogPricingRuleIds'] ?? null; $purchasableIds = $config['purchasableIds'] ?? null; $storeId = $config['storeId'] ?? null; - $this->markPricesAsUpdatePending($catalogPricingRuleIds, $purchasableIds, $storeId); + + /** @var CatalogPricingJobEvent $event */ + $event = Craft::createObject( + CatalogPricingJobEvent::class, compact('catalogPricingRuleIds', 'purchasableIds', 'storeId'), + ); + + if ($this->hasEventHandlers(self::EVENT_BEFORE_CREATE_CATALOG_PRICING_JOB)) { + $this->trigger(self::EVENT_BEFORE_CREATE_CATALOG_PRICING_JOB, $event); + } + + if (!$event->isValid) { + return; + } + + $this->markPricesAsUpdatePending($event->catalogPricingRuleIds, $event->purchasableIds, $event->storeId); $config = array_merge([ 'class' => CatalogPricingJob::class, From 55a49656c718694fc4b4d22e54e5b470ecd87421 Mon Sep 17 00:00:00 2001 From: Luke Holder Date: Wed, 13 Nov 2024 13:22:14 +0800 Subject: [PATCH 2/2] Cleanup --- src/events/CatalogPricingJobEvent.php | 3 --- src/services/CatalogPricing.php | 2 +- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/src/events/CatalogPricingJobEvent.php b/src/events/CatalogPricingJobEvent.php index 2a3d953e09..8622c263ea 100644 --- a/src/events/CatalogPricingJobEvent.php +++ b/src/events/CatalogPricingJobEvent.php @@ -7,9 +7,6 @@ namespace craft\commerce\events; -use craft\commerce\base\Plan; -use craft\commerce\models\subscriptions\SubscriptionForm; -use craft\elements\User; use craft\events\CancelableEvent; /** diff --git a/src/services/CatalogPricing.php b/src/services/CatalogPricing.php index 2cf5d3dbbd..c76f1276ee 100755 --- a/src/services/CatalogPricing.php +++ b/src/services/CatalogPricing.php @@ -44,7 +44,7 @@ class CatalogPricing extends Component /** * @since 5.3.0 */ - const EVENT_BEFORE_CREATE_CATALOG_PRICING_JOB = 'beforeCreateCatalogPricingJob'; + public const EVENT_BEFORE_CREATE_CATALOG_PRICING_JOB = 'beforeCreateCatalogPricingJob'; /** * @var array|null