form.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543
  1. <?php namespace Laravel;
  2. class Form {
  3. /**
  4. * All of the label names that have been created.
  5. *
  6. * These names are stored so that input elements can automatically be assigned
  7. * an ID based on the corresponding label name.
  8. *
  9. * @var array
  10. */
  11. protected static $labels = array();
  12. /**
  13. * Open a HTML form.
  14. *
  15. * If PUT or DELETE is specified as the form method, a hidden input field will be generated
  16. * containing the request method. PUT and DELETE are not supported by HTML forms, so the
  17. * hidden field will allow us to "spoof" PUT and DELETE requests.
  18. *
  19. * Unless specified, the "accept-charset" attribute will be set to the application encoding.
  20. *
  21. * <code>
  22. * // Open a "POST" form to the current request URI
  23. * echo Form::open();
  24. *
  25. * // Open a "POST" form to a given URI
  26. * echo Form::open('user/profile');
  27. *
  28. * // Open a "PUT" form to a given URI
  29. * echo Form::open('user/profile', 'put');
  30. *
  31. * // Open a form that has HTML attributes
  32. * echo Form::open('user/profile', 'post', array('class' => 'profile'));
  33. * </code>
  34. *
  35. * @param string $action
  36. * @param string $method
  37. * @param array $attributes
  38. * @param bool $https
  39. * @return string
  40. */
  41. public static function open($action = null, $method = 'POST', $attributes = array(), $https = false)
  42. {
  43. $attributes['method'] = static::method($method);
  44. $attributes['action'] = static::action($action, $https);
  45. if ( ! array_key_exists('accept-charset', $attributes))
  46. {
  47. $attributes['accept-charset'] = Config::get('application.encoding');
  48. }
  49. $append = '';
  50. if ($method == 'PUT' or $method == 'DELETE')
  51. {
  52. $append = static::hidden(Request::spoofer, $method);
  53. }
  54. return '<form'.HTML::attributes($attributes).'>'.$append.PHP_EOL;
  55. }
  56. /**
  57. * Determine the appropriate request method to use for a form.
  58. *
  59. * Since PUT and DELETE requests are spoofed using POST requests, we will substitute
  60. * POST for any PUT or DELETE methods. Otherwise, the specified method will be used.
  61. *
  62. * @param string $method
  63. * @return string
  64. */
  65. protected static function method($method)
  66. {
  67. return strtoupper(($method == 'PUT' or $method == 'DELETE') ? 'POST' : $method);
  68. }
  69. /**
  70. * Determine the appropriate action parameter to use for a form.
  71. *
  72. * If no action is specified, the current request URI will be used.
  73. *
  74. * @param string $action
  75. * @param bool $https
  76. * @return string
  77. */
  78. protected static function action($action, $https)
  79. {
  80. return HTML::entities(URL::to(((is_null($action)) ? Request::uri() : $action), $https));
  81. }
  82. /**
  83. * Open a HTML form with a HTTPS action URI.
  84. *
  85. * @param string $action
  86. * @param string $method
  87. * @param array $attributes
  88. * @return string
  89. */
  90. public static function open_secure($action = null, $method = 'POST', $attributes = array())
  91. {
  92. return static::open($action, $method, $attributes, true);
  93. }
  94. /**
  95. * Open a HTML form that accepts file uploads.
  96. *
  97. * @param string $action
  98. * @param string $method
  99. * @param array $attributes
  100. * @param bool $https
  101. * @return string
  102. */
  103. public static function open_for_files($action = null, $method = 'POST', $attributes = array(), $https = false)
  104. {
  105. $attributes['enctype'] = 'multipart/form-data';
  106. return static::open($action, $method, $attributes, $https);
  107. }
  108. /**
  109. * Open a HTML form that accepts file uploads with a HTTPS action URI.
  110. *
  111. * @param string $action
  112. * @param string $method
  113. * @param array $attributes
  114. * @return string
  115. */
  116. public static function open_secure_for_files($action = null, $method = 'POST', $attributes = array())
  117. {
  118. return static::open_for_files($action, $method, $attributes, true);
  119. }
  120. /**
  121. * Close a HTML form.
  122. *
  123. * @return string
  124. */
  125. public static function close()
  126. {
  127. return '</form>';
  128. }
  129. /**
  130. * Generate a hidden field containing the current CSRF token.
  131. *
  132. * @return string
  133. */
  134. public static function token()
  135. {
  136. $token = IoC::core('session')->token();
  137. return static::input('hidden', 'csrf_token', $token);
  138. }
  139. /**
  140. * Create a HTML label element.
  141. *
  142. * <code>
  143. * // Create a label for the "email" input element
  144. * echo Form::label('email', 'E-Mail Address');
  145. * </code>
  146. *
  147. * @param string $name
  148. * @param string $value
  149. * @param array $attributes
  150. * @return string
  151. */
  152. public static function label($name, $value, $attributes = array())
  153. {
  154. static::$labels[] = $name;
  155. $attributes = HTML::attributes($attributes);
  156. $value = HTML::entities($value);
  157. return '<label for="'.$name.'"'.$attributes.'>'.$value.'</label>'.PHP_EOL;
  158. }
  159. /**
  160. * Create a HTML input element.
  161. *
  162. * If an ID attribute is not specified and a label has been generated matching the input
  163. * element name, the label name will be used as the element ID.
  164. *
  165. * <code>
  166. * // Create a "text" input element named "email"
  167. * echo Form::input('text', 'email');
  168. *
  169. * // Create an input element with a specified default value
  170. * echo Form::input('text', 'email', 'example@gmail.com');
  171. * </code>
  172. *
  173. * @param string $name
  174. * @param mixed $value
  175. * @param array $attributes
  176. * @return string
  177. */
  178. public static function input($type, $name, $value = null, $attributes = array())
  179. {
  180. $name = (isset($attributes['name'])) ? $attributes['name'] : $name;
  181. $id = static::id($name, $attributes);
  182. $attributes = array_merge($attributes, compact('type', 'name', 'value', 'id'));
  183. return '<input'.HTML::attributes($attributes).'>'.PHP_EOL;
  184. }
  185. /**
  186. * Create a HTML text input element.
  187. *
  188. * @param string $name
  189. * @param string $value
  190. * @param array $attributes
  191. * @return string
  192. */
  193. public static function text($name, $value = null, $attributes = array())
  194. {
  195. return static::input('text', $name, $value, $attributes);
  196. }
  197. /**
  198. * Create a HTML password input element.
  199. *
  200. * @param string $name
  201. * @param array $attributes
  202. * @return string
  203. */
  204. public static function password($name, $attributes = array())
  205. {
  206. return static::input('password', $name, null, $attributes);
  207. }
  208. /**
  209. * Create a HTML hidden input element.
  210. *
  211. * @param string $name
  212. * @param string $value
  213. * @param array $attributes
  214. * @return string
  215. */
  216. public static function hidden($name, $value = null, $attributes = array())
  217. {
  218. return static::input('hidden', $name, $value, $attributes);
  219. }
  220. /**
  221. * Create a HTML search input element.
  222. *
  223. * @param string $name
  224. * @param string $value
  225. * @param array $attributes
  226. * @return string
  227. */
  228. public static function search($name, $value = null, $attributes = array())
  229. {
  230. return static::input('search', $name, $value, $attributes);
  231. }
  232. /**
  233. * Create a HTML email input element.
  234. *
  235. * @param string $name
  236. * @param string $value
  237. * @param array $attributes
  238. * @return string
  239. */
  240. public static function email($name, $value = null, $attributes = array())
  241. {
  242. return static::input('email', $name, $value, $attributes);
  243. }
  244. /**
  245. * Create a HTML telephone input element.
  246. *
  247. * @param string $name
  248. * @param string $value
  249. * @param array $attributes
  250. * @return string
  251. */
  252. public static function telephone($name, $value = null, $attributes = array())
  253. {
  254. return static::input('tel', $name, $value, $attributes);
  255. }
  256. /**
  257. * Create a HTML URL input element.
  258. *
  259. * @param string $name
  260. * @param string $value
  261. * @param array $attributes
  262. * @return string
  263. */
  264. public static function url($name, $value = null, $attributes = array())
  265. {
  266. return static::input('url', $name, $value, $attributes);
  267. }
  268. /**
  269. * Create a HTML number input element.
  270. *
  271. * @param string $name
  272. * @param string $value
  273. * @param array $attributes
  274. * @return string
  275. */
  276. public static function number($name, $value = null, $attributes = array())
  277. {
  278. return static::input('number', $name, $value, $attributes);
  279. }
  280. /**
  281. * Create a HTML file input element.
  282. *
  283. * @param string $name
  284. * @param array $attributes
  285. * @return string
  286. */
  287. public static function file($name, $attributes = array())
  288. {
  289. return static::input('file', $name, null, $attributes);
  290. }
  291. /**
  292. * Create a HTML textarea element.
  293. *
  294. * @param string $name
  295. * @param string $value
  296. * @param array $attributes
  297. * @return string
  298. */
  299. public static function textarea($name, $value = '', $attributes = array())
  300. {
  301. $attributes['name'] = $name;
  302. $attributes['id'] = static::id($name, $attributes);
  303. if ( ! isset($attributes['rows'])) $attributes['rows'] = 10;
  304. if ( ! isset($attributes['cols'])) $attributes['cols'] = 50;
  305. return '<textarea'.HTML::attributes($attributes).'>'.HTML::entities($value).'</textarea>'.PHP_EOL;
  306. }
  307. /**
  308. * Create a HTML select element.
  309. *
  310. * <code>
  311. * // Create a HTML select element filled with options
  312. * echo Form::select('sizes', array('S' => 'Small', 'L' => 'Large'));
  313. *
  314. * // Create a select element with a default selected value
  315. * echo Form::select('sizes', array('S' => 'Small', 'L' => 'Large'), 'L');
  316. * </code>
  317. *
  318. * @param string $name
  319. * @param array $options
  320. * @param string $selected
  321. * @param array $attributes
  322. * @return string
  323. */
  324. public static function select($name, $options = array(), $selected = null, $attributes = array())
  325. {
  326. $attributes['id'] = static::id($name, $attributes);
  327. $attributes['name'] = $name;
  328. $html = array();
  329. foreach ($options as $value => $display)
  330. {
  331. $html[] = static::option($value, $display, $selected);
  332. }
  333. return '<select'.HTML::attributes($attributes).'>'.implode('', $html).'</select>'.PHP_EOL;
  334. }
  335. /**
  336. * Create a HTML select element option.
  337. *
  338. * @param string $value
  339. * @param string $display
  340. * @return string $selected
  341. * @return string
  342. */
  343. protected static function option($value, $display, $selected)
  344. {
  345. $selected = ($value == $selected) ? 'selected' : null;
  346. $attributes = array('value' => HTML::entities($value), 'selected' => $selected);
  347. return '<option'.HTML::attributes($attributes).'>'.HTML::entities($display).'</option>';
  348. }
  349. /**
  350. * Create a HTML checkbox input element.
  351. *
  352. * <code>
  353. * // Create a checkbox element
  354. * echo Form::checkbox('terms', 'yes');
  355. *
  356. * // Create a checkbox that is selected by default
  357. * echo Form::checkbox('terms', 'yes', true);
  358. * </code>
  359. *
  360. * @param string $name
  361. * @param string $value
  362. * @param bool $checked
  363. * @param array $attributes
  364. * @return string
  365. */
  366. public static function checkbox($name, $value = 1, $checked = false, $attributes = array())
  367. {
  368. return static::checkable('checkbox', $name, $value, $checked, $attributes);
  369. }
  370. /**
  371. * Create a HTML radio button input element.
  372. *
  373. * <code>
  374. * // Create a radio button element
  375. * echo Form::radio('drinks', 'Milk');
  376. *
  377. * // Create a radio button that is selected by default
  378. * echo Form::radio('drinks', 'Milk', true);
  379. * </code>
  380. *
  381. * @param string $name
  382. * @param string $value
  383. * @param bool $checked
  384. * @param array $attributes
  385. * @return string
  386. */
  387. public static function radio($name, $value = null, $checked = false, $attributes = array())
  388. {
  389. if (is_null($value)) $value = $name;
  390. return static::checkable('radio', $name, $value, $checked, $attributes);
  391. }
  392. /**
  393. * Create a checkable input element.
  394. *
  395. * @param string $type
  396. * @param string $name
  397. * @param string $value
  398. * @param bool $checked
  399. * @param array $attributes
  400. * @return string
  401. */
  402. protected static function checkable($type, $name, $value, $checked, $attributes)
  403. {
  404. if ($checked) $attributes['checked'] = 'checked';
  405. $attributes['id'] = static::id($name, $attributes);
  406. return static::input($type, $name, $value, $attributes);
  407. }
  408. /**
  409. * Create a HTML submit input element.
  410. *
  411. * @param string $value
  412. * @param array $attributes
  413. * @return string
  414. */
  415. public static function submit($value, $attributes = array())
  416. {
  417. return static::input('submit', null, $value, $attributes);
  418. }
  419. /**
  420. * Create a HTML reset input element.
  421. *
  422. * @param string $value
  423. * @param array $attributes
  424. * @return string
  425. */
  426. public static function reset($value, $attributes = array())
  427. {
  428. return static::input('reset', null, $value, $attributes);
  429. }
  430. /**
  431. * Create a HTML image input element.
  432. *
  433. * The URL::to_asset method will be called on the given URL.
  434. *
  435. * <code>
  436. * // Create an image input element
  437. * echo Form::image('img/submit.png');
  438. * </code>
  439. *
  440. * @param string $url
  441. * @param array $attributes
  442. * @return string
  443. */
  444. public static function image($url, $name = null, $attributes = array())
  445. {
  446. $attributes['src'] = URL::to_asset($url);
  447. return static::input('image', $name, null, $attributes);
  448. }
  449. /**
  450. * Create a HTML button element.
  451. *
  452. * @param string $name
  453. * @param string $value
  454. * @param array $attributes
  455. * @return string
  456. */
  457. public static function button($value, $attributes = array())
  458. {
  459. return '<button'.HTML::attributes($attributes).'>'.HTML::entities($value).'</button>'.PHP_EOL;
  460. }
  461. /**
  462. * Determine the ID attribute for a form element.
  463. *
  464. * An explicitly specified ID in the attributes takes first precedence, then
  465. * the label names will be checked for a label matching the element name.
  466. *
  467. * @param string $name
  468. * @param array $attributes
  469. * @return mixed
  470. */
  471. protected static function id($name, $attributes)
  472. {
  473. if (array_key_exists('id', $attributes))
  474. {
  475. return $attributes['id'];
  476. }
  477. if (in_array($name, static::$labels))
  478. {
  479. return $name;
  480. }
  481. }
  482. }