index = $index; $this->_configFile = $cf; $this->loadForm($form_name, $form); } /** * Returns type of given option * * @param string $option_name path or field name * * @return string|null one of: boolean, integer, double, string, select, array */ public function getOptionType($option_name) { $key = ltrim( /*overload*/mb_substr( $option_name, /*overload*/mb_strrpos($option_name, '/') ), '/' ); return isset($this->_fieldsTypes[$key]) ? $this->_fieldsTypes[$key] : null; } /** * Returns allowed values for select fields * * @param string $option_path Option path * * @return array */ public function getOptionValueList($option_path) { $value = $this->_configFile->getDbEntry($option_path); if ($value === null) { trigger_error("$option_path - select options not defined", E_USER_ERROR); return array(); } if (!is_array($value)) { trigger_error("$option_path - not a static value list", E_USER_ERROR); return array(); } // convert array('#', 'a', 'b') to array('a', 'b') if (isset($value[0]) && $value[0] === '#') { // remove first element ('#') array_shift($value); // $value has keys and value names, return it return $value; } // convert value list array('a', 'b') to array('a' => 'a', 'b' => 'b') $has_string_keys = false; $keys = array(); for ($i = 0, $nb = count($value); $i < $nb; $i++) { if (!isset($value[$i])) { $has_string_keys = true; break; } $keys[] = is_bool($value[$i]) ? (int)$value[$i] : $value[$i]; } if (! $has_string_keys) { $value = array_combine($keys, $value); } // $value has keys and value names, return it return $value; } /** * array_walk callback function, reads path of form fields from * array (see file comment in setup.forms.php or user_preferences.forms.inc) * * @param mixed $value Value * @param mixed $key Key * @param mixed $prefix Prefix * * @return void */ private function _readFormPathsCallback($value, $key, $prefix) { static $group_counter = 0; if (is_array($value)) { $prefix .= $key . '/'; array_walk($value, array($this, '_readFormPathsCallback'), $prefix); return; } if (!is_int($key)) { $this->default[$prefix . $key] = $value; $value = $key; } // add unique id to group ends if ($value == ':group:end') { $value .= ':' . $group_counter++; } $this->fields[] = $prefix . $value; } /** * Reads form paths to {@link $fields} * * @param array $form Form * * @return void */ protected function readFormPaths($form) { // flatten form fields' paths and save them to $fields $this->fields = array(); array_walk($form, array($this, '_readFormPathsCallback'), ''); // $this->fields is an array of the form: [0..n] => 'field path' // change numeric indexes to contain field names (last part of the path) $paths = $this->fields; $this->fields = array(); foreach ($paths as $path) { $key = ltrim( /*overload*/mb_substr($path, /*overload*/mb_strrpos($path, '/')), '/' ); $this->fields[$key] = $path; } // now $this->fields is an array of the form: 'field name' => 'field path' } /** * Reads fields' types to $this->_fieldsTypes * * @return void */ protected function readTypes() { $cf = $this->_configFile; foreach ($this->fields as $name => $path) { if (/*overload*/mb_strpos($name, ':group:') === 0) { $this->_fieldsTypes[$name] = 'group'; continue; } $v = $cf->getDbEntry($path); if ($v !== null) { $type = is_array($v) ? 'select' : $v; } else { $type = gettype($cf->getDefault($path)); } $this->_fieldsTypes[$name] = $type; } } /** * Reads form settings and prepares class to work with given subset of * config file * * @param string $form_name Form name * @param array $form Form * * @return void */ public function loadForm($form_name, $form) { $this->name = $form_name; $this->readFormPaths($form); $this->readTypes(); } } ?>