| @@ -13,182 +13,182 @@ | ||
| 13 | 13 | class EE_Specific_Registrations_Line_Item_Filter extends EE_Line_Item_Filter_Base | 
| 14 | 14 |  { | 
| 15 | 15 | |
| 16 | - /** | |
| 17 | - * array of line item codes and their corresponding quantities for registrations | |
| 18 | - * | |
| 19 | - * @type array $_line_item_registrations | |
| 20 | - */ | |
| 21 | - protected $_line_item_registrations = array(); | |
| 16 | + /** | |
| 17 | + * array of line item codes and their corresponding quantities for registrations | |
| 18 | + * | |
| 19 | + * @type array $_line_item_registrations | |
| 20 | + */ | |
| 21 | + protected $_line_item_registrations = array(); | |
| 22 | 22 | |
| 23 | - /** | |
| 24 | - * Just kept in case we want it someday. Currently unused | |
| 25 | - * | |
| 26 | - * @var EE_Registration[] | |
| 27 | - */ | |
| 28 | - protected $_registrations = array(); | |
| 23 | + /** | |
| 24 | + * Just kept in case we want it someday. Currently unused | |
| 25 | + * | |
| 26 | + * @var EE_Registration[] | |
| 27 | + */ | |
| 28 | + protected $_registrations = array(); | |
| 29 | 29 | |
| 30 | - /** | |
| 31 | - * @var EE_Registration | |
| 32 | - */ | |
| 33 | - protected $_current_registration; | |
| 30 | + /** | |
| 31 | + * @var EE_Registration | |
| 32 | + */ | |
| 33 | + protected $_current_registration; | |
| 34 | 34 | |
| 35 | - /** | |
| 36 | - * these reg statuses should NOT increment the line item quantity | |
| 37 | - * | |
| 38 | - * @var array | |
| 39 | - */ | |
| 40 | - protected $_closed_reg_statuses = array(); | |
| 35 | + /** | |
| 36 | + * these reg statuses should NOT increment the line item quantity | |
| 37 | + * | |
| 38 | + * @var array | |
| 39 | + */ | |
| 40 | + protected $_closed_reg_statuses = array(); | |
| 41 | 41 | |
| 42 | 42 | |
| 43 | - /** | |
| 44 | - * EE_Billable_Line_Item_Filter constructor. | |
| 45 | - * | |
| 46 | - * @param EE_Registration[] $registrations | |
| 47 | - * @throws EE_Error | |
| 48 | - */ | |
| 49 | - public function __construct($registrations) | |
| 50 | -    { | |
| 51 | - $this->_registrations = $registrations; | |
| 52 | - $this->_calculate_registrations_per_line_item_code($registrations); | |
| 53 | - // these reg statuses should NOT increment the line item quantity | |
| 54 | - $this->_closed_reg_statuses = EEM_Registration::closed_reg_statuses(); | |
| 55 | - } | |
| 43 | + /** | |
| 44 | + * EE_Billable_Line_Item_Filter constructor. | |
| 45 | + * | |
| 46 | + * @param EE_Registration[] $registrations | |
| 47 | + * @throws EE_Error | |
| 48 | + */ | |
| 49 | + public function __construct($registrations) | |
| 50 | +	{ | |
| 51 | + $this->_registrations = $registrations; | |
| 52 | + $this->_calculate_registrations_per_line_item_code($registrations); | |
| 53 | + // these reg statuses should NOT increment the line item quantity | |
| 54 | + $this->_closed_reg_statuses = EEM_Registration::closed_reg_statuses(); | |
| 55 | + } | |
| 56 | 56 | |
| 57 | 57 | |
| 58 | - /** | |
| 59 | - * sets the _line_item_registrations from the provided registrations | |
| 60 | - * | |
| 61 | - * @param EE_Registration[] $registrations | |
| 62 | - * @return void | |
| 63 | - * @throws EE_Error | |
| 64 | - */ | |
| 65 | - protected function _calculate_registrations_per_line_item_code($registrations) | |
| 66 | -    { | |
| 67 | -        foreach ($registrations as $registration) { | |
| 68 | - $line_item_code = EEM_Line_Item::instance()->get_var( | |
| 69 | - EEM_Line_Item::instance()->line_item_for_registration_query_params( | |
| 70 | - $registration, | |
| 71 | -                    array('limit' => 1) | |
| 72 | - ), | |
| 73 | - 'LIN_code' | |
| 74 | - ); | |
| 75 | -            if ($line_item_code) { | |
| 76 | -                if (! isset($this->_line_item_registrations[ $line_item_code ])) { | |
| 77 | - $this->_line_item_registrations[ $line_item_code ] = array(); | |
| 78 | - } | |
| 79 | - $this->_line_item_registrations[ $line_item_code ][ $registration->ID() ] = $registration; | |
| 80 | - } | |
| 81 | - } | |
| 82 | - } | |
| 58 | + /** | |
| 59 | + * sets the _line_item_registrations from the provided registrations | |
| 60 | + * | |
| 61 | + * @param EE_Registration[] $registrations | |
| 62 | + * @return void | |
| 63 | + * @throws EE_Error | |
| 64 | + */ | |
| 65 | + protected function _calculate_registrations_per_line_item_code($registrations) | |
| 66 | +	{ | |
| 67 | +		foreach ($registrations as $registration) { | |
| 68 | + $line_item_code = EEM_Line_Item::instance()->get_var( | |
| 69 | + EEM_Line_Item::instance()->line_item_for_registration_query_params( | |
| 70 | + $registration, | |
| 71 | +					array('limit' => 1) | |
| 72 | + ), | |
| 73 | + 'LIN_code' | |
| 74 | + ); | |
| 75 | +			if ($line_item_code) { | |
| 76 | +				if (! isset($this->_line_item_registrations[ $line_item_code ])) { | |
| 77 | + $this->_line_item_registrations[ $line_item_code ] = array(); | |
| 78 | + } | |
| 79 | + $this->_line_item_registrations[ $line_item_code ][ $registration->ID() ] = $registration; | |
| 80 | + } | |
| 81 | + } | |
| 82 | + } | |
| 83 | 83 | |
| 84 | 84 | |
| 85 | - /** | |
| 86 | - * Creates a duplicate of the line item tree, except only includes billable items | |
| 87 | - * and the portion of line items attributed to billable things | |
| 88 | - * | |
| 89 | - * @param EEI_Line_Item $line_item | |
| 90 | - * @return EEI_Line_Item | |
| 91 | - * @throws EE_Error | |
| 92 | - */ | |
| 93 | - public function process(EEI_Line_Item $line_item) | |
| 94 | -    { | |
| 95 | - $this->_adjust_line_item_quantity($line_item); | |
| 96 | -        if (! $line_item->children()) { | |
| 97 | - return $line_item; | |
| 98 | - } | |
| 99 | - // the original running total (taking ALL tickets into account) | |
| 100 | - $running_total_of_children = 0; | |
| 101 | - // the new running total (only taking the specified ticket quantities into account) | |
| 102 | - $running_total_of_children_under_consideration = 0; | |
| 103 | - // let's also track the quantity of tickets that pertain to the registrations | |
| 104 | - $total_child_ticket_quantity = 0; | |
| 105 | -        foreach ($line_item->children() as $child_line_item) { | |
| 106 | - $original_li_total = $child_line_item->is_percent() | |
| 107 | - ? $running_total_of_children * $child_line_item->percent() / 100 | |
| 108 | - : $child_line_item->unit_price() * $child_line_item->quantity(); | |
| 109 | - $this->process($child_line_item); | |
| 110 | - // If this line item is a normal line item that isn't for a ticket, | |
| 111 | - // we want to modify its total (and unit price if not a percentage line item) | |
| 112 | - // so it reflects only that portion of the surcharge/discount shared by these registrations | |
| 113 | - if ($child_line_item->type() === EEM_Line_Item::type_line_item | |
| 114 | - && $child_line_item->OBJ_type() !== 'Ticket' | |
| 115 | -            ) { | |
| 116 | - $percent_of_running_total = $running_total_of_children | |
| 117 | - ? $original_li_total / $running_total_of_children | |
| 118 | - : 0; | |
| 119 | - $child_line_item->set_total( | |
| 120 | - $running_total_of_children_under_consideration * $percent_of_running_total | |
| 121 | - ); | |
| 122 | -                if (! $child_line_item->is_percent()) { | |
| 123 | - $child_line_item->set_unit_price($child_line_item->total() / $child_line_item->quantity()); | |
| 124 | - } | |
| 125 | - } elseif (// make sure this item's quantity and total matches its parent | |
| 126 | - $line_item->type() === EEM_Line_Item::type_line_item | |
| 127 | - && $line_item->OBJ_type() === 'Ticket' | |
| 128 | - // but not if it's a percentage modifier | |
| 129 | - && ! $child_line_item->is_percent() | |
| 130 | - && ! ( | |
| 131 | - // or a cancellation | |
| 132 | - $child_line_item->is_cancelled() | |
| 133 | - && ! ( | |
| 134 | - // unless it IS a cancellation and the current registration is cancelled | |
| 135 | - $child_line_item->is_cancelled() | |
| 136 | - && $this->_current_registration instanceof EE_Registration | |
| 137 | - && in_array($this->_current_registration->status_ID(), $this->_closed_reg_statuses, true) | |
| 138 | - ) | |
| 139 | - ) | |
| 140 | -            ) { | |
| 141 | - $child_line_item->set_quantity($line_item->quantity()); | |
| 142 | - $child_line_item->set_total($child_line_item->unit_price() * $child_line_item->quantity()); | |
| 143 | - } | |
| 144 | - $running_total_of_children += $original_li_total; | |
| 145 | - $running_total_of_children_under_consideration += $child_line_item->total(); | |
| 146 | -            if ($child_line_item->OBJ_type() === 'Ticket') { | |
| 147 | - $total_child_ticket_quantity += $child_line_item->quantity(); | |
| 148 | - } | |
| 149 | - } | |
| 150 | - $line_item->set_total($running_total_of_children_under_consideration); | |
| 151 | -        if ($line_item->quantity()) { | |
| 152 | - $line_item->set_unit_price($running_total_of_children_under_consideration / $line_item->quantity()); | |
| 153 | -        } else { | |
| 154 | - $line_item->set_unit_price(0); | |
| 155 | - } | |
| 156 | -        if ($line_item->OBJ_type() === 'Event') { | |
| 157 | - $line_item->set_quantity($total_child_ticket_quantity); | |
| 158 | - } | |
| 159 | - return $line_item; | |
| 160 | - } | |
| 85 | + /** | |
| 86 | + * Creates a duplicate of the line item tree, except only includes billable items | |
| 87 | + * and the portion of line items attributed to billable things | |
| 88 | + * | |
| 89 | + * @param EEI_Line_Item $line_item | |
| 90 | + * @return EEI_Line_Item | |
| 91 | + * @throws EE_Error | |
| 92 | + */ | |
| 93 | + public function process(EEI_Line_Item $line_item) | |
| 94 | +	{ | |
| 95 | + $this->_adjust_line_item_quantity($line_item); | |
| 96 | +		if (! $line_item->children()) { | |
| 97 | + return $line_item; | |
| 98 | + } | |
| 99 | + // the original running total (taking ALL tickets into account) | |
| 100 | + $running_total_of_children = 0; | |
| 101 | + // the new running total (only taking the specified ticket quantities into account) | |
| 102 | + $running_total_of_children_under_consideration = 0; | |
| 103 | + // let's also track the quantity of tickets that pertain to the registrations | |
| 104 | + $total_child_ticket_quantity = 0; | |
| 105 | +		foreach ($line_item->children() as $child_line_item) { | |
| 106 | + $original_li_total = $child_line_item->is_percent() | |
| 107 | + ? $running_total_of_children * $child_line_item->percent() / 100 | |
| 108 | + : $child_line_item->unit_price() * $child_line_item->quantity(); | |
| 109 | + $this->process($child_line_item); | |
| 110 | + // If this line item is a normal line item that isn't for a ticket, | |
| 111 | + // we want to modify its total (and unit price if not a percentage line item) | |
| 112 | + // so it reflects only that portion of the surcharge/discount shared by these registrations | |
| 113 | + if ($child_line_item->type() === EEM_Line_Item::type_line_item | |
| 114 | + && $child_line_item->OBJ_type() !== 'Ticket' | |
| 115 | +			) { | |
| 116 | + $percent_of_running_total = $running_total_of_children | |
| 117 | + ? $original_li_total / $running_total_of_children | |
| 118 | + : 0; | |
| 119 | + $child_line_item->set_total( | |
| 120 | + $running_total_of_children_under_consideration * $percent_of_running_total | |
| 121 | + ); | |
| 122 | +				if (! $child_line_item->is_percent()) { | |
| 123 | + $child_line_item->set_unit_price($child_line_item->total() / $child_line_item->quantity()); | |
| 124 | + } | |
| 125 | + } elseif (// make sure this item's quantity and total matches its parent | |
| 126 | + $line_item->type() === EEM_Line_Item::type_line_item | |
| 127 | + && $line_item->OBJ_type() === 'Ticket' | |
| 128 | + // but not if it's a percentage modifier | |
| 129 | + && ! $child_line_item->is_percent() | |
| 130 | + && ! ( | |
| 131 | + // or a cancellation | |
| 132 | + $child_line_item->is_cancelled() | |
| 133 | + && ! ( | |
| 134 | + // unless it IS a cancellation and the current registration is cancelled | |
| 135 | + $child_line_item->is_cancelled() | |
| 136 | + && $this->_current_registration instanceof EE_Registration | |
| 137 | + && in_array($this->_current_registration->status_ID(), $this->_closed_reg_statuses, true) | |
| 138 | + ) | |
| 139 | + ) | |
| 140 | +			) { | |
| 141 | + $child_line_item->set_quantity($line_item->quantity()); | |
| 142 | + $child_line_item->set_total($child_line_item->unit_price() * $child_line_item->quantity()); | |
| 143 | + } | |
| 144 | + $running_total_of_children += $original_li_total; | |
| 145 | + $running_total_of_children_under_consideration += $child_line_item->total(); | |
| 146 | +			if ($child_line_item->OBJ_type() === 'Ticket') { | |
| 147 | + $total_child_ticket_quantity += $child_line_item->quantity(); | |
| 148 | + } | |
| 149 | + } | |
| 150 | + $line_item->set_total($running_total_of_children_under_consideration); | |
| 151 | +		if ($line_item->quantity()) { | |
| 152 | + $line_item->set_unit_price($running_total_of_children_under_consideration / $line_item->quantity()); | |
| 153 | +		} else { | |
| 154 | + $line_item->set_unit_price(0); | |
| 155 | + } | |
| 156 | +		if ($line_item->OBJ_type() === 'Event') { | |
| 157 | + $line_item->set_quantity($total_child_ticket_quantity); | |
| 158 | + } | |
| 159 | + return $line_item; | |
| 160 | + } | |
| 161 | 161 | |
| 162 | 162 | |
| 163 | - /** | |
| 164 | - * Adjusts quantities for line items for tickets according to the registrations provided | |
| 165 | - * in the constructor | |
| 166 | - * | |
| 167 | - * @param EEI_Line_Item $line_item | |
| 168 | - * @return EEI_Line_Item | |
| 169 | - */ | |
| 170 | - protected function _adjust_line_item_quantity(EEI_Line_Item $line_item) | |
| 171 | -    { | |
| 172 | - // is this a ticket ? | |
| 173 | -        if ($line_item->type() === EEM_Line_Item::type_line_item && $line_item->OBJ_type() === 'Ticket') { | |
| 174 | - $this->_current_registration = null; | |
| 175 | - $quantity = 0; | |
| 176 | - // if this ticket is billable at this moment, then we should have a positive quantity | |
| 177 | - if (isset($this->_line_item_registrations[ $line_item->code() ]) | |
| 178 | - && is_array($this->_line_item_registrations[ $line_item->code() ]) | |
| 179 | -            ) { | |
| 180 | - // set quantity based on number of open registrations for this ticket | |
| 181 | -                foreach ($this->_line_item_registrations[ $line_item->code() ] as $registration) { | |
| 182 | - if ($registration instanceof EE_Registration | |
| 183 | -                    ) { | |
| 184 | - $quantity++; | |
| 185 | - $this->_current_registration = $registration; | |
| 186 | - } | |
| 187 | - } | |
| 188 | - } | |
| 189 | - $line_item->set_quantity($quantity); | |
| 190 | - $line_item->set_total($line_item->unit_price() * $line_item->quantity()); | |
| 191 | - } | |
| 192 | - return $line_item; | |
| 193 | - } | |
| 163 | + /** | |
| 164 | + * Adjusts quantities for line items for tickets according to the registrations provided | |
| 165 | + * in the constructor | |
| 166 | + * | |
| 167 | + * @param EEI_Line_Item $line_item | |
| 168 | + * @return EEI_Line_Item | |
| 169 | + */ | |
| 170 | + protected function _adjust_line_item_quantity(EEI_Line_Item $line_item) | |
| 171 | +	{ | |
| 172 | + // is this a ticket ? | |
| 173 | +		if ($line_item->type() === EEM_Line_Item::type_line_item && $line_item->OBJ_type() === 'Ticket') { | |
| 174 | + $this->_current_registration = null; | |
| 175 | + $quantity = 0; | |
| 176 | + // if this ticket is billable at this moment, then we should have a positive quantity | |
| 177 | + if (isset($this->_line_item_registrations[ $line_item->code() ]) | |
| 178 | + && is_array($this->_line_item_registrations[ $line_item->code() ]) | |
| 179 | +			) { | |
| 180 | + // set quantity based on number of open registrations for this ticket | |
| 181 | +				foreach ($this->_line_item_registrations[ $line_item->code() ] as $registration) { | |
| 182 | + if ($registration instanceof EE_Registration | |
| 183 | +					) { | |
| 184 | + $quantity++; | |
| 185 | + $this->_current_registration = $registration; | |
| 186 | + } | |
| 187 | + } | |
| 188 | + } | |
| 189 | + $line_item->set_quantity($quantity); | |
| 190 | + $line_item->set_total($line_item->unit_price() * $line_item->quantity()); | |
| 191 | + } | |
| 192 | + return $line_item; | |
| 193 | + } | |
| 194 | 194 | } | 
| @@ -73,10 +73,10 @@ discard block | ||
| 73 | 73 | 'LIN_code' | 
| 74 | 74 | ); | 
| 75 | 75 |              if ($line_item_code) { | 
| 76 | -                if (! isset($this->_line_item_registrations[ $line_item_code ])) { | |
| 77 | - $this->_line_item_registrations[ $line_item_code ] = array(); | |
| 76 | +                if ( ! isset($this->_line_item_registrations[$line_item_code])) { | |
| 77 | + $this->_line_item_registrations[$line_item_code] = array(); | |
| 78 | 78 | } | 
| 79 | - $this->_line_item_registrations[ $line_item_code ][ $registration->ID() ] = $registration; | |
| 79 | + $this->_line_item_registrations[$line_item_code][$registration->ID()] = $registration; | |
| 80 | 80 | } | 
| 81 | 81 | } | 
| 82 | 82 | } | 
| @@ -93,7 +93,7 @@ discard block | ||
| 93 | 93 | public function process(EEI_Line_Item $line_item) | 
| 94 | 94 |      { | 
| 95 | 95 | $this->_adjust_line_item_quantity($line_item); | 
| 96 | -        if (! $line_item->children()) { | |
| 96 | +        if ( ! $line_item->children()) { | |
| 97 | 97 | return $line_item; | 
| 98 | 98 | } | 
| 99 | 99 | // the original running total (taking ALL tickets into account) | 
| @@ -119,7 +119,7 @@ discard block | ||
| 119 | 119 | $child_line_item->set_total( | 
| 120 | 120 | $running_total_of_children_under_consideration * $percent_of_running_total | 
| 121 | 121 | ); | 
| 122 | -                if (! $child_line_item->is_percent()) { | |
| 122 | +                if ( ! $child_line_item->is_percent()) { | |
| 123 | 123 | $child_line_item->set_unit_price($child_line_item->total() / $child_line_item->quantity()); | 
| 124 | 124 | } | 
| 125 | 125 | } elseif (// make sure this item's quantity and total matches its parent | 
| @@ -174,11 +174,11 @@ discard block | ||
| 174 | 174 | $this->_current_registration = null; | 
| 175 | 175 | $quantity = 0; | 
| 176 | 176 | // if this ticket is billable at this moment, then we should have a positive quantity | 
| 177 | - if (isset($this->_line_item_registrations[ $line_item->code() ]) | |
| 178 | - && is_array($this->_line_item_registrations[ $line_item->code() ]) | |
| 177 | + if (isset($this->_line_item_registrations[$line_item->code()]) | |
| 178 | + && is_array($this->_line_item_registrations[$line_item->code()]) | |
| 179 | 179 |              ) { | 
| 180 | 180 | // set quantity based on number of open registrations for this ticket | 
| 181 | -                foreach ($this->_line_item_registrations[ $line_item->code() ] as $registration) { | |
| 181 | +                foreach ($this->_line_item_registrations[$line_item->code()] as $registration) { | |
| 182 | 182 | if ($registration instanceof EE_Registration | 
| 183 | 183 |                      ) { | 
| 184 | 184 | $quantity++; | 
| @@ -14,62 +14,62 @@ | ||
| 14 | 14 | class EE_Line_Item_Display | 
| 15 | 15 |  { | 
| 16 | 16 | |
| 17 | - private $strategy = null; | |
| 17 | + private $strategy = null; | |
| 18 | 18 | |
| 19 | 19 | |
| 20 | - /** | |
| 21 | - * @param string $context - where/how the line items are being displayed | |
| 22 | - * @param string $other_line_item_display_strategy | |
| 23 | - */ | |
| 24 | - public function __construct($context = '', $other_line_item_display_strategy = '') | |
| 25 | -    { | |
| 26 | - $context = strtolower($context); | |
| 27 | -        switch ($context) { | |
| 28 | - case 'invoice': | |
| 29 | - $this->strategy = new EE_Invoice_Line_Item_Display_Strategy(); | |
| 30 | - break; | |
| 31 | - case 'receipt': | |
| 32 | - $this->strategy = new EE_Receipt_Line_Item_Display_Strategy(); | |
| 33 | - break; | |
| 34 | - case 'spco': | |
| 35 | - $this->strategy = new EE_SPCO_Line_Item_Display_Strategy(); | |
| 36 | - break; | |
| 37 | - default: | |
| 38 | - if (! empty($other_line_item_display_strategy) && | |
| 39 | - class_exists($other_line_item_display_strategy) | |
| 40 | -                ) { | |
| 41 | - $this->strategy = new $other_line_item_display_strategy(); | |
| 42 | -                } else { | |
| 43 | - $this->strategy = new EE_Default_Line_Item_Display_Strategy(); | |
| 44 | - } | |
| 45 | - } | |
| 46 | - } | |
| 20 | + /** | |
| 21 | + * @param string $context - where/how the line items are being displayed | |
| 22 | + * @param string $other_line_item_display_strategy | |
| 23 | + */ | |
| 24 | + public function __construct($context = '', $other_line_item_display_strategy = '') | |
| 25 | +	{ | |
| 26 | + $context = strtolower($context); | |
| 27 | +		switch ($context) { | |
| 28 | + case 'invoice': | |
| 29 | + $this->strategy = new EE_Invoice_Line_Item_Display_Strategy(); | |
| 30 | + break; | |
| 31 | + case 'receipt': | |
| 32 | + $this->strategy = new EE_Receipt_Line_Item_Display_Strategy(); | |
| 33 | + break; | |
| 34 | + case 'spco': | |
| 35 | + $this->strategy = new EE_SPCO_Line_Item_Display_Strategy(); | |
| 36 | + break; | |
| 37 | + default: | |
| 38 | + if (! empty($other_line_item_display_strategy) && | |
| 39 | + class_exists($other_line_item_display_strategy) | |
| 40 | +				) { | |
| 41 | + $this->strategy = new $other_line_item_display_strategy(); | |
| 42 | +				} else { | |
| 43 | + $this->strategy = new EE_Default_Line_Item_Display_Strategy(); | |
| 44 | + } | |
| 45 | + } | |
| 46 | + } | |
| 47 | 47 | |
| 48 | - /** | |
| 49 | - * @param EE_Line_Item $line_item | |
| 50 | - * @param array $options | |
| 51 | - * @return mixed | |
| 52 | - */ | |
| 53 | - public function display_line_item(EE_Line_Item $line_item, $options = array()) | |
| 54 | -    { | |
| 55 | - return $this->strategy->display_line_item($line_item, $options); | |
| 56 | - } | |
| 48 | + /** | |
| 49 | + * @param EE_Line_Item $line_item | |
| 50 | + * @param array $options | |
| 51 | + * @return mixed | |
| 52 | + */ | |
| 53 | + public function display_line_item(EE_Line_Item $line_item, $options = array()) | |
| 54 | +	{ | |
| 55 | + return $this->strategy->display_line_item($line_item, $options); | |
| 56 | + } | |
| 57 | 57 | |
| 58 | 58 | |
| 59 | - /** | |
| 60 | - * @return float | |
| 61 | - */ | |
| 62 | - public function grand_total() | |
| 63 | -    { | |
| 64 | - return $this->strategy->grand_total(); | |
| 65 | - } | |
| 59 | + /** | |
| 60 | + * @return float | |
| 61 | + */ | |
| 62 | + public function grand_total() | |
| 63 | +	{ | |
| 64 | + return $this->strategy->grand_total(); | |
| 65 | + } | |
| 66 | 66 | |
| 67 | 67 | |
| 68 | - /** | |
| 69 | - * @return float | |
| 70 | - */ | |
| 71 | - public function total_items() | |
| 72 | -    { | |
| 73 | - return $this->strategy->total_items(); | |
| 74 | - } | |
| 68 | + /** | |
| 69 | + * @return float | |
| 70 | + */ | |
| 71 | + public function total_items() | |
| 72 | +	{ | |
| 73 | + return $this->strategy->total_items(); | |
| 74 | + } | |
| 75 | 75 | } | 
| @@ -35,7 +35,7 @@ | ||
| 35 | 35 | $this->strategy = new EE_SPCO_Line_Item_Display_Strategy(); | 
| 36 | 36 | break; | 
| 37 | 37 | default: | 
| 38 | - if (! empty($other_line_item_display_strategy) && | |
| 38 | + if ( ! empty($other_line_item_display_strategy) && | |
| 39 | 39 | class_exists($other_line_item_display_strategy) | 
| 40 | 40 |                  ) { | 
| 41 | 41 | $this->strategy = new $other_line_item_display_strategy(); | 
| @@ -14,195 +14,195 @@ | ||
| 14 | 14 | class EE_Template_Part_Manager | 
| 15 | 15 |  { | 
| 16 | 16 | |
| 17 | - /** | |
| 18 | - * @param EE_Template_Part_PriorityQueue $template_parts | |
| 19 | - */ | |
| 20 | - protected $template_parts; | |
| 21 | - | |
| 22 | - /** | |
| 23 | - * @param array $priorities | |
| 24 | - */ | |
| 25 | - protected $priorities = array(); | |
| 26 | - | |
| 27 | - /** | |
| 28 | - * @param int $event_desc_priority | |
| 29 | - */ | |
| 30 | - protected $event_desc_priority; | |
| 31 | - | |
| 32 | - /** | |
| 33 | - * @param string $before_event_content | |
| 34 | - */ | |
| 35 | - protected $before_event_content; | |
| 36 | - | |
| 37 | - /** | |
| 38 | - * @param string $event_content | |
| 39 | - */ | |
| 40 | - protected $event_content; | |
| 41 | - | |
| 42 | - /** | |
| 43 | - * @param string $after_event_content | |
| 44 | - */ | |
| 45 | - protected $after_event_content; | |
| 46 | - | |
| 47 | - | |
| 48 | - /** | |
| 49 | - * class constructor | |
| 50 | - */ | |
| 51 | - public function __construct() | |
| 52 | -    { | |
| 53 | - $this->template_parts = new EE_Template_Part_PriorityQueue(); | |
| 54 | - } | |
| 55 | - | |
| 56 | - | |
| 57 | - /** | |
| 58 | - * add_template_part | |
| 59 | - * | |
| 60 | - * used for setting the details about a particular template part | |
| 61 | - * | |
| 62 | - * @param string $name - just a simple string identifier - do NOT use 'event' | |
| 63 | - * @param string $label - template part label displayed in admin | |
| 64 | - * @param string $template - name or path of template to be used by EEH_Template::locate_template() | |
| 65 | - * @param int $priority - order in which template parts should be applied | |
| 66 | - */ | |
| 67 | - public function add_template_part($name, $label, $template, $priority) | |
| 68 | -    { | |
| 69 | - // SplPriorityQueue doesn't play nice with multiple items having the same priority | |
| 70 | - // so if the incoming priority is already occupied, then let's increment it by one, | |
| 71 | - // and then pass everything back into this method and try again with the new priority | |
| 72 | -        if (isset($this->priorities[ $priority ])) { | |
| 73 | - $priority++; | |
| 74 | - $this->add_template_part($name, $label, $template, $priority); | |
| 75 | - return; | |
| 76 | - } | |
| 77 | - // kk now we can mark this priority as being occupied | |
| 78 | - $this->priorities[ $priority ] = true; | |
| 79 | - // create the template part and add to the queue | |
| 80 | - $this->template_parts->insert( | |
| 81 | - new EE_Template_Part($name, $label, $template, $priority), | |
| 82 | - $priority | |
| 83 | - ); | |
| 84 | -        if ($name === 'event') { | |
| 85 | - $this->event_desc_priority = $priority; | |
| 86 | - } | |
| 87 | - } | |
| 88 | - | |
| 89 | - | |
| 90 | - /** | |
| 91 | - * apply_template_part_filters | |
| 92 | - * | |
| 93 | - * adds template parts to the supplied content | |
| 94 | - * according to the details set when the template parts were added | |
| 95 | - * | |
| 96 | - * @access public | |
| 97 | - * @param string $content | |
| 98 | - * @return string | |
| 99 | - */ | |
| 100 | - public function apply_template_part_filters($content = '') | |
| 101 | -    { | |
| 102 | - $this->template_parts->rewind(); | |
| 103 | - // loop through template parts and position content | |
| 104 | -        while ($this->template_parts->valid()) { | |
| 105 | - $this->_position_template_part( | |
| 106 | - $content, | |
| 107 | - $this->template_parts->current()->template(), | |
| 108 | - $this->template_parts->current()->priority() | |
| 109 | - ); | |
| 110 | - $this->template_parts->next(); | |
| 111 | - } | |
| 112 | - // now simply add our three strings of content together | |
| 113 | - return $this->before_event_content . $this->event_content . $this->after_event_content; | |
| 114 | - } | |
| 115 | - | |
| 116 | - | |
| 117 | - /** | |
| 118 | - * position_template_part | |
| 119 | - * | |
| 120 | - * based on the priority of the incoming template part | |
| 121 | - * relative to the known event description template part priority, | |
| 122 | - * this method will assign template parts to one of the following: | |
| 123 | - * $this->before_event_content | |
| 124 | - * $this->event_content | |
| 125 | - * $this->after_event_content | |
| 126 | - * | |
| 127 | - * @access protected | |
| 128 | - * @param string $content | |
| 129 | - * @param string $template | |
| 130 | - * @param int $priority | |
| 131 | - * @return void | |
| 132 | - */ | |
| 133 | - protected function _position_template_part($content, $template, $priority) | |
| 134 | -    { | |
| 135 | - // Event Description content is the actual incoming content itself | |
| 136 | -        if ($priority === $this->event_desc_priority) { | |
| 137 | - $this->event_content = $content; | |
| 138 | -        } elseif ($priority < $this->event_desc_priority) { | |
| 139 | - // everything BEFORE the Event Description | |
| 140 | - $this->before_event_content .= EEH_Template::locate_template($template); | |
| 141 | -        } elseif ($priority > $this->event_desc_priority) { | |
| 142 | - // everything AFTER the Event Description | |
| 143 | - $this->after_event_content .= EEH_Template::locate_template($template); | |
| 144 | - } | |
| 145 | - } | |
| 146 | - | |
| 147 | - | |
| 148 | - /** | |
| 149 | - * generate_sortable_list_of_template_parts | |
| 150 | - * | |
| 151 | - * creates an HTML list (<ul>) with list items (<li>) for each template part, | |
| 152 | - * in a format that can be used as a sortable list in the admin | |
| 153 | - * | |
| 154 | - * @access public | |
| 155 | - * @param string $list_css_id | |
| 156 | - * @param string $list_css_class | |
| 157 | - * @param string $list_item_css_class | |
| 158 | - * @param string $list_item_css_id_prefix | |
| 159 | - * @return string | |
| 160 | - */ | |
| 161 | - public function generate_sortable_list_of_template_parts( | |
| 162 | - $list_css_id = '', | |
| 163 | - $list_css_class = '', | |
| 164 | - $list_item_css_class = '', | |
| 165 | - $list_item_css_id_prefix = '' | |
| 166 | -    ) { | |
| 167 | - $event_archive_display_order = EEH_HTML::ul($list_css_id, $list_css_class); | |
| 168 | - $this->template_parts->rewind(); | |
| 169 | - // loop through template parts and add template content | |
| 170 | -        while ($this->template_parts->valid()) { | |
| 171 | - $event_archive_display_order .= EEH_HTML::li( | |
| 172 | -                EEH_HTML::span('', '', 'dashicons dashicons-arrow-up-alt2') . | |
| 173 | -                EEH_HTML::span('', '', 'dashicons dashicons-arrow-down-alt2') . | |
| 174 | - $this->template_parts->current()->label(), | |
| 175 | - $list_item_css_id_prefix . $this->template_parts->current()->name(), | |
| 176 | - $list_item_css_class | |
| 177 | - ); | |
| 178 | - $this->template_parts->next(); | |
| 179 | - } | |
| 180 | - $event_archive_display_order .= EEH_HTML::ulx(); | |
| 181 | - return $event_archive_display_order; | |
| 182 | - } | |
| 183 | - | |
| 184 | - | |
| 185 | - /** | |
| 186 | - * display_template_parts | |
| 187 | - * | |
| 188 | - * just for debugging purposes | |
| 189 | - * | |
| 190 | - * @access public | |
| 191 | - * @return void | |
| 192 | - */ | |
| 193 | - public function display_template_parts() | |
| 194 | -    { | |
| 195 | -        if (WP_DEBUG) { | |
| 196 | - $this->template_parts->rewind(); | |
| 197 | -            while ($this->template_parts->valid()) { | |
| 198 | - EEH_Debug_Tools::printr( | |
| 199 | - $this->template_parts->current(), | |
| 200 | - 'template_part', | |
| 201 | - __FILE__, | |
| 202 | - __LINE__ | |
| 203 | - ); | |
| 204 | - $this->template_parts->next(); | |
| 205 | - } | |
| 206 | - } | |
| 207 | - } | |
| 17 | + /** | |
| 18 | + * @param EE_Template_Part_PriorityQueue $template_parts | |
| 19 | + */ | |
| 20 | + protected $template_parts; | |
| 21 | + | |
| 22 | + /** | |
| 23 | + * @param array $priorities | |
| 24 | + */ | |
| 25 | + protected $priorities = array(); | |
| 26 | + | |
| 27 | + /** | |
| 28 | + * @param int $event_desc_priority | |
| 29 | + */ | |
| 30 | + protected $event_desc_priority; | |
| 31 | + | |
| 32 | + /** | |
| 33 | + * @param string $before_event_content | |
| 34 | + */ | |
| 35 | + protected $before_event_content; | |
| 36 | + | |
| 37 | + /** | |
| 38 | + * @param string $event_content | |
| 39 | + */ | |
| 40 | + protected $event_content; | |
| 41 | + | |
| 42 | + /** | |
| 43 | + * @param string $after_event_content | |
| 44 | + */ | |
| 45 | + protected $after_event_content; | |
| 46 | + | |
| 47 | + | |
| 48 | + /** | |
| 49 | + * class constructor | |
| 50 | + */ | |
| 51 | + public function __construct() | |
| 52 | +	{ | |
| 53 | + $this->template_parts = new EE_Template_Part_PriorityQueue(); | |
| 54 | + } | |
| 55 | + | |
| 56 | + | |
| 57 | + /** | |
| 58 | + * add_template_part | |
| 59 | + * | |
| 60 | + * used for setting the details about a particular template part | |
| 61 | + * | |
| 62 | + * @param string $name - just a simple string identifier - do NOT use 'event' | |
| 63 | + * @param string $label - template part label displayed in admin | |
| 64 | + * @param string $template - name or path of template to be used by EEH_Template::locate_template() | |
| 65 | + * @param int $priority - order in which template parts should be applied | |
| 66 | + */ | |
| 67 | + public function add_template_part($name, $label, $template, $priority) | |
| 68 | +	{ | |
| 69 | + // SplPriorityQueue doesn't play nice with multiple items having the same priority | |
| 70 | + // so if the incoming priority is already occupied, then let's increment it by one, | |
| 71 | + // and then pass everything back into this method and try again with the new priority | |
| 72 | +		if (isset($this->priorities[ $priority ])) { | |
| 73 | + $priority++; | |
| 74 | + $this->add_template_part($name, $label, $template, $priority); | |
| 75 | + return; | |
| 76 | + } | |
| 77 | + // kk now we can mark this priority as being occupied | |
| 78 | + $this->priorities[ $priority ] = true; | |
| 79 | + // create the template part and add to the queue | |
| 80 | + $this->template_parts->insert( | |
| 81 | + new EE_Template_Part($name, $label, $template, $priority), | |
| 82 | + $priority | |
| 83 | + ); | |
| 84 | +		if ($name === 'event') { | |
| 85 | + $this->event_desc_priority = $priority; | |
| 86 | + } | |
| 87 | + } | |
| 88 | + | |
| 89 | + | |
| 90 | + /** | |
| 91 | + * apply_template_part_filters | |
| 92 | + * | |
| 93 | + * adds template parts to the supplied content | |
| 94 | + * according to the details set when the template parts were added | |
| 95 | + * | |
| 96 | + * @access public | |
| 97 | + * @param string $content | |
| 98 | + * @return string | |
| 99 | + */ | |
| 100 | + public function apply_template_part_filters($content = '') | |
| 101 | +	{ | |
| 102 | + $this->template_parts->rewind(); | |
| 103 | + // loop through template parts and position content | |
| 104 | +		while ($this->template_parts->valid()) { | |
| 105 | + $this->_position_template_part( | |
| 106 | + $content, | |
| 107 | + $this->template_parts->current()->template(), | |
| 108 | + $this->template_parts->current()->priority() | |
| 109 | + ); | |
| 110 | + $this->template_parts->next(); | |
| 111 | + } | |
| 112 | + // now simply add our three strings of content together | |
| 113 | + return $this->before_event_content . $this->event_content . $this->after_event_content; | |
| 114 | + } | |
| 115 | + | |
| 116 | + | |
| 117 | + /** | |
| 118 | + * position_template_part | |
| 119 | + * | |
| 120 | + * based on the priority of the incoming template part | |
| 121 | + * relative to the known event description template part priority, | |
| 122 | + * this method will assign template parts to one of the following: | |
| 123 | + * $this->before_event_content | |
| 124 | + * $this->event_content | |
| 125 | + * $this->after_event_content | |
| 126 | + * | |
| 127 | + * @access protected | |
| 128 | + * @param string $content | |
| 129 | + * @param string $template | |
| 130 | + * @param int $priority | |
| 131 | + * @return void | |
| 132 | + */ | |
| 133 | + protected function _position_template_part($content, $template, $priority) | |
| 134 | +	{ | |
| 135 | + // Event Description content is the actual incoming content itself | |
| 136 | +		if ($priority === $this->event_desc_priority) { | |
| 137 | + $this->event_content = $content; | |
| 138 | +		} elseif ($priority < $this->event_desc_priority) { | |
| 139 | + // everything BEFORE the Event Description | |
| 140 | + $this->before_event_content .= EEH_Template::locate_template($template); | |
| 141 | +		} elseif ($priority > $this->event_desc_priority) { | |
| 142 | + // everything AFTER the Event Description | |
| 143 | + $this->after_event_content .= EEH_Template::locate_template($template); | |
| 144 | + } | |
| 145 | + } | |
| 146 | + | |
| 147 | + | |
| 148 | + /** | |
| 149 | + * generate_sortable_list_of_template_parts | |
| 150 | + * | |
| 151 | + * creates an HTML list (<ul>) with list items (<li>) for each template part, | |
| 152 | + * in a format that can be used as a sortable list in the admin | |
| 153 | + * | |
| 154 | + * @access public | |
| 155 | + * @param string $list_css_id | |
| 156 | + * @param string $list_css_class | |
| 157 | + * @param string $list_item_css_class | |
| 158 | + * @param string $list_item_css_id_prefix | |
| 159 | + * @return string | |
| 160 | + */ | |
| 161 | + public function generate_sortable_list_of_template_parts( | |
| 162 | + $list_css_id = '', | |
| 163 | + $list_css_class = '', | |
| 164 | + $list_item_css_class = '', | |
| 165 | + $list_item_css_id_prefix = '' | |
| 166 | +	) { | |
| 167 | + $event_archive_display_order = EEH_HTML::ul($list_css_id, $list_css_class); | |
| 168 | + $this->template_parts->rewind(); | |
| 169 | + // loop through template parts and add template content | |
| 170 | +		while ($this->template_parts->valid()) { | |
| 171 | + $event_archive_display_order .= EEH_HTML::li( | |
| 172 | +				EEH_HTML::span('', '', 'dashicons dashicons-arrow-up-alt2') . | |
| 173 | +				EEH_HTML::span('', '', 'dashicons dashicons-arrow-down-alt2') . | |
| 174 | + $this->template_parts->current()->label(), | |
| 175 | + $list_item_css_id_prefix . $this->template_parts->current()->name(), | |
| 176 | + $list_item_css_class | |
| 177 | + ); | |
| 178 | + $this->template_parts->next(); | |
| 179 | + } | |
| 180 | + $event_archive_display_order .= EEH_HTML::ulx(); | |
| 181 | + return $event_archive_display_order; | |
| 182 | + } | |
| 183 | + | |
| 184 | + | |
| 185 | + /** | |
| 186 | + * display_template_parts | |
| 187 | + * | |
| 188 | + * just for debugging purposes | |
| 189 | + * | |
| 190 | + * @access public | |
| 191 | + * @return void | |
| 192 | + */ | |
| 193 | + public function display_template_parts() | |
| 194 | +	{ | |
| 195 | +		if (WP_DEBUG) { | |
| 196 | + $this->template_parts->rewind(); | |
| 197 | +			while ($this->template_parts->valid()) { | |
| 198 | + EEH_Debug_Tools::printr( | |
| 199 | + $this->template_parts->current(), | |
| 200 | + 'template_part', | |
| 201 | + __FILE__, | |
| 202 | + __LINE__ | |
| 203 | + ); | |
| 204 | + $this->template_parts->next(); | |
| 205 | + } | |
| 206 | + } | |
| 207 | + } | |
| 208 | 208 | } | 
| @@ -69,13 +69,13 @@ discard block | ||
| 69 | 69 | // SplPriorityQueue doesn't play nice with multiple items having the same priority | 
| 70 | 70 | // so if the incoming priority is already occupied, then let's increment it by one, | 
| 71 | 71 | // and then pass everything back into this method and try again with the new priority | 
| 72 | -        if (isset($this->priorities[ $priority ])) { | |
| 72 | +        if (isset($this->priorities[$priority])) { | |
| 73 | 73 | $priority++; | 
| 74 | 74 | $this->add_template_part($name, $label, $template, $priority); | 
| 75 | 75 | return; | 
| 76 | 76 | } | 
| 77 | 77 | // kk now we can mark this priority as being occupied | 
| 78 | - $this->priorities[ $priority ] = true; | |
| 78 | + $this->priorities[$priority] = true; | |
| 79 | 79 | // create the template part and add to the queue | 
| 80 | 80 | $this->template_parts->insert( | 
| 81 | 81 | new EE_Template_Part($name, $label, $template, $priority), | 
| @@ -110,7 +110,7 @@ discard block | ||
| 110 | 110 | $this->template_parts->next(); | 
| 111 | 111 | } | 
| 112 | 112 | // now simply add our three strings of content together | 
| 113 | - return $this->before_event_content . $this->event_content . $this->after_event_content; | |
| 113 | + return $this->before_event_content.$this->event_content.$this->after_event_content; | |
| 114 | 114 | } | 
| 115 | 115 | |
| 116 | 116 | |
| @@ -169,10 +169,10 @@ discard block | ||
| 169 | 169 | // loop through template parts and add template content | 
| 170 | 170 |          while ($this->template_parts->valid()) { | 
| 171 | 171 | $event_archive_display_order .= EEH_HTML::li( | 
| 172 | -                EEH_HTML::span('', '', 'dashicons dashicons-arrow-up-alt2') . | |
| 173 | -                EEH_HTML::span('', '', 'dashicons dashicons-arrow-down-alt2') . | |
| 172 | +                EEH_HTML::span('', '', 'dashicons dashicons-arrow-up-alt2'). | |
| 173 | +                EEH_HTML::span('', '', 'dashicons dashicons-arrow-down-alt2'). | |
| 174 | 174 | $this->template_parts->current()->label(), | 
| 175 | - $list_item_css_id_prefix . $this->template_parts->current()->name(), | |
| 175 | + $list_item_css_id_prefix.$this->template_parts->current()->name(), | |
| 176 | 176 | $list_item_css_class | 
| 177 | 177 | ); | 
| 178 | 178 | $this->template_parts->next(); | 
| @@ -16,112 +16,112 @@ | ||
| 16 | 16 |  { | 
| 17 | 17 | |
| 18 | 18 | |
| 19 | - /** | |
| 20 | - * @type string $name | |
| 21 | - */ | |
| 22 | - protected $name; | |
| 23 | - | |
| 24 | - /** | |
| 25 | - * @type string $label | |
| 26 | - */ | |
| 27 | - protected $label; | |
| 28 | - | |
| 29 | - /** | |
| 30 | - * @type string $template | |
| 31 | - */ | |
| 32 | - protected $template; | |
| 33 | - | |
| 34 | - /** | |
| 35 | - * @type int $priority | |
| 36 | - */ | |
| 37 | - protected $priority; | |
| 38 | - | |
| 39 | - | |
| 40 | - /** | |
| 41 | - * class constructor | |
| 42 | - * | |
| 43 | - * @param string $name | |
| 44 | - * @param string $label | |
| 45 | - * @param string $template | |
| 46 | - * @param int $priority | |
| 47 | - */ | |
| 48 | - public function __construct($name, $label, $template, $priority = 100) | |
| 49 | -    { | |
| 50 | - $this->set_name($name); | |
| 51 | - $this->set_label($label); | |
| 52 | - $this->set_template($template); | |
| 53 | - $this->set_priority($priority); | |
| 54 | - } | |
| 55 | - | |
| 56 | - | |
| 57 | - /** | |
| 58 | - * @return mixed | |
| 59 | - */ | |
| 60 | - public function name() | |
| 61 | -    { | |
| 62 | - return $this->name; | |
| 63 | - } | |
| 64 | - | |
| 65 | - | |
| 66 | - /** | |
| 67 | - * @param mixed $name | |
| 68 | - */ | |
| 69 | - public function set_name($name) | |
| 70 | -    { | |
| 71 | - $this->name = $name; | |
| 72 | - } | |
| 73 | - | |
| 74 | - | |
| 75 | - /** | |
| 76 | - * @return string | |
| 77 | - */ | |
| 78 | - public function label() | |
| 79 | -    { | |
| 80 | - return $this->label; | |
| 81 | - } | |
| 82 | - | |
| 83 | - | |
| 84 | - /** | |
| 85 | - * @param string $label | |
| 86 | - */ | |
| 87 | - public function set_label($label) | |
| 88 | -    { | |
| 89 | - $this->label = $label; | |
| 90 | - } | |
| 91 | - | |
| 92 | - | |
| 93 | - /** | |
| 94 | - * @return array | |
| 95 | - */ | |
| 96 | - public function template() | |
| 97 | -    { | |
| 98 | - return $this->template; | |
| 99 | - } | |
| 100 | - | |
| 101 | - | |
| 102 | - /** | |
| 103 | - * @param string $template | |
| 104 | - */ | |
| 105 | - public function set_template($template) | |
| 106 | -    { | |
| 107 | - $this->template = $template; | |
| 108 | - } | |
| 109 | - | |
| 110 | - | |
| 111 | - /** | |
| 112 | - * @return int | |
| 113 | - */ | |
| 114 | - public function priority() | |
| 115 | -    { | |
| 116 | - return $this->priority; | |
| 117 | - } | |
| 118 | - | |
| 119 | - | |
| 120 | - /** | |
| 121 | - * @param int $priority | |
| 122 | - */ | |
| 123 | - public function set_priority($priority) | |
| 124 | -    { | |
| 125 | - $this->priority = intval($priority); | |
| 126 | - } | |
| 19 | + /** | |
| 20 | + * @type string $name | |
| 21 | + */ | |
| 22 | + protected $name; | |
| 23 | + | |
| 24 | + /** | |
| 25 | + * @type string $label | |
| 26 | + */ | |
| 27 | + protected $label; | |
| 28 | + | |
| 29 | + /** | |
| 30 | + * @type string $template | |
| 31 | + */ | |
| 32 | + protected $template; | |
| 33 | + | |
| 34 | + /** | |
| 35 | + * @type int $priority | |
| 36 | + */ | |
| 37 | + protected $priority; | |
| 38 | + | |
| 39 | + | |
| 40 | + /** | |
| 41 | + * class constructor | |
| 42 | + * | |
| 43 | + * @param string $name | |
| 44 | + * @param string $label | |
| 45 | + * @param string $template | |
| 46 | + * @param int $priority | |
| 47 | + */ | |
| 48 | + public function __construct($name, $label, $template, $priority = 100) | |
| 49 | +	{ | |
| 50 | + $this->set_name($name); | |
| 51 | + $this->set_label($label); | |
| 52 | + $this->set_template($template); | |
| 53 | + $this->set_priority($priority); | |
| 54 | + } | |
| 55 | + | |
| 56 | + | |
| 57 | + /** | |
| 58 | + * @return mixed | |
| 59 | + */ | |
| 60 | + public function name() | |
| 61 | +	{ | |
| 62 | + return $this->name; | |
| 63 | + } | |
| 64 | + | |
| 65 | + | |
| 66 | + /** | |
| 67 | + * @param mixed $name | |
| 68 | + */ | |
| 69 | + public function set_name($name) | |
| 70 | +	{ | |
| 71 | + $this->name = $name; | |
| 72 | + } | |
| 73 | + | |
| 74 | + | |
| 75 | + /** | |
| 76 | + * @return string | |
| 77 | + */ | |
| 78 | + public function label() | |
| 79 | +	{ | |
| 80 | + return $this->label; | |
| 81 | + } | |
| 82 | + | |
| 83 | + | |
| 84 | + /** | |
| 85 | + * @param string $label | |
| 86 | + */ | |
| 87 | + public function set_label($label) | |
| 88 | +	{ | |
| 89 | + $this->label = $label; | |
| 90 | + } | |
| 91 | + | |
| 92 | + | |
| 93 | + /** | |
| 94 | + * @return array | |
| 95 | + */ | |
| 96 | + public function template() | |
| 97 | +	{ | |
| 98 | + return $this->template; | |
| 99 | + } | |
| 100 | + | |
| 101 | + | |
| 102 | + /** | |
| 103 | + * @param string $template | |
| 104 | + */ | |
| 105 | + public function set_template($template) | |
| 106 | +	{ | |
| 107 | + $this->template = $template; | |
| 108 | + } | |
| 109 | + | |
| 110 | + | |
| 111 | + /** | |
| 112 | + * @return int | |
| 113 | + */ | |
| 114 | + public function priority() | |
| 115 | +	{ | |
| 116 | + return $this->priority; | |
| 117 | + } | |
| 118 | + | |
| 119 | + | |
| 120 | + /** | |
| 121 | + * @param int $priority | |
| 122 | + */ | |
| 123 | + public function set_priority($priority) | |
| 124 | +	{ | |
| 125 | + $this->priority = intval($priority); | |
| 126 | + } | |
| 127 | 127 | } | 
| @@ -17,43 +17,43 @@ | ||
| 17 | 17 |  { | 
| 18 | 18 | |
| 19 | 19 | |
| 20 | - /** | |
| 21 | - * add | |
| 22 | - * | |
| 23 | - * attaches aTemplate_Part to the Collection | |
| 24 | - * and sets any supplied data associated with the current iterator entry | |
| 25 | - * | |
| 26 | - * @access public | |
| 27 | - * @param EE_Template_Part $object | |
| 28 | - * @param int $priority | |
| 29 | - * @return bool | |
| 30 | - */ | |
| 31 | - public function insert($object, $priority = 100) | |
| 32 | -    { | |
| 33 | -        if ($object instanceof EE_Template_Part) { | |
| 34 | - parent::insert($object, $priority); | |
| 35 | - return true; | |
| 36 | -        } else { | |
| 37 | - return false; | |
| 38 | - } | |
| 39 | - } | |
| 20 | + /** | |
| 21 | + * add | |
| 22 | + * | |
| 23 | + * attaches aTemplate_Part to the Collection | |
| 24 | + * and sets any supplied data associated with the current iterator entry | |
| 25 | + * | |
| 26 | + * @access public | |
| 27 | + * @param EE_Template_Part $object | |
| 28 | + * @param int $priority | |
| 29 | + * @return bool | |
| 30 | + */ | |
| 31 | + public function insert($object, $priority = 100) | |
| 32 | +	{ | |
| 33 | +		if ($object instanceof EE_Template_Part) { | |
| 34 | + parent::insert($object, $priority); | |
| 35 | + return true; | |
| 36 | +		} else { | |
| 37 | + return false; | |
| 38 | + } | |
| 39 | + } | |
| 40 | 40 | |
| 41 | 41 | |
| 42 | - /** | |
| 43 | - * compare | |
| 44 | - * | |
| 45 | - * sorts EE_Template_Part in ascending order based on set priority | |
| 46 | - * | |
| 47 | - * @access public | |
| 48 | - * @param int $priority1 | |
| 49 | - * @param int $priority2 | |
| 50 | - * @return bool | |
| 51 | - */ | |
| 52 | - public function compare($priority1, $priority2) | |
| 53 | -    { | |
| 54 | -        if ($priority1 === $priority2) { | |
| 55 | - return 0; | |
| 56 | - } | |
| 57 | - return $priority1 > $priority2 ? -1 : 1; | |
| 58 | - } | |
| 42 | + /** | |
| 43 | + * compare | |
| 44 | + * | |
| 45 | + * sorts EE_Template_Part in ascending order based on set priority | |
| 46 | + * | |
| 47 | + * @access public | |
| 48 | + * @param int $priority1 | |
| 49 | + * @param int $priority2 | |
| 50 | + * @return bool | |
| 51 | + */ | |
| 52 | + public function compare($priority1, $priority2) | |
| 53 | +	{ | |
| 54 | +		if ($priority1 === $priority2) { | |
| 55 | + return 0; | |
| 56 | + } | |
| 57 | + return $priority1 > $priority2 ? -1 : 1; | |
| 58 | + } | |
| 59 | 59 | } | 
| @@ -14,71 +14,71 @@ | ||
| 14 | 14 | class EE_Processor_Base | 
| 15 | 15 |  { | 
| 16 | 16 | |
| 17 | - /** | |
| 18 | - * Used to indicate whether current request is for an IPN or not. | |
| 19 | - * | |
| 20 | - * @var bool | |
| 21 | - */ | |
| 22 | - protected static $IPN = false; | |
| 17 | + /** | |
| 18 | + * Used to indicate whether current request is for an IPN or not. | |
| 19 | + * | |
| 20 | + * @var bool | |
| 21 | + */ | |
| 22 | + protected static $IPN = false; | |
| 23 | 23 | |
| 24 | - /** | |
| 25 | - * Used to indicate whether SPCO is being revisited by registrant or not. | |
| 26 | - * | |
| 27 | - * @var bool | |
| 28 | - */ | |
| 29 | - protected $_revisit = false; | |
| 24 | + /** | |
| 25 | + * Used to indicate whether SPCO is being revisited by registrant or not. | |
| 26 | + * | |
| 27 | + * @var bool | |
| 28 | + */ | |
| 29 | + protected $_revisit = false; | |
| 30 | 30 | |
| 31 | 31 | |
| 32 | - /** | |
| 33 | - * @param boolean $IPN | |
| 34 | - */ | |
| 35 | - public static function set_IPN($IPN) | |
| 36 | -    { | |
| 37 | - self::$IPN = filter_var($IPN, FILTER_VALIDATE_BOOLEAN); | |
| 38 | - } | |
| 32 | + /** | |
| 33 | + * @param boolean $IPN | |
| 34 | + */ | |
| 35 | + public static function set_IPN($IPN) | |
| 36 | +	{ | |
| 37 | + self::$IPN = filter_var($IPN, FILTER_VALIDATE_BOOLEAN); | |
| 38 | + } | |
| 39 | 39 | |
| 40 | 40 | |
| 41 | - /** | |
| 42 | - * Allows external class (usually checkout) to set whether SPCO is being revisited by registrant or not. | |
| 43 | - * | |
| 44 | - * @param bool $revisit | |
| 45 | - * @return void | |
| 46 | - */ | |
| 47 | - public function set_revisit($revisit = false) | |
| 48 | -    { | |
| 49 | - $this->_revisit = filter_var($revisit, FILTER_VALIDATE_BOOLEAN); | |
| 50 | - } | |
| 41 | + /** | |
| 42 | + * Allows external class (usually checkout) to set whether SPCO is being revisited by registrant or not. | |
| 43 | + * | |
| 44 | + * @param bool $revisit | |
| 45 | + * @return void | |
| 46 | + */ | |
| 47 | + public function set_revisit($revisit = false) | |
| 48 | +	{ | |
| 49 | + $this->_revisit = filter_var($revisit, FILTER_VALIDATE_BOOLEAN); | |
| 50 | + } | |
| 51 | 51 | |
| 52 | 52 | |
| 53 | - /** | |
| 54 | - * debug | |
| 55 | - * | |
| 56 | - * @param string $class | |
| 57 | - * @param string $func | |
| 58 | - * @param string $line | |
| 59 | - * @param \EE_Transaction $transaction | |
| 60 | - * @param array $info | |
| 61 | - * @param bool $display_request | |
| 62 | - */ | |
| 63 | - protected function log( | |
| 64 | - $class = '', | |
| 65 | - $func = '', | |
| 66 | - $line = '', | |
| 67 | - EE_Transaction $transaction, | |
| 68 | - $info = array(), | |
| 69 | - $display_request = false | |
| 70 | -    ) { | |
| 71 | -        if (WP_DEBUG && false) { | |
| 72 | -            if ($transaction instanceof EE_Transaction) { | |
| 73 | - // don't serialize objects | |
| 74 | - $info = EEH_Debug_Tools::strip_objects($info); | |
| 75 | -                if ($transaction->ID()) { | |
| 76 | - $info['TXN_status'] = $transaction->status_ID(); | |
| 77 | - $info['TXN_reg_steps'] = $transaction->reg_steps(); | |
| 78 | - $index = 'EE_Transaction: ' . $transaction->ID(); | |
| 79 | - EEH_Debug_Tools::log($class, $func, $line, $info, $display_request, $index); | |
| 80 | - } | |
| 81 | - } | |
| 82 | - } | |
| 83 | - } | |
| 53 | + /** | |
| 54 | + * debug | |
| 55 | + * | |
| 56 | + * @param string $class | |
| 57 | + * @param string $func | |
| 58 | + * @param string $line | |
| 59 | + * @param \EE_Transaction $transaction | |
| 60 | + * @param array $info | |
| 61 | + * @param bool $display_request | |
| 62 | + */ | |
| 63 | + protected function log( | |
| 64 | + $class = '', | |
| 65 | + $func = '', | |
| 66 | + $line = '', | |
| 67 | + EE_Transaction $transaction, | |
| 68 | + $info = array(), | |
| 69 | + $display_request = false | |
| 70 | +	) { | |
| 71 | +		if (WP_DEBUG && false) { | |
| 72 | +			if ($transaction instanceof EE_Transaction) { | |
| 73 | + // don't serialize objects | |
| 74 | + $info = EEH_Debug_Tools::strip_objects($info); | |
| 75 | +				if ($transaction->ID()) { | |
| 76 | + $info['TXN_status'] = $transaction->status_ID(); | |
| 77 | + $info['TXN_reg_steps'] = $transaction->reg_steps(); | |
| 78 | + $index = 'EE_Transaction: ' . $transaction->ID(); | |
| 79 | + EEH_Debug_Tools::log($class, $func, $line, $info, $display_request, $index); | |
| 80 | + } | |
| 81 | + } | |
| 82 | + } | |
| 83 | + } | |
| 84 | 84 | } | 
| @@ -75,7 +75,7 @@ | ||
| 75 | 75 |                  if ($transaction->ID()) { | 
| 76 | 76 | $info['TXN_status'] = $transaction->status_ID(); | 
| 77 | 77 | $info['TXN_reg_steps'] = $transaction->reg_steps(); | 
| 78 | - $index = 'EE_Transaction: ' . $transaction->ID(); | |
| 78 | + $index = 'EE_Transaction: '.$transaction->ID(); | |
| 79 | 79 | EEH_Debug_Tools::log($class, $func, $line, $info, $display_request, $index); | 
| 80 | 80 | } | 
| 81 | 81 | } | 
| @@ -15,51 +15,51 @@ | ||
| 15 | 15 | class EE_Help_Tour_final_stop extends EE_Help_Tour | 
| 16 | 16 |  { | 
| 17 | 17 | |
| 18 | - protected function _set_tour_properties() | |
| 19 | -    { | |
| 20 | -        $this->_label = __('Final Stop Tour', 'event_espresso'); | |
| 21 | - $this->_slug = 'final-stop-tour'; | |
| 22 | - } | |
| 18 | + protected function _set_tour_properties() | |
| 19 | +	{ | |
| 20 | +		$this->_label = __('Final Stop Tour', 'event_espresso'); | |
| 21 | + $this->_slug = 'final-stop-tour'; | |
| 22 | + } | |
| 23 | 23 | |
| 24 | 24 | |
| 25 | - protected function _set_tour_stops() | |
| 26 | -    { | |
| 27 | - $this->_stops = array( | |
| 28 | - 10 => array( | |
| 29 | - 'id' => 'contextual-help-link', | |
| 30 | - 'content' => $this->_end(), | |
| 31 | -                'button_text' => __('Quit', 'event_espresso'), | |
| 32 | - 'options' => array( | |
| 33 | - 'tipLocation' => 'left', | |
| 34 | - 'tipAdjustmentY' => -20, | |
| 35 | - 'tipAdjustmentX' => 10, | |
| 36 | - ), | |
| 37 | - ), | |
| 38 | - ); | |
| 39 | - } | |
| 25 | + protected function _set_tour_stops() | |
| 26 | +	{ | |
| 27 | + $this->_stops = array( | |
| 28 | + 10 => array( | |
| 29 | + 'id' => 'contextual-help-link', | |
| 30 | + 'content' => $this->_end(), | |
| 31 | +				'button_text' => __('Quit', 'event_espresso'), | |
| 32 | + 'options' => array( | |
| 33 | + 'tipLocation' => 'left', | |
| 34 | + 'tipAdjustmentY' => -20, | |
| 35 | + 'tipAdjustmentX' => 10, | |
| 36 | + ), | |
| 37 | + ), | |
| 38 | + ); | |
| 39 | + } | |
| 40 | 40 | |
| 41 | 41 | |
| 42 | - /** | |
| 43 | - * This is the default last stop for all tours that is displayed at the end of a tour OR when a tour is exited for | |
| 44 | - * the first time. | |
| 45 | - * | |
| 46 | - * @return string | |
| 47 | - */ | |
| 48 | - protected function _end() | |
| 49 | -    { | |
| 50 | - $query_args = array( | |
| 51 | - 'action' => 'admin_option_settings', | |
| 52 | - 'page' => 'espresso_general_settings', | |
| 53 | - ); | |
| 54 | - return '<p>' | |
| 55 | - . sprintf( | |
| 56 | - __( | |
| 57 | - 'That\'s it for the tour! At any time you can restart a tour by clicking on this help dropdown and then clicking one of the Tour buttons. There are help tours available on all Event Espresso Admin pages. If you want to turn off help tours for all pages, %sgo here%s. All the best with your events!', | |
| 58 | - 'event_espresso' | |
| 59 | - ), | |
| 60 | -                   '<a href="' . EE_Admin_Page::add_query_args_and_nonce($query_args, admin_url('admin.php')) . '">', | |
| 61 | - '</a>' | |
| 62 | - ) | |
| 63 | - . '</p>'; | |
| 64 | - } | |
| 42 | + /** | |
| 43 | + * This is the default last stop for all tours that is displayed at the end of a tour OR when a tour is exited for | |
| 44 | + * the first time. | |
| 45 | + * | |
| 46 | + * @return string | |
| 47 | + */ | |
| 48 | + protected function _end() | |
| 49 | +	{ | |
| 50 | + $query_args = array( | |
| 51 | + 'action' => 'admin_option_settings', | |
| 52 | + 'page' => 'espresso_general_settings', | |
| 53 | + ); | |
| 54 | + return '<p>' | |
| 55 | + . sprintf( | |
| 56 | + __( | |
| 57 | + 'That\'s it for the tour! At any time you can restart a tour by clicking on this help dropdown and then clicking one of the Tour buttons. There are help tours available on all Event Espresso Admin pages. If you want to turn off help tours for all pages, %sgo here%s. All the best with your events!', | |
| 58 | + 'event_espresso' | |
| 59 | + ), | |
| 60 | +				   '<a href="' . EE_Admin_Page::add_query_args_and_nonce($query_args, admin_url('admin.php')) . '">', | |
| 61 | + '</a>' | |
| 62 | + ) | |
| 63 | + . '</p>'; | |
| 64 | + } | |
| 65 | 65 | } | 
| @@ -57,7 +57,7 @@ | ||
| 57 | 57 | 'That\'s it for the tour! At any time you can restart a tour by clicking on this help dropdown and then clicking one of the Tour buttons. There are help tours available on all Event Espresso Admin pages. If you want to turn off help tours for all pages, %sgo here%s. All the best with your events!', | 
| 58 | 58 | 'event_espresso' | 
| 59 | 59 | ), | 
| 60 | -                   '<a href="' . EE_Admin_Page::add_query_args_and_nonce($query_args, admin_url('admin.php')) . '">', | |
| 60 | +                   '<a href="'.EE_Admin_Page::add_query_args_and_nonce($query_args, admin_url('admin.php')).'">', | |
| 61 | 61 | '</a>' | 
| 62 | 62 | ) | 
| 63 | 63 | . '</p>'; | 
| @@ -12,631 +12,631 @@ | ||
| 12 | 12 | abstract class EE_SPCO_Reg_Step | 
| 13 | 13 |  { | 
| 14 | 14 | |
| 15 | - /** | |
| 16 | - * $_completed - TRUE if this step has fully completed it's duties | |
| 17 | - * | |
| 18 | - * @access protected | |
| 19 | - * @type bool $_completed | |
| 20 | - */ | |
| 21 | - protected $_completed = false; | |
| 22 | - | |
| 23 | - /** | |
| 24 | - * $_is_current_step - TRUE if this is the current step | |
| 25 | - * | |
| 26 | - * @access protected | |
| 27 | - * @type bool $_is_current_step | |
| 28 | - */ | |
| 29 | - protected $_is_current_step = false; | |
| 30 | - | |
| 31 | - /** | |
| 32 | - * $_order - when the reg step should be run relative to other steps | |
| 33 | - * | |
| 34 | - * @access protected | |
| 35 | - * @type int $_template | |
| 36 | - */ | |
| 37 | - protected $_order = 0; | |
| 38 | - | |
| 39 | - /** | |
| 40 | - * $_slug - URL param for this step | |
| 41 | - * | |
| 42 | - * @access protected | |
| 43 | - * @type string $_slug | |
| 44 | - */ | |
| 45 | - protected $_slug; | |
| 46 | - | |
| 47 | - /** | |
| 48 | - * $_name - Step Name - translatable string | |
| 49 | - * | |
| 50 | - * @access protected | |
| 51 | - * @type string $_slug | |
| 52 | - */ | |
| 53 | - protected $_name; | |
| 54 | - | |
| 55 | - /** | |
| 56 | - * $_submit_button_text - translatable string that appears on this step's submit button | |
| 57 | - * | |
| 58 | - * @access protected | |
| 59 | - * @type string $_slug | |
| 60 | - */ | |
| 61 | - protected $_submit_button_text; | |
| 62 | - | |
| 63 | - /** | |
| 64 | - * $_template - template name | |
| 65 | - * | |
| 66 | - * @access protected | |
| 67 | - * @type string $_template | |
| 68 | - */ | |
| 69 | - protected $_template; | |
| 70 | - | |
| 71 | - /** | |
| 72 | - * $_reg_form_name - the form input name and id attribute | |
| 73 | - * | |
| 74 | - * @access protected | |
| 75 | - * @var string $_reg_form_name | |
| 76 | - */ | |
| 77 | - protected $_reg_form_name; | |
| 78 | - | |
| 79 | - /** | |
| 80 | - * $_success_message - text to display upon successful form submission | |
| 81 | - * | |
| 82 | - * @access private | |
| 83 | - * @var string $_success_message | |
| 84 | - */ | |
| 85 | - protected $_success_message; | |
| 86 | - | |
| 87 | - /** | |
| 88 | - * $_instructions - a brief description of how to complete the reg step. | |
| 89 | - * Usually displayed in conjunction with the previous step's success message. | |
| 90 | - * | |
| 91 | - * @access private | |
| 92 | - * @var string $_instructions | |
| 93 | - */ | |
| 94 | - protected $_instructions; | |
| 95 | - | |
| 96 | - /** | |
| 97 | - * $_valid_data - the normalized and validated data for this step | |
| 98 | - * | |
| 99 | - * @access public | |
| 100 | - * @var array $_valid_data | |
| 101 | - */ | |
| 102 | - protected $_valid_data = array(); | |
| 103 | - | |
| 104 | - /** | |
| 105 | - * $reg_form - the registration form for this step | |
| 106 | - * | |
| 107 | - * @access public | |
| 108 | - * @var EE_Form_Section_Proper $reg_form | |
| 109 | - */ | |
| 110 | - public $reg_form; | |
| 111 | - | |
| 112 | - /** | |
| 113 | - * $checkout - EE_Checkout object for handling the properties of the current checkout process | |
| 114 | - * | |
| 115 | - * @access public | |
| 116 | - * @var EE_Checkout $checkout | |
| 117 | - */ | |
| 118 | - public $checkout; | |
| 119 | - | |
| 120 | - | |
| 121 | - /** | |
| 122 | - * @return void | |
| 123 | - */ | |
| 124 | - abstract public function translate_js_strings(); | |
| 125 | - | |
| 126 | - | |
| 127 | - /** | |
| 128 | - * @return void | |
| 129 | - */ | |
| 130 | - abstract public function enqueue_styles_and_scripts(); | |
| 131 | - | |
| 132 | - | |
| 133 | - /** | |
| 134 | - * @return boolean | |
| 135 | - */ | |
| 136 | - abstract public function initialize_reg_step(); | |
| 137 | - | |
| 138 | - | |
| 139 | - /** | |
| 140 | - * @return string | |
| 141 | - */ | |
| 142 | - abstract public function generate_reg_form(); | |
| 143 | - | |
| 144 | - | |
| 145 | - /** | |
| 146 | - * @return boolean | |
| 147 | - */ | |
| 148 | - abstract public function process_reg_step(); | |
| 149 | - | |
| 150 | - | |
| 151 | - /** | |
| 152 | - * @return boolean | |
| 153 | - */ | |
| 154 | - abstract public function update_reg_step(); | |
| 155 | - | |
| 156 | - | |
| 157 | - /** | |
| 158 | - * @return boolean | |
| 159 | - */ | |
| 160 | - public function completed() | |
| 161 | -    { | |
| 162 | - return $this->_completed; | |
| 163 | - } | |
| 164 | - | |
| 165 | - | |
| 166 | - /** | |
| 167 | - * set_completed - toggles $_completed to TRUE | |
| 168 | - */ | |
| 169 | - public function set_completed() | |
| 170 | -    { | |
| 171 | - // DEBUG LOG | |
| 172 | - // $this->checkout->log( __CLASS__, __FUNCTION__, __LINE__ ); | |
| 173 | -        $this->_completed = apply_filters('FHEE__EE_SPCO_Reg_Step__set_completed___completed', true, $this); | |
| 174 | - } | |
| 175 | - | |
| 176 | - | |
| 177 | - /** | |
| 178 | - * set_completed - toggles $_completed to FALSE | |
| 179 | - */ | |
| 180 | - public function set_not_completed() | |
| 181 | -    { | |
| 182 | - $this->_completed = false; | |
| 183 | - } | |
| 184 | - | |
| 185 | - | |
| 186 | - /** | |
| 187 | - * @return string | |
| 188 | - */ | |
| 189 | - public function name() | |
| 190 | -    { | |
| 191 | - return $this->_name; | |
| 192 | - } | |
| 193 | - | |
| 194 | - | |
| 195 | - /** | |
| 196 | - * @return string | |
| 197 | - */ | |
| 198 | - public function slug() | |
| 199 | -    { | |
| 200 | - return $this->_slug; | |
| 201 | - } | |
| 202 | - | |
| 203 | - | |
| 204 | - /** | |
| 205 | - * submit_button_text | |
| 206 | - * the text that appears on the reg step form submit button | |
| 207 | - * | |
| 208 | - * @return string | |
| 209 | - */ | |
| 210 | - public function submit_button_text() | |
| 211 | -    { | |
| 212 | - return $this->_submit_button_text; | |
| 213 | - } | |
| 214 | - | |
| 215 | - | |
| 216 | - /** | |
| 217 | - * set_submit_button_text | |
| 218 | - * sets the text that appears on the reg step form submit button | |
| 219 | - * | |
| 220 | - * @param string $submit_button_text | |
| 221 | - */ | |
| 222 | - public function set_submit_button_text($submit_button_text = '') | |
| 223 | -    { | |
| 224 | -        if (! empty($submit_button_text)) { | |
| 225 | - $this->_submit_button_text = $submit_button_text; | |
| 226 | -        } elseif ($this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | |
| 227 | -            if ($this->checkout->revisit) { | |
| 228 | - $this->_submit_button_text = sprintf( | |
| 229 | -                    __('Update %s', 'event_espresso'), | |
| 230 | - $this->checkout->current_step->name() | |
| 231 | - ); | |
| 232 | -            } else { | |
| 233 | - $this->_submit_button_text = sprintf( | |
| 234 | -                    __('Proceed to %s', 'event_espresso'), | |
| 235 | - $this->checkout->next_step->name() | |
| 236 | - ); | |
| 237 | - } | |
| 238 | - } | |
| 239 | - // filters the submit button text | |
| 240 | - $this->_submit_button_text = apply_filters( | |
| 241 | - 'FHEE__EE_SPCO_Reg_Step__set_submit_button_text___submit_button_text', | |
| 242 | - $this->_submit_button_text, | |
| 243 | - $this->checkout | |
| 244 | - ); | |
| 245 | - } | |
| 246 | - | |
| 247 | - | |
| 248 | - /** | |
| 249 | - * @param boolean $is_current_step | |
| 250 | - */ | |
| 251 | - public function set_is_current_step($is_current_step) | |
| 252 | -    { | |
| 253 | - $this->_is_current_step = $is_current_step; | |
| 254 | - } | |
| 255 | - | |
| 256 | - | |
| 257 | - /** | |
| 258 | - * @return boolean | |
| 259 | - */ | |
| 260 | - public function is_current_step() | |
| 261 | -    { | |
| 262 | - return $this->_is_current_step; | |
| 263 | - } | |
| 264 | - | |
| 265 | - | |
| 266 | - /** | |
| 267 | - * @return boolean | |
| 268 | - */ | |
| 269 | - public function is_final_step() | |
| 270 | -    { | |
| 271 | - return $this instanceof EE_SPCO_Reg_Step_Finalize_Registration ? true : false; | |
| 272 | - } | |
| 273 | - | |
| 274 | - | |
| 275 | - /** | |
| 276 | - * @param int $order | |
| 277 | - */ | |
| 278 | - public function set_order($order) | |
| 279 | -    { | |
| 280 | - $this->_order = $order; | |
| 281 | - } | |
| 282 | - | |
| 283 | - | |
| 284 | - /** | |
| 285 | - * @return int | |
| 286 | - */ | |
| 287 | - public function order() | |
| 288 | -    { | |
| 289 | - return $this->_order; | |
| 290 | - } | |
| 291 | - | |
| 292 | - | |
| 293 | - /** | |
| 294 | - * @return string | |
| 295 | - */ | |
| 296 | - public function template() | |
| 297 | -    { | |
| 298 | - return $this->_template; | |
| 299 | - } | |
| 300 | - | |
| 301 | - | |
| 302 | - /** | |
| 303 | - * @return string | |
| 304 | - */ | |
| 305 | - public function success_message() | |
| 306 | -    { | |
| 307 | - return $this->_success_message; | |
| 308 | - } | |
| 309 | - | |
| 310 | - | |
| 311 | - /** | |
| 312 | - * _set_success_message | |
| 313 | - * | |
| 314 | - * @param string $success_message | |
| 315 | - */ | |
| 316 | - protected function _set_success_message($success_message) | |
| 317 | -    { | |
| 318 | - $this->_success_message = $success_message; | |
| 319 | - } | |
| 320 | - | |
| 321 | - | |
| 322 | - /** | |
| 323 | - * _reset_success_message | |
| 324 | - * | |
| 325 | - * @return void | |
| 326 | - */ | |
| 327 | - protected function _reset_success_message() | |
| 328 | -    { | |
| 329 | - $this->_success_message = ''; | |
| 330 | - } | |
| 331 | - | |
| 332 | - | |
| 333 | - /** | |
| 334 | - * @return string | |
| 335 | - */ | |
| 336 | - public function _instructions() | |
| 337 | -    { | |
| 338 | - return $this->_instructions; | |
| 339 | - } | |
| 340 | - | |
| 341 | - | |
| 342 | - /** | |
| 343 | - * @param string $instructions | |
| 344 | - */ | |
| 345 | - public function set_instructions($instructions) | |
| 346 | -    { | |
| 347 | - $this->_instructions = apply_filters( | |
| 348 | - 'FHEE__EE_SPCO_Reg_Step__set_instructions__instructions', | |
| 349 | - $instructions, | |
| 350 | - $this | |
| 351 | - ); | |
| 352 | - } | |
| 353 | - | |
| 354 | - | |
| 355 | - /** | |
| 356 | - * @param array $valid_data | |
| 357 | - */ | |
| 358 | - public function set_valid_data($valid_data) | |
| 359 | -    { | |
| 360 | - $this->_valid_data = $valid_data; | |
| 361 | - } | |
| 362 | - | |
| 363 | - | |
| 364 | - /** | |
| 365 | - * @return array | |
| 366 | - */ | |
| 367 | - public function valid_data() | |
| 368 | -    { | |
| 369 | -        if (empty($this->_valid_data)) { | |
| 370 | - $this->_valid_data = $this->reg_form->valid_data(); | |
| 371 | - } | |
| 372 | - return $this->_valid_data; | |
| 373 | - } | |
| 374 | - | |
| 375 | - | |
| 376 | - /** | |
| 377 | - * @return string | |
| 378 | - */ | |
| 379 | - public function reg_form_name() | |
| 380 | -    { | |
| 381 | -        if (empty($this->_reg_form_name)) { | |
| 382 | -            $this->set_reg_form_name('ee-spco-' . $this->slug() . '-reg-step-form'); | |
| 383 | - } | |
| 384 | - return $this->_reg_form_name; | |
| 385 | - } | |
| 386 | - | |
| 387 | - | |
| 388 | - /** | |
| 389 | - * @param string $reg_form_name | |
| 390 | - */ | |
| 391 | - protected function set_reg_form_name($reg_form_name) | |
| 392 | -    { | |
| 393 | - $this->_reg_form_name = $reg_form_name; | |
| 394 | - } | |
| 395 | - | |
| 396 | - | |
| 397 | - /** | |
| 398 | - * reg_step_url | |
| 399 | - * | |
| 400 | - * @param string $action | |
| 401 | - * @return string | |
| 402 | - */ | |
| 403 | - public function reg_step_url($action = '') | |
| 404 | -    { | |
| 405 | -        $query_args = array('step' => $this->slug()); | |
| 406 | -        if (! empty($action)) { | |
| 407 | - $query_args['action'] = $action; | |
| 408 | - } | |
| 409 | - // final step has no display | |
| 410 | -        if ($this instanceof EE_SPCO_Reg_Step_Finalize_Registration && $action === 'display_spco_reg_step') { | |
| 411 | - $query_args['action'] = 'process_reg_step'; | |
| 412 | - } | |
| 413 | -        if ($this->checkout->revisit) { | |
| 414 | - $query_args['revisit'] = true; | |
| 415 | - } | |
| 416 | -        if ($this->checkout->reg_url_link) { | |
| 417 | - $query_args['e_reg_url_link'] = $this->checkout->reg_url_link; | |
| 418 | - } | |
| 419 | - return add_query_arg($query_args, $this->checkout->reg_page_base_url); | |
| 420 | - } | |
| 421 | - | |
| 422 | - | |
| 423 | - /** | |
| 424 | - * creates the default hidden inputs section | |
| 425 | - * | |
| 426 | - * @return EE_Form_Section_Proper | |
| 427 | - * @throws \EE_Error | |
| 428 | - */ | |
| 429 | - public function reg_step_hidden_inputs() | |
| 430 | -    { | |
| 431 | - // hidden inputs for admin registrations | |
| 432 | -        if ($this->checkout->admin_request) { | |
| 433 | - return new EE_Form_Section_Proper( | |
| 434 | - array( | |
| 435 | - 'layout_strategy' => new EE_Div_Per_Section_Layout(), | |
| 436 | - 'html_id' => 'ee-' . $this->slug() . '-hidden-inputs', | |
| 437 | - 'subsections' => array( | |
| 438 | - 'next_step' => new EE_Fixed_Hidden_Input( | |
| 439 | - array( | |
| 440 | - 'html_name' => 'next_step', | |
| 441 | - 'html_id' => 'spco-' . $this->slug() . '-next-step', | |
| 442 | - 'default' => $this->checkout->next_step instanceof EE_SPCO_Reg_Step | |
| 443 | - ? $this->checkout->next_step->slug() | |
| 444 | - : '', | |
| 445 | - ) | |
| 446 | - ), | |
| 447 | - ), | |
| 448 | - ) | |
| 449 | - ); | |
| 450 | - } | |
| 451 | - // hidden inputs for frontend registrations | |
| 452 | - return new EE_Form_Section_Proper( | |
| 453 | - array( | |
| 454 | - 'layout_strategy' => new EE_Div_Per_Section_Layout(), | |
| 455 | - 'html_id' => 'ee-' . $this->slug() . '-hidden-inputs', | |
| 456 | - 'subsections' => array( | |
| 457 | - 'action' => new EE_Fixed_Hidden_Input( | |
| 458 | - array( | |
| 459 | - 'html_name' => 'action', | |
| 460 | - 'html_id' => 'spco-' . $this->slug() . '-action', | |
| 461 | - 'default' => apply_filters( | |
| 462 | - 'FHEE__EE_SPCO_Reg_Step__reg_step_hidden_inputs__default_form_action', | |
| 463 | - empty($this->checkout->reg_url_link) | |
| 464 | - ? 'process_reg_step' | |
| 465 | - : 'update_reg_step', | |
| 466 | - $this | |
| 467 | - ), | |
| 468 | - ) | |
| 469 | - ), | |
| 470 | - 'next_step' => new EE_Fixed_Hidden_Input( | |
| 471 | - array( | |
| 472 | - 'html_name' => 'next_step', | |
| 473 | - 'html_id' => 'spco-' . $this->slug() . '-next-step', | |
| 474 | - 'default' => $this->checkout->next_step instanceof EE_SPCO_Reg_Step | |
| 475 | - ? $this->checkout->next_step->slug() | |
| 476 | - : '', | |
| 477 | - ) | |
| 478 | - ), | |
| 479 | - 'e_reg_url_link' => new EE_Fixed_Hidden_Input( | |
| 480 | - array( | |
| 481 | - 'html_name' => 'e_reg_url_link', | |
| 482 | - 'html_id' => 'spco-reg_url_link', | |
| 483 | - 'default' => $this->checkout->reg_url_link, | |
| 484 | - ) | |
| 485 | - ), | |
| 486 | - 'revisit' => new EE_Fixed_Hidden_Input( | |
| 487 | - array( | |
| 488 | - 'html_name' => 'revisit', | |
| 489 | - 'html_id' => 'spco-revisit', | |
| 490 | - 'default' => $this->checkout->revisit, | |
| 491 | - ) | |
| 492 | - ), | |
| 493 | - ), | |
| 494 | - ) | |
| 495 | - ); | |
| 496 | - } | |
| 497 | - | |
| 498 | - | |
| 499 | - /** | |
| 500 | - * generate_reg_form_for_actions | |
| 501 | - * | |
| 502 | - * @param array $actions | |
| 503 | - * @return void | |
| 504 | - */ | |
| 505 | - public function generate_reg_form_for_actions($actions = array()) | |
| 506 | -    { | |
| 507 | - $actions = array_merge( | |
| 508 | - array( | |
| 509 | - 'generate_reg_form', | |
| 510 | - 'display_spco_reg_step', | |
| 511 | - 'process_reg_step', | |
| 512 | - 'update_reg_step', | |
| 513 | - ), | |
| 514 | - $actions | |
| 515 | - ); | |
| 516 | - $this->checkout->generate_reg_form = in_array($this->checkout->action, $actions, true) ? true : false; | |
| 517 | - } | |
| 518 | - | |
| 519 | - | |
| 520 | - /** | |
| 521 | - * @return string | |
| 522 | - * @throws \EE_Error | |
| 523 | - */ | |
| 524 | - public function display_reg_form() | |
| 525 | -    { | |
| 526 | - $html = ''; | |
| 527 | -        if ($this->reg_form instanceof EE_Form_Section_Proper) { | |
| 528 | -            do_action('AHEE__EE_SPCO_Reg_Step__display_reg_form__reg_form', $this->reg_form, $this); | |
| 529 | - $html .= ! $this->checkout->admin_request ? $this->reg_form->form_open($this->reg_step_url()) : ''; | |
| 530 | -            if (EE_Registry::instance()->REQ->ajax) { | |
| 531 | - $this->reg_form->localize_validation_rules(); | |
| 532 | - $this->checkout->json_response->add_validation_rules(EE_Form_Section_Proper::js_localization()); | |
| 533 | - } | |
| 534 | - $html .= $this->reg_form->get_html(); | |
| 535 | - $html .= ! $this->checkout->admin_request ? $this->reg_step_submit_button() : ''; | |
| 536 | - $html .= ! $this->checkout->admin_request ? $this->reg_form->form_close() : ''; | |
| 537 | - } | |
| 538 | - return $html; | |
| 539 | - } | |
| 540 | - | |
| 541 | - | |
| 542 | - /** | |
| 543 | - * div_class - returns nothing for current step, but a css class of "hidden" for others | |
| 544 | - * | |
| 545 | - * @return string | |
| 546 | - * @throws \EE_Error | |
| 547 | - */ | |
| 548 | - public function reg_step_submit_button() | |
| 549 | -    { | |
| 550 | -        if (! $this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | |
| 551 | - return ''; | |
| 552 | - } | |
| 553 | - ob_start(); | |
| 554 | - do_action( | |
| 555 | - 'AHEE__before_spco_whats_next_buttons', | |
| 556 | - $this->slug(), | |
| 557 | - $this->checkout->next_step->slug(), | |
| 558 | - $this->checkout | |
| 559 | - ); | |
| 560 | - $html = ob_get_clean(); | |
| 561 | - // generate submit button | |
| 562 | - $sbmt_btn = new EE_Submit_Input( | |
| 563 | - array( | |
| 564 | - 'html_name' => 'spco-go-to-step-' . $this->checkout->next_step->slug(), | |
| 565 | - 'html_id' => 'spco-go-to-step-' . $this->checkout->next_step->slug(), | |
| 566 | - 'html_class' => 'spco-next-step-btn', | |
| 567 | - 'other_html_attributes' => ' rel="' . $this->slug() . '"', | |
| 568 | - 'default' => $this->submit_button_text(), | |
| 569 | - ) | |
| 570 | - ); | |
| 571 | - $sbmt_btn->set_button_css_attributes(true, 'large'); | |
| 572 | - $sbmt_btn_html = $sbmt_btn->get_html_for_input(); | |
| 573 | - $html .= EEH_HTML::div( | |
| 574 | -            apply_filters('FHEE__EE_SPCO_Reg_Step__reg_step_submit_button__sbmt_btn_html', $sbmt_btn_html, $this), | |
| 575 | - 'spco-' . $this->slug() . '-whats-next-buttons-dv', | |
| 576 | - 'spco-whats-next-buttons' | |
| 577 | - ); | |
| 578 | - return $html; | |
| 579 | - } | |
| 580 | - | |
| 581 | - | |
| 582 | - /** | |
| 583 | - * div_class - returns nothing for current step, but a css class of "hidden" for others | |
| 584 | - * | |
| 585 | - * @return string | |
| 586 | - */ | |
| 587 | - public function div_class() | |
| 588 | -    { | |
| 589 | - return $this->is_current_step() ? '' : ' hidden'; | |
| 590 | - } | |
| 591 | - | |
| 592 | - | |
| 593 | - /** | |
| 594 | - * div_class - returns a css class of "hidden" for current step, but nothing for others | |
| 595 | - * | |
| 596 | - * @return string | |
| 597 | - */ | |
| 598 | - public function edit_lnk_url() | |
| 599 | -    { | |
| 600 | -        return add_query_arg(array('step' => $this->slug()), $this->checkout->reg_page_base_url); | |
| 601 | - } | |
| 602 | - | |
| 603 | - | |
| 604 | - /** | |
| 605 | - * div_class - returns a css class of "hidden" for current step, but nothing for others | |
| 606 | - * | |
| 607 | - * @return string | |
| 608 | - */ | |
| 609 | - public function edit_link_class() | |
| 610 | -    { | |
| 611 | - return $this->is_current_step() ? ' hidden' : ''; | |
| 612 | - } | |
| 613 | - | |
| 614 | - | |
| 615 | - /** | |
| 616 | - * update_checkout with changes that have been made to the cart | |
| 617 | - * | |
| 618 | - * @return void | |
| 619 | - * @throws \EE_Error | |
| 620 | - */ | |
| 621 | - public function update_checkout() | |
| 622 | -    { | |
| 623 | - // grab the cart grand total and reset TXN total | |
| 624 | - $this->checkout->transaction->set_total($this->checkout->cart->get_cart_grand_total()); | |
| 625 | - $this->checkout->stash_transaction_and_checkout(); | |
| 626 | - } | |
| 627 | - | |
| 628 | - | |
| 629 | - /** | |
| 630 | - * __sleep | |
| 631 | - * to conserve db space, let's remove the reg_form and the EE_Checkout object from EE_SPCO_Reg_Step objects upon | |
| 632 | - * serialization EE_Checkout will handle the reimplementation of itself upon waking, but we won't bother with the | |
| 633 | - * reg form, because if needed, it will be regenerated anyways | |
| 634 | - * | |
| 635 | - * @return array | |
| 636 | - */ | |
| 637 | - public function __sleep() | |
| 638 | -    { | |
| 639 | - // remove the reg form and the checkout | |
| 640 | -        return array_diff(array_keys(get_object_vars($this)), array('reg_form', 'checkout')); | |
| 641 | - } | |
| 15 | + /** | |
| 16 | + * $_completed - TRUE if this step has fully completed it's duties | |
| 17 | + * | |
| 18 | + * @access protected | |
| 19 | + * @type bool $_completed | |
| 20 | + */ | |
| 21 | + protected $_completed = false; | |
| 22 | + | |
| 23 | + /** | |
| 24 | + * $_is_current_step - TRUE if this is the current step | |
| 25 | + * | |
| 26 | + * @access protected | |
| 27 | + * @type bool $_is_current_step | |
| 28 | + */ | |
| 29 | + protected $_is_current_step = false; | |
| 30 | + | |
| 31 | + /** | |
| 32 | + * $_order - when the reg step should be run relative to other steps | |
| 33 | + * | |
| 34 | + * @access protected | |
| 35 | + * @type int $_template | |
| 36 | + */ | |
| 37 | + protected $_order = 0; | |
| 38 | + | |
| 39 | + /** | |
| 40 | + * $_slug - URL param for this step | |
| 41 | + * | |
| 42 | + * @access protected | |
| 43 | + * @type string $_slug | |
| 44 | + */ | |
| 45 | + protected $_slug; | |
| 46 | + | |
| 47 | + /** | |
| 48 | + * $_name - Step Name - translatable string | |
| 49 | + * | |
| 50 | + * @access protected | |
| 51 | + * @type string $_slug | |
| 52 | + */ | |
| 53 | + protected $_name; | |
| 54 | + | |
| 55 | + /** | |
| 56 | + * $_submit_button_text - translatable string that appears on this step's submit button | |
| 57 | + * | |
| 58 | + * @access protected | |
| 59 | + * @type string $_slug | |
| 60 | + */ | |
| 61 | + protected $_submit_button_text; | |
| 62 | + | |
| 63 | + /** | |
| 64 | + * $_template - template name | |
| 65 | + * | |
| 66 | + * @access protected | |
| 67 | + * @type string $_template | |
| 68 | + */ | |
| 69 | + protected $_template; | |
| 70 | + | |
| 71 | + /** | |
| 72 | + * $_reg_form_name - the form input name and id attribute | |
| 73 | + * | |
| 74 | + * @access protected | |
| 75 | + * @var string $_reg_form_name | |
| 76 | + */ | |
| 77 | + protected $_reg_form_name; | |
| 78 | + | |
| 79 | + /** | |
| 80 | + * $_success_message - text to display upon successful form submission | |
| 81 | + * | |
| 82 | + * @access private | |
| 83 | + * @var string $_success_message | |
| 84 | + */ | |
| 85 | + protected $_success_message; | |
| 86 | + | |
| 87 | + /** | |
| 88 | + * $_instructions - a brief description of how to complete the reg step. | |
| 89 | + * Usually displayed in conjunction with the previous step's success message. | |
| 90 | + * | |
| 91 | + * @access private | |
| 92 | + * @var string $_instructions | |
| 93 | + */ | |
| 94 | + protected $_instructions; | |
| 95 | + | |
| 96 | + /** | |
| 97 | + * $_valid_data - the normalized and validated data for this step | |
| 98 | + * | |
| 99 | + * @access public | |
| 100 | + * @var array $_valid_data | |
| 101 | + */ | |
| 102 | + protected $_valid_data = array(); | |
| 103 | + | |
| 104 | + /** | |
| 105 | + * $reg_form - the registration form for this step | |
| 106 | + * | |
| 107 | + * @access public | |
| 108 | + * @var EE_Form_Section_Proper $reg_form | |
| 109 | + */ | |
| 110 | + public $reg_form; | |
| 111 | + | |
| 112 | + /** | |
| 113 | + * $checkout - EE_Checkout object for handling the properties of the current checkout process | |
| 114 | + * | |
| 115 | + * @access public | |
| 116 | + * @var EE_Checkout $checkout | |
| 117 | + */ | |
| 118 | + public $checkout; | |
| 119 | + | |
| 120 | + | |
| 121 | + /** | |
| 122 | + * @return void | |
| 123 | + */ | |
| 124 | + abstract public function translate_js_strings(); | |
| 125 | + | |
| 126 | + | |
| 127 | + /** | |
| 128 | + * @return void | |
| 129 | + */ | |
| 130 | + abstract public function enqueue_styles_and_scripts(); | |
| 131 | + | |
| 132 | + | |
| 133 | + /** | |
| 134 | + * @return boolean | |
| 135 | + */ | |
| 136 | + abstract public function initialize_reg_step(); | |
| 137 | + | |
| 138 | + | |
| 139 | + /** | |
| 140 | + * @return string | |
| 141 | + */ | |
| 142 | + abstract public function generate_reg_form(); | |
| 143 | + | |
| 144 | + | |
| 145 | + /** | |
| 146 | + * @return boolean | |
| 147 | + */ | |
| 148 | + abstract public function process_reg_step(); | |
| 149 | + | |
| 150 | + | |
| 151 | + /** | |
| 152 | + * @return boolean | |
| 153 | + */ | |
| 154 | + abstract public function update_reg_step(); | |
| 155 | + | |
| 156 | + | |
| 157 | + /** | |
| 158 | + * @return boolean | |
| 159 | + */ | |
| 160 | + public function completed() | |
| 161 | +	{ | |
| 162 | + return $this->_completed; | |
| 163 | + } | |
| 164 | + | |
| 165 | + | |
| 166 | + /** | |
| 167 | + * set_completed - toggles $_completed to TRUE | |
| 168 | + */ | |
| 169 | + public function set_completed() | |
| 170 | +	{ | |
| 171 | + // DEBUG LOG | |
| 172 | + // $this->checkout->log( __CLASS__, __FUNCTION__, __LINE__ ); | |
| 173 | +		$this->_completed = apply_filters('FHEE__EE_SPCO_Reg_Step__set_completed___completed', true, $this); | |
| 174 | + } | |
| 175 | + | |
| 176 | + | |
| 177 | + /** | |
| 178 | + * set_completed - toggles $_completed to FALSE | |
| 179 | + */ | |
| 180 | + public function set_not_completed() | |
| 181 | +	{ | |
| 182 | + $this->_completed = false; | |
| 183 | + } | |
| 184 | + | |
| 185 | + | |
| 186 | + /** | |
| 187 | + * @return string | |
| 188 | + */ | |
| 189 | + public function name() | |
| 190 | +	{ | |
| 191 | + return $this->_name; | |
| 192 | + } | |
| 193 | + | |
| 194 | + | |
| 195 | + /** | |
| 196 | + * @return string | |
| 197 | + */ | |
| 198 | + public function slug() | |
| 199 | +	{ | |
| 200 | + return $this->_slug; | |
| 201 | + } | |
| 202 | + | |
| 203 | + | |
| 204 | + /** | |
| 205 | + * submit_button_text | |
| 206 | + * the text that appears on the reg step form submit button | |
| 207 | + * | |
| 208 | + * @return string | |
| 209 | + */ | |
| 210 | + public function submit_button_text() | |
| 211 | +	{ | |
| 212 | + return $this->_submit_button_text; | |
| 213 | + } | |
| 214 | + | |
| 215 | + | |
| 216 | + /** | |
| 217 | + * set_submit_button_text | |
| 218 | + * sets the text that appears on the reg step form submit button | |
| 219 | + * | |
| 220 | + * @param string $submit_button_text | |
| 221 | + */ | |
| 222 | + public function set_submit_button_text($submit_button_text = '') | |
| 223 | +	{ | |
| 224 | +		if (! empty($submit_button_text)) { | |
| 225 | + $this->_submit_button_text = $submit_button_text; | |
| 226 | +		} elseif ($this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | |
| 227 | +			if ($this->checkout->revisit) { | |
| 228 | + $this->_submit_button_text = sprintf( | |
| 229 | +					__('Update %s', 'event_espresso'), | |
| 230 | + $this->checkout->current_step->name() | |
| 231 | + ); | |
| 232 | +			} else { | |
| 233 | + $this->_submit_button_text = sprintf( | |
| 234 | +					__('Proceed to %s', 'event_espresso'), | |
| 235 | + $this->checkout->next_step->name() | |
| 236 | + ); | |
| 237 | + } | |
| 238 | + } | |
| 239 | + // filters the submit button text | |
| 240 | + $this->_submit_button_text = apply_filters( | |
| 241 | + 'FHEE__EE_SPCO_Reg_Step__set_submit_button_text___submit_button_text', | |
| 242 | + $this->_submit_button_text, | |
| 243 | + $this->checkout | |
| 244 | + ); | |
| 245 | + } | |
| 246 | + | |
| 247 | + | |
| 248 | + /** | |
| 249 | + * @param boolean $is_current_step | |
| 250 | + */ | |
| 251 | + public function set_is_current_step($is_current_step) | |
| 252 | +	{ | |
| 253 | + $this->_is_current_step = $is_current_step; | |
| 254 | + } | |
| 255 | + | |
| 256 | + | |
| 257 | + /** | |
| 258 | + * @return boolean | |
| 259 | + */ | |
| 260 | + public function is_current_step() | |
| 261 | +	{ | |
| 262 | + return $this->_is_current_step; | |
| 263 | + } | |
| 264 | + | |
| 265 | + | |
| 266 | + /** | |
| 267 | + * @return boolean | |
| 268 | + */ | |
| 269 | + public function is_final_step() | |
| 270 | +	{ | |
| 271 | + return $this instanceof EE_SPCO_Reg_Step_Finalize_Registration ? true : false; | |
| 272 | + } | |
| 273 | + | |
| 274 | + | |
| 275 | + /** | |
| 276 | + * @param int $order | |
| 277 | + */ | |
| 278 | + public function set_order($order) | |
| 279 | +	{ | |
| 280 | + $this->_order = $order; | |
| 281 | + } | |
| 282 | + | |
| 283 | + | |
| 284 | + /** | |
| 285 | + * @return int | |
| 286 | + */ | |
| 287 | + public function order() | |
| 288 | +	{ | |
| 289 | + return $this->_order; | |
| 290 | + } | |
| 291 | + | |
| 292 | + | |
| 293 | + /** | |
| 294 | + * @return string | |
| 295 | + */ | |
| 296 | + public function template() | |
| 297 | +	{ | |
| 298 | + return $this->_template; | |
| 299 | + } | |
| 300 | + | |
| 301 | + | |
| 302 | + /** | |
| 303 | + * @return string | |
| 304 | + */ | |
| 305 | + public function success_message() | |
| 306 | +	{ | |
| 307 | + return $this->_success_message; | |
| 308 | + } | |
| 309 | + | |
| 310 | + | |
| 311 | + /** | |
| 312 | + * _set_success_message | |
| 313 | + * | |
| 314 | + * @param string $success_message | |
| 315 | + */ | |
| 316 | + protected function _set_success_message($success_message) | |
| 317 | +	{ | |
| 318 | + $this->_success_message = $success_message; | |
| 319 | + } | |
| 320 | + | |
| 321 | + | |
| 322 | + /** | |
| 323 | + * _reset_success_message | |
| 324 | + * | |
| 325 | + * @return void | |
| 326 | + */ | |
| 327 | + protected function _reset_success_message() | |
| 328 | +	{ | |
| 329 | + $this->_success_message = ''; | |
| 330 | + } | |
| 331 | + | |
| 332 | + | |
| 333 | + /** | |
| 334 | + * @return string | |
| 335 | + */ | |
| 336 | + public function _instructions() | |
| 337 | +	{ | |
| 338 | + return $this->_instructions; | |
| 339 | + } | |
| 340 | + | |
| 341 | + | |
| 342 | + /** | |
| 343 | + * @param string $instructions | |
| 344 | + */ | |
| 345 | + public function set_instructions($instructions) | |
| 346 | +	{ | |
| 347 | + $this->_instructions = apply_filters( | |
| 348 | + 'FHEE__EE_SPCO_Reg_Step__set_instructions__instructions', | |
| 349 | + $instructions, | |
| 350 | + $this | |
| 351 | + ); | |
| 352 | + } | |
| 353 | + | |
| 354 | + | |
| 355 | + /** | |
| 356 | + * @param array $valid_data | |
| 357 | + */ | |
| 358 | + public function set_valid_data($valid_data) | |
| 359 | +	{ | |
| 360 | + $this->_valid_data = $valid_data; | |
| 361 | + } | |
| 362 | + | |
| 363 | + | |
| 364 | + /** | |
| 365 | + * @return array | |
| 366 | + */ | |
| 367 | + public function valid_data() | |
| 368 | +	{ | |
| 369 | +		if (empty($this->_valid_data)) { | |
| 370 | + $this->_valid_data = $this->reg_form->valid_data(); | |
| 371 | + } | |
| 372 | + return $this->_valid_data; | |
| 373 | + } | |
| 374 | + | |
| 375 | + | |
| 376 | + /** | |
| 377 | + * @return string | |
| 378 | + */ | |
| 379 | + public function reg_form_name() | |
| 380 | +	{ | |
| 381 | +		if (empty($this->_reg_form_name)) { | |
| 382 | +			$this->set_reg_form_name('ee-spco-' . $this->slug() . '-reg-step-form'); | |
| 383 | + } | |
| 384 | + return $this->_reg_form_name; | |
| 385 | + } | |
| 386 | + | |
| 387 | + | |
| 388 | + /** | |
| 389 | + * @param string $reg_form_name | |
| 390 | + */ | |
| 391 | + protected function set_reg_form_name($reg_form_name) | |
| 392 | +	{ | |
| 393 | + $this->_reg_form_name = $reg_form_name; | |
| 394 | + } | |
| 395 | + | |
| 396 | + | |
| 397 | + /** | |
| 398 | + * reg_step_url | |
| 399 | + * | |
| 400 | + * @param string $action | |
| 401 | + * @return string | |
| 402 | + */ | |
| 403 | + public function reg_step_url($action = '') | |
| 404 | +	{ | |
| 405 | +		$query_args = array('step' => $this->slug()); | |
| 406 | +		if (! empty($action)) { | |
| 407 | + $query_args['action'] = $action; | |
| 408 | + } | |
| 409 | + // final step has no display | |
| 410 | +		if ($this instanceof EE_SPCO_Reg_Step_Finalize_Registration && $action === 'display_spco_reg_step') { | |
| 411 | + $query_args['action'] = 'process_reg_step'; | |
| 412 | + } | |
| 413 | +		if ($this->checkout->revisit) { | |
| 414 | + $query_args['revisit'] = true; | |
| 415 | + } | |
| 416 | +		if ($this->checkout->reg_url_link) { | |
| 417 | + $query_args['e_reg_url_link'] = $this->checkout->reg_url_link; | |
| 418 | + } | |
| 419 | + return add_query_arg($query_args, $this->checkout->reg_page_base_url); | |
| 420 | + } | |
| 421 | + | |
| 422 | + | |
| 423 | + /** | |
| 424 | + * creates the default hidden inputs section | |
| 425 | + * | |
| 426 | + * @return EE_Form_Section_Proper | |
| 427 | + * @throws \EE_Error | |
| 428 | + */ | |
| 429 | + public function reg_step_hidden_inputs() | |
| 430 | +	{ | |
| 431 | + // hidden inputs for admin registrations | |
| 432 | +		if ($this->checkout->admin_request) { | |
| 433 | + return new EE_Form_Section_Proper( | |
| 434 | + array( | |
| 435 | + 'layout_strategy' => new EE_Div_Per_Section_Layout(), | |
| 436 | + 'html_id' => 'ee-' . $this->slug() . '-hidden-inputs', | |
| 437 | + 'subsections' => array( | |
| 438 | + 'next_step' => new EE_Fixed_Hidden_Input( | |
| 439 | + array( | |
| 440 | + 'html_name' => 'next_step', | |
| 441 | + 'html_id' => 'spco-' . $this->slug() . '-next-step', | |
| 442 | + 'default' => $this->checkout->next_step instanceof EE_SPCO_Reg_Step | |
| 443 | + ? $this->checkout->next_step->slug() | |
| 444 | + : '', | |
| 445 | + ) | |
| 446 | + ), | |
| 447 | + ), | |
| 448 | + ) | |
| 449 | + ); | |
| 450 | + } | |
| 451 | + // hidden inputs for frontend registrations | |
| 452 | + return new EE_Form_Section_Proper( | |
| 453 | + array( | |
| 454 | + 'layout_strategy' => new EE_Div_Per_Section_Layout(), | |
| 455 | + 'html_id' => 'ee-' . $this->slug() . '-hidden-inputs', | |
| 456 | + 'subsections' => array( | |
| 457 | + 'action' => new EE_Fixed_Hidden_Input( | |
| 458 | + array( | |
| 459 | + 'html_name' => 'action', | |
| 460 | + 'html_id' => 'spco-' . $this->slug() . '-action', | |
| 461 | + 'default' => apply_filters( | |
| 462 | + 'FHEE__EE_SPCO_Reg_Step__reg_step_hidden_inputs__default_form_action', | |
| 463 | + empty($this->checkout->reg_url_link) | |
| 464 | + ? 'process_reg_step' | |
| 465 | + : 'update_reg_step', | |
| 466 | + $this | |
| 467 | + ), | |
| 468 | + ) | |
| 469 | + ), | |
| 470 | + 'next_step' => new EE_Fixed_Hidden_Input( | |
| 471 | + array( | |
| 472 | + 'html_name' => 'next_step', | |
| 473 | + 'html_id' => 'spco-' . $this->slug() . '-next-step', | |
| 474 | + 'default' => $this->checkout->next_step instanceof EE_SPCO_Reg_Step | |
| 475 | + ? $this->checkout->next_step->slug() | |
| 476 | + : '', | |
| 477 | + ) | |
| 478 | + ), | |
| 479 | + 'e_reg_url_link' => new EE_Fixed_Hidden_Input( | |
| 480 | + array( | |
| 481 | + 'html_name' => 'e_reg_url_link', | |
| 482 | + 'html_id' => 'spco-reg_url_link', | |
| 483 | + 'default' => $this->checkout->reg_url_link, | |
| 484 | + ) | |
| 485 | + ), | |
| 486 | + 'revisit' => new EE_Fixed_Hidden_Input( | |
| 487 | + array( | |
| 488 | + 'html_name' => 'revisit', | |
| 489 | + 'html_id' => 'spco-revisit', | |
| 490 | + 'default' => $this->checkout->revisit, | |
| 491 | + ) | |
| 492 | + ), | |
| 493 | + ), | |
| 494 | + ) | |
| 495 | + ); | |
| 496 | + } | |
| 497 | + | |
| 498 | + | |
| 499 | + /** | |
| 500 | + * generate_reg_form_for_actions | |
| 501 | + * | |
| 502 | + * @param array $actions | |
| 503 | + * @return void | |
| 504 | + */ | |
| 505 | + public function generate_reg_form_for_actions($actions = array()) | |
| 506 | +	{ | |
| 507 | + $actions = array_merge( | |
| 508 | + array( | |
| 509 | + 'generate_reg_form', | |
| 510 | + 'display_spco_reg_step', | |
| 511 | + 'process_reg_step', | |
| 512 | + 'update_reg_step', | |
| 513 | + ), | |
| 514 | + $actions | |
| 515 | + ); | |
| 516 | + $this->checkout->generate_reg_form = in_array($this->checkout->action, $actions, true) ? true : false; | |
| 517 | + } | |
| 518 | + | |
| 519 | + | |
| 520 | + /** | |
| 521 | + * @return string | |
| 522 | + * @throws \EE_Error | |
| 523 | + */ | |
| 524 | + public function display_reg_form() | |
| 525 | +	{ | |
| 526 | + $html = ''; | |
| 527 | +		if ($this->reg_form instanceof EE_Form_Section_Proper) { | |
| 528 | +			do_action('AHEE__EE_SPCO_Reg_Step__display_reg_form__reg_form', $this->reg_form, $this); | |
| 529 | + $html .= ! $this->checkout->admin_request ? $this->reg_form->form_open($this->reg_step_url()) : ''; | |
| 530 | +			if (EE_Registry::instance()->REQ->ajax) { | |
| 531 | + $this->reg_form->localize_validation_rules(); | |
| 532 | + $this->checkout->json_response->add_validation_rules(EE_Form_Section_Proper::js_localization()); | |
| 533 | + } | |
| 534 | + $html .= $this->reg_form->get_html(); | |
| 535 | + $html .= ! $this->checkout->admin_request ? $this->reg_step_submit_button() : ''; | |
| 536 | + $html .= ! $this->checkout->admin_request ? $this->reg_form->form_close() : ''; | |
| 537 | + } | |
| 538 | + return $html; | |
| 539 | + } | |
| 540 | + | |
| 541 | + | |
| 542 | + /** | |
| 543 | + * div_class - returns nothing for current step, but a css class of "hidden" for others | |
| 544 | + * | |
| 545 | + * @return string | |
| 546 | + * @throws \EE_Error | |
| 547 | + */ | |
| 548 | + public function reg_step_submit_button() | |
| 549 | +	{ | |
| 550 | +		if (! $this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | |
| 551 | + return ''; | |
| 552 | + } | |
| 553 | + ob_start(); | |
| 554 | + do_action( | |
| 555 | + 'AHEE__before_spco_whats_next_buttons', | |
| 556 | + $this->slug(), | |
| 557 | + $this->checkout->next_step->slug(), | |
| 558 | + $this->checkout | |
| 559 | + ); | |
| 560 | + $html = ob_get_clean(); | |
| 561 | + // generate submit button | |
| 562 | + $sbmt_btn = new EE_Submit_Input( | |
| 563 | + array( | |
| 564 | + 'html_name' => 'spco-go-to-step-' . $this->checkout->next_step->slug(), | |
| 565 | + 'html_id' => 'spco-go-to-step-' . $this->checkout->next_step->slug(), | |
| 566 | + 'html_class' => 'spco-next-step-btn', | |
| 567 | + 'other_html_attributes' => ' rel="' . $this->slug() . '"', | |
| 568 | + 'default' => $this->submit_button_text(), | |
| 569 | + ) | |
| 570 | + ); | |
| 571 | + $sbmt_btn->set_button_css_attributes(true, 'large'); | |
| 572 | + $sbmt_btn_html = $sbmt_btn->get_html_for_input(); | |
| 573 | + $html .= EEH_HTML::div( | |
| 574 | +			apply_filters('FHEE__EE_SPCO_Reg_Step__reg_step_submit_button__sbmt_btn_html', $sbmt_btn_html, $this), | |
| 575 | + 'spco-' . $this->slug() . '-whats-next-buttons-dv', | |
| 576 | + 'spco-whats-next-buttons' | |
| 577 | + ); | |
| 578 | + return $html; | |
| 579 | + } | |
| 580 | + | |
| 581 | + | |
| 582 | + /** | |
| 583 | + * div_class - returns nothing for current step, but a css class of "hidden" for others | |
| 584 | + * | |
| 585 | + * @return string | |
| 586 | + */ | |
| 587 | + public function div_class() | |
| 588 | +	{ | |
| 589 | + return $this->is_current_step() ? '' : ' hidden'; | |
| 590 | + } | |
| 591 | + | |
| 592 | + | |
| 593 | + /** | |
| 594 | + * div_class - returns a css class of "hidden" for current step, but nothing for others | |
| 595 | + * | |
| 596 | + * @return string | |
| 597 | + */ | |
| 598 | + public function edit_lnk_url() | |
| 599 | +	{ | |
| 600 | +		return add_query_arg(array('step' => $this->slug()), $this->checkout->reg_page_base_url); | |
| 601 | + } | |
| 602 | + | |
| 603 | + | |
| 604 | + /** | |
| 605 | + * div_class - returns a css class of "hidden" for current step, but nothing for others | |
| 606 | + * | |
| 607 | + * @return string | |
| 608 | + */ | |
| 609 | + public function edit_link_class() | |
| 610 | +	{ | |
| 611 | + return $this->is_current_step() ? ' hidden' : ''; | |
| 612 | + } | |
| 613 | + | |
| 614 | + | |
| 615 | + /** | |
| 616 | + * update_checkout with changes that have been made to the cart | |
| 617 | + * | |
| 618 | + * @return void | |
| 619 | + * @throws \EE_Error | |
| 620 | + */ | |
| 621 | + public function update_checkout() | |
| 622 | +	{ | |
| 623 | + // grab the cart grand total and reset TXN total | |
| 624 | + $this->checkout->transaction->set_total($this->checkout->cart->get_cart_grand_total()); | |
| 625 | + $this->checkout->stash_transaction_and_checkout(); | |
| 626 | + } | |
| 627 | + | |
| 628 | + | |
| 629 | + /** | |
| 630 | + * __sleep | |
| 631 | + * to conserve db space, let's remove the reg_form and the EE_Checkout object from EE_SPCO_Reg_Step objects upon | |
| 632 | + * serialization EE_Checkout will handle the reimplementation of itself upon waking, but we won't bother with the | |
| 633 | + * reg form, because if needed, it will be regenerated anyways | |
| 634 | + * | |
| 635 | + * @return array | |
| 636 | + */ | |
| 637 | + public function __sleep() | |
| 638 | +	{ | |
| 639 | + // remove the reg form and the checkout | |
| 640 | +		return array_diff(array_keys(get_object_vars($this)), array('reg_form', 'checkout')); | |
| 641 | + } | |
| 642 | 642 | } | 
| @@ -221,7 +221,7 @@ discard block | ||
| 221 | 221 | */ | 
| 222 | 222 | public function set_submit_button_text($submit_button_text = '') | 
| 223 | 223 |      { | 
| 224 | -        if (! empty($submit_button_text)) { | |
| 224 | +        if ( ! empty($submit_button_text)) { | |
| 225 | 225 | $this->_submit_button_text = $submit_button_text; | 
| 226 | 226 |          } elseif ($this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | 
| 227 | 227 |              if ($this->checkout->revisit) { | 
| @@ -379,7 +379,7 @@ discard block | ||
| 379 | 379 | public function reg_form_name() | 
| 380 | 380 |      { | 
| 381 | 381 |          if (empty($this->_reg_form_name)) { | 
| 382 | -            $this->set_reg_form_name('ee-spco-' . $this->slug() . '-reg-step-form'); | |
| 382 | +            $this->set_reg_form_name('ee-spco-'.$this->slug().'-reg-step-form'); | |
| 383 | 383 | } | 
| 384 | 384 | return $this->_reg_form_name; | 
| 385 | 385 | } | 
| @@ -403,7 +403,7 @@ discard block | ||
| 403 | 403 | public function reg_step_url($action = '') | 
| 404 | 404 |      { | 
| 405 | 405 |          $query_args = array('step' => $this->slug()); | 
| 406 | -        if (! empty($action)) { | |
| 406 | +        if ( ! empty($action)) { | |
| 407 | 407 | $query_args['action'] = $action; | 
| 408 | 408 | } | 
| 409 | 409 | // final step has no display | 
| @@ -433,12 +433,12 @@ discard block | ||
| 433 | 433 | return new EE_Form_Section_Proper( | 
| 434 | 434 | array( | 
| 435 | 435 | 'layout_strategy' => new EE_Div_Per_Section_Layout(), | 
| 436 | - 'html_id' => 'ee-' . $this->slug() . '-hidden-inputs', | |
| 436 | + 'html_id' => 'ee-'.$this->slug().'-hidden-inputs', | |
| 437 | 437 | 'subsections' => array( | 
| 438 | 438 | 'next_step' => new EE_Fixed_Hidden_Input( | 
| 439 | 439 | array( | 
| 440 | 440 | 'html_name' => 'next_step', | 
| 441 | - 'html_id' => 'spco-' . $this->slug() . '-next-step', | |
| 441 | + 'html_id' => 'spco-'.$this->slug().'-next-step', | |
| 442 | 442 | 'default' => $this->checkout->next_step instanceof EE_SPCO_Reg_Step | 
| 443 | 443 | ? $this->checkout->next_step->slug() | 
| 444 | 444 | : '', | 
| @@ -452,12 +452,12 @@ discard block | ||
| 452 | 452 | return new EE_Form_Section_Proper( | 
| 453 | 453 | array( | 
| 454 | 454 | 'layout_strategy' => new EE_Div_Per_Section_Layout(), | 
| 455 | - 'html_id' => 'ee-' . $this->slug() . '-hidden-inputs', | |
| 455 | + 'html_id' => 'ee-'.$this->slug().'-hidden-inputs', | |
| 456 | 456 | 'subsections' => array( | 
| 457 | 457 | 'action' => new EE_Fixed_Hidden_Input( | 
| 458 | 458 | array( | 
| 459 | 459 | 'html_name' => 'action', | 
| 460 | - 'html_id' => 'spco-' . $this->slug() . '-action', | |
| 460 | + 'html_id' => 'spco-'.$this->slug().'-action', | |
| 461 | 461 | 'default' => apply_filters( | 
| 462 | 462 | 'FHEE__EE_SPCO_Reg_Step__reg_step_hidden_inputs__default_form_action', | 
| 463 | 463 | empty($this->checkout->reg_url_link) | 
| @@ -470,7 +470,7 @@ discard block | ||
| 470 | 470 | 'next_step' => new EE_Fixed_Hidden_Input( | 
| 471 | 471 | array( | 
| 472 | 472 | 'html_name' => 'next_step', | 
| 473 | - 'html_id' => 'spco-' . $this->slug() . '-next-step', | |
| 473 | + 'html_id' => 'spco-'.$this->slug().'-next-step', | |
| 474 | 474 | 'default' => $this->checkout->next_step instanceof EE_SPCO_Reg_Step | 
| 475 | 475 | ? $this->checkout->next_step->slug() | 
| 476 | 476 | : '', | 
| @@ -547,7 +547,7 @@ discard block | ||
| 547 | 547 | */ | 
| 548 | 548 | public function reg_step_submit_button() | 
| 549 | 549 |      { | 
| 550 | -        if (! $this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | |
| 550 | +        if ( ! $this->checkout->next_step instanceof EE_SPCO_Reg_Step) { | |
| 551 | 551 | return ''; | 
| 552 | 552 | } | 
| 553 | 553 | ob_start(); | 
| @@ -561,10 +561,10 @@ discard block | ||
| 561 | 561 | // generate submit button | 
| 562 | 562 | $sbmt_btn = new EE_Submit_Input( | 
| 563 | 563 | array( | 
| 564 | - 'html_name' => 'spco-go-to-step-' . $this->checkout->next_step->slug(), | |
| 565 | - 'html_id' => 'spco-go-to-step-' . $this->checkout->next_step->slug(), | |
| 564 | + 'html_name' => 'spco-go-to-step-'.$this->checkout->next_step->slug(), | |
| 565 | + 'html_id' => 'spco-go-to-step-'.$this->checkout->next_step->slug(), | |
| 566 | 566 | 'html_class' => 'spco-next-step-btn', | 
| 567 | - 'other_html_attributes' => ' rel="' . $this->slug() . '"', | |
| 567 | + 'other_html_attributes' => ' rel="'.$this->slug().'"', | |
| 568 | 568 | 'default' => $this->submit_button_text(), | 
| 569 | 569 | ) | 
| 570 | 570 | ); | 
| @@ -572,7 +572,7 @@ discard block | ||
| 572 | 572 | $sbmt_btn_html = $sbmt_btn->get_html_for_input(); | 
| 573 | 573 | $html .= EEH_HTML::div( | 
| 574 | 574 |              apply_filters('FHEE__EE_SPCO_Reg_Step__reg_step_submit_button__sbmt_btn_html', $sbmt_btn_html, $this), | 
| 575 | - 'spco-' . $this->slug() . '-whats-next-buttons-dv', | |
| 575 | + 'spco-'.$this->slug().'-whats-next-buttons-dv', | |
| 576 | 576 | 'spco-whats-next-buttons' | 
| 577 | 577 | ); | 
| 578 | 578 | return $html; | 
| @@ -92,14 +92,14 @@ discard block | ||
| 92 | 92 | $txn_update_params | 
| 93 | 93 | ); | 
| 94 | 94 | // check if transaction has a primary registrant and that it has a related Attendee object | 
| 95 | -        if (! $this->_validate_primary_registrant()) { | |
| 95 | +        if ( ! $this->_validate_primary_registrant()) { | |
| 96 | 96 | return false; | 
| 97 | 97 | } | 
| 98 | 98 | // you don't have to go home but you can't stay here ! | 
| 99 | 99 | $this->checkout->redirect = true; | 
| 100 | 100 | $this->checkout->continue_reg = true; | 
| 101 | 101 | $this->checkout->json_response->set_redirect_url($this->checkout->redirect_url); | 
| 102 | - if (! ( | |
| 102 | + if ( ! ( | |
| 103 | 103 | $this->checkout->payment_method instanceof EE_Payment_Method | 
| 104 | 104 | && $this->checkout->payment_method->is_off_site() | 
| 105 | 105 |          )) { | 
| @@ -210,7 +210,7 @@ discard block | ||
| 210 | 210 | */ | 
| 211 | 211 | protected function _validate_primary_registrant() | 
| 212 | 212 |      { | 
| 213 | -        if (! $this->checkout->transaction_has_primary_registrant()) { | |
| 213 | +        if ( ! $this->checkout->transaction_has_primary_registrant()) { | |
| 214 | 214 | EE_Error::add_error( | 
| 215 | 215 |                  __('A valid Primary Registration for this Transaction could not be found.', 'event_espresso'), | 
| 216 | 216 | __FILE__, | 
| @@ -236,7 +236,7 @@ discard block | ||
| 236 | 236 | public function update_reg_step() | 
| 237 | 237 |      { | 
| 238 | 238 | EE_Error::doing_it_wrong( | 
| 239 | - __CLASS__ . '::' . __FILE__, | |
| 239 | + __CLASS__.'::'.__FILE__, | |
| 240 | 240 | __( | 
| 241 | 241 | 'Can not call update_reg_step() on the Finalize Registration reg step.', | 
| 242 | 242 | 'event_espresso' | 
| @@ -12,240 +12,240 @@ | ||
| 12 | 12 | class EE_SPCO_Reg_Step_Finalize_Registration extends EE_SPCO_Reg_Step | 
| 13 | 13 |  { | 
| 14 | 14 | |
| 15 | - /** | |
| 16 | - * class constructor | |
| 17 | - * | |
| 18 | - * @access public | |
| 19 | - * @param EE_Checkout $checkout | |
| 20 | - */ | |
| 21 | - public function __construct(EE_Checkout $checkout) | |
| 22 | -    { | |
| 23 | - $this->_slug = 'finalize_registration'; | |
| 24 | -        $this->_name = __('Finalize Registration', 'event_espresso'); | |
| 25 | - $this->_submit_button_text = $this->_name; | |
| 26 | - $this->_template = ''; | |
| 27 | - $this->checkout = $checkout; | |
| 28 | - } | |
| 29 | - | |
| 30 | - | |
| 31 | - public function translate_js_strings() | |
| 32 | -    { | |
| 33 | - } | |
| 34 | - | |
| 35 | - | |
| 36 | - public function enqueue_styles_and_scripts() | |
| 37 | -    { | |
| 38 | - } | |
| 39 | - | |
| 40 | - | |
| 41 | - /** | |
| 42 | - * @return boolean | |
| 43 | - */ | |
| 44 | - public function initialize_reg_step() | |
| 45 | -    { | |
| 46 | - // there's actually no reg form to process if this is the final step | |
| 47 | -        if ($this->is_current_step()) { | |
| 48 | - $this->checkout->step = $_REQUEST['step'] = $this->slug(); | |
| 49 | - $this->checkout->action = $_REQUEST['action'] = 'process_reg_step'; | |
| 50 | - $this->checkout->generate_reg_form = false; | |
| 51 | - } | |
| 52 | - return true; | |
| 53 | - } | |
| 54 | - | |
| 55 | - | |
| 56 | - /** | |
| 57 | - * @return string | |
| 58 | - * @throws \EE_Error | |
| 59 | - */ | |
| 60 | - public function generate_reg_form() | |
| 61 | -    { | |
| 62 | - // create empty form so that things don't break | |
| 63 | - $this->reg_form = new EE_Form_Section_Proper(); | |
| 64 | - return ''; | |
| 65 | - } | |
| 66 | - | |
| 67 | - | |
| 68 | - /** | |
| 69 | - * @return boolean | |
| 70 | - * @throws \RuntimeException | |
| 71 | - * @throws \EE_Error | |
| 72 | - */ | |
| 73 | - public function process_reg_step() | |
| 74 | -    { | |
| 75 | - // ensure all data gets refreshed from the db | |
| 76 | - $this->checkout->refresh_all_entities(true); | |
| 77 | - // ensures that all details and statuses for transaction, registration, and payments are updated | |
| 78 | - $txn_update_params = $this->_finalize_transaction(); | |
| 79 | - // maybe send messages | |
| 80 | - $this->_set_notification_triggers(); | |
| 81 | - // send messages | |
| 82 | - /** @type EE_Registration_Processor $registration_processor */ | |
| 83 | -        $registration_processor = EE_Registry::instance()->load_class('Registration_Processor'); | |
| 84 | - $registration_processor->trigger_registration_update_notifications( | |
| 85 | - $this->checkout->transaction->primary_registration(), | |
| 86 | - $txn_update_params | |
| 87 | - ); | |
| 88 | - // set a hook point | |
| 89 | - do_action( | |
| 90 | - 'AHEE__EE_SPCO_Reg_Step_Finalize_Registration__process_reg_step__completed', | |
| 91 | - $this->checkout, | |
| 92 | - $txn_update_params | |
| 93 | - ); | |
| 94 | - // check if transaction has a primary registrant and that it has a related Attendee object | |
| 95 | -        if (! $this->_validate_primary_registrant()) { | |
| 96 | - return false; | |
| 97 | - } | |
| 98 | - // you don't have to go home but you can't stay here ! | |
| 99 | - $this->checkout->redirect = true; | |
| 100 | - $this->checkout->continue_reg = true; | |
| 101 | - $this->checkout->json_response->set_redirect_url($this->checkout->redirect_url); | |
| 102 | - if (! ( | |
| 103 | - $this->checkout->payment_method instanceof EE_Payment_Method | |
| 104 | - && $this->checkout->payment_method->is_off_site() | |
| 105 | -        )) { | |
| 106 | - // mark this reg step as completed | |
| 107 | - $this->set_completed(); | |
| 108 | - } | |
| 109 | - $this->checkout->set_exit_spco(); | |
| 110 | - return true; | |
| 111 | - } | |
| 112 | - | |
| 113 | - | |
| 114 | - /** | |
| 115 | - * _finalize_transaction | |
| 116 | - * ensures that all details and statuses for transaction, registration, and payments are updated | |
| 117 | - * | |
| 118 | - * @return array | |
| 119 | - * @throws \RuntimeException | |
| 120 | - * @throws \EE_Error | |
| 121 | - */ | |
| 122 | - protected function _finalize_transaction() | |
| 123 | -    { | |
| 124 | - /** @type EE_Transaction_Processor $transaction_processor */ | |
| 125 | -        $transaction_processor = EE_Registry::instance()->load_class('Transaction_Processor'); | |
| 126 | - // set revisit flag in txn processor | |
| 127 | - $transaction_processor->set_revisit($this->checkout->revisit); | |
| 128 | - // at this point we'll consider a TXN to not have been abandoned | |
| 129 | - $this->checkout->transaction->toggle_abandoned_transaction_status(); | |
| 130 | -        if ($this->checkout->cart instanceof EE_Cart) { | |
| 131 | - // save TXN data to the cart | |
| 132 | - $this->checkout->cart->get_grand_total()->save_this_and_descendants_to_txn( | |
| 133 | - $this->checkout->transaction->ID() | |
| 134 | - ); | |
| 135 | - } | |
| 136 | - // maybe update status, but don't save transaction just yet | |
| 137 | - $this->checkout->transaction->update_status_based_on_total_paid(false); | |
| 138 | - // this will result in the base session properties getting saved to the TXN_Session_data field | |
| 139 | - $session_data = EE_Registry::instance()->SSN->get_session_data(null, true); | |
| 140 | - // anonymize the last part of the IP address, now that the transaction is complete (we won't be using the IP address | |
| 141 | - // for spam or bot detection now) | |
| 142 | -        if (function_exists('wp_privacy_anonymize_ip') && isset($session_data['ip_address'])) { | |
| 143 | - $session_data['ip_address'] = wp_privacy_anonymize_ip($session_data['ip_address']); | |
| 144 | - } | |
| 145 | - $this->checkout->transaction->set_txn_session_data($session_data); | |
| 146 | - // update the TXN if payment conditions have changed, but do NOT trigger notifications, | |
| 147 | - // because we will do that in process_reg_step() after setting some more triggers | |
| 148 | - return $transaction_processor->update_transaction_and_registrations_after_checkout_or_payment( | |
| 149 | - $this->checkout->transaction, | |
| 150 | - $this->checkout->payment, | |
| 151 | - $this->checkout->reg_cache_where_params, | |
| 152 | - false | |
| 153 | - ); | |
| 154 | - } | |
| 155 | - | |
| 156 | - | |
| 157 | - /** | |
| 158 | - * If request is not a revisit, and an Off-Site gateway using IPNs has NOT been selected... | |
| 159 | - * OR | |
| 160 | - * if it IS a revisit and the TXN and/or one or more REG statuses have changed... | |
| 161 | - * then trigger notifications | |
| 162 | - * | |
| 163 | - * @return void | |
| 164 | - * @throws \EE_Error | |
| 165 | - */ | |
| 166 | - protected function _set_notification_triggers() | |
| 167 | -    { | |
| 168 | - | |
| 169 | -        if ($this->checkout->payment_method instanceof EE_Payment_Method) { | |
| 170 | - // let's start with the assumption that we need to trigger notifications | |
| 171 | - // then toggle this to false for conditions where we know we don't need to | |
| 172 | - $deliver_notifications = true; | |
| 173 | - if (// if SPCO revisit | |
| 174 | - filter_var($this->checkout->revisit, FILTER_VALIDATE_BOOLEAN) | |
| 175 | - // and TXN or REG statuses have NOT changed due to a payment | |
| 176 | - && ! ( | |
| 177 | - $this->checkout->transaction->txn_status_updated() | |
| 178 | - || $this->checkout->any_reg_status_updated() | |
| 179 | - ) | |
| 180 | -            ) { | |
| 181 | - $deliver_notifications = false; | |
| 182 | - } | |
| 183 | -            if ($this->checkout->payment_method->is_off_site()) { | |
| 184 | - /** @var EE_Gateway $gateway */ | |
| 185 | - $gateway = $this->checkout->payment_method->type_obj()->get_gateway(); | |
| 186 | - // and the gateway uses a separate request to process the IPN | |
| 187 | - if ($gateway instanceof EE_Offsite_Gateway | |
| 188 | - && $gateway->handle_IPN_in_this_request(\EE_Registry::instance()->REQ->params(), true) | |
| 189 | -                ) { | |
| 190 | - // IPN request will handle triggering notifications | |
| 191 | - $deliver_notifications = false; | |
| 192 | - // no really... don't send any notices in this request | |
| 193 | -                    remove_all_filters('FHEE__EED_Messages___maybe_registration__deliver_notifications'); | |
| 194 | - add_filter( | |
| 195 | - 'FHEE__EED_Messages___maybe_registration__deliver_notifications', | |
| 196 | - '__return_false', | |
| 197 | - 15 | |
| 198 | - ); | |
| 199 | - } | |
| 200 | - } | |
| 201 | -            if ($deliver_notifications) { | |
| 202 | - // send out notifications | |
| 203 | -                add_filter('FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_true', 10); | |
| 204 | - } | |
| 205 | - } | |
| 206 | - } | |
| 207 | - | |
| 208 | - | |
| 209 | - /** | |
| 210 | - * check if transaction has a primary registrant and that it has a related Attendee object | |
| 211 | - * | |
| 212 | - * @return boolean | |
| 213 | - * @throws \EE_Error | |
| 214 | - */ | |
| 215 | - protected function _validate_primary_registrant() | |
| 216 | -    { | |
| 217 | -        if (! $this->checkout->transaction_has_primary_registrant()) { | |
| 218 | - EE_Error::add_error( | |
| 219 | -                __('A valid Primary Registration for this Transaction could not be found.', 'event_espresso'), | |
| 220 | - __FILE__, | |
| 221 | - __FUNCTION__, | |
| 222 | - __LINE__ | |
| 223 | - ); | |
| 224 | - $this->checkout->redirect = false; | |
| 225 | - $this->checkout->continue_reg = false; | |
| 226 | - return false; | |
| 227 | - } | |
| 228 | - // setup URL for redirect | |
| 229 | - $this->checkout->redirect_url = add_query_arg( | |
| 230 | -            array('e_reg_url_link' => $this->checkout->transaction->primary_registration()->reg_url_link()), | |
| 231 | - $this->checkout->thank_you_page_url | |
| 232 | - ); | |
| 233 | - return true; | |
| 234 | - } | |
| 235 | - | |
| 236 | - | |
| 237 | - /** | |
| 238 | - * @return void | |
| 239 | - */ | |
| 240 | - public function update_reg_step() | |
| 241 | -    { | |
| 242 | - EE_Error::doing_it_wrong( | |
| 243 | - __CLASS__ . '::' . __FILE__, | |
| 244 | - __( | |
| 245 | - 'Can not call update_reg_step() on the Finalize Registration reg step.', | |
| 246 | - 'event_espresso' | |
| 247 | - ), | |
| 248 | - '4.6.0' | |
| 249 | - ); | |
| 250 | - } | |
| 15 | + /** | |
| 16 | + * class constructor | |
| 17 | + * | |
| 18 | + * @access public | |
| 19 | + * @param EE_Checkout $checkout | |
| 20 | + */ | |
| 21 | + public function __construct(EE_Checkout $checkout) | |
| 22 | +	{ | |
| 23 | + $this->_slug = 'finalize_registration'; | |
| 24 | +		$this->_name = __('Finalize Registration', 'event_espresso'); | |
| 25 | + $this->_submit_button_text = $this->_name; | |
| 26 | + $this->_template = ''; | |
| 27 | + $this->checkout = $checkout; | |
| 28 | + } | |
| 29 | + | |
| 30 | + | |
| 31 | + public function translate_js_strings() | |
| 32 | +	{ | |
| 33 | + } | |
| 34 | + | |
| 35 | + | |
| 36 | + public function enqueue_styles_and_scripts() | |
| 37 | +	{ | |
| 38 | + } | |
| 39 | + | |
| 40 | + | |
| 41 | + /** | |
| 42 | + * @return boolean | |
| 43 | + */ | |
| 44 | + public function initialize_reg_step() | |
| 45 | +	{ | |
| 46 | + // there's actually no reg form to process if this is the final step | |
| 47 | +		if ($this->is_current_step()) { | |
| 48 | + $this->checkout->step = $_REQUEST['step'] = $this->slug(); | |
| 49 | + $this->checkout->action = $_REQUEST['action'] = 'process_reg_step'; | |
| 50 | + $this->checkout->generate_reg_form = false; | |
| 51 | + } | |
| 52 | + return true; | |
| 53 | + } | |
| 54 | + | |
| 55 | + | |
| 56 | + /** | |
| 57 | + * @return string | |
| 58 | + * @throws \EE_Error | |
| 59 | + */ | |
| 60 | + public function generate_reg_form() | |
| 61 | +	{ | |
| 62 | + // create empty form so that things don't break | |
| 63 | + $this->reg_form = new EE_Form_Section_Proper(); | |
| 64 | + return ''; | |
| 65 | + } | |
| 66 | + | |
| 67 | + | |
| 68 | + /** | |
| 69 | + * @return boolean | |
| 70 | + * @throws \RuntimeException | |
| 71 | + * @throws \EE_Error | |
| 72 | + */ | |
| 73 | + public function process_reg_step() | |
| 74 | +	{ | |
| 75 | + // ensure all data gets refreshed from the db | |
| 76 | + $this->checkout->refresh_all_entities(true); | |
| 77 | + // ensures that all details and statuses for transaction, registration, and payments are updated | |
| 78 | + $txn_update_params = $this->_finalize_transaction(); | |
| 79 | + // maybe send messages | |
| 80 | + $this->_set_notification_triggers(); | |
| 81 | + // send messages | |
| 82 | + /** @type EE_Registration_Processor $registration_processor */ | |
| 83 | +		$registration_processor = EE_Registry::instance()->load_class('Registration_Processor'); | |
| 84 | + $registration_processor->trigger_registration_update_notifications( | |
| 85 | + $this->checkout->transaction->primary_registration(), | |
| 86 | + $txn_update_params | |
| 87 | + ); | |
| 88 | + // set a hook point | |
| 89 | + do_action( | |
| 90 | + 'AHEE__EE_SPCO_Reg_Step_Finalize_Registration__process_reg_step__completed', | |
| 91 | + $this->checkout, | |
| 92 | + $txn_update_params | |
| 93 | + ); | |
| 94 | + // check if transaction has a primary registrant and that it has a related Attendee object | |
| 95 | +		if (! $this->_validate_primary_registrant()) { | |
| 96 | + return false; | |
| 97 | + } | |
| 98 | + // you don't have to go home but you can't stay here ! | |
| 99 | + $this->checkout->redirect = true; | |
| 100 | + $this->checkout->continue_reg = true; | |
| 101 | + $this->checkout->json_response->set_redirect_url($this->checkout->redirect_url); | |
| 102 | + if (! ( | |
| 103 | + $this->checkout->payment_method instanceof EE_Payment_Method | |
| 104 | + && $this->checkout->payment_method->is_off_site() | |
| 105 | +		)) { | |
| 106 | + // mark this reg step as completed | |
| 107 | + $this->set_completed(); | |
| 108 | + } | |
| 109 | + $this->checkout->set_exit_spco(); | |
| 110 | + return true; | |
| 111 | + } | |
| 112 | + | |
| 113 | + | |
| 114 | + /** | |
| 115 | + * _finalize_transaction | |
| 116 | + * ensures that all details and statuses for transaction, registration, and payments are updated | |
| 117 | + * | |
| 118 | + * @return array | |
| 119 | + * @throws \RuntimeException | |
| 120 | + * @throws \EE_Error | |
| 121 | + */ | |
| 122 | + protected function _finalize_transaction() | |
| 123 | +	{ | |
| 124 | + /** @type EE_Transaction_Processor $transaction_processor */ | |
| 125 | +		$transaction_processor = EE_Registry::instance()->load_class('Transaction_Processor'); | |
| 126 | + // set revisit flag in txn processor | |
| 127 | + $transaction_processor->set_revisit($this->checkout->revisit); | |
| 128 | + // at this point we'll consider a TXN to not have been abandoned | |
| 129 | + $this->checkout->transaction->toggle_abandoned_transaction_status(); | |
| 130 | +		if ($this->checkout->cart instanceof EE_Cart) { | |
| 131 | + // save TXN data to the cart | |
| 132 | + $this->checkout->cart->get_grand_total()->save_this_and_descendants_to_txn( | |
| 133 | + $this->checkout->transaction->ID() | |
| 134 | + ); | |
| 135 | + } | |
| 136 | + // maybe update status, but don't save transaction just yet | |
| 137 | + $this->checkout->transaction->update_status_based_on_total_paid(false); | |
| 138 | + // this will result in the base session properties getting saved to the TXN_Session_data field | |
| 139 | + $session_data = EE_Registry::instance()->SSN->get_session_data(null, true); | |
| 140 | + // anonymize the last part of the IP address, now that the transaction is complete (we won't be using the IP address | |
| 141 | + // for spam or bot detection now) | |
| 142 | +		if (function_exists('wp_privacy_anonymize_ip') && isset($session_data['ip_address'])) { | |
| 143 | + $session_data['ip_address'] = wp_privacy_anonymize_ip($session_data['ip_address']); | |
| 144 | + } | |
| 145 | + $this->checkout->transaction->set_txn_session_data($session_data); | |
| 146 | + // update the TXN if payment conditions have changed, but do NOT trigger notifications, | |
| 147 | + // because we will do that in process_reg_step() after setting some more triggers | |
| 148 | + return $transaction_processor->update_transaction_and_registrations_after_checkout_or_payment( | |
| 149 | + $this->checkout->transaction, | |
| 150 | + $this->checkout->payment, | |
| 151 | + $this->checkout->reg_cache_where_params, | |
| 152 | + false | |
| 153 | + ); | |
| 154 | + } | |
| 155 | + | |
| 156 | + | |
| 157 | + /** | |
| 158 | + * If request is not a revisit, and an Off-Site gateway using IPNs has NOT been selected... | |
| 159 | + * OR | |
| 160 | + * if it IS a revisit and the TXN and/or one or more REG statuses have changed... | |
| 161 | + * then trigger notifications | |
| 162 | + * | |
| 163 | + * @return void | |
| 164 | + * @throws \EE_Error | |
| 165 | + */ | |
| 166 | + protected function _set_notification_triggers() | |
| 167 | +	{ | |
| 168 | + | |
| 169 | +		if ($this->checkout->payment_method instanceof EE_Payment_Method) { | |
| 170 | + // let's start with the assumption that we need to trigger notifications | |
| 171 | + // then toggle this to false for conditions where we know we don't need to | |
| 172 | + $deliver_notifications = true; | |
| 173 | + if (// if SPCO revisit | |
| 174 | + filter_var($this->checkout->revisit, FILTER_VALIDATE_BOOLEAN) | |
| 175 | + // and TXN or REG statuses have NOT changed due to a payment | |
| 176 | + && ! ( | |
| 177 | + $this->checkout->transaction->txn_status_updated() | |
| 178 | + || $this->checkout->any_reg_status_updated() | |
| 179 | + ) | |
| 180 | +			) { | |
| 181 | + $deliver_notifications = false; | |
| 182 | + } | |
| 183 | +			if ($this->checkout->payment_method->is_off_site()) { | |
| 184 | + /** @var EE_Gateway $gateway */ | |
| 185 | + $gateway = $this->checkout->payment_method->type_obj()->get_gateway(); | |
| 186 | + // and the gateway uses a separate request to process the IPN | |
| 187 | + if ($gateway instanceof EE_Offsite_Gateway | |
| 188 | + && $gateway->handle_IPN_in_this_request(\EE_Registry::instance()->REQ->params(), true) | |
| 189 | +				) { | |
| 190 | + // IPN request will handle triggering notifications | |
| 191 | + $deliver_notifications = false; | |
| 192 | + // no really... don't send any notices in this request | |
| 193 | +					remove_all_filters('FHEE__EED_Messages___maybe_registration__deliver_notifications'); | |
| 194 | + add_filter( | |
| 195 | + 'FHEE__EED_Messages___maybe_registration__deliver_notifications', | |
| 196 | + '__return_false', | |
| 197 | + 15 | |
| 198 | + ); | |
| 199 | + } | |
| 200 | + } | |
| 201 | +			if ($deliver_notifications) { | |
| 202 | + // send out notifications | |
| 203 | +				add_filter('FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_true', 10); | |
| 204 | + } | |
| 205 | + } | |
| 206 | + } | |
| 207 | + | |
| 208 | + | |
| 209 | + /** | |
| 210 | + * check if transaction has a primary registrant and that it has a related Attendee object | |
| 211 | + * | |
| 212 | + * @return boolean | |
| 213 | + * @throws \EE_Error | |
| 214 | + */ | |
| 215 | + protected function _validate_primary_registrant() | |
| 216 | +	{ | |
| 217 | +		if (! $this->checkout->transaction_has_primary_registrant()) { | |
| 218 | + EE_Error::add_error( | |
| 219 | +				__('A valid Primary Registration for this Transaction could not be found.', 'event_espresso'), | |
| 220 | + __FILE__, | |
| 221 | + __FUNCTION__, | |
| 222 | + __LINE__ | |
| 223 | + ); | |
| 224 | + $this->checkout->redirect = false; | |
| 225 | + $this->checkout->continue_reg = false; | |
| 226 | + return false; | |
| 227 | + } | |
| 228 | + // setup URL for redirect | |
| 229 | + $this->checkout->redirect_url = add_query_arg( | |
| 230 | +			array('e_reg_url_link' => $this->checkout->transaction->primary_registration()->reg_url_link()), | |
| 231 | + $this->checkout->thank_you_page_url | |
| 232 | + ); | |
| 233 | + return true; | |
| 234 | + } | |
| 235 | + | |
| 236 | + | |
| 237 | + /** | |
| 238 | + * @return void | |
| 239 | + */ | |
| 240 | + public function update_reg_step() | |
| 241 | +	{ | |
| 242 | + EE_Error::doing_it_wrong( | |
| 243 | + __CLASS__ . '::' . __FILE__, | |
| 244 | + __( | |
| 245 | + 'Can not call update_reg_step() on the Finalize Registration reg step.', | |
| 246 | + 'event_espresso' | |
| 247 | + ), | |
| 248 | + '4.6.0' | |
| 249 | + ); | |
| 250 | + } | |
| 251 | 251 | } |