You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

862 lines
28 KiB

  1. ---
  2. layout : 'default'
  3. css : 'dropdown'
  4. title : 'Dropdown'
  5. description : 'A dropdown allows a user to select a value from a series of options'
  6. type : 'UI Module'
  7. element : 'dropdown'
  8. elementType : 'module'
  9. themes : ['Default']
  10. ---
  11. <link rel="stylesheet/less" type="text/css" href="/build/less/definitions/modules/dropdown.less" />
  12. <script src="/javascript/dropdown.js"></script>
  13. <%- @partial('header', { tabs: 'module' }) %>
  14. <div class="main container">
  15. <div class="ui active tab" data-tab="definition">
  16. <div class="peek">
  17. <div class="ui vertical pointing secondary menu">
  18. <a class="active item">Types</a>
  19. <a class="item">Variations</a>
  20. <a class="item">States</a>
  21. </div>
  22. </div>
  23. <h2 class="ui dividing header">Types</h2>
  24. <div class="dropdown example">
  25. <h4 class="ui header">Dropdown</h4>
  26. <p>A basic dropdown has no special formatting of its own</p>
  27. <div class="ui dropdown">
  28. <div class="text">Select</div>
  29. <i class="dropdown icon"></i>
  30. <div class="menu">
  31. <div class="item">Edit</div>
  32. <div class="item">Remove</div>
  33. <div class="item">Hide</div>
  34. </div>
  35. </div>
  36. </div>
  37. <div class="dropdown example">
  38. <h4 class="ui header">Inline</h4>
  39. <p>A dropdown can be formatted to appear inline in other content</p>
  40. <div>Show me posts trending
  41. <div class="ui inline dropdown">
  42. <div class="text">today</div>
  43. <i class="dropdown icon"></i>
  44. <div class="menu">
  45. <div class="item" data-text="today">Today</div>
  46. <div class="item" data-text="this week">This Week</div>
  47. <div class="item" data-text="this month">This Month</div>
  48. </div>
  49. </div>
  50. </div>
  51. </div>
  52. <div class="dropdown example">
  53. <h4 class="ui header">Selection</h4>
  54. <p>A dropdown can point to other content to show its relationship</p>
  55. <div class="ui selection dropdown">
  56. <input type="hidden" name="gender">
  57. <div class="default text">Gender</div>
  58. <i class="dropdown icon"></i>
  59. <div class="menu">
  60. <div class="item" data-value="1">Male</div>
  61. <div class="item" data-value="0">Female</div>
  62. <div class="item" data-value="2">Unknown</div>
  63. </div>
  64. </div>
  65. </div>
  66. <div class="button example">
  67. <h4 class="ui header">Floating</h4>
  68. <p>A dropdown menu can appear to be floating below an element.</p>
  69. <div class="ui teal buttons">
  70. <div class="ui button">Save</div>
  71. <div class="ui floating dropdown icon button">
  72. <i class="dropdown icon"></i>
  73. <div class="menu">
  74. <div class="item"><i class="edit icon"></i> Edit Post</div>
  75. <div class="item"><i class="delete icon"></i> Remove Post</div>
  76. <div class="item"><i class="hide icon"></i> Hide Post</div>
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. <div class="hover example">
  82. <h4 class="ui header">Pointing</h4>
  83. <p>A dropdown can be formatted so that its menu is pointing</p>
  84. <div class="ui menu">
  85. <div class="menu">
  86. <a class="active item">
  87. Home
  88. </a>
  89. <div class="ui pointing dropdown link item">
  90. <i class="dropdown icon"></i>
  91. Messages
  92. <div class="menu">
  93. <a class="item"><i class="mail icon"></i>Inbox</a>
  94. <a class="item"><i class="book icon"></i>Archive</a>
  95. </div>
  96. </div>
  97. <a class="item">
  98. Browse
  99. </a>
  100. <a class="item">
  101. Help
  102. </a>
  103. </div>
  104. </div>
  105. </div>
  106. <div class="another button example">
  107. <div class="ui blue labeled icon top left pointing dropdown button">
  108. <i class="settings icon"></i>
  109. <span class="text">Settings</span>
  110. <div class="menu">
  111. <div class="item"><i class="edit icon"></i> Edit</div>
  112. <div class="item"><i class="delete icon"></i> Remove</div>
  113. <div class="item"><i class="hide icon"></i> Hide</div>
  114. </div>
  115. </div>
  116. <div class="ui red labeled icon top right pointing dropdown button">
  117. <i class="settings icon"></i>
  118. <span class="text">Settings</span>
  119. <div class="menu">
  120. <div class="item"><i class="edit icon"></i> Edit</div>
  121. <div class="item"><i class="delete icon"></i> Remove</div>
  122. <div class="item"><i class="hide icon"></i> Hide</div>
  123. </div>
  124. </div>
  125. </div>
  126. <div class="another button example">
  127. <div class="ui right pointing dropdown icon button">
  128. <i class="settings icon"></i>
  129. <div class="menu">
  130. <div class="item"><i class="edit icon"></i> Edit</div>
  131. <div class="item"><i class="delete icon"></i> Remove</div>
  132. <div class="item"><i class="hide icon"></i> Hide</div>
  133. </div>
  134. </div>
  135. <div class="ui left pointing dropdown icon button">
  136. <i class="settings icon"></i>
  137. <div class="menu">
  138. <div class="item"><i class="edit icon"></i> Edit</div>
  139. <div class="item"><i class="delete icon"></i> Remove</div>
  140. <div class="item"><i class="hide icon"></i> Hide</div>
  141. </div>
  142. </div>
  143. </div>
  144. <div class="example">
  145. <h4 class="ui header">Simple</h4>
  146. <p>A simple dropdown can open without javascript</p>
  147. <div class="ui compact menu">
  148. <div class="ui simple dropdown item">
  149. <i class="dropdown icon"></i>
  150. Dropdown
  151. <div class="menu">
  152. <div class="item">Choice 1</div>
  153. <div class="item">Choice 2</div>
  154. <div class="item">Choice 3</div>
  155. </div>
  156. </div>
  157. </div>
  158. </div>
  159. <h2 class="ui dividing header">Variations</h2>
  160. <div class="dropdown example">
  161. <h4 class="ui header">Fluid</h4>
  162. <p>A dropdown can take the full width of its parent</p>
  163. <div class="ui vertical menu">
  164. <a class="item">Link 1</a>
  165. <a class="item">Link 2</a>
  166. <div class="header item">All Sections</div>
  167. <div class="ui item">
  168. <div class="ui fluid selection dropdown">
  169. <div class="text">More</div>
  170. <i class="dropdown icon"></i>
  171. <div class="menu">
  172. <div class="item">Choice 1</div>
  173. <div class="item">Choice 2</div>
  174. <div class="item">Choice 3</div>
  175. </div>
  176. </div>
  177. </div>
  178. </div>
  179. </div>
  180. <h2 class="ui dividing header">States</h2>
  181. <div class="dropdown example">
  182. <h4 class="ui header">Error</h4>
  183. <p>An errored dropddown can alert a user to a problem</p>
  184. <div class="ui floating dropdown error">
  185. Dropdown <i class="dropdown icon"></i>
  186. <div class="menu">
  187. <div class="item">Choice 1</div>
  188. <div class="item">Choice 2</div>
  189. <div class="item">Choice 3</div>
  190. </div>
  191. </div>
  192. <br><br>
  193. <div class="ui selection dropdown error">
  194. Dropdown <i class="dropdown icon"></i>
  195. <div class="menu">
  196. <div class="item">Choice 1</div>
  197. <div class="item">Choice 2</div>
  198. <div class="item">Choice 3</div>
  199. </div>
  200. </div>
  201. </div>
  202. <h4 class="ui header">Simple Dropdown (No Javascript)</h4>
  203. <div class="example">
  204. <h4 class="ui header">Active</h4>
  205. <p>An active dropdown has its menu open</p>
  206. <div class="ui info message">An active state will only affect a simple dropdown. To activate a menu on a dropdown module use <code>$('.ui.dropdown').dropdown('show');</code></div>
  207. <div class="ui simple active dropdown">
  208. Dropdown <i class="dropdown icon"></i>
  209. <div class="menu">
  210. <div class="item">Choice 1</div>
  211. <div class="item">Choice 2</div>
  212. </div>
  213. </div>
  214. </div>
  215. <div class="example">
  216. <h4 class="ui header">Disabled</h4>
  217. <p>A disabled dropdown menu will not open or close</p>
  218. <div class="ui info message">A disabled state will only affect a simple dropdown. To disable a dropdown module use <code>$('.ui.dropdown').dropdown('destroy');</code></div>
  219. <div class="ui simple disabled dropdown">
  220. Dropdown <i class="dropdown icon"></i>
  221. <div class="menu">
  222. <div class="item">Choice 1</div>
  223. <div class="item">Choice 2</div>
  224. <div class="item">Choice 3</div>
  225. </div>
  226. </div>
  227. </div>
  228. </div>
  229. <div class="ui tab" data-tab="usage">
  230. <h2 class="ui dividing header">Initializing</h2>
  231. <h3 class="ui header">Initializing a dropdown</h3>
  232. <div class="code" data-label="HTML" data-type="html">
  233. <div class="ui dropdown">
  234. <div class="text">Select</div>
  235. <i class="dropdown icon"></i>
  236. <div class="menu">
  237. <div class="item" data-value="option1">Option 1</div>
  238. <div class="item" data-value="option2">Option 2</div>
  239. </div>
  240. </div>
  241. </div>
  242. <div class="code" data-label="Javascript" data-type="javascript">
  243. $('.ui.dropdown')
  244. .dropdown()
  245. ;
  246. </div>
  247. <h2 class="ui dividing header">Behavior</h2>
  248. <p>All the following <a href="/module.html#/behavior">behaviors</a> can be called using the syntax:</p>
  249. <div class="code">
  250. $('.your.element')
  251. .dropdown('behavior name', argumentOne, argumentTwo)
  252. ;
  253. </div>
  254. <table class="ui definition sortable celled table segment">
  255. <thead>
  256. <tr>
  257. <th>Behavior</th>
  258. <th>Description</th>
  259. </tr>
  260. </thead>
  261. <tbody>
  262. <tr>
  263. <td>toggle</td>
  264. <td>Toggles current visibility of dropdown</td>
  265. </tr>
  266. <tr>
  267. <td>show</td>
  268. <td>Shows dropdown</td>
  269. </tr>
  270. <tr>
  271. <td>hide</td>
  272. <td>Hides dropdown</td>
  273. </tr>
  274. <tr>
  275. <td>hide others</td>
  276. <td>Hides all other dropdowns that is not current dropdown</td>
  277. </tr>
  278. <tr>
  279. <td>restore defaults</td>
  280. <td>Restores dropdown text and value to its value on page load</td>
  281. </tr>
  282. <tr>
  283. <td>restore default text</td>
  284. <td>Restores dropdown text to its value on page load</td>
  285. </tr>
  286. <tr>
  287. <td>restore default value</td>
  288. <td>Restores dropdown value to its value on page load</td>
  289. </tr>
  290. <tr>
  291. <td>save defaults</td>
  292. <td>Saves current text and value as new defaults (for use with restore)</td>
  293. </tr>
  294. <tr>
  295. <td>set selected(value)</td>
  296. <td>Sets selected state to a given value</td>
  297. </tr>
  298. <tr>
  299. <td>set text(text)</td>
  300. <td>Sets dropdown text to a value</td>
  301. </tr>
  302. <tr>
  303. <td>set value(value)</td>
  304. <td>Sets dropdown input to value</td>
  305. </tr>
  306. <tr>
  307. <td>get text</td>
  308. <td>Returns current dropdown text</td>
  309. </tr>
  310. <tr>
  311. <td>get value</td>
  312. <td>Returns current dropdown input value</td>
  313. </tr>
  314. <tr>
  315. <td>get item(value)</td>
  316. <td>Returns DOM element that matches a given input value</td>
  317. </tr>
  318. <tr>
  319. <td>bind touch events</td>
  320. <td>Adds touch events to element</td>
  321. </tr>
  322. <tr>
  323. <td>mouse events</td>
  324. <td>Adds mouse events to element</td>
  325. </tr>
  326. <tr>
  327. <td>bind intent</td>
  328. <td>Binds a click to document to determine if you click away from a dropdown</td>
  329. </tr>
  330. <tr>
  331. <td>unbind intent</td>
  332. <td>Unbinds document intent click</td>
  333. </tr>
  334. <tr>
  335. <td>determine intent</td>
  336. <td>Returns whether event occurred inside dropdown</td>
  337. </tr>
  338. <tr>
  339. <td>determine select action(text, value)</td>
  340. <td>Triggers preset item selection action based on settings passing text/value</td>
  341. </tr>
  342. <tr>
  343. <td>set active</td>
  344. <td>Sets dropdown to active state
  345. <tr>
  346. <td>set visible</td>
  347. <td>Sets dropdown to visible state</td>
  348. </tr>
  349. <tr>
  350. <td>remove active</td>
  351. <td>rRemoves dropdown active state
  352. <tr>
  353. <td>remove visible</td>
  354. <td>Removes dropdown visible state</td>
  355. </tr>
  356. <tr>
  357. <td>is selection</td>
  358. <td>Returns whether dropdown is a selection dropdown</td>
  359. </tr>
  360. <tr>
  361. <td>is animated</td>
  362. <td>Returns whether dropdown is animated</td>
  363. </tr>
  364. <tr>
  365. <td>is visible</td>
  366. <td>Returns whether dropdown is visible</td>
  367. </tr>
  368. <tr>
  369. <td>is hidden</td>
  370. <td>Returns whether dropdown is hidden</td>
  371. </tr>
  372. </tbody>
  373. </table>
  374. </div>
  375. <div class="ui tab" data-tab="examples">
  376. <div class="transition example">
  377. <h3 class="ui header">Changing Transitions</h3>
  378. <p>A dropdown can specify a different <a href="/modules/transition.html">transitions</a>.</p>
  379. <div class="code" data-type="javascript">
  380. $('.dropdown')
  381. .dropdown({
  382. // you can use any ui transition
  383. transition: 'drop'
  384. })
  385. ;
  386. </div>
  387. <div class="ui teal buttons">
  388. <div class="ui button">Toggle</div>
  389. <div class="ui floating dropdown icon button">
  390. <i class="dropdown icon"></i>
  391. <div class="menu">
  392. <div class="item" data-value="drop">Drop</div>
  393. <div class="item" data-value="horizontal flip">Horizontal Flip</div>
  394. <div class="item" data-value="fade up">Fade Up</div>
  395. <div class="item" data-value="scale">Scale</div>
  396. </div>
  397. </div>
  398. </div>
  399. </div>
  400. <div class="dropdown example">
  401. <h3 class="ui header">Multiple Levels</h3>
  402. <p>A dropdown menu can also contain sub menus inside of it</p>
  403. My favorite animal breed is <div class="ui inline dropdown">
  404. <input type="hidden" name="gender">
  405. <div class="text">Shiba Inu</div>
  406. <i class="dropdown icon"></i>
  407. <div class="menu">
  408. <div class="item">
  409. <i class="dropdown icon"></i>
  410. Dogs
  411. <div class="menu">
  412. <div class="item">Shiba Inu</div>
  413. <div class="item">Poodle</div>
  414. <div class="item">Labrador</div>
  415. </div>
  416. </div>
  417. <div class="item">
  418. <i class="dropdown icon"></i>
  419. Cats
  420. <div class="menu">
  421. <div class="item">Aegean</div>
  422. <div class="item">Balinese</div>
  423. <div class="item">Persian</div>
  424. </div>
  425. </div>
  426. </div>
  427. </div>
  428. </div>
  429. <div class="dropdown example">
  430. <h3 class="ui header">Preserving User Selections</h3>
  431. <p>This example uses a preset text value to preserve the menu item on page navigation</p>
  432. <div class="ui ignored info icon message">
  433. <i class="help circle icon"></i>
  434. <div class="content">
  435. <p>A dropdown will automatically select on page load any menu item that includes the currently value of <code>text</code> or your dropdown's <code>hidden input</code> value.</p>
  436. <p>This is used to preserve a user's selection on page navigation and will automatically remove and default text placeholder formatting.</p>
  437. </div>
  438. </div>
  439. Current action: <div class="ui inline dropdown">
  440. <div class="text">Hide</div>
  441. <i class="dropdown icon"></i>
  442. <div class="menu">
  443. <div class="item">Edit</div>
  444. <div class="item">Remove</div>
  445. <div class="item">Hide</div>
  446. </div>
  447. </div>
  448. </div>
  449. <div class="dropdown example">
  450. <h3 class="ui header">Button Group</h3>
  451. <p>A <a href="/elements/button.html">button group</a> can be formatted to show additional content as a dropdown</p>
  452. <div class="ui icon buttons">
  453. <div class="ui top left pointing dropdown button">
  454. <i class="user icon"></i>
  455. <div class="menu">
  456. <div class="item"><i class="edit icon"></i>Edit User</div>
  457. <div class="item"><i class="delete icon"></i>Remove User</div>
  458. <div class="item"><i class="hide icon"></i>Make Invisible</div>
  459. </div>
  460. </div>
  461. <div class="ui top left pointing dropdown button">
  462. <i class="users icon"></i>
  463. <div class="menu">
  464. <div class="item"><i class="edit icon"></i>Edit Group</div>
  465. <div class="item"><i class="delete icon"></i>Remove Group</div>
  466. <div class="item"><i class="hide icon"></i>Hide from Group</div>
  467. </div>
  468. </div>
  469. <div class="ui top right pointing dropdown button">
  470. <i class="settings icon"></i>
  471. <div class="menu">
  472. <div class="item"><i class="edit icon"></i> Edit</div>
  473. <div class="item"><i class="delete icon"></i> Remove</div>
  474. <div class="item"><i class="hide icon"></i> Hide</div>
  475. </div>
  476. </div>
  477. </div>
  478. </div>
  479. <div class="hover example">
  480. <h3 class="ui header">Menu</h3>
  481. <p>A <a href="/collections/menu.html">menu</a> element can contain a dropdown</p>
  482. <div class="ui tiered purple inverted menu">
  483. <div class="menu">
  484. <a class="active item">
  485. Home
  486. </a>
  487. <a class="ui dropdown item">
  488. <i class="dropdown icon"></i>Messages
  489. <div class="menu">
  490. <div class="item">
  491. <i class="dropdown icon"></i>
  492. Categories
  493. <div class="menu">
  494. <div class="item">Unread</div>
  495. <div class="item">Promotions</div>
  496. <div class="item">Updates</div>
  497. </div>
  498. </div>
  499. <div class="item">Archive</div>
  500. </div>
  501. </a>
  502. <a class="item">
  503. Browse
  504. </a>
  505. </div>
  506. <div class="sub menu">
  507. <a class="item">Activity Feed</a>
  508. <a class="item">Profile</a>
  509. <a class="item">Events</a>
  510. </div>
  511. </div>
  512. </div>
  513. <div class="dropdown example">
  514. <h3 class="ui header">Form</h3>
  515. <p>A dropdown can be formatted to allow selection inside a <a href="/collections/form.html">form</a></p>
  516. <div class="ui form segment">
  517. <p>Let's go ahead and get you signed up.</p>
  518. <div class="two fields">
  519. <div class="field">
  520. <label>First Name</label>
  521. <input placeholder="First Name" type="text">
  522. </div>
  523. <div class="field">
  524. <label>Last Name</label>
  525. <input placeholder="Last Name" type="text">
  526. </div>
  527. </div>
  528. <div class="field">
  529. <label>Gender</label>
  530. <div class="ui dropdown selection">
  531. <input type="hidden" name="gender">
  532. <div class="default text">...</div>
  533. <i class="dropdown icon"></i>
  534. <div class="menu">
  535. <div class="item" data-value="male">Male</div>
  536. <div class="item" data-value="female">Female</div>
  537. </div>
  538. </div>
  539. </div>
  540. </div>
  541. </div>
  542. <h3 class="ui dividing header">Using Different Dropdown Actions</h3>
  543. <div class="button example">
  544. <h4 class="ui header">Combo Dropdowns</h4>
  545. <div class="ignored">
  546. <p>A <a href="/elements/button.html">button</a> can be formatted with a dropdown.</p>
  547. <p>You can change the default action that occurs on selection to different presets built into <em>ui dropdown</em>.</p>
  548. <p>For example, using the <code>combo</code> preset will change the preceding buttons text value to the current selected alue</p>
  549. <div class="evaluated code" data-type="javascript">
  550. $('.combo.dropdown')
  551. .dropdown({
  552. action: 'combo'
  553. })
  554. ;
  555. </div>
  556. <div class="ui teal buttons">
  557. <div class="ui button">Save</div>
  558. <div class="ui combo dropdown icon button">
  559. <i class="dropdown icon"></i>
  560. <div class="menu">
  561. <div class="item"><i class="edit icon"></i> Edit</div>
  562. <div class="item"><i class="delete icon"></i> Delete</div>
  563. <div class="item"><i class="hide icon"></i> Hide</div>
  564. </div>
  565. </div>
  566. </div>
  567. </div>
  568. <div class="button example">
  569. <h4 class="ui header">Link Dropdowns</h4>
  570. <div class="ignored">
  571. <p>If each option in your dropdown links out to another page, you might just want to make your menu hide without changing any value.</p>
  572. <div class="evaluated code" data-type="javascript">
  573. $('.link.dropdown')
  574. .dropdown({
  575. action: 'hide'
  576. })
  577. ;
  578. </div>
  579. <div class="ui link dropdown icon button">
  580. <div class="text">Go to</div>
  581. <i class="dropdown icon"></i>
  582. <div class="menu">
  583. <a class="item" href="#link1"><i class="home icon"></i> Home</a>
  584. <a class="item" href="#link2"><i class="users icon"></i> Browse</a>
  585. <a class="item" href="#link3"><i class="search icon"></i> Search</a>
  586. </div>
  587. </div>
  588. </div>
  589. </div>
  590. <div class="ui tab" data-tab="settings">
  591. <h3 class="ui header">
  592. Dropdown Settings
  593. <div class="sub header">Dropdown settings modify the dropdown's behavior</div>
  594. </h3>
  595. <table class="ui celled sortable definition table segment">
  596. <thead>
  597. <tr>
  598. <th>Setting</th>
  599. <th class="four wide">Default</th>
  600. <th>Description</th>
  601. </tr>
  602. </thead>
  603. <tbody>
  604. <tr>
  605. <td>on</td>
  606. <td>click</td>
  607. <td>Event used to trigger dropdown (Hover, Click)</td>
  608. </tr>
  609. <tr>
  610. <td>delay</td>
  611. <td>
  612. <div class="code">
  613. delay: {
  614. show: 50,
  615. hide: 300
  616. }
  617. </div>
  618. </td>
  619. <td>Time in milliseconds to debounce show or hide behavior when <code>on: hover</code> is used.</td>
  620. </tr>
  621. <tr>
  622. <td>transition</td>
  623. <td>
  624. slide down
  625. </td>
  626. <td>Named transition to use when animating menu in and out. Fade and slide down are available without including <a href="/modules/transition.html">ui transitions</a></td>
  627. </tr>
  628. <tr>
  629. <td>duration</td>
  630. <td>
  631. 250
  632. </td>
  633. <td>Duration of animation events</td>
  634. </tr>
  635. <tr>
  636. <td>action</td>
  637. <td>auto</td>
  638. <td>Sets a default action to occur.
  639. <div class="ui vertical divided list">
  640. <div class="item">
  641. <div class="header">activate</div>
  642. <div class="description">Most likely action will be determined by type of dropdown, for example a selection dropdown will automatically use updateForm</div>
  643. </div>
  644. <div class="item">
  645. <div class="header">combo</div>
  646. <div class="description">changes text of previous element matching text selector</div>
  647. </div>
  648. <div class="item">
  649. <div class="header">select</div>
  650. <div class="description">activates menu item but does not change text</div>
  651. </div>
  652. <div class="item">
  653. <div class="header">nothing</div>
  654. <div class="description">no action occurs</div>
  655. </div>
  656. <div class="item">
  657. <div class="header">hide</div>
  658. <div class="description">Dropdown menu is hidden</div>
  659. </div>
  660. <div class="item">
  661. <div class="header">function(){}</div>
  662. <div class="description">custom function is executed</div>
  663. </div>
  664. </div>
  665. </tr>
  666. </tbody>
  667. </table>
  668. <div class="ui horizontal section divider"><i class="icon setting"></i></div>
  669. <h3 class="ui header">
  670. Callbacks
  671. <div class="sub header">Callbacks specify a function to occur after a specific behavior.</div>
  672. </h3>
  673. <table class="ui celled sortable definition table segment">
  674. <thead>
  675. <tr>
  676. <th class="four wide">Setting</th>
  677. <th>Context</th>
  678. <th>Description</th>
  679. </tr>
  680. </thead>
  681. <tbody>
  682. <tr>
  683. <td>onChange(value, text)</td>
  684. <td>Dropdown</td>
  685. <td>Is called after a dropdown item is selected. receives the name and value of selection.</td>
  686. </tr>
  687. <tr>
  688. <td>onShow</td>
  689. <td>Dropdown</td>
  690. <td>Is called after a dropdown is shown.</td>
  691. </tr>
  692. <tr>
  693. <td>onHide</td>
  694. <td>Dropdown</td>
  695. <td>Is called after a dropdown is hidden.</td>
  696. </tr>
  697. </tbody>
  698. </table>
  699. <h3 class="ui header">
  700. DOM Settings
  701. <div class="sub header">DOM settings specify how this module should interface with the DOM</div>
  702. </h3>
  703. <table class="ui celled sortable definition table segment">
  704. <thead>
  705. <tr>
  706. <th>Setting</th>
  707. <th class="four wide">Default</th>
  708. <th>Description</th>
  709. </tr>
  710. </thead>
  711. <tbody>
  712. <tr>
  713. <td>namespace</td>
  714. <td>dropdown</td>
  715. <td>Event namespace. Makes sure module teardown does not effect other events attached to an element.</td>
  716. </tr>
  717. <tr>
  718. <td>selector</td>
  719. <td colspan="2">
  720. <div class="code">
  721. selector : {
  722. input : '> input[type="hidden"]',
  723. item : '.menu > .item',
  724. menu : '.menu',
  725. text : '> .text'
  726. }
  727. </div>
  728. </td>
  729. </tr>
  730. <tr>
  731. <td>metadata</td>
  732. <td colspan="2">
  733. <div class="code">
  734. metadata: {
  735. text : 'text',
  736. value : 'value'
  737. }
  738. </div>
  739. </td>
  740. </tr>
  741. <tr>
  742. <td>className</td>
  743. <td colspan="2">
  744. <div class="code">
  745. className : {
  746. active : 'active',
  747. disabled : 'disabled',
  748. placeholder : 'default',
  749. visible : 'visible'
  750. }
  751. </div>
  752. </td>
  753. </tr>
  754. </tbody>
  755. </table>
  756. <h3 class="ui header">
  757. Debug Settings
  758. <div class="sub header">Debug settings controls debug output to the console</div>
  759. </h3>
  760. <table class="ui celled sortable definition table segment">
  761. <thead>
  762. <tr>
  763. <th>Setting</th>
  764. <th class="four wide">Default</th>
  765. <th>Description</th>
  766. </tr>
  767. </thead>
  768. <tbody>
  769. <tr>
  770. <td>name</td>
  771. <td>Dropdown</td>
  772. <td>Name used in debug logs</td>
  773. </tr>
  774. <tr>
  775. <td>debug</td>
  776. <td>True</td>
  777. <td>Provides standard debug output to console</td>
  778. </tr>
  779. <tr>
  780. <td>performance</td>
  781. <td>True</td>
  782. <td>Provides standard debug output to console</td>
  783. </tr>
  784. <tr>
  785. <td>verbose</td>
  786. <td>True</td>
  787. <td>Provides ancillary debug output to console</td>
  788. </tr>
  789. <tr>
  790. <td>error</td>
  791. <td colspan="2">
  792. <div class="code">
  793. error : {
  794. action : 'You called a dropdown action that was not defined',
  795. method : 'The method you called is not defined.',
  796. transition : 'The requested transition was not found'
  797. }
  798. </div>
  799. </td>
  800. </tr>
  801. </tbody>
  802. </table>
  803. </div>
  804. </div>