Changeset 1153:1e48950b05af for inc/admin
- Timestamp:
- 04/02/13 13:15:32 (12 years ago)
- Branch:
- twig
- Parents:
- 1152:fbd922f6ed09 (diff), 1138:11db80678704 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent. - Location:
- inc/admin
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
inc/admin/class.dc.admincontext.php
r1128 r1153 12 12 if (!defined('DC_RC_PATH')) { return; } 13 13 14 15 class dcProxy { 16 protected $object; 17 protected $attributes; 18 protected $methods; 19 protected $default; 20 protected $denyfirst; 21 22 /** 23 * valuesToArray - converts a list of strings to an array having these strings as keys. 24 * 25 * @param mixed $val the list to convert. 26 * @access protected 27 * @return mixed Value The resulting array 28 */ 29 protected function valuesToArray($val) { 30 $arr = array(); 31 foreach ($val as $k) { 32 $arr[$k]=true; 33 } 34 return $arr; 35 } 36 37 protected function isAllowed ($name,$list) { 38 if ($this->denyfirst) { 39 return isset($list[$name]); 40 } else { 41 return !isset($list[$name]); 42 } 43 } 44 45 public function __construct($object,$rights,$default='',$denyfirst=true) { 46 $this->object = $object; 47 $this->attributes = array(); 48 $this->methods = array(); 49 $this->denyfirst = $denyfirst; 50 if (isset($rights['attr'])) { 51 $this->attributes = $this->valuesToArray($rights['attr']); 52 } 53 if (isset($rights['methods'])) { 54 $this->methods = $this->valuesToArray($rights['methods']); 55 } 56 } 57 58 public function __get($name) { 59 if ($this->isAllowed($name,$this->attributes)) { 60 return $this->object->$name; 61 } else { 62 return $this->default; 63 } 64 } 65 66 public function __call($name,$args) { 67 if ($this->isAllowed($name,$this->methods) && 68 is_callable(array($this->object,$name))) { 69 return call_user_func_array(array($this->object,$name),$args); 70 } else { 71 return $this->default; 72 } 73 74 } 75 } 76 77 class dcArrayProxy extends dcProxy implements ArrayAccess { 78 public function offsetExists ($offset) { 79 return (isset($this->value[$offset])); 80 } 81 public function offsetGet ($offset) { 82 return new ProxyValue($this->object[$offset],$this->rights); 83 } 84 public function offsetSet ($offset ,$value ) { 85 // Do nothing, we are read only 86 } 87 public function offsetUnset ($offset) { 88 // Do nothing, we are read only 89 } 90 } 91 92 14 93 /** 15 *@ingroup DC_CORE16 * @brief Template extension for admin context. 17 * 18 *This extends template environment with tools required in admin context.19 20 class dcAdminContext extends dcContext94 @ingroup DC_CORE 95 @brief Template extension for admin context 96 97 This extends template environment with tools required in admin context. 98 */ 99 class dcAdminContext extends Twig_Extension 21 100 { 101 protected $core; 102 protected $globals = array(); 103 protected $protected_globals = array(); 104 protected $memory = array(); 105 22 106 public function __construct($core) 23 107 { 24 parent::__construct($core); 25 26 $this->protected_globals = array_merge($this->protected_globals,array( 108 $this->core = $core; 109 110 # Globals editable via context 111 $this->globals = array(); 112 113 # Globals not editable via context 114 $this->protected_globals = array( 115 'messages' => array( 116 'static' => array(), 117 'lists' => array(), 118 'alert' => '', 119 'errors' => array() 120 ), 121 27 122 'page_title' => array(), 28 123 'page_global' => false, 29 124 30 125 'admin_url' => DC_ADMIN_URL, 31 'theme_url' => DC_ADMIN_URL.'index.php?tf=',126 'theme_url' => '', 32 127 'plugin_url' => DC_ADMIN_URL.'index.php?pf=', 33 )); 34 } 35 36 /** 37 * Returns a list of global variables to add to the existing list. 38 * 39 * This merges overloaded variables with defined variables. 40 * 41 * @return array An array of global variables 42 */ 128 129 'version' => DC_VERSION, 130 'vendor_name' => DC_VENDOR_NAME, 131 132 'safe_mode' => isset($_SESSION['sess_safe_mode']) && $_SESSION['sess_safe_mode'], 133 'debug_mode' => DC_DEBUG 134 ); 135 } 136 137 /** 138 Prevent call crash from template on method that return this class 139 */ 140 public function __toString() 141 { 142 return ''; 143 } 144 145 /** 146 Test a global variable 147 148 @param string $name Name of the variable to test 149 @return boolean 150 */ 151 public function __isset($name) 152 { 153 return isset($this->globals[$name]); 154 } 155 156 /** 157 Add a global variable 158 159 @param string $name Name of the variable 160 @param mixed $value Value of the variable 161 */ 162 public function __set($name,$value) 163 { 164 /* 165 # Overload protect 166 if ($value === null && isset($this->globals[$name])) { 167 unset($this->globals[$name]); 168 } 169 elseif (!isset($this->globals[$name])) { 170 throw new Exception('Modification of overloaded globals has no effect'); 171 } 172 //*/ 173 $this->globals[$name] = $value; 174 } 175 176 /** 177 Get a global variable 178 179 @param string $name Name of the variable 180 @return mixed Value of the variable or null 181 */ 182 public function __get($name) 183 { 184 return isset($this->globals[$name]) ? $this->globals[$name] : null; 185 } 186 187 /** 188 Returns a list of filters to add to the existing list. 189 190 @return array An array of filters 191 */ 192 public function getFilters() 193 { 194 return array( 195 'trans' => new Twig_Filter_Function("__", array('is_safe' => array('html'))) 196 ); 197 } 198 199 /** 200 Returns a list of functions to add to the existing list. 201 202 @return array An array of functions 203 */ 204 public function getFunctions() 205 { 206 return array( 207 '__' => new Twig_Function_Function("__", array('is_safe' => array('html'))), 208 'debug_info' => new Twig_Function_Method($this, 'getDebugInfo', array('is_safe' => array('html'))), 209 'memorize' => new Twig_Function_Method($this, 'setMemory', array('is_safe' => array('html'))), 210 'memorized' => new Twig_Function_Method($this, 'getMemory', array('is_safe' => array('html'))) 211 ); 212 } 213 214 /** 215 Returns a list of global variables to add to the existing list. 216 217 This merges overloaded variables with defined variables. 218 219 @return array An array of global variables 220 */ 43 221 public function getGlobals() 44 222 { … … 65 243 66 244 /** 67 * Fill the page title. 68 * 69 * $title can be: 70 * - a string for page title part or 71 * - TRUE to add blog name at the begining of title or 72 * - NULL to empty/reset title 73 * 74 * @param mixed $title A title part 75 * @param boolean $url Link of the title part 76 * @return object self 77 */ 245 Returns the name of the extension. 246 247 @return string The extension name 248 */ 249 public function getName() 250 { 251 return 'AdminContext'; 252 } 253 254 255 /** 256 Add an informational message 257 258 @param string $message A message 259 @return object self 260 */ 261 public function setSafeMode($safe_mode) 262 { 263 $this->protected_globals['safe_mode'] = (boolean) $safe_mode; 264 return $this; 265 } 266 267 /** 268 Add an informational message 269 270 @param string $message A message 271 @return object self 272 */ 273 public function addMessageStatic($message) 274 { 275 $this->protected_globals['messages']['static'][] = $message; 276 return $this; 277 } 278 279 /** 280 Add a list of informational messages 281 282 @param string $message A title 283 @param array $message A list of messages 284 @return object self 285 */ 286 public function addMessagesList($title,$messages) 287 { 288 $this->protected_globals['messages']['lists'][$title] = $messages; 289 return $this; 290 } 291 292 /** 293 Set an important message 294 295 @param string $message A message 296 @return object self 297 */ 298 public function setAlert($message) 299 { 300 $this->protected_globals['messages']['alert'] = $message; 301 return $this; 302 } 303 304 /** 305 Add an error message 306 307 @param string Error message 308 @return object self 309 */ 310 public function addError($error) 311 { 312 $this->protected_globals['messages']['errors'][] = $error; 313 return $this; 314 } 315 316 /** 317 Check if there is an error message 318 319 @return boolean 320 */ 321 public function hasError() 322 { 323 return !empty($this->protected_globals['messages']['errors']); 324 } 325 326 /** 327 Fill the page title 328 329 $title can be: 330 a string for page title part or 331 TRUE to add blog name at the begining of title or 332 NULL to empty/reset title 333 334 @param mixed $title A title part 335 @param boolean $url Link of the title part 336 @return object self 337 */ 78 338 public function fillPageTitle($title,$url='') 79 339 { … … 95 355 96 356 /** 97 *Check if a page title is set98 357 Check if a page title is set 358 */ 99 359 public function hasPageTitle() 100 360 { … … 103 363 104 364 /** 105 *Get list of blogs106 365 Get list of blogs 366 */ 107 367 protected function getBlogs() 108 368 { … … 116 376 while ($rs_blogs->fetch()) { 117 377 $blogs[$rs_blogs->blog_id] = $rs_blogs->blog_name.' - '.$rs_blogs->blog_url; 118 $this->protected_globals['blogs'][$rs_blogs->blog_id] = array( 119 'id' => $rs_blogs->blog_id, 120 'name' => $rs_blogs->blog_name, 121 'desc' => $rs_blogs->blog_desc, 122 'url' => $rs_blogs->blog_url, 123 'creadt' => $rs_blogs->blog_creadt, 124 'upddt' => $rs_blogs->blog_upddt 125 ); 378 $this->protected_globals['blogs'][$rs_blogs->blog_id] = 379 new dcArrayProxy($rs_blogs, array( 380 'blog_id','blog_name','blog_desc','blog_url','blog_creadt','blog_upddt')); 126 381 } 127 382 } … … 140 395 141 396 /** 142 *Get current blog information143 397 Get current blog information 398 */ 144 399 protected function getCurrentBlog() 145 400 { 146 401 $this->protected_globals['current_blog'] = $this->core->auth->blog_count ? 147 array( 148 'id' => $this->core->blog->id, 149 'name' => $this->core->blog->name, 150 'desc' => $this->core->blog->desc, 151 'url' => $this->core->blog->url, 152 'host' => $this->core->blog->host, 153 'creadt' => $this->core->blog->creadt, 154 'upddt' => $this->core->blog->upddt 155 ) : array( 402 new dcProxy($this->core->blog,array( 403 'id','name','desc','url','host','creadt','upddt' 404 )) : array( 156 405 'id' => '', 157 406 'name' => '', … … 165 414 166 415 /** 167 *Get current user information168 416 Get current user information 417 */ 169 418 protected function getCurrentUser() 170 419 { … … 214 463 215 464 /** 216 *Get sidebar menus217 465 Get sidebar menus 466 */ 218 467 protected function getMenus() 219 468 { … … 235 484 } 236 485 } 486 487 /** 488 Get an array of debug/dev infos 489 */ 490 public function getDebugInfo() 491 { 492 if (!DC_DEBUG) { 493 return array(); 494 } 495 496 $di = array( 497 'global_vars' => implode(', ',array_keys($GLOBALS)), 498 'memory' => array( 499 'usage' => memory_get_usage(), 500 'size' => files::size(memory_get_usage()) 501 ), 502 'xdebug' => array() 503 ); 504 505 if (function_exists('xdebug_get_profiler_filename')) { 506 507 $url = http::getSelfURI(); 508 $url .= strpos($url,'?') === false ? '?' : '&'; 509 $url .= 'XDEBUG_PROFILE'; 510 511 $di['xdebug'] = array( 512 'elapse_time' => xdebug_time_index(), 513 'profiler_file' => xdebug_get_profiler_filename(), 514 'profiler_url' => $url 515 ); 516 517 /* xdebug configuration: 518 zend_extension = /.../xdebug.so 519 xdebug.auto_trace = On 520 xdebug.trace_format = 0 521 xdebug.trace_options = 1 522 xdebug.show_mem_delta = On 523 xdebug.profiler_enable = 0 524 xdebug.profiler_enable_trigger = 1 525 xdebug.profiler_output_dir = /tmp 526 xdebug.profiler_append = 0 527 xdebug.profiler_output_name = timestamp 528 */ 529 } 530 531 return $di; 532 } 533 534 /** 535 Add a value in a namespace memory 536 537 This help keep variable when recalling Twig macros 538 539 @param string $ns A namespace 540 @param string $str A value to memorize in this namespace 541 */ 542 public function setMemory($ns,$str) 543 { 544 if (!array_key_exists($ns,$this->memory) || !in_array($str,$this->memory[$ns])) { 545 $this->memory[$ns][] = $str; 546 } 547 } 548 549 /** 550 Check if a value is previously memorized in a namespace 551 552 @param string $ns A namespace 553 @param string $str A value to search in this namespace 554 @return array True if exists 555 */ 556 public function getMemory($ns,$str) 557 { 558 return array_key_exists($ns,$this->memory) && in_array($str,$this->memory[$ns]); 559 } 237 560 } 238 561 ?> -
inc/admin/class.dc.form.php
r1137 r1153 13 13 14 14 /** 15 * Template form node 16 */ 15 * dcFormNode 16 * 17 * @uses Twig_Node 18 * 19 */ 17 20 class dcFormNode extends Twig_Node 18 21 { … … 30 33 { 31 34 $compiler 32 ->addDebugInfo($this) 33 ->write("\$context['dc_form']->beginForm('". 34 $this->getAttribute('name')."');\n") 35 ->addDebugInfo($this); 36 $compiler 37 ->write("\$context['dc_form']->beginForm(") 38 ->subcompile($this->getAttribute('name')) 39 ->write(");\n"); 40 $compiler 35 41 ->subcompile($this->getNode('body')) 36 42 ->write("\$context['dc_form']->renderHiddenWidgets();\n") … … 49 55 $lineno = $token->getLine(); 50 56 $stream = $this->parser->getStream(); 51 $name = $ stream->expect(Twig_Token::NAME_TYPE)->getValue();57 $name = $this->parser->getExpressionParser()->parseExpression(); 52 58 $stream->expect(Twig_Token::BLOCK_END_TYPE); 53 59 $body = $this->parser->subparse(array($this,'decideBlockEnd'),true); … … 77 83 protected $core; 78 84 protected $twig; 79 protected $blocks;80 85 protected $forms; 81 86 protected $currentForm; 87 protected $blocks; 82 88 83 89 public function __construct($core) 84 90 { 85 91 $this->core = $core; 86 $this->tpl = 'form_layout.html.twig';92 $this->tpl = array('@forms/form_layout.html.twig'); 87 93 $this->forms = array(); 94 $this->blocks = array(); 88 95 $this->currentForm = null; 89 96 } … … 92 99 { 93 100 $this->twig = $environment; 94 $this->template = $this->twig->loadTemplate($this->tpl); 95 $this->blocks = $this->template->getBlocks(); 96 } 97 101 $this->twig->getLoader()->addPath(dirname(__FILE__).'/default-templates/forms','forms'); 102 foreach ($this->tpl as $tpl) { 103 $this->template = $this->twig->loadTemplate($tpl); 104 $this->blocks = array_merge($this->blocks,$this->template->getBlocks()); 105 } 106 } 107 108 public function addTemplate($tpl) { 109 $this->tpl[]=$tpl; 110 if (isset($this->twig)) { 111 $this->template = $this->twig->loadTemplate($tpl); 112 $this->blocks = array_merge($this->blocks,$this->template->getBlocks()); 113 } 114 } 115 98 116 public function getGlobals() 99 117 { … … 104 122 { 105 123 return array( 106 'form_field' => new Twig_Function_Method(107 $this,108 'renderWidget',124 new Twig_SimpleFunction( 125 'widget', 126 array($this,'renderWidget'), 109 127 array('is_safe' => array('html')) 110 128 ), 111 '_form_is_choice_group' => new Twig_Function_Method(112 $this,113 'isChoiceGroup',129 new Twig_SimpleFunction( 130 'haswidget', 131 array($this,'hasWidget'), 114 132 array('is_safe' => array('html')) 115 133 ), 116 '_form_is_choice_selected' => new Twig_Function_Method( 117 $this, 118 'isChoiceSelected', 134 new Twig_SimpleFunction( 135 'form_field', 136 array($this,'renderField'), 137 array('is_safe' => array('html')) 138 ), 139 new Twig_SimpleFunction( 140 '_form_is_choice_group', 141 array($this,'isChoiceGroup'), 142 array('is_safe' => array('html')) 143 ), 144 new Twig_SimpleFunction( 145 '_form_is_choice_selected', 146 array($this,'isChoiceSelected'), 119 147 array('is_safe' => array('html')) 120 148 ) … … 137 165 } 138 166 139 public function renderWidget($name,$attributes=array()) 167 public function hasWidget($name) { 168 return isset($this->blocks[$name]); 169 } 170 public function renderWidget($name,$attr) { 171 if (!isset($this->blocks[$name])) 172 return ''; 173 echo $this->template->renderBlock( 174 $name, 175 $attr, 176 $this->blocks 177 ); 178 } 179 180 public function getCurrentForm() { 181 return $this->currentForm; 182 } 183 184 public function renderField($name,$attributes=array(),$extra=array()) 140 185 { 141 186 $field = $this->currentForm->$name; 142 187 if ($field) { 143 echo $this->template->renderBlock( 188 $attr = $field->getAttributes($attributes); 189 if (isset($attr['attr'])) { 190 $attr['attr'] = array_merge($attr['attr'],$attributes); 191 } else { 192 $attr['attr'] = $attributes; 193 } 194 $this->renderWidget( 144 195 $field->getWidgetBlock(), 145 196 array_merge( 146 $field->getAttributes(), 147 array('attr' => $attributes) 148 ), 149 $this->blocks 197 $attr, 198 $extra 199 ) 150 200 ); 151 201 } … … 155 205 { 156 206 foreach ($this->currentForm->getHiddenFields() as $h) { 157 $this->render Widget($h->getName());207 $this->renderField($h->getName()); 158 208 } 159 209 } … … 197 247 198 248 /** 199 * Template form 200 */ 249 * dcForm - Template form 250 * 251 */ 201 252 class dcForm 202 253 { … … 211 262 protected $errors; 212 263 213 private function addNonce() 264 public function addTemplate($t) { 265 $this->core->tpl->getExtension('dc_form')->addTemplate($t); 266 } 267 268 /** 269 * addNonce -- adds dc nonce to form fields 270 * 271 * @access protected 272 * 273 * @return nothing 274 */ 275 protected function addNonce() 214 276 { 215 277 $this->addField( … … 219 281 } 220 282 221 protected function getNID($nid) 283 284 /** 285 * Defines Name & ID from field 286 * 287 * @param mixed $nid either an array (name, id) or a string (name only, id will be set to null). 288 * 289 * @access protected 290 * 291 * @return nothing. 292 */ 293 protected function setNID($nid) 222 294 { 223 295 if (is_array($nid)) { … … 231 303 } 232 304 305 public function getContext() { 306 return array(); 307 } 308 309 /** 310 * Class constructor 311 * 312 * @param mixed $core dotclear core 313 * @param mixed $name form name 314 * @param mixed $action form action 315 * @param string $method form method ('GET' or 'POST') 316 * 317 * @access public 318 * 319 * @return mixed Value. 320 */ 233 321 public function __construct($core,$name,$action,$method='POST') 234 322 { 235 323 $this->core = $core; 236 $this-> getNID($name);324 $this->setNID($name); 237 325 $this->method = $method; 238 326 $this->action = $action; … … 247 335 } 248 336 337 338 /** 339 * Returns form name 340 * 341 * @access public 342 * 343 * @return mixed Value. 344 */ 249 345 public function getName() 250 346 { … … 270 366 } 271 367 368 public function removeField(dcField $f) { 369 $n = $f->getName(); 370 if (isset($this->fields[$n])){ 371 unset($this->fields[$n]); 372 } 373 374 } 375 public function renameField($field,$newname) { 376 $oldname = $field->getName(); 377 if (isset($this->fields[$oldname])) { 378 unset($this->fields[$oldname]); 379 $field->setName($newname); 380 $this->fields[$newname] = $field; 381 } 382 } 272 383 public function begin() 273 384 { … … 292 403 public function __get($name) 293 404 { 294 return isset($this->fields[$name]) ? 405 return isset($this->fields[$name]) ? 295 406 $this->fields[$name] : null; 296 407 } 297 408 298 409 public function __set($name,$value) 299 410 { 300 411 if (isset($this->fields[$name])) { 301 $this->fields[$name]->set Attribute('value',$value);302 } 303 } 304 412 $this->fields[$name]->setValue($value); 413 } 414 } 415 305 416 public function isSubmitted() 306 417 { 307 418 $from = $this->method == 'POST' ? $_POST : $_GET; 308 echo "form fields :\n"; 309 } 310 311 public function setup() 312 { 419 } 420 421 protected function setupFields() { 313 422 $from = $this->method == 'POST' ? $_POST : $_GET; 314 423 foreach ($this->fields as $f) { 315 424 $f->setup($from); 316 425 } 426 } 427 428 protected function handleActions($submitted) { 429 foreach ($submitted as $f) { 430 $action = $f->getAction(); 431 if ($action != NULL) { 432 $ret = call_user_func($action,$this); 433 } 434 } 435 } 436 437 protected function getSubmittedFields() { 438 $s = array(); 317 439 foreach ($this->submitfields as $f) { 318 440 if ($f->isDefined()) { 319 $ret = call_user_func($f->getAction(),$this); 320 return; 441 $s[$f->getName()] = $f; 321 442 } 322 443 } 323 } 324 444 return $s; 445 } 446 447 public function setup() 448 { 449 $this->setupFields(); 450 $submitted = $this->getSubmittedFields(); 451 $this->handleActions($submitted); 452 } 453 325 454 public function check() 326 455 { … … 344 473 * Template form field 345 474 */ 346 abstract class dcField 347 { 348 protected $ attributes;475 abstract class dcField implements Countable 476 { 477 protected $options; 349 478 protected $name; 350 protected $value ;479 protected $values; 351 480 protected $id; 481 protected $multiple; 352 482 protected $defined; 353 483 354 protected function getNID($nid)484 protected function setNID($nid) 355 485 { 356 486 if (is_array($nid)) { … … 363 493 } 364 494 365 public function __construct($name,$value ,$attributes=array())366 { 367 $this-> getNID($name);368 $this-> attributes = $attributes;369 $this->value = $value;370 $this->attributes['name'] = $this->name;371 $this->attributes['id'] = $this->id;372 $this-> attributes['value'] = $this->value;495 public function __construct($name,$values,$options=array()) 496 { 497 $this->setNID($name); 498 $this->options = new ArrayObject($options); 499 if ($values === NULL){ 500 $values = array(); 501 } 502 $this->setValues($values); 373 503 $this->defined = false; 374 } 375 504 $this->multiple = (isset($options['multiple']) && $options['multiple']); 505 506 } 507 508 public function setValue($value,$offset=0) { 509 $this->values[$offset] = $value; 510 } 511 512 public function setValues($values) { 513 if (is_array($values)) { 514 $this->values = $values; 515 } elseif ($values !== NULL) { 516 $this->values = array($values); 517 } 518 519 } 520 521 public function getValues() { 522 return $this->values; 523 } 524 525 public function getValue($offset=0) { 526 if (isset($this->values[$offset])) { 527 return $this->values[$offset]; 528 } 529 } 530 531 public function addValue($value) { 532 $this->values[] = $value; 533 } 534 public function delValue($offset) { 535 if (isset($this->values[$offset])) { 536 array_splice($this->values,$offset,1); 537 } 538 } 539 540 public function count() { 541 return count($this->values); 542 } 543 376 544 public function __toString() 377 545 { 378 return (string) $this->value;546 return join(',',$this->values); 379 547 } 380 548 381 549 abstract public function getWidgetBlock(); 382 550 383 public function setAttribute($name,$value) 384 { 385 $this->attributes[$name] = $value; 386 } 387 388 public function getAttributes() 389 { 390 return $this->attributes; 391 } 392 551 public function getAttributes($options) 552 { 553 $offset = isset($options['offset']) ? $options['offset'] : 0; 554 555 $attr = $this->options->getArrayCopy(); 556 if (isset($this->values[$offset])) { 557 $attr['value'] = $this->values[$offset]; 558 } else { 559 $attr['value'] = $this->getDefaultValue(); 560 } 561 if ($offset==0) { 562 $attr['id']=$this->id; 563 } 564 $attr['name'] = $this->name; 565 if ($this->multiple) { 566 $attr['name'] = $attr['name'].'[]'; 567 } 568 return $attr; 569 } 570 571 public function getDefaultValue() { 572 return ''; 573 } 574 393 575 public function getName() 394 576 { 395 577 return $this->name; 396 578 } 397 579 580 public function setName($name) { 581 $this->setNID($name); 582 } 583 398 584 public function check() 399 585 { 400 if (!$this->defined && $this-> attributes['defined']) {586 if (!$this->defined && $this->options['mandatory']) { 401 587 throw new InvalidFieldException(sprintf( 402 588 'Field "%s" is mandatory', … … 406 592 } 407 593 594 public function parseValues($from) { 595 if (isset($from[$this->name])) { 596 $n = $from[$this->name]; 597 if (!is_array($n)) { 598 $n = array($n); 599 } 600 return $n; 601 } 602 return array(); 603 } 604 408 605 public function setup($from) 409 606 { 410 if (isset($from[$this->id])) { 411 $this->value = $from[$this->id]; 607 $values = $this->parseValues($from); 608 if (count($values)) { 609 $this->setValues($values); 412 610 $this->defined = true; 413 611 } … … 420 618 } 421 619 620 422 621 /** 423 622 * Template form field of type "password" … … 473 672 return "field_checkbox"; 474 673 } 674 675 public function getDefaultValue() { 676 return 0; 677 } 475 678 } 476 679 … … 481 684 { 482 685 protected $action; 483 484 public function __construct($name,$value,$attributes=array()) 485 { 486 parent::__construct($name,$value,$attributes); 487 488 if (isset($attributes['action'])) { 489 $this->action = $attributes['action']; 490 } 491 } 492 686 687 public function __construct($name,$values,$options=array()) 688 { 689 parent::__construct($name,$values,$options); 690 691 if (isset($options['action'])) { 692 $this->action = $options['action']; 693 } else { 694 $this->action = NULL; 695 } 696 } 697 493 698 public function getAction() 494 699 { … … 513 718 class dcFieldCombo extends dcField 514 719 { 515 protected $options; 516 517 public function __construct($name,$value,$options,$attributes=array()) 518 { 519 $this->options = $options; 520 parent::__construct($name,$value,$attributes); 521 $this->attributes['options']=$options; 720 protected $combo; 721 722 public function __construct($name,$value,$combo,$options=array()) 723 { 724 $this->combo = $combo; 725 parent::__construct($name,$value,$options); 522 726 } 523 727 … … 527 731 } 528 732 529 } 733 public function getDefaultValue() { 734 return current($this->combo); 735 } 736 737 public function parseValues($from) { 738 $values = parent::parseValues($from); 739 if (!is_array($values)) { 740 $values = array($values); 741 } 742 foreach ($values as &$v) { 743 if (!isset($this->combo[$v])) 744 $v = $this->getDefaultValue(); 745 } 746 return $values; 747 } 748 749 public function getAttributes($options) { 750 $attr = parent::getAttributes($options); 751 $attr['options'] = $this->combo; 752 return $attr; 753 } 754 } 755 530 756 ?> -
inc/admin/default-templates/forms/form_layout.html.twig
r1152 r1153 57 57 <label for="{{name}}" class="classic"> 58 58 {% endif %} 59 <input type="checkbox" {{ block(' widget_attributes') }}{% if value is defined %} value="{{ value }}"{% endif %}{% if checked %} checked="checked"{% endif %} />59 <input type="checkbox" {{ block('field_attr') }}{% if value is defined %} value="{{ value }}"{% endif %}{% if checked %} checked="checked"{% endif %} /> 60 60 {% if label is not empty %} 61 61 {{ label }}</label>
Note: See TracChangeset
for help on using the changeset viewer.