@hipay/hipay-material-ui 1.0.0-beta.1 → 1.0.0-beta.10

Sign up to get free protection for your applications and to get access to all the features.
Files changed (391) hide show
  1. package/HI-CHANGELOG.md +58 -0
  2. package/HiAlertModal/HiAlertModal.js +247 -0
  3. package/HiAlertModal/index.js +16 -0
  4. package/HiBreadcrumb/HiBreadcrumb.js +143 -0
  5. package/HiBreadcrumb/HiStep.js +123 -0
  6. package/HiBreadcrumb/HiStepConnector.js +142 -0
  7. package/HiBreadcrumb/HiStepIcon.js +134 -0
  8. package/HiBreadcrumb/HiStepLabel.js +182 -0
  9. package/HiBreadcrumb/HiStepper.js +125 -0
  10. package/HiBreadcrumb/index.js +16 -0
  11. package/HiCheckbox/HiCheckbox.js +4 -1
  12. package/HiChip/HiChip.js +4 -4
  13. package/HiChip/HiChipSwitch.js +11 -4
  14. package/HiColoredLabel/HiColoredLabel.js +3 -2
  15. package/HiDatePicker/HiDatePicker.js +34 -30
  16. package/HiDatePicker/HiDateRangePicker.js +7 -5
  17. package/HiDatePicker/HiDateRangeSelector.js +23 -11
  18. package/HiDatePicker/ListPicker.js +32 -7
  19. package/HiDatePicker/Overlays/MonthPickerOverlay.js +5 -1
  20. package/HiDatePicker/Overlays/YearPickerOverlay.js +2 -1
  21. package/HiDotsStepper/HiDot.js +151 -0
  22. package/HiDotsStepper/HiDotsStepper.js +146 -0
  23. package/HiDotsStepper/index.js +16 -0
  24. package/HiExpansionPanel/HiExpansionPanel.js +231 -0
  25. package/HiExpansionPanel/index.js +16 -0
  26. package/HiForm/HiAddressField.js +204 -0
  27. package/HiForm/HiFormControl.js +39 -31
  28. package/HiForm/HiInput.js +70 -97
  29. package/HiForm/HiSearchField.js +2 -2
  30. package/HiForm/index.js +9 -0
  31. package/HiPdfReader/HiPdfReader.js +282 -0
  32. package/HiPdfReader/index.js +16 -0
  33. package/HiPins/HiPins.js +0 -1
  34. package/HiSelect/HiSelect.js +400 -353
  35. package/HiSelect/HiSelectField.js +8 -6
  36. package/HiSelect/HiSuggestSelect.js +27 -47
  37. package/HiSelect/HiSuggestSelectField.js +88 -80
  38. package/HiSelect/SelectInput.js +34 -23
  39. package/HiSelectableList/HiSelectableList.js +9 -3
  40. package/HiSelectableList/HiSelectableListItem.js +96 -55
  41. package/HiSwitch/HiSwitchState.js +1 -1
  42. package/HiSwitch/index.js +6 -0
  43. package/HiTable/BodyCellBuilder.js +91 -96
  44. package/HiTable/BodyCells/CellCountry.js +11 -36
  45. package/HiTable/BodyCells/CellIcon.js +4 -2
  46. package/HiTable/BodyCells/CellImage.js +23 -10
  47. package/HiTable/BodyCells/CellLayout.js +25 -19
  48. package/HiTable/BodyCells/CellSentinel.js +12 -4
  49. package/HiTable/BodyCells/CellStatus.js +6 -2
  50. package/HiTable/BodyCells/CellText.js +2 -1
  51. package/HiTable/BodyCells/CellThirdPartySecurity.js +5 -6
  52. package/HiTable/BodyRow.js +78 -57
  53. package/HiTable/ColumnFilter.js +28 -15
  54. package/HiTable/HeaderCell.js +17 -14
  55. package/HiTable/HiTable.js +26 -10
  56. package/HiTable/HiTableBody.js +38 -14
  57. package/HiTable/HiTableContextMenu.js +7 -3
  58. package/HiTable/HiTableFooterScroll.js +1 -1
  59. package/HiTable/HiTableHead.js +24 -7
  60. package/HiTable/OrderColumns.js +6 -2
  61. package/HiTopBar/HiTopBar.js +57 -139
  62. package/README.md +13 -13
  63. package/es/HiAlertModal/HiAlertModal.js +189 -0
  64. package/es/HiAlertModal/index.js +1 -0
  65. package/es/HiBreadcrumb/HiBreadcrumb.js +73 -0
  66. package/es/HiBreadcrumb/HiStep.js +93 -0
  67. package/es/HiBreadcrumb/HiStepConnector.js +83 -0
  68. package/es/HiBreadcrumb/HiStepIcon.js +81 -0
  69. package/es/HiBreadcrumb/HiStepLabel.js +154 -0
  70. package/es/HiBreadcrumb/HiStepper.js +62 -0
  71. package/es/HiBreadcrumb/index.js +1 -0
  72. package/es/HiCheckbox/HiCheckbox.js +4 -1
  73. package/es/HiChip/HiChip.js +4 -4
  74. package/es/HiChip/HiChipSwitch.js +11 -4
  75. package/es/HiColoredLabel/HiColoredLabel.js +3 -2
  76. package/es/HiDatePicker/HiDatePicker.js +30 -25
  77. package/es/HiDatePicker/HiDateRangePicker.js +7 -5
  78. package/es/HiDatePicker/HiDateRangeSelector.js +24 -12
  79. package/es/HiDatePicker/ListPicker.js +39 -20
  80. package/es/HiDatePicker/Overlays/MonthPickerOverlay.js +5 -1
  81. package/es/HiDatePicker/Overlays/YearPickerOverlay.js +2 -1
  82. package/es/HiDotsStepper/HiDot.js +92 -0
  83. package/es/HiDotsStepper/HiDotsStepper.js +83 -0
  84. package/es/HiDotsStepper/index.js +1 -0
  85. package/es/HiExpansionPanel/HiExpansionPanel.js +170 -0
  86. package/es/HiExpansionPanel/index.js +1 -0
  87. package/es/HiForm/HiAddressField.js +142 -0
  88. package/es/HiForm/HiFormControl.js +32 -18
  89. package/es/HiForm/HiInput.js +68 -97
  90. package/es/HiForm/HiSearchField.js +2 -2
  91. package/es/HiForm/index.js +2 -1
  92. package/es/HiPdfReader/HiPdfReader.js +198 -0
  93. package/es/HiPdfReader/index.js +1 -0
  94. package/es/HiPins/HiPins.js +0 -1
  95. package/es/HiSelect/HiSelect.js +375 -324
  96. package/es/HiSelect/HiSelectField.js +9 -7
  97. package/es/HiSelect/HiSuggestSelect.js +26 -39
  98. package/es/HiSelect/HiSuggestSelectField.js +77 -69
  99. package/es/HiSelect/SelectInput.js +44 -23
  100. package/es/HiSelectableList/HiSelectableList.js +10 -4
  101. package/es/HiSelectableList/HiSelectableListItem.js +91 -55
  102. package/es/HiSwitch/HiSwitchState.js +1 -1
  103. package/es/HiSwitch/index.js +1 -0
  104. package/es/HiTable/BodyCellBuilder.js +90 -97
  105. package/es/HiTable/BodyCells/CellCountry.js +10 -35
  106. package/es/HiTable/BodyCells/CellIcon.js +4 -2
  107. package/es/HiTable/BodyCells/CellImage.js +23 -10
  108. package/es/HiTable/BodyCells/CellLayout.js +27 -21
  109. package/es/HiTable/BodyCells/CellSentinel.js +12 -4
  110. package/es/HiTable/BodyCells/CellStatus.js +6 -2
  111. package/es/HiTable/BodyCells/CellText.js +2 -1
  112. package/es/HiTable/BodyCells/CellThirdPartySecurity.js +5 -6
  113. package/es/HiTable/BodyRow.js +79 -56
  114. package/es/HiTable/ColumnFilter.js +15 -9
  115. package/es/HiTable/HeaderCell.js +17 -14
  116. package/es/HiTable/HiTable.js +26 -10
  117. package/es/HiTable/HiTableBody.js +34 -11
  118. package/es/HiTable/HiTableContextMenu.js +7 -3
  119. package/es/HiTable/HiTableFooterScroll.js +1 -1
  120. package/es/HiTable/HiTableHead.js +19 -7
  121. package/es/HiTable/OrderColumns.js +6 -2
  122. package/es/HiTopBar/HiTopBar.js +58 -127
  123. package/es/styles/createHiMuiTheme.js +11 -0
  124. package/es/utils/HiIconBuilder.js +13 -5
  125. package/es/utils/hiHelpers.js +2 -2
  126. package/hmu/images/countries/ad.svg +151 -0
  127. package/hmu/images/countries/ae.svg +6 -0
  128. package/hmu/images/countries/af.svg +83 -0
  129. package/hmu/images/countries/ag.svg +15 -0
  130. package/hmu/images/countries/ai.svg +767 -0
  131. package/hmu/images/countries/al.svg +5 -0
  132. package/hmu/images/countries/am.svg +5 -0
  133. package/hmu/images/countries/ao.svg +13 -0
  134. package/hmu/images/countries/aq.svg +6 -0
  135. package/hmu/images/countries/ar.svg +32 -0
  136. package/hmu/images/countries/as.svg +33 -0
  137. package/hmu/images/countries/at.svg +6 -0
  138. package/hmu/images/countries/au.svg +9 -0
  139. package/hmu/images/countries/aw.svg +186 -0
  140. package/hmu/images/countries/ax.svg +18 -0
  141. package/hmu/images/countries/az.svg +8 -0
  142. package/hmu/images/countries/ba.svg +12 -0
  143. package/hmu/images/countries/bb.svg +6 -0
  144. package/hmu/images/countries/bd.svg +4 -0
  145. package/hmu/images/countries/be.svg +7 -0
  146. package/hmu/images/countries/bf.svg +7 -0
  147. package/hmu/images/countries/bg.svg +7 -0
  148. package/hmu/images/countries/bh.svg +11 -0
  149. package/hmu/images/countries/bi.svg +15 -0
  150. package/hmu/images/countries/bj.svg +14 -0
  151. package/hmu/images/countries/bl.svg +7 -0
  152. package/hmu/images/countries/bm.svg +99 -0
  153. package/hmu/images/countries/bn.svg +36 -0
  154. package/hmu/images/countries/bo.svg +686 -0
  155. package/hmu/images/countries/bq.svg +5 -0
  156. package/hmu/images/countries/br.svg +45 -0
  157. package/hmu/images/countries/bs.svg +13 -0
  158. package/hmu/images/countries/bt.svg +89 -0
  159. package/hmu/images/countries/bv.svg +13 -0
  160. package/hmu/images/countries/bw.svg +7 -0
  161. package/hmu/images/countries/by.svg +61 -0
  162. package/hmu/images/countries/bz.svg +146 -0
  163. package/hmu/images/countries/ca.svg +4 -0
  164. package/hmu/images/countries/cc.svg +19 -0
  165. package/hmu/images/countries/cd.svg +5 -0
  166. package/hmu/images/countries/cf.svg +15 -0
  167. package/hmu/images/countries/cg.svg +12 -0
  168. package/hmu/images/countries/ch.svg +9 -0
  169. package/hmu/images/countries/ci.svg +7 -0
  170. package/hmu/images/countries/ck.svg +9 -0
  171. package/hmu/images/countries/cl.svg +13 -0
  172. package/hmu/images/countries/cm.svg +15 -0
  173. package/hmu/images/countries/cn.svg +11 -0
  174. package/hmu/images/countries/co.svg +7 -0
  175. package/hmu/images/countries/cr.svg +7 -0
  176. package/hmu/images/countries/cu.svg +13 -0
  177. package/hmu/images/countries/cv.svg +13 -0
  178. package/hmu/images/countries/cw.svg +14 -0
  179. package/hmu/images/countries/cx.svg +15 -0
  180. package/hmu/images/countries/cy.svg +6 -0
  181. package/hmu/images/countries/cz.svg +12 -0
  182. package/hmu/images/countries/de.svg +5 -0
  183. package/hmu/images/countries/dj.svg +13 -0
  184. package/hmu/images/countries/dk.svg +5 -0
  185. package/hmu/images/countries/dm.svg +152 -0
  186. package/hmu/images/countries/do.svg +6745 -0
  187. package/hmu/images/countries/dz.svg +5 -0
  188. package/hmu/images/countries/ec.svg +141 -0
  189. package/hmu/images/countries/ee.svg +7 -0
  190. package/hmu/images/countries/eg.svg +38 -0
  191. package/hmu/images/countries/eh.svg +15 -0
  192. package/hmu/images/countries/er.svg +8 -0
  193. package/hmu/images/countries/es-ct.svg +4 -0
  194. package/hmu/images/countries/es.svg +581 -0
  195. package/hmu/images/countries/et.svg +14 -0
  196. package/hmu/images/countries/eu.svg +28 -0
  197. package/hmu/images/countries/fi.svg +5 -0
  198. package/hmu/images/countries/fj.svg +124 -0
  199. package/hmu/images/countries/fk.svg +90 -0
  200. package/hmu/images/countries/fm.svg +11 -0
  201. package/hmu/images/countries/fo.svg +12 -0
  202. package/hmu/images/countries/fr.svg +7 -0
  203. package/hmu/images/countries/ga.svg +7 -0
  204. package/hmu/images/countries/gb-eng.svg +5 -0
  205. package/hmu/images/countries/gb-nir.svg +137 -0
  206. package/hmu/images/countries/gb-sct.svg +4 -0
  207. package/hmu/images/countries/gb-wls.svg +9 -0
  208. package/hmu/images/countries/gb.svg +15 -0
  209. package/hmu/images/countries/gd.svg +27 -0
  210. package/hmu/images/countries/ge.svg +6 -0
  211. package/hmu/images/countries/gf.svg +5 -0
  212. package/hmu/images/countries/gg.svg +9 -0
  213. package/hmu/images/countries/gh.svg +6 -0
  214. package/hmu/images/countries/gi.svg +33 -0
  215. package/hmu/images/countries/gl.svg +4 -0
  216. package/hmu/images/countries/gm.svg +14 -0
  217. package/hmu/images/countries/gn.svg +7 -0
  218. package/hmu/images/countries/gp.svg +7 -0
  219. package/hmu/images/countries/gq.svg +23 -0
  220. package/hmu/images/countries/gr.svg +22 -0
  221. package/hmu/images/countries/gs.svg +205 -0
  222. package/hmu/images/countries/gt.svg +204 -0
  223. package/hmu/images/countries/gu.svg +39 -0
  224. package/hmu/images/countries/gw.svg +13 -0
  225. package/hmu/images/countries/gy.svg +9 -0
  226. package/hmu/images/countries/hk.svg +32 -0
  227. package/hmu/images/countries/hm.svg +9 -0
  228. package/hmu/images/countries/hn.svg +18 -0
  229. package/hmu/images/countries/hr.svg +59 -0
  230. package/hmu/images/countries/ht.svg +122 -0
  231. package/hmu/images/countries/hu.svg +7 -0
  232. package/hmu/images/countries/id.svg +6 -0
  233. package/hmu/images/countries/ie.svg +7 -0
  234. package/hmu/images/countries/il.svg +14 -0
  235. package/hmu/images/countries/im.svg +36 -0
  236. package/hmu/images/countries/in.svg +25 -0
  237. package/hmu/images/countries/io.svg +148 -0
  238. package/hmu/images/countries/iq.svg +10 -0
  239. package/hmu/images/countries/ir.svg +219 -0
  240. package/hmu/images/countries/is.svg +12 -0
  241. package/hmu/images/countries/it.svg +7 -0
  242. package/hmu/images/countries/je.svg +32 -0
  243. package/hmu/images/countries/jm.svg +8 -0
  244. package/hmu/images/countries/jo.svg +16 -0
  245. package/hmu/images/countries/jp.svg +11 -0
  246. package/hmu/images/countries/ke.svg +23 -0
  247. package/hmu/images/countries/kg.svg +15 -0
  248. package/hmu/images/countries/kh.svg +69 -0
  249. package/hmu/images/countries/ki.svg +36 -0
  250. package/hmu/images/countries/km.svg +16 -0
  251. package/hmu/images/countries/kn.svg +14 -0
  252. package/hmu/images/countries/kp.svg +15 -0
  253. package/hmu/images/countries/kr.svg +24 -0
  254. package/hmu/images/countries/kw.svg +13 -0
  255. package/hmu/images/countries/ky.svg +63 -0
  256. package/hmu/images/countries/kz.svg +23 -0
  257. package/hmu/images/countries/la.svg +12 -0
  258. package/hmu/images/countries/lb.svg +15 -0
  259. package/hmu/images/countries/lc.svg +8 -0
  260. package/hmu/images/countries/li.svg +43 -0
  261. package/hmu/images/countries/lk.svg +22 -0
  262. package/hmu/images/countries/lr.svg +14 -0
  263. package/hmu/images/countries/ls.svg +8 -0
  264. package/hmu/images/countries/lt.svg +7 -0
  265. package/hmu/images/countries/lu.svg +5 -0
  266. package/hmu/images/countries/lv.svg +6 -0
  267. package/hmu/images/countries/ly.svg +13 -0
  268. package/hmu/images/countries/ma.svg +4 -0
  269. package/hmu/images/countries/mc.svg +6 -0
  270. package/hmu/images/countries/md.svg +72 -0
  271. package/hmu/images/countries/me.svg +118 -0
  272. package/hmu/images/countries/mf.svg +7 -0
  273. package/hmu/images/countries/mg.svg +7 -0
  274. package/hmu/images/countries/mh.svg +7 -0
  275. package/hmu/images/countries/mk.svg +5 -0
  276. package/hmu/images/countries/ml.svg +7 -0
  277. package/hmu/images/countries/mm.svg +16 -0
  278. package/hmu/images/countries/mn.svg +13 -0
  279. package/hmu/images/countries/mo.svg +9 -0
  280. package/hmu/images/countries/mp.svg +86 -0
  281. package/hmu/images/countries/mq.svg +7 -0
  282. package/hmu/images/countries/mr.svg +6 -0
  283. package/hmu/images/countries/ms.svg +39 -0
  284. package/hmu/images/countries/mt.svg +49 -0
  285. package/hmu/images/countries/mu.svg +8 -0
  286. package/hmu/images/countries/mv.svg +6 -0
  287. package/hmu/images/countries/mw.svg +10 -0
  288. package/hmu/images/countries/mx.svg +385 -0
  289. package/hmu/images/countries/my.svg +15 -0
  290. package/hmu/images/countries/mz.svg +21 -0
  291. package/hmu/images/countries/na.svg +16 -0
  292. package/hmu/images/countries/nc.svg +7 -0
  293. package/hmu/images/countries/ne.svg +6 -0
  294. package/hmu/images/countries/nf.svg +9 -0
  295. package/hmu/images/countries/ng.svg +6 -0
  296. package/hmu/images/countries/ni.svg +131 -0
  297. package/hmu/images/countries/nl.svg +7 -0
  298. package/hmu/images/countries/no.svg +7 -0
  299. package/hmu/images/countries/np.svg +14 -0
  300. package/hmu/images/countries/nr.svg +12 -0
  301. package/hmu/images/countries/nu.svg +26 -0
  302. package/hmu/images/countries/nz.svg +41 -0
  303. package/hmu/images/countries/om.svg +116 -0
  304. package/hmu/images/countries/pa.svg +14 -0
  305. package/hmu/images/countries/pe.svg +279 -0
  306. package/hmu/images/countries/pf.svg +19 -0
  307. package/hmu/images/countries/pg.svg +9 -0
  308. package/hmu/images/countries/ph.svg +28 -0
  309. package/hmu/images/countries/pk.svg +15 -0
  310. package/hmu/images/countries/pl.svg +6 -0
  311. package/hmu/images/countries/pm.svg +7 -0
  312. package/hmu/images/countries/pn.svg +62 -0
  313. package/hmu/images/countries/pr.svg +13 -0
  314. package/hmu/images/countries/ps.svg +15 -0
  315. package/hmu/images/countries/pt.svg +57 -0
  316. package/hmu/images/countries/pw.svg +11 -0
  317. package/hmu/images/countries/py.svg +157 -0
  318. package/hmu/images/countries/qa.svg +4 -0
  319. package/hmu/images/countries/re.svg +7 -0
  320. package/hmu/images/countries/ro.svg +7 -0
  321. package/hmu/images/countries/rs.svg +292 -0
  322. package/hmu/images/countries/ru.svg +7 -0
  323. package/hmu/images/countries/rw.svg +13 -0
  324. package/hmu/images/countries/sa.svg +26 -0
  325. package/hmu/images/countries/sb.svg +13 -0
  326. package/hmu/images/countries/sc.svg +14 -0
  327. package/hmu/images/countries/sd.svg +13 -0
  328. package/hmu/images/countries/se.svg +16 -0
  329. package/hmu/images/countries/sg.svg +13 -0
  330. package/hmu/images/countries/sh.svg +74 -0
  331. package/hmu/images/countries/si.svg +18 -0
  332. package/hmu/images/countries/sj.svg +7 -0
  333. package/hmu/images/countries/sk.svg +9 -0
  334. package/hmu/images/countries/sl.svg +7 -0
  335. package/hmu/images/countries/sm.svg +91 -0
  336. package/hmu/images/countries/sn.svg +8 -0
  337. package/hmu/images/countries/so.svg +11 -0
  338. package/hmu/images/countries/sr.svg +6 -0
  339. package/hmu/images/countries/ss.svg +8 -0
  340. package/hmu/images/countries/st.svg +16 -0
  341. package/hmu/images/countries/sv.svg +618 -0
  342. package/hmu/images/countries/sx.svg +56 -0
  343. package/hmu/images/countries/sy.svg +6 -0
  344. package/hmu/images/countries/sz.svg +45 -0
  345. package/hmu/images/countries/tc.svg +67 -0
  346. package/hmu/images/countries/td.svg +7 -0
  347. package/hmu/images/countries/tf.svg +15 -0
  348. package/hmu/images/countries/tg.svg +14 -0
  349. package/hmu/images/countries/th.svg +7 -0
  350. package/hmu/images/countries/tj.svg +22 -0
  351. package/hmu/images/countries/tk.svg +5 -0
  352. package/hmu/images/countries/tl.svg +13 -0
  353. package/hmu/images/countries/tm.svg +213 -0
  354. package/hmu/images/countries/tn.svg +13 -0
  355. package/hmu/images/countries/to.svg +10 -0
  356. package/hmu/images/countries/tr.svg +8 -0
  357. package/hmu/images/countries/tt.svg +5 -0
  358. package/hmu/images/countries/tv.svg +27 -0
  359. package/hmu/images/countries/tw.svg +14 -0
  360. package/hmu/images/countries/tz.svg +13 -0
  361. package/hmu/images/countries/ua.svg +6 -0
  362. package/hmu/images/countries/ug.svg +30 -0
  363. package/hmu/images/countries/um.svg +23 -0
  364. package/hmu/images/countries/un.svg +16 -0
  365. package/hmu/images/countries/us.svg +12 -0
  366. package/hmu/images/countries/uy.svg +28 -0
  367. package/hmu/images/countries/uz.svg +30 -0
  368. package/hmu/images/countries/va.svg +483 -0
  369. package/hmu/images/countries/vc.svg +8 -0
  370. package/hmu/images/countries/ve.svg +26 -0
  371. package/hmu/images/countries/vg.svg +133 -0
  372. package/hmu/images/countries/vi.svg +31 -0
  373. package/hmu/images/countries/vn.svg +11 -0
  374. package/hmu/images/countries/vu.svg +18 -0
  375. package/hmu/images/countries/wf.svg +7 -0
  376. package/hmu/images/countries/ws.svg +7 -0
  377. package/hmu/images/countries/ye.svg +7 -0
  378. package/hmu/images/countries/yt.svg +7 -0
  379. package/hmu/images/countries/za.svg +17 -0
  380. package/hmu/images/countries/zm.svg +27 -0
  381. package/hmu/images/countries/zw.svg +21 -0
  382. package/hmu/images/hipay-white-logo.svg +42 -0
  383. package/hmu/images/logo_visa_75wx45h.gif +0 -0
  384. package/index.es.js +1 -1
  385. package/index.js +1 -1
  386. package/package.json +4 -3
  387. package/styles/createHiMuiTheme.js +11 -0
  388. package/umd/hipay-material-ui.development.js +11339 -11003
  389. package/umd/hipay-material-ui.production.min.js +5 -5
  390. package/utils/HiIconBuilder.js +17 -7
  391. package/utils/hiHelpers.js +2 -2
@@ -31,9 +31,10 @@ class HiSelectField extends React.PureComponent {
31
31
  iconAll,
32
32
  checkbox,
33
33
  searchable,
34
- translations
34
+ translations,
35
+ className
35
36
  } = _props,
36
- others = _objectWithoutProperties(_props, ['label', 'required', 'disabled', 'error', 'errorText', 'helperText', 'helperIcon', 'id', 'name', 'value', 'options', 'type', 'multiple', 'iconAll', 'checkbox', 'searchable', 'translations']);
37
+ others = _objectWithoutProperties(_props, ['label', 'required', 'disabled', 'error', 'errorText', 'helperText', 'helperIcon', 'id', 'name', 'value', 'options', 'type', 'multiple', 'iconAll', 'checkbox', 'searchable', 'translations', 'className']);
37
38
 
38
39
  return React.createElement(
39
40
  HiFormControl,
@@ -45,7 +46,8 @@ class HiSelectField extends React.PureComponent {
45
46
  error: error,
46
47
  errorText: errorText,
47
48
  helperText: helperText,
48
- helperIcon: helperIcon
49
+ helperIcon: helperIcon,
50
+ className: className
49
51
  },
50
52
  React.createElement(HiSelect, _extends({
51
53
  id: id,
@@ -58,10 +60,6 @@ class HiSelectField extends React.PureComponent {
58
60
  checkbox: checkbox,
59
61
  searchable: searchable,
60
62
  translations: translations,
61
- onClick: this.handleClick,
62
- onMouseEnter: this.handleMouseEnter,
63
- onMouseLeave: this.handleMouseLeave,
64
- onClose: this.handleClose,
65
63
  disabled: disabled,
66
64
  error: error
67
65
  }, others))
@@ -70,6 +68,10 @@ class HiSelectField extends React.PureComponent {
70
68
  }
71
69
 
72
70
  HiSelectField.propTypes = process.env.NODE_ENV !== "production" ? {
71
+ /**
72
+ * Surcharge des styles
73
+ */
74
+ className: PropTypes.string,
73
75
  /**
74
76
  * Si `true`, l'input sera inactif.
75
77
  */
@@ -4,17 +4,12 @@ import _objectWithoutProperties from 'babel-runtime/helpers/objectWithoutPropert
4
4
 
5
5
  import React from 'react';
6
6
  import PropTypes from 'prop-types';
7
-
8
- import classNames from 'classnames';
9
7
  import { findDOMNode } from 'react-dom';
10
8
  import Grow from 'material-ui/transitions/Grow';
11
9
  import Paper from 'material-ui/Paper';
12
- import ClickAwayListener from 'material-ui/utils/ClickAwayListener';
13
10
  import { Manager, Target, Popper } from 'react-popper';
14
-
15
11
  import HiSelectableList from '../HiSelectableList';
16
12
  import HiInput from '../HiForm/HiInput';
17
-
18
13
  import { withStyles } from '../styles';
19
14
  import { getNextItemSelectable } from '../utils/hiHelpers';
20
15
 
@@ -22,7 +17,7 @@ export const styles = theme => ({
22
17
  root: {
23
18
  backgroundColor: theme.palette.background2,
24
19
  maxWidth: 500,
25
- minWidth: 250,
20
+ minWidth: 200,
26
21
  width: '100%'
27
22
  },
28
23
  popper: {
@@ -31,9 +26,6 @@ export const styles = theme => ({
31
26
  zIndex: 9,
32
27
  top: '100%'
33
28
  },
34
- popperClose: {
35
- pointerEvents: 'none'
36
- },
37
29
  paper: {
38
30
  borderRadius: '0px 2px',
39
31
  maxHeight: 440,
@@ -85,6 +77,8 @@ class HiSuggestSelect extends React.PureComponent {
85
77
  items[0].focus();
86
78
  }
87
79
  }, 1);
80
+ } else if (event.key === 'Escape') {
81
+ this.setState({ options: [] });
88
82
  }
89
83
  };
90
84
 
@@ -94,34 +88,29 @@ class HiSuggestSelect extends React.PureComponent {
94
88
  };
95
89
 
96
90
  this.handleSelect = this.handleSelect.bind(this);
97
- this.handleClose = this.handleClose.bind(this);
98
91
  this.handleBlur = this.handleBlur.bind(this);
92
+ this.handleFocus = this.handleFocus.bind(this);
99
93
  }
100
94
 
101
95
  componentWillReceiveProps(nextProps) {
102
96
  this.setState({ options: nextProps.options });
103
97
  }
104
98
 
105
- handleClose() {
106
- document.body.style.overflow = 'auto';
107
- this.setState({
108
- focused: false, // TODO - Make difference between open and focus
109
- options: []
110
- });
111
- }
112
-
113
99
  // Key down on list items
114
100
 
115
101
 
116
102
  // Key down on search input
117
103
 
118
104
 
105
+ handleFocus() {
106
+ this.setState({ focused: true });
107
+ }
108
+
119
109
  handleBlur(event) {
120
110
  // Si on click sur un élément de HiInput, on garde le focus
121
111
  // Par exemple sur l'icone reset
122
- const overlay = this.overlay;
123
112
  if (!event.relatedTarget || !this.overlay || !this.overlay.contains(event.relatedTarget)) {
124
- this.setState({ options: [] });
113
+ this.setState({ options: [], focused: false });
125
114
  }
126
115
  }
127
116
 
@@ -131,7 +120,8 @@ class HiSuggestSelect extends React.PureComponent {
131
120
  otherProps = _objectWithoutProperties(_props, ['classes', 'translations', 'id', 'onSearch']);
132
121
 
133
122
  const { focused, options } = this.state;
134
- const open = !!options.length;
123
+ const open = !!options.length && focused;
124
+
135
125
  return React.createElement(
136
126
  'div',
137
127
  {
@@ -154,7 +144,8 @@ class HiSuggestSelect extends React.PureComponent {
154
144
  },
155
145
  onChange: onSearch,
156
146
  onKeyDown: this.handleKeyDownSearch,
157
- onBlur: this.handleBlur
147
+ onBlur: this.handleBlur,
148
+ onFocus: this.handleFocus
158
149
  }))
159
150
  ),
160
151
  open && React.createElement(
@@ -162,26 +153,22 @@ class HiSuggestSelect extends React.PureComponent {
162
153
  {
163
154
  placement: 'bottom-start',
164
155
  eventsEnabled: open,
165
- className: classNames(classes.popper, { [classes.popperClose]: !open })
156
+ className: classes.popper
166
157
  },
167
158
  React.createElement(
168
- ClickAwayListener,
169
- { onClickAway: this.handleClose },
159
+ Grow,
160
+ { 'in': open, id: 'menu-list', style: { transformOrigin: '0 0 0' } },
170
161
  React.createElement(
171
- Grow,
172
- { 'in': open, id: 'menu-list', style: { transformOrigin: '0 0 0' } },
173
- React.createElement(
174
- Paper,
175
- { className: classes.paper },
176
- React.createElement(HiSelectableList, {
177
- itemList: options,
178
- selectedIdList: [],
179
- checkbox: false,
180
- onSelect: this.handleSelect,
181
- translations: translations,
182
- onKeyDown: this.handleKeyDown
183
- })
184
- )
162
+ Paper,
163
+ { className: classes.paper },
164
+ React.createElement(HiSelectableList, {
165
+ itemList: options,
166
+ selectedIdList: [],
167
+ checkbox: false,
168
+ onSelect: this.handleSelect,
169
+ translations: translations,
170
+ onKeyDown: this.handleKeyDown
171
+ })
185
172
  )
186
173
  )
187
174
  )
@@ -12,78 +12,86 @@ import HiSuggestSelect from './HiSuggestSelect';
12
12
  */
13
13
  class HiSuggestSelectField extends React.PureComponent {
14
14
 
15
- render() {
16
- const _props = this.props,
17
- {
18
- label,
19
- required,
20
- disabled,
21
- error,
22
- errorText,
23
- helperText,
24
- helperIcon,
25
- id
26
- } = _props,
27
- others = _objectWithoutProperties(_props, ['label', 'required', 'disabled', 'error', 'errorText', 'helperText', 'helperIcon', 'id']);
15
+ render() {
16
+ const _props = this.props,
17
+ {
18
+ label,
19
+ required,
20
+ disabled,
21
+ error,
22
+ errorText,
23
+ helperText,
24
+ helperIcon,
25
+ id,
26
+ className
27
+ } = _props,
28
+ others = _objectWithoutProperties(_props, ['label', 'required', 'disabled', 'error', 'errorText', 'helperText', 'helperIcon', 'id', 'className']);
28
29
 
29
- return React.createElement(
30
- HiFormControl,
31
- {
32
- id: id,
33
- label: label,
34
- required: required,
35
- disabled: disabled,
36
- error: error,
37
- errorText: errorText,
38
- helperText: helperText,
39
- helperIcon: helperIcon
40
- },
41
- React.createElement(HiSuggestSelect, _extends({
42
- id: id,
43
- translations: {
44
- all: 'Tous les pays',
45
- no_result_match: 'Aucun résultat correspondant',
46
- search: 'Recherche',
47
- n_items_selected: '%s pays sélectionnés',
48
- one_item_selected: '%s pays sélectionné'
49
- }
50
- }, others))
51
- );
52
- }
30
+ return React.createElement(
31
+ HiFormControl,
32
+ {
33
+ id: id,
34
+ label: label,
35
+ required: required,
36
+ disabled: disabled,
37
+ error: error,
38
+ errorText: errorText,
39
+ helperText: helperText,
40
+ helperIcon: helperIcon,
41
+ className: className
42
+ },
43
+ React.createElement(HiSuggestSelect, _extends({
44
+ id: id,
45
+ translations: {
46
+ all: 'Tous les pays',
47
+ no_result_match: 'Aucun résultat correspondant',
48
+ search: 'Recherche',
49
+ n_items_selected: '%s pays sélectionnés',
50
+ one_item_selected: '%s pays sélectionné'
51
+ },
52
+ disabled: disabled,
53
+ error: error
54
+ }, others))
55
+ );
56
+ }
53
57
  }
54
58
 
55
59
  HiSuggestSelectField.propTypes = process.env.NODE_ENV !== "production" ? {
56
- /**
57
- * Si `true`, l'input sera inactif.
58
- */
59
- disabled: PropTypes.bool,
60
- /**
61
- * Si `true`, le champs sera en erreur.
62
- */
63
- error: PropTypes.bool,
64
- /**
65
- * Texte de l'erreur
66
- */
67
- errorText: PropTypes.string,
68
- /**
69
- * Si "true", le texte d'aide s'affichera seulement au clic sur l'icône "Information"
70
- */
71
- helperIcon: PropTypes.bool,
72
- /**
73
- * Texte de l'aide
74
- */
75
- helperText: PropTypes.string,
76
- /**
77
- * id de l'élément input
78
- */
79
- id: PropTypes.string,
80
- /**
81
- * Label du champs
82
- */
83
- label: PropTypes.string,
84
- /**
85
- * true si champs obligatoire
86
- */
87
- required: PropTypes.bool
60
+ /**
61
+ * Surcharge des styles
62
+ */
63
+ className: PropTypes.string,
64
+ /**
65
+ * Si `true`, l'input sera inactif.
66
+ */
67
+ disabled: PropTypes.bool,
68
+ /**
69
+ * Si `true`, le champs sera en erreur.
70
+ */
71
+ error: PropTypes.bool,
72
+ /**
73
+ * Texte de l'erreur
74
+ */
75
+ errorText: PropTypes.string,
76
+ /**
77
+ * Si "true", le texte d'aide s'affichera seulement au clic sur l'icône "Information"
78
+ */
79
+ helperIcon: PropTypes.bool,
80
+ /**
81
+ * Texte de l'aide
82
+ */
83
+ helperText: PropTypes.string,
84
+ /**
85
+ * id de l'élément input
86
+ */
87
+ id: PropTypes.string,
88
+ /**
89
+ * Label du champs
90
+ */
91
+ label: PropTypes.string,
92
+ /**
93
+ * true si champs obligatoire
94
+ */
95
+ required: PropTypes.bool
88
96
  } : {};
89
97
  export default HiSuggestSelectField;
@@ -15,7 +15,8 @@ export const styles = theme => ({
15
15
  height: 40,
16
16
  maxWidth: 500,
17
17
  justifyContent: 'flex-start',
18
- padding: 8
18
+ padding: 8,
19
+ cursor: 'pointer'
19
20
  },
20
21
  underline: {
21
22
  '&:before': {
@@ -47,7 +48,7 @@ export const styles = theme => ({
47
48
  },
48
49
  inkbar: {
49
50
  '&:not($disabled)': {
50
- '&:after': {
51
+ '&:not($error):after': {
51
52
  backgroundColor: theme.palette.business.primary.normal,
52
53
  left: 0,
53
54
  bottom: 0,
@@ -77,7 +78,6 @@ export const styles = theme => ({
77
78
  },
78
79
  disabled: {
79
80
  color: `${theme.palette.action.disabled}`,
80
- backgroundColor: `${theme.palette.input.disabled}`,
81
81
  '&:before': {
82
82
  display: 'none'
83
83
  }
@@ -136,7 +136,18 @@ class SelectInput extends React.PureComponent {
136
136
  }
137
137
 
138
138
  render() {
139
- const { classes, noButton, disabled, onClick, value, open, focused, error, id } = this.props;
139
+ const {
140
+ classes,
141
+ noButton,
142
+ disabled,
143
+ onClick,
144
+ value,
145
+ open,
146
+ focused,
147
+ error,
148
+ id,
149
+ refElement
150
+ } = this.props;
140
151
 
141
152
  // On utilise classNames pour variabiliser les styles et merge les classes appliquées
142
153
  const rootClass = classNames(classes.root, classes.inkbar, classes.underline, {
@@ -163,7 +174,10 @@ class SelectInput extends React.PureComponent {
163
174
  onFocus: this.props.onFocus,
164
175
  onBlur: this.props.onBlur,
165
176
  role: 'button',
166
- tabIndex: '0'
177
+ tabIndex: '0',
178
+ ref: el => {
179
+ refElement && refElement(el);
180
+ }
167
181
  },
168
182
  React.createElement(
169
183
  'span',
@@ -182,7 +196,10 @@ class SelectInput extends React.PureComponent {
182
196
  onMouseLeave: this.props.onMouseLeave,
183
197
  onKeyDown: this.handleKeyDown,
184
198
  onFocus: this.props.onFocus,
185
- onBlur: this.props.onBlur
199
+ onBlur: this.props.onBlur,
200
+ buttonRef: el => {
201
+ refElement && refElement(el);
202
+ }
186
203
  },
187
204
  React.createElement(
188
205
  'span',
@@ -217,6 +234,23 @@ SelectInput.propTypes = process.env.NODE_ENV !== "production" ? {
217
234
  * If `true`, the select will be disabled.
218
235
  */
219
236
  disabled: PropTypes.bool,
237
+ /**
238
+ * Applique le style error
239
+ */
240
+ error: PropTypes.bool,
241
+ /**
242
+ * Applique le style focused
243
+ */
244
+ focused: PropTypes.bool,
245
+ /**
246
+ * id du select
247
+ */
248
+ id: PropTypes.string,
249
+ /**
250
+ * Affiche sous forme de div à la place d'un bouton.
251
+ * Si des éléments cliquables sont à l'intérieur.
252
+ */
253
+ noButton: PropTypes.bool,
220
254
  /**
221
255
  * Fonction de callback au blur du bouton
222
256
  */
@@ -233,30 +267,17 @@ SelectInput.propTypes = process.env.NODE_ENV !== "production" ? {
233
267
  * Fonction de callback à la pression de touche
234
268
  */
235
269
  onKeyDown: PropTypes.func,
236
- /**
237
- * Valeur à afficher (déjà formattée)
238
- */
239
- value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.node]),
240
270
  /**
241
271
  * Applique le style open et effectue une rotation de l'icône
242
272
  */
243
273
  open: PropTypes.bool,
244
274
  /**
245
- * Affiche sous forme de div à la place d'un bouton.
246
- * Si des éléments cliquables sont à l'intérieur.
247
- */
248
- noButton: PropTypes.bool,
249
- /**
250
- * Applique le style focused
251
- */
252
- focused: PropTypes.bool,
253
- /**
254
- * Applique le style error
275
+ * Use that property to pass a ref callback to the native component.
255
276
  */
256
- error: PropTypes.bool,
277
+ refElement: PropTypes.func,
257
278
  /**
258
- * id du select
279
+ * Valeur à afficher (déjà formattée)
259
280
  */
260
- id: PropTypes.string
281
+ value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.node])
261
282
  } : {};
262
283
  export default withStyles(styles, { name: 'HmuiSelectInput' })(SelectInput);
@@ -37,9 +37,10 @@ class HiSelectableList extends React.PureComponent {
37
37
  checkedIcon,
38
38
  allSelected,
39
39
  checkbox,
40
- hierarchic
40
+ hierarchic,
41
+ disabledIds
41
42
  } = _props,
42
- others = _objectWithoutProperties(_props, ['classes', 'itemList', 'selectedIdList', 'onSelect', 'maxHeight', 'hierarchySelected', 'parentItemSelectable', 'hierarchy', 'translations', 'icon', 'parentIcon', 'hoverIcon', 'checkedIcon', 'allSelected', 'checkbox', 'hierarchic']);
43
+ others = _objectWithoutProperties(_props, ['classes', 'itemList', 'selectedIdList', 'onSelect', 'maxHeight', 'hierarchySelected', 'parentItemSelectable', 'hierarchy', 'translations', 'icon', 'parentIcon', 'hoverIcon', 'checkedIcon', 'allSelected', 'checkbox', 'hierarchic', 'disabledIds']);
43
44
 
44
45
  let parents = [];
45
46
 
@@ -100,7 +101,8 @@ class HiSelectableList extends React.PureComponent {
100
101
  hoverIcon: hoverIcon,
101
102
  checkedIcon: checkedIcon,
102
103
  checkbox: checkbox,
103
- level: parents.length
104
+ level: parents.length,
105
+ disabled: disabledIds ? disabledIds.includes(item.id) : false
104
106
  }, others));
105
107
  })
106
108
  )
@@ -111,7 +113,7 @@ class HiSelectableList extends React.PureComponent {
111
113
  HiSelectableList.defaultProps = {
112
114
  checkbox: true,
113
115
  allSelected: false,
114
- maxHeight: 360,
116
+ maxHeight: 400,
115
117
  hierarchySelected: {},
116
118
  parentItemSelectable: false,
117
119
  icon: React.createElement(CheckboxBlankOutline, { style: { width: 20, height: 20 } }),
@@ -140,6 +142,10 @@ HiSelectableList.propTypes = process.env.NODE_ENV !== "production" ? {
140
142
  * Useful to extend the style applied to components.
141
143
  */
142
144
  classes: PropTypes.object,
145
+ /**
146
+ * Liste des ids des items disabled
147
+ */
148
+ disabledIds: PropTypes.array,
143
149
  /**
144
150
  * Tableau associatif : parentId => [children objects]
145
151
  */