Invision Power Services, Inc. * @copyright (c) Invision Power Services, Inc. * @license https://www.invisioncommunity.com/legal/standards/ * @package Invision Community {subpackage} * @since {date} */ namespace IPS\{app}\extensions\core\ProfileSteps; /* To prevent PHP errors (extending class does not exist) revealing path */ if ( !defined( '\IPS\SUITE_UNIQUE_KEY' ) ) { header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' ); exit; } /** * Profile Completion Extension */ class _{class} { /** * Available Actions to complete steps * * @return array array( 'key' => 'lang_string' ) */ public static function actions() { return array( ... ); } /** * Available sub actions to complete steps * * @return array array( 'key' => 'lang_string' ) */ public static function subActions() { return array( ... ); } /** * Can the actions have multiple choices? * * @param string $action Action key (basic_profile, etc) * @return boolean */ public static function actionMultipleChoice( $action ) { return FALSE; } /** * Has a specific step been completed? * * @param \IPS\Member\ProfileStep $step The step to check * @param \IPS\Member|NULL $member The member to check, or NULL for currently logged in * @return bool */ public function completed( \IPS\Member\ProfileStep $step, \IPS\Member $member = NULL ) { return FALSE; } /** * Can be set as required? * * @return array * @note This is intended for items which have their own independent settings and dedicated enable pages, such as MFA and Social Login integration */ public static function canBeRequired() { return array(); } /** * Action URL * * @param string $action The action * @param \IPS\Member|NULL $member The member, or NULL for currently logged in * @return \IPS\Http\Url */ public function url( $action, \IPS\Member $member = NULL ) { return \IPS\Http\Url::internal( ... ); } /** * Post ACP Save * * @param \IPS\Member\ProfileStep $step The step * @param array $values Form Values * @return void */ public function postAcpSave( \IPS\Member\ProfileStep $step, array $values ) { } /** * Format Form Values * * @param array $values The values from the form * @param \IPS\Member $member The member * @param \IPS\Helpers\Form $form The form * @return void */ public static function formatFormValues( $values, &$member, &$form ) { } /** * Wizard Steps * * @param \IPS\Member $member Member or NULL for currently logged in member * @return array */ public static function wizard( \IPS\Member $member = NULL ) { return array( ... ); } /** * Post Delete * @param \IPS\Member\ProfileStep The step * * @return void */ public function onDelete( \IPS\Member\ProfileStep $step ) { } }