@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.
- package/HI-CHANGELOG.md +58 -0
- package/HiAlertModal/HiAlertModal.js +247 -0
- package/HiAlertModal/index.js +16 -0
- package/HiBreadcrumb/HiBreadcrumb.js +143 -0
- package/HiBreadcrumb/HiStep.js +123 -0
- package/HiBreadcrumb/HiStepConnector.js +142 -0
- package/HiBreadcrumb/HiStepIcon.js +134 -0
- package/HiBreadcrumb/HiStepLabel.js +182 -0
- package/HiBreadcrumb/HiStepper.js +125 -0
- package/HiBreadcrumb/index.js +16 -0
- package/HiCheckbox/HiCheckbox.js +4 -1
- package/HiChip/HiChip.js +4 -4
- package/HiChip/HiChipSwitch.js +11 -4
- package/HiColoredLabel/HiColoredLabel.js +3 -2
- package/HiDatePicker/HiDatePicker.js +34 -30
- package/HiDatePicker/HiDateRangePicker.js +7 -5
- package/HiDatePicker/HiDateRangeSelector.js +23 -11
- package/HiDatePicker/ListPicker.js +32 -7
- package/HiDatePicker/Overlays/MonthPickerOverlay.js +5 -1
- package/HiDatePicker/Overlays/YearPickerOverlay.js +2 -1
- package/HiDotsStepper/HiDot.js +151 -0
- package/HiDotsStepper/HiDotsStepper.js +146 -0
- package/HiDotsStepper/index.js +16 -0
- package/HiExpansionPanel/HiExpansionPanel.js +231 -0
- package/HiExpansionPanel/index.js +16 -0
- package/HiForm/HiAddressField.js +204 -0
- package/HiForm/HiFormControl.js +39 -31
- package/HiForm/HiInput.js +70 -97
- package/HiForm/HiSearchField.js +2 -2
- package/HiForm/index.js +9 -0
- package/HiPdfReader/HiPdfReader.js +282 -0
- package/HiPdfReader/index.js +16 -0
- package/HiPins/HiPins.js +0 -1
- package/HiSelect/HiSelect.js +400 -353
- package/HiSelect/HiSelectField.js +8 -6
- package/HiSelect/HiSuggestSelect.js +27 -47
- package/HiSelect/HiSuggestSelectField.js +88 -80
- package/HiSelect/SelectInput.js +34 -23
- package/HiSelectableList/HiSelectableList.js +9 -3
- package/HiSelectableList/HiSelectableListItem.js +96 -55
- package/HiSwitch/HiSwitchState.js +1 -1
- package/HiSwitch/index.js +6 -0
- package/HiTable/BodyCellBuilder.js +91 -96
- package/HiTable/BodyCells/CellCountry.js +11 -36
- package/HiTable/BodyCells/CellIcon.js +4 -2
- package/HiTable/BodyCells/CellImage.js +23 -10
- package/HiTable/BodyCells/CellLayout.js +25 -19
- package/HiTable/BodyCells/CellSentinel.js +12 -4
- package/HiTable/BodyCells/CellStatus.js +6 -2
- package/HiTable/BodyCells/CellText.js +2 -1
- package/HiTable/BodyCells/CellThirdPartySecurity.js +5 -6
- package/HiTable/BodyRow.js +78 -57
- package/HiTable/ColumnFilter.js +28 -15
- package/HiTable/HeaderCell.js +17 -14
- package/HiTable/HiTable.js +26 -10
- package/HiTable/HiTableBody.js +38 -14
- package/HiTable/HiTableContextMenu.js +7 -3
- package/HiTable/HiTableFooterScroll.js +1 -1
- package/HiTable/HiTableHead.js +24 -7
- package/HiTable/OrderColumns.js +6 -2
- package/HiTopBar/HiTopBar.js +57 -139
- package/README.md +13 -13
- package/es/HiAlertModal/HiAlertModal.js +189 -0
- package/es/HiAlertModal/index.js +1 -0
- package/es/HiBreadcrumb/HiBreadcrumb.js +73 -0
- package/es/HiBreadcrumb/HiStep.js +93 -0
- package/es/HiBreadcrumb/HiStepConnector.js +83 -0
- package/es/HiBreadcrumb/HiStepIcon.js +81 -0
- package/es/HiBreadcrumb/HiStepLabel.js +154 -0
- package/es/HiBreadcrumb/HiStepper.js +62 -0
- package/es/HiBreadcrumb/index.js +1 -0
- package/es/HiCheckbox/HiCheckbox.js +4 -1
- package/es/HiChip/HiChip.js +4 -4
- package/es/HiChip/HiChipSwitch.js +11 -4
- package/es/HiColoredLabel/HiColoredLabel.js +3 -2
- package/es/HiDatePicker/HiDatePicker.js +30 -25
- package/es/HiDatePicker/HiDateRangePicker.js +7 -5
- package/es/HiDatePicker/HiDateRangeSelector.js +24 -12
- package/es/HiDatePicker/ListPicker.js +39 -20
- package/es/HiDatePicker/Overlays/MonthPickerOverlay.js +5 -1
- package/es/HiDatePicker/Overlays/YearPickerOverlay.js +2 -1
- package/es/HiDotsStepper/HiDot.js +92 -0
- package/es/HiDotsStepper/HiDotsStepper.js +83 -0
- package/es/HiDotsStepper/index.js +1 -0
- package/es/HiExpansionPanel/HiExpansionPanel.js +170 -0
- package/es/HiExpansionPanel/index.js +1 -0
- package/es/HiForm/HiAddressField.js +142 -0
- package/es/HiForm/HiFormControl.js +32 -18
- package/es/HiForm/HiInput.js +68 -97
- package/es/HiForm/HiSearchField.js +2 -2
- package/es/HiForm/index.js +2 -1
- package/es/HiPdfReader/HiPdfReader.js +198 -0
- package/es/HiPdfReader/index.js +1 -0
- package/es/HiPins/HiPins.js +0 -1
- package/es/HiSelect/HiSelect.js +375 -324
- package/es/HiSelect/HiSelectField.js +9 -7
- package/es/HiSelect/HiSuggestSelect.js +26 -39
- package/es/HiSelect/HiSuggestSelectField.js +77 -69
- package/es/HiSelect/SelectInput.js +44 -23
- package/es/HiSelectableList/HiSelectableList.js +10 -4
- package/es/HiSelectableList/HiSelectableListItem.js +91 -55
- package/es/HiSwitch/HiSwitchState.js +1 -1
- package/es/HiSwitch/index.js +1 -0
- package/es/HiTable/BodyCellBuilder.js +90 -97
- package/es/HiTable/BodyCells/CellCountry.js +10 -35
- package/es/HiTable/BodyCells/CellIcon.js +4 -2
- package/es/HiTable/BodyCells/CellImage.js +23 -10
- package/es/HiTable/BodyCells/CellLayout.js +27 -21
- package/es/HiTable/BodyCells/CellSentinel.js +12 -4
- package/es/HiTable/BodyCells/CellStatus.js +6 -2
- package/es/HiTable/BodyCells/CellText.js +2 -1
- package/es/HiTable/BodyCells/CellThirdPartySecurity.js +5 -6
- package/es/HiTable/BodyRow.js +79 -56
- package/es/HiTable/ColumnFilter.js +15 -9
- package/es/HiTable/HeaderCell.js +17 -14
- package/es/HiTable/HiTable.js +26 -10
- package/es/HiTable/HiTableBody.js +34 -11
- package/es/HiTable/HiTableContextMenu.js +7 -3
- package/es/HiTable/HiTableFooterScroll.js +1 -1
- package/es/HiTable/HiTableHead.js +19 -7
- package/es/HiTable/OrderColumns.js +6 -2
- package/es/HiTopBar/HiTopBar.js +58 -127
- package/es/styles/createHiMuiTheme.js +11 -0
- package/es/utils/HiIconBuilder.js +13 -5
- package/es/utils/hiHelpers.js +2 -2
- package/hmu/images/countries/ad.svg +151 -0
- package/hmu/images/countries/ae.svg +6 -0
- package/hmu/images/countries/af.svg +83 -0
- package/hmu/images/countries/ag.svg +15 -0
- package/hmu/images/countries/ai.svg +767 -0
- package/hmu/images/countries/al.svg +5 -0
- package/hmu/images/countries/am.svg +5 -0
- package/hmu/images/countries/ao.svg +13 -0
- package/hmu/images/countries/aq.svg +6 -0
- package/hmu/images/countries/ar.svg +32 -0
- package/hmu/images/countries/as.svg +33 -0
- package/hmu/images/countries/at.svg +6 -0
- package/hmu/images/countries/au.svg +9 -0
- package/hmu/images/countries/aw.svg +186 -0
- package/hmu/images/countries/ax.svg +18 -0
- package/hmu/images/countries/az.svg +8 -0
- package/hmu/images/countries/ba.svg +12 -0
- package/hmu/images/countries/bb.svg +6 -0
- package/hmu/images/countries/bd.svg +4 -0
- package/hmu/images/countries/be.svg +7 -0
- package/hmu/images/countries/bf.svg +7 -0
- package/hmu/images/countries/bg.svg +7 -0
- package/hmu/images/countries/bh.svg +11 -0
- package/hmu/images/countries/bi.svg +15 -0
- package/hmu/images/countries/bj.svg +14 -0
- package/hmu/images/countries/bl.svg +7 -0
- package/hmu/images/countries/bm.svg +99 -0
- package/hmu/images/countries/bn.svg +36 -0
- package/hmu/images/countries/bo.svg +686 -0
- package/hmu/images/countries/bq.svg +5 -0
- package/hmu/images/countries/br.svg +45 -0
- package/hmu/images/countries/bs.svg +13 -0
- package/hmu/images/countries/bt.svg +89 -0
- package/hmu/images/countries/bv.svg +13 -0
- package/hmu/images/countries/bw.svg +7 -0
- package/hmu/images/countries/by.svg +61 -0
- package/hmu/images/countries/bz.svg +146 -0
- package/hmu/images/countries/ca.svg +4 -0
- package/hmu/images/countries/cc.svg +19 -0
- package/hmu/images/countries/cd.svg +5 -0
- package/hmu/images/countries/cf.svg +15 -0
- package/hmu/images/countries/cg.svg +12 -0
- package/hmu/images/countries/ch.svg +9 -0
- package/hmu/images/countries/ci.svg +7 -0
- package/hmu/images/countries/ck.svg +9 -0
- package/hmu/images/countries/cl.svg +13 -0
- package/hmu/images/countries/cm.svg +15 -0
- package/hmu/images/countries/cn.svg +11 -0
- package/hmu/images/countries/co.svg +7 -0
- package/hmu/images/countries/cr.svg +7 -0
- package/hmu/images/countries/cu.svg +13 -0
- package/hmu/images/countries/cv.svg +13 -0
- package/hmu/images/countries/cw.svg +14 -0
- package/hmu/images/countries/cx.svg +15 -0
- package/hmu/images/countries/cy.svg +6 -0
- package/hmu/images/countries/cz.svg +12 -0
- package/hmu/images/countries/de.svg +5 -0
- package/hmu/images/countries/dj.svg +13 -0
- package/hmu/images/countries/dk.svg +5 -0
- package/hmu/images/countries/dm.svg +152 -0
- package/hmu/images/countries/do.svg +6745 -0
- package/hmu/images/countries/dz.svg +5 -0
- package/hmu/images/countries/ec.svg +141 -0
- package/hmu/images/countries/ee.svg +7 -0
- package/hmu/images/countries/eg.svg +38 -0
- package/hmu/images/countries/eh.svg +15 -0
- package/hmu/images/countries/er.svg +8 -0
- package/hmu/images/countries/es-ct.svg +4 -0
- package/hmu/images/countries/es.svg +581 -0
- package/hmu/images/countries/et.svg +14 -0
- package/hmu/images/countries/eu.svg +28 -0
- package/hmu/images/countries/fi.svg +5 -0
- package/hmu/images/countries/fj.svg +124 -0
- package/hmu/images/countries/fk.svg +90 -0
- package/hmu/images/countries/fm.svg +11 -0
- package/hmu/images/countries/fo.svg +12 -0
- package/hmu/images/countries/fr.svg +7 -0
- package/hmu/images/countries/ga.svg +7 -0
- package/hmu/images/countries/gb-eng.svg +5 -0
- package/hmu/images/countries/gb-nir.svg +137 -0
- package/hmu/images/countries/gb-sct.svg +4 -0
- package/hmu/images/countries/gb-wls.svg +9 -0
- package/hmu/images/countries/gb.svg +15 -0
- package/hmu/images/countries/gd.svg +27 -0
- package/hmu/images/countries/ge.svg +6 -0
- package/hmu/images/countries/gf.svg +5 -0
- package/hmu/images/countries/gg.svg +9 -0
- package/hmu/images/countries/gh.svg +6 -0
- package/hmu/images/countries/gi.svg +33 -0
- package/hmu/images/countries/gl.svg +4 -0
- package/hmu/images/countries/gm.svg +14 -0
- package/hmu/images/countries/gn.svg +7 -0
- package/hmu/images/countries/gp.svg +7 -0
- package/hmu/images/countries/gq.svg +23 -0
- package/hmu/images/countries/gr.svg +22 -0
- package/hmu/images/countries/gs.svg +205 -0
- package/hmu/images/countries/gt.svg +204 -0
- package/hmu/images/countries/gu.svg +39 -0
- package/hmu/images/countries/gw.svg +13 -0
- package/hmu/images/countries/gy.svg +9 -0
- package/hmu/images/countries/hk.svg +32 -0
- package/hmu/images/countries/hm.svg +9 -0
- package/hmu/images/countries/hn.svg +18 -0
- package/hmu/images/countries/hr.svg +59 -0
- package/hmu/images/countries/ht.svg +122 -0
- package/hmu/images/countries/hu.svg +7 -0
- package/hmu/images/countries/id.svg +6 -0
- package/hmu/images/countries/ie.svg +7 -0
- package/hmu/images/countries/il.svg +14 -0
- package/hmu/images/countries/im.svg +36 -0
- package/hmu/images/countries/in.svg +25 -0
- package/hmu/images/countries/io.svg +148 -0
- package/hmu/images/countries/iq.svg +10 -0
- package/hmu/images/countries/ir.svg +219 -0
- package/hmu/images/countries/is.svg +12 -0
- package/hmu/images/countries/it.svg +7 -0
- package/hmu/images/countries/je.svg +32 -0
- package/hmu/images/countries/jm.svg +8 -0
- package/hmu/images/countries/jo.svg +16 -0
- package/hmu/images/countries/jp.svg +11 -0
- package/hmu/images/countries/ke.svg +23 -0
- package/hmu/images/countries/kg.svg +15 -0
- package/hmu/images/countries/kh.svg +69 -0
- package/hmu/images/countries/ki.svg +36 -0
- package/hmu/images/countries/km.svg +16 -0
- package/hmu/images/countries/kn.svg +14 -0
- package/hmu/images/countries/kp.svg +15 -0
- package/hmu/images/countries/kr.svg +24 -0
- package/hmu/images/countries/kw.svg +13 -0
- package/hmu/images/countries/ky.svg +63 -0
- package/hmu/images/countries/kz.svg +23 -0
- package/hmu/images/countries/la.svg +12 -0
- package/hmu/images/countries/lb.svg +15 -0
- package/hmu/images/countries/lc.svg +8 -0
- package/hmu/images/countries/li.svg +43 -0
- package/hmu/images/countries/lk.svg +22 -0
- package/hmu/images/countries/lr.svg +14 -0
- package/hmu/images/countries/ls.svg +8 -0
- package/hmu/images/countries/lt.svg +7 -0
- package/hmu/images/countries/lu.svg +5 -0
- package/hmu/images/countries/lv.svg +6 -0
- package/hmu/images/countries/ly.svg +13 -0
- package/hmu/images/countries/ma.svg +4 -0
- package/hmu/images/countries/mc.svg +6 -0
- package/hmu/images/countries/md.svg +72 -0
- package/hmu/images/countries/me.svg +118 -0
- package/hmu/images/countries/mf.svg +7 -0
- package/hmu/images/countries/mg.svg +7 -0
- package/hmu/images/countries/mh.svg +7 -0
- package/hmu/images/countries/mk.svg +5 -0
- package/hmu/images/countries/ml.svg +7 -0
- package/hmu/images/countries/mm.svg +16 -0
- package/hmu/images/countries/mn.svg +13 -0
- package/hmu/images/countries/mo.svg +9 -0
- package/hmu/images/countries/mp.svg +86 -0
- package/hmu/images/countries/mq.svg +7 -0
- package/hmu/images/countries/mr.svg +6 -0
- package/hmu/images/countries/ms.svg +39 -0
- package/hmu/images/countries/mt.svg +49 -0
- package/hmu/images/countries/mu.svg +8 -0
- package/hmu/images/countries/mv.svg +6 -0
- package/hmu/images/countries/mw.svg +10 -0
- package/hmu/images/countries/mx.svg +385 -0
- package/hmu/images/countries/my.svg +15 -0
- package/hmu/images/countries/mz.svg +21 -0
- package/hmu/images/countries/na.svg +16 -0
- package/hmu/images/countries/nc.svg +7 -0
- package/hmu/images/countries/ne.svg +6 -0
- package/hmu/images/countries/nf.svg +9 -0
- package/hmu/images/countries/ng.svg +6 -0
- package/hmu/images/countries/ni.svg +131 -0
- package/hmu/images/countries/nl.svg +7 -0
- package/hmu/images/countries/no.svg +7 -0
- package/hmu/images/countries/np.svg +14 -0
- package/hmu/images/countries/nr.svg +12 -0
- package/hmu/images/countries/nu.svg +26 -0
- package/hmu/images/countries/nz.svg +41 -0
- package/hmu/images/countries/om.svg +116 -0
- package/hmu/images/countries/pa.svg +14 -0
- package/hmu/images/countries/pe.svg +279 -0
- package/hmu/images/countries/pf.svg +19 -0
- package/hmu/images/countries/pg.svg +9 -0
- package/hmu/images/countries/ph.svg +28 -0
- package/hmu/images/countries/pk.svg +15 -0
- package/hmu/images/countries/pl.svg +6 -0
- package/hmu/images/countries/pm.svg +7 -0
- package/hmu/images/countries/pn.svg +62 -0
- package/hmu/images/countries/pr.svg +13 -0
- package/hmu/images/countries/ps.svg +15 -0
- package/hmu/images/countries/pt.svg +57 -0
- package/hmu/images/countries/pw.svg +11 -0
- package/hmu/images/countries/py.svg +157 -0
- package/hmu/images/countries/qa.svg +4 -0
- package/hmu/images/countries/re.svg +7 -0
- package/hmu/images/countries/ro.svg +7 -0
- package/hmu/images/countries/rs.svg +292 -0
- package/hmu/images/countries/ru.svg +7 -0
- package/hmu/images/countries/rw.svg +13 -0
- package/hmu/images/countries/sa.svg +26 -0
- package/hmu/images/countries/sb.svg +13 -0
- package/hmu/images/countries/sc.svg +14 -0
- package/hmu/images/countries/sd.svg +13 -0
- package/hmu/images/countries/se.svg +16 -0
- package/hmu/images/countries/sg.svg +13 -0
- package/hmu/images/countries/sh.svg +74 -0
- package/hmu/images/countries/si.svg +18 -0
- package/hmu/images/countries/sj.svg +7 -0
- package/hmu/images/countries/sk.svg +9 -0
- package/hmu/images/countries/sl.svg +7 -0
- package/hmu/images/countries/sm.svg +91 -0
- package/hmu/images/countries/sn.svg +8 -0
- package/hmu/images/countries/so.svg +11 -0
- package/hmu/images/countries/sr.svg +6 -0
- package/hmu/images/countries/ss.svg +8 -0
- package/hmu/images/countries/st.svg +16 -0
- package/hmu/images/countries/sv.svg +618 -0
- package/hmu/images/countries/sx.svg +56 -0
- package/hmu/images/countries/sy.svg +6 -0
- package/hmu/images/countries/sz.svg +45 -0
- package/hmu/images/countries/tc.svg +67 -0
- package/hmu/images/countries/td.svg +7 -0
- package/hmu/images/countries/tf.svg +15 -0
- package/hmu/images/countries/tg.svg +14 -0
- package/hmu/images/countries/th.svg +7 -0
- package/hmu/images/countries/tj.svg +22 -0
- package/hmu/images/countries/tk.svg +5 -0
- package/hmu/images/countries/tl.svg +13 -0
- package/hmu/images/countries/tm.svg +213 -0
- package/hmu/images/countries/tn.svg +13 -0
- package/hmu/images/countries/to.svg +10 -0
- package/hmu/images/countries/tr.svg +8 -0
- package/hmu/images/countries/tt.svg +5 -0
- package/hmu/images/countries/tv.svg +27 -0
- package/hmu/images/countries/tw.svg +14 -0
- package/hmu/images/countries/tz.svg +13 -0
- package/hmu/images/countries/ua.svg +6 -0
- package/hmu/images/countries/ug.svg +30 -0
- package/hmu/images/countries/um.svg +23 -0
- package/hmu/images/countries/un.svg +16 -0
- package/hmu/images/countries/us.svg +12 -0
- package/hmu/images/countries/uy.svg +28 -0
- package/hmu/images/countries/uz.svg +30 -0
- package/hmu/images/countries/va.svg +483 -0
- package/hmu/images/countries/vc.svg +8 -0
- package/hmu/images/countries/ve.svg +26 -0
- package/hmu/images/countries/vg.svg +133 -0
- package/hmu/images/countries/vi.svg +31 -0
- package/hmu/images/countries/vn.svg +11 -0
- package/hmu/images/countries/vu.svg +18 -0
- package/hmu/images/countries/wf.svg +7 -0
- package/hmu/images/countries/ws.svg +7 -0
- package/hmu/images/countries/ye.svg +7 -0
- package/hmu/images/countries/yt.svg +7 -0
- package/hmu/images/countries/za.svg +17 -0
- package/hmu/images/countries/zm.svg +27 -0
- package/hmu/images/countries/zw.svg +21 -0
- package/hmu/images/hipay-white-logo.svg +42 -0
- package/hmu/images/logo_visa_75wx45h.gif +0 -0
- package/index.es.js +1 -1
- package/index.js +1 -1
- package/package.json +4 -3
- package/styles/createHiMuiTheme.js +11 -0
- package/umd/hipay-material-ui.development.js +11339 -11003
- package/umd/hipay-material-ui.production.min.js +5 -5
- package/utils/HiIconBuilder.js +17 -7
- 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:
|
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:
|
156
|
+
className: classes.popper
|
166
157
|
},
|
167
158
|
React.createElement(
|
168
|
-
|
169
|
-
{
|
159
|
+
Grow,
|
160
|
+
{ 'in': open, id: 'menu-list', style: { transformOrigin: '0 0 0' } },
|
170
161
|
React.createElement(
|
171
|
-
|
172
|
-
{
|
173
|
-
React.createElement(
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
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
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
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
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
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
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
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 {
|
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
|
-
*
|
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
|
-
|
277
|
+
refElement: PropTypes.func,
|
257
278
|
/**
|
258
|
-
*
|
279
|
+
* Valeur à afficher (déjà formattée)
|
259
280
|
*/
|
260
|
-
|
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:
|
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
|
*/
|