forked from rebillar/site-accueil-insa
		
	
		
			
				
	
	
		
			144 lines
		
	
	
		
			No EOL
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			No EOL
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Matomo - free/libre analytics platform
 | |
|  *
 | |
|  * @link https://matomo.org
 | |
|  * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
 | |
|  *
 | |
|  */
 | |
| namespace Piwik\Plugins\Ecommerce\Columns;
 | |
| 
 | |
| use Piwik\Columns\DimensionSegmentFactory;
 | |
| use Piwik\Columns\Discriminator;
 | |
| use Piwik\Common;
 | |
| use Piwik\Piwik;
 | |
| use Piwik\Plugin\Segment;
 | |
| use Piwik\Segment\SegmentExpression;
 | |
| use Piwik\Segment\SegmentsList;
 | |
| use Piwik\Tracker\Action;
 | |
| use Piwik\Tracker\GoalManager;
 | |
| use Piwik\Tracker\Request;
 | |
| use Piwik\Tracker\Visitor;
 | |
| 
 | |
| class Revenue extends BaseConversion
 | |
| {
 | |
|     protected $columnName = 'revenue';
 | |
|     protected $columnType = 'float default NULL';
 | |
|     protected $type = self::TYPE_MONEY;
 | |
|     protected $category = 'Goals_Ecommerce';
 | |
|     protected $nameSingular = 'Ecommerce_OrderValue';
 | |
| 
 | |
|     public function getDbDiscriminator()
 | |
|     {
 | |
|         return new Discriminator($this->dbTableName, 'idgoal', GoalManager::IDGOAL_ORDER);
 | |
|     }
 | |
| 
 | |
| 
 | |
|     public function configureSegments(SegmentsList $segmentsList, DimensionSegmentFactory $dimensionSegmentFactory)
 | |
|     {
 | |
|         //new Segment revenue on order
 | |
|         $segment = new Segment();
 | |
|         $segment->setCategory($this->category);
 | |
|         $segment->setName(Piwik::translate('Ecommerce_OrderRevenue'));
 | |
|         $segment->setSegment('revenueOrder');
 | |
|         $segment->setSqlSegment('log_conversion.idvisit');
 | |
|         $segment->setSqlFilter(function ($valueToMatch, $sqlField, $matchType) {
 | |
|             return $this->getRevenueQuery($valueToMatch, $sqlField , $matchType, 0);
 | |
|         });
 | |
|         $segmentsList->addSegment($dimensionSegmentFactory->createSegment($segment));
 | |
| 
 | |
|         //new Segment revenue left in cart
 | |
|         $segment = new Segment();
 | |
|         $segment->setCategory($this->category);
 | |
|         $segment->setName(Piwik::translate('Ecommerce_RevenueLeftInCart'));
 | |
|         $segment->setSegment('revenueAbandonedCart');
 | |
|         $segment->setSqlSegment('log_conversion.idvisit');
 | |
|         $segment->setSqlFilter(function ($valueToMatch, $sqlField , $matchType) {
 | |
|            return $this->getRevenueQuery($valueToMatch, $sqlField , $matchType,-1);
 | |
|         });
 | |
|         $segmentsList->addSegment($dimensionSegmentFactory->createSegment($segment));
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * revenue sql filter
 | |
|      * @param $valueToMatch
 | |
|      * @param $sqlField
 | |
|      * @param $matchType
 | |
|      * @param false $cart
 | |
|      * @return array
 | |
|      */
 | |
|     private function getRevenueQuery($valueToMatch, $sqlField , $matchType, $idGoal)
 | |
|     {
 | |
|         //supported operator type
 | |
|         $supportType = [
 | |
|           SegmentExpression::MATCH_EQUAL,
 | |
|           SegmentExpression::MATCH_GREATER_OR_EQUAL,
 | |
|           SegmentExpression::MATCH_LESS_OR_EQUAL,
 | |
|           SegmentExpression::MATCH_GREATER,
 | |
|           SegmentExpression::MATCH_LESS,
 | |
|         ];
 | |
| 
 | |
|         if (!in_array($matchType, $supportType)) {
 | |
|             throw new \Exception("This match type $matchType is not available for action-segments.");
 | |
|         }
 | |
| 
 | |
|         //to fit mysql operator
 | |
|         if ($matchType === SegmentExpression::MATCH_EQUAL) {
 | |
|             $matchType = "=";
 | |
|         }
 | |
| 
 | |
|         $table = Common::prefixTable($this->dbTableName);
 | |
|         $sql = " SELECT idvisit from {$table} WHERE (idgoal = {$idGoal} and revenue {$matchType} ?) ";
 | |
|         return [
 | |
|           'SQL'  => $sql,
 | |
|           'bind' =>(float)$valueToMatch,
 | |
|         ];
 | |
|     }
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * @param Request $request
 | |
|      * @param Visitor $visitor
 | |
|      * @param Action|null $action
 | |
|      * @param GoalManager $goalManager
 | |
|      *
 | |
|      * @return mixed|false
 | |
|      */
 | |
|     public function onGoalConversion(Request $request, Visitor $visitor, $action, GoalManager $goalManager)
 | |
|     {
 | |
|         $defaultRevenue = $goalManager->getGoalColumn('revenue');
 | |
|         $revenue        = $request->getGoalRevenue($defaultRevenue);
 | |
| 
 | |
|         return $this->roundRevenueIfNeeded($revenue);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param Request $request
 | |
|      * @param Visitor $visitor
 | |
|      * @param Action|null $action
 | |
|      * @param GoalManager $goalManager
 | |
|      *
 | |
|      * @return mixed|false
 | |
|      */
 | |
|     public function onEcommerceOrderConversion(Request $request, Visitor $visitor, $action, GoalManager $goalManager)
 | |
|     {
 | |
|         $defaultRevenue = 0;
 | |
|         $revenue = $request->getGoalRevenue($defaultRevenue);
 | |
| 
 | |
|         return $this->roundRevenueIfNeeded($revenue);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param Request $request
 | |
|      * @param Visitor $visitor
 | |
|      * @param Action|null $action
 | |
|      * @param GoalManager $goalManager
 | |
|      *
 | |
|      * @return mixed|false
 | |
|      */
 | |
|     public function onEcommerceCartUpdateConversion(Request $request, Visitor $visitor, $action, GoalManager $goalManager)
 | |
|     {
 | |
|         return $this->onEcommerceOrderConversion($request, $visitor, $action, $goalManager);
 | |
|     }
 | |
| } |