* @license GNU General Public License, version 2 * @link http://addthis.com AddThis website */ class AddThisSharingButtonsMobileToolbarTool extends AddThisSharingButtonsToolParent { public $prettyName = 'Mobile Toolbar'; public $edition = 'basic'; public $anonymousSupport = true; public $inline = false; public $settingsSubVariableName = 'smlmo'; public $layersApiProductName = 'dock'; protected $defaultConfigs = array( 'enabled' => false, 'follow' => 'on', // off 'buttonBarTheme' => 'light', // gray or dark 'buttonBarPosition' => 'bottom', // top ); /** * Creates tool specific settings for the JavaScript variable * addthis_layers, used to bootstrap layers * * @param array $configs optional array of settings (used with widgets) * * @return array an associative array */ public function getAddThisLayers($configs = array()) { if (empty($configs)) { $configs = $this->getToolConfigs(); } $layers = array( 'follow' => $configs['follow'], 'buttonBarTheme' => $configs['buttonBarTheme'], 'buttonBarPosition' => $configs['buttonBarPosition'], ); $layers['followServices'] = AddThisFollowButtonsToolParent::formatServicesForAddThisLayers($configs['followServices']); $result = array($this->layersApiProductName => $layers); return $result; } /** * This must be public as it's used in the feature object with this tool * * This takes form input for a tool sub settings variable, manipulates * it, and returns the variables that should be saved to the database. * * @param array $input An associative array of values * input for this tools' settings * @param boolean $addDefaultConfigs Whether to populate in default * values for missing fields * * @return array A cleaned up associative array of settings specific to * this feature. */ public function sanitizeSettings($input, $addDefaultConfigs = true) { $output = array(); if (is_array($input)) { foreach ($input as $field => $value) { switch ($field) { case 'enabled': $output[$field] = (boolean)$value; break; case 'follow': if ($value === 'off' || $value === 'on') { $output[$field] = $value; } break; case 'followServices': if (is_array($value)) { foreach ($value as $service => $username) { if (!empty($username)) { $output['followServices'][$service] = sanitize_text_field($username); } } } break; case 'buttonBarTheme': if ($value === 'gray' || $value === 'dark' || $value === 'light') { $output[$field] = $value; } break; case 'buttonBarPosition': if ($value === 'top' || $value === 'bottom') { $output[$field] = $value; } break; } } } if ($addDefaultConfigs) { $output = $this->addDefaultConfigs($output); } if (empty($output['followServices'])) { $output['followServices'] = new stdClass(); } return $output; } } }