@dnb/eufemia 10.56.0 → 10.57.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +41 -0
- package/assets/flags/1x1/ad.svg +148 -0
- package/assets/flags/1x1/ae.svg +6 -0
- package/assets/flags/1x1/af.svg +81 -0
- package/assets/flags/1x1/ag.svg +14 -0
- package/assets/flags/1x1/ai.svg +29 -0
- package/assets/flags/1x1/al.svg +5 -0
- package/assets/flags/1x1/am.svg +5 -0
- package/assets/flags/1x1/ao.svg +13 -0
- package/assets/flags/1x1/aq.svg +5 -0
- package/assets/flags/1x1/ar.svg +32 -0
- package/assets/flags/1x1/arab.svg +109 -0
- package/assets/flags/1x1/as.svg +73 -0
- package/assets/flags/1x1/at.svg +4 -0
- package/assets/flags/1x1/au.svg +8 -0
- package/assets/flags/1x1/aw.svg +186 -0
- package/assets/flags/1x1/ax.svg +18 -0
- package/assets/flags/1x1/az.svg +8 -0
- package/assets/flags/1x1/ba.svg +12 -0
- package/assets/flags/1x1/bb.svg +6 -0
- package/assets/flags/1x1/bd.svg +4 -0
- package/assets/flags/1x1/be.svg +7 -0
- package/assets/flags/1x1/bf.svg +7 -0
- package/assets/flags/1x1/bg.svg +5 -0
- package/assets/flags/1x1/bh.svg +4 -0
- package/assets/flags/1x1/bi.svg +15 -0
- package/assets/flags/1x1/bj.svg +14 -0
- package/assets/flags/1x1/bl.svg +7 -0
- package/assets/flags/1x1/bm.svg +97 -0
- package/assets/flags/1x1/bn.svg +36 -0
- package/assets/flags/1x1/bo.svg +674 -0
- package/assets/flags/1x1/bq.svg +5 -0
- package/assets/flags/1x1/br.svg +45 -0
- package/assets/flags/1x1/bs.svg +13 -0
- package/assets/flags/1x1/bt.svg +89 -0
- package/assets/flags/1x1/bv.svg +13 -0
- package/assets/flags/1x1/bw.svg +7 -0
- package/assets/flags/1x1/by.svg +18 -0
- package/assets/flags/1x1/bz.svg +145 -0
- package/assets/flags/1x1/ca.svg +4 -0
- package/assets/flags/1x1/cc.svg +19 -0
- package/assets/flags/1x1/cd.svg +12 -0
- package/assets/flags/1x1/cefta.svg +13 -0
- package/assets/flags/1x1/cf.svg +15 -0
- package/assets/flags/1x1/cg.svg +12 -0
- package/assets/flags/1x1/ch.svg +9 -0
- package/assets/flags/1x1/ci.svg +7 -0
- package/assets/flags/1x1/ck.svg +9 -0
- package/assets/flags/1x1/cl.svg +13 -0
- package/assets/flags/1x1/cm.svg +15 -0
- package/assets/flags/1x1/cn.svg +11 -0
- package/assets/flags/1x1/co.svg +7 -0
- package/assets/flags/1x1/cp.svg +7 -0
- package/assets/flags/1x1/cr.svg +7 -0
- package/assets/flags/1x1/cu.svg +13 -0
- package/assets/flags/1x1/cv.svg +13 -0
- package/assets/flags/1x1/cw.svg +14 -0
- package/assets/flags/1x1/cx.svg +15 -0
- package/assets/flags/1x1/cy.svg +6 -0
- package/assets/flags/1x1/cz.svg +5 -0
- package/assets/flags/1x1/de.svg +5 -0
- package/assets/flags/1x1/dg.svg +130 -0
- package/assets/flags/1x1/dj.svg +13 -0
- package/assets/flags/1x1/dk.svg +5 -0
- package/assets/flags/1x1/dm.svg +152 -0
- package/assets/flags/1x1/do.svg +123 -0
- package/assets/flags/1x1/dz.svg +5 -0
- package/assets/flags/1x1/eac.svg +48 -0
- package/assets/flags/1x1/ec.svg +138 -0
- package/assets/flags/1x1/ee.svg +5 -0
- package/assets/flags/1x1/eg.svg +38 -0
- package/assets/flags/1x1/eh.svg +11 -0
- package/assets/flags/1x1/er.svg +13 -0
- package/assets/flags/1x1/es-ct.svg +4 -0
- package/assets/flags/1x1/es-ga.svg +187 -0
- package/assets/flags/1x1/es-pv.svg +5 -0
- package/assets/flags/1x1/es.svg +547 -0
- package/assets/flags/1x1/et.svg +14 -0
- package/assets/flags/1x1/eu.svg +28 -0
- package/assets/flags/1x1/fi.svg +5 -0
- package/assets/flags/1x1/fj.svg +123 -0
- package/assets/flags/1x1/fk.svg +89 -0
- package/assets/flags/1x1/fm.svg +11 -0
- package/assets/flags/1x1/fo.svg +12 -0
- package/assets/flags/1x1/fr.svg +5 -0
- package/assets/flags/1x1/ga.svg +7 -0
- package/assets/flags/1x1/gb-eng.svg +5 -0
- package/assets/flags/1x1/gb-nir.svg +131 -0
- package/assets/flags/1x1/gb-sct.svg +4 -0
- package/assets/flags/1x1/gb-wls.svg +9 -0
- package/assets/flags/1x1/gb.svg +7 -0
- package/assets/flags/1x1/gd.svg +27 -0
- package/assets/flags/1x1/ge.svg +6 -0
- package/assets/flags/1x1/gf.svg +5 -0
- package/assets/flags/1x1/gg.svg +9 -0
- package/assets/flags/1x1/gh.svg +6 -0
- package/assets/flags/1x1/gi.svg +32 -0
- package/assets/flags/1x1/gl.svg +4 -0
- package/assets/flags/1x1/gm.svg +9 -0
- package/assets/flags/1x1/gn.svg +7 -0
- package/assets/flags/1x1/gp.svg +5 -0
- package/assets/flags/1x1/gq.svg +23 -0
- package/assets/flags/1x1/gr.svg +16 -0
- package/assets/flags/1x1/gs.svg +132 -0
- package/assets/flags/1x1/gt.svg +204 -0
- package/assets/flags/1x1/gu.svg +23 -0
- package/assets/flags/1x1/gw.svg +15 -0
- package/assets/flags/1x1/gy.svg +9 -0
- package/assets/flags/1x1/hk.svg +8 -0
- package/assets/flags/1x1/hm.svg +8 -0
- package/assets/flags/1x1/hn.svg +18 -0
- package/assets/flags/1x1/hr.svg +56 -0
- package/assets/flags/1x1/ht.svg +116 -0
- package/assets/flags/1x1/hu.svg +7 -0
- package/assets/flags/1x1/ic.svg +7 -0
- package/assets/flags/1x1/id.svg +4 -0
- package/assets/flags/1x1/ie.svg +7 -0
- package/assets/flags/1x1/il.svg +14 -0
- package/assets/flags/1x1/im.svg +36 -0
- package/assets/flags/1x1/in.svg +25 -0
- package/assets/flags/1x1/io.svg +130 -0
- package/assets/flags/1x1/iq.svg +10 -0
- package/assets/flags/1x1/ir.svg +219 -0
- package/assets/flags/1x1/is.svg +12 -0
- package/assets/flags/1x1/it.svg +7 -0
- package/assets/flags/1x1/je.svg +62 -0
- package/assets/flags/1x1/jm.svg +8 -0
- package/assets/flags/1x1/jo.svg +16 -0
- package/assets/flags/1x1/jp.svg +11 -0
- package/assets/flags/1x1/ke.svg +23 -0
- package/assets/flags/1x1/kg.svg +15 -0
- package/assets/flags/1x1/kh.svg +61 -0
- package/assets/flags/1x1/ki.svg +36 -0
- package/assets/flags/1x1/km.svg +16 -0
- package/assets/flags/1x1/kn.svg +14 -0
- package/assets/flags/1x1/kp.svg +15 -0
- package/assets/flags/1x1/kr.svg +17 -0
- package/assets/flags/1x1/kw.svg +13 -0
- package/assets/flags/1x1/ky.svg +103 -0
- package/assets/flags/1x1/kz.svg +36 -0
- package/assets/flags/1x1/la.svg +12 -0
- package/assets/flags/1x1/lb.svg +15 -0
- package/assets/flags/1x1/lc.svg +8 -0
- package/assets/flags/1x1/li.svg +43 -0
- package/assets/flags/1x1/lk.svg +22 -0
- package/assets/flags/1x1/lr.svg +14 -0
- package/assets/flags/1x1/ls.svg +8 -0
- package/assets/flags/1x1/lt.svg +7 -0
- package/assets/flags/1x1/lu.svg +5 -0
- package/assets/flags/1x1/lv.svg +6 -0
- package/assets/flags/1x1/ly.svg +13 -0
- package/assets/flags/1x1/ma.svg +4 -0
- package/assets/flags/1x1/mc.svg +6 -0
- package/assets/flags/1x1/md.svg +71 -0
- package/assets/flags/1x1/me.svg +118 -0
- package/assets/flags/1x1/mf.svg +5 -0
- package/assets/flags/1x1/mg.svg +7 -0
- package/assets/flags/1x1/mh.svg +8 -0
- package/assets/flags/1x1/mk.svg +5 -0
- package/assets/flags/1x1/ml.svg +7 -0
- package/assets/flags/1x1/mm.svg +10 -0
- package/assets/flags/1x1/mn.svg +14 -0
- package/assets/flags/1x1/mo.svg +9 -0
- package/assets/flags/1x1/mp.svg +86 -0
- package/assets/flags/1x1/mq.svg +5 -0
- package/assets/flags/1x1/mr.svg +6 -0
- package/assets/flags/1x1/ms.svg +25 -0
- package/assets/flags/1x1/mt.svg +56 -0
- package/assets/flags/1x1/mu.svg +8 -0
- package/assets/flags/1x1/mv.svg +6 -0
- package/assets/flags/1x1/mw.svg +15 -0
- package/assets/flags/1x1/mx.svg +377 -0
- package/assets/flags/1x1/my.svg +18 -0
- package/assets/flags/1x1/mz.svg +21 -0
- package/assets/flags/1x1/na.svg +16 -0
- package/assets/flags/1x1/nc.svg +12 -0
- package/assets/flags/1x1/ne.svg +6 -0
- package/assets/flags/1x1/nf.svg +11 -0
- package/assets/flags/1x1/ng.svg +6 -0
- package/assets/flags/1x1/ni.svg +129 -0
- package/assets/flags/1x1/nl.svg +5 -0
- package/assets/flags/1x1/no.svg +7 -0
- package/assets/flags/1x1/np.svg +18 -0
- package/assets/flags/1x1/nr.svg +12 -0
- package/assets/flags/1x1/nu.svg +10 -0
- package/assets/flags/1x1/nz.svg +36 -0
- package/assets/flags/1x1/om.svg +115 -0
- package/assets/flags/1x1/pa.svg +13 -0
- package/assets/flags/1x1/pc.svg +33 -0
- package/assets/flags/1x1/pe.svg +4 -0
- package/assets/flags/1x1/pf.svg +18 -0
- package/assets/flags/1x1/pg.svg +16 -0
- package/assets/flags/1x1/ph.svg +6 -0
- package/assets/flags/1x1/pk.svg +15 -0
- package/assets/flags/1x1/pl.svg +6 -0
- package/assets/flags/1x1/pm.svg +5 -0
- package/assets/flags/1x1/pn.svg +53 -0
- package/assets/flags/1x1/pr.svg +13 -0
- package/assets/flags/1x1/ps.svg +15 -0
- package/assets/flags/1x1/pt.svg +57 -0
- package/assets/flags/1x1/pw.svg +11 -0
- package/assets/flags/1x1/py.svg +156 -0
- package/assets/flags/1x1/qa.svg +4 -0
- package/assets/flags/1x1/re.svg +7 -0
- package/assets/flags/1x1/ro.svg +7 -0
- package/assets/flags/1x1/rs.svg +296 -0
- package/assets/flags/1x1/ru.svg +5 -0
- package/assets/flags/1x1/rw.svg +13 -0
- package/assets/flags/1x1/sa.svg +25 -0
- package/assets/flags/1x1/sb.svg +13 -0
- package/assets/flags/1x1/sc.svg +7 -0
- package/assets/flags/1x1/sd.svg +13 -0
- package/assets/flags/1x1/se.svg +4 -0
- package/assets/flags/1x1/sg.svg +13 -0
- package/assets/flags/1x1/sh-ac.svg +690 -0
- package/assets/flags/1x1/sh-hl.svg +164 -0
- package/assets/flags/1x1/sh-ta.svg +76 -0
- package/assets/flags/1x1/sh.svg +7 -0
- package/assets/flags/1x1/si.svg +18 -0
- package/assets/flags/1x1/sj.svg +7 -0
- package/assets/flags/1x1/sk.svg +9 -0
- package/assets/flags/1x1/sl.svg +12 -0
- package/assets/flags/1x1/sm.svg +73 -0
- package/assets/flags/1x1/sn.svg +8 -0
- package/assets/flags/1x1/so.svg +11 -0
- package/assets/flags/1x1/sr.svg +6 -0
- package/assets/flags/1x1/ss.svg +8 -0
- package/assets/flags/1x1/st.svg +16 -0
- package/assets/flags/1x1/sv.svg +594 -0
- package/assets/flags/1x1/sx.svg +56 -0
- package/assets/flags/1x1/sy.svg +6 -0
- package/assets/flags/1x1/sz.svg +34 -0
- package/assets/flags/1x1/tc.svg +50 -0
- package/assets/flags/1x1/td.svg +7 -0
- package/assets/flags/1x1/tf.svg +15 -0
- package/assets/flags/1x1/tg.svg +14 -0
- package/assets/flags/1x1/th.svg +7 -0
- package/assets/flags/1x1/tj.svg +26 -0
- package/assets/flags/1x1/tk.svg +5 -0
- package/assets/flags/1x1/tl.svg +13 -0
- package/assets/flags/1x1/tm.svg +205 -0
- package/assets/flags/1x1/tn.svg +4 -0
- package/assets/flags/1x1/to.svg +10 -0
- package/assets/flags/1x1/tr.svg +8 -0
- package/assets/flags/1x1/tt.svg +7 -0
- package/assets/flags/1x1/tv.svg +9 -0
- package/assets/flags/1x1/tw.svg +32 -0
- package/assets/flags/1x1/tz.svg +15 -0
- package/assets/flags/1x1/ua.svg +6 -0
- package/assets/flags/1x1/ug.svg +30 -0
- package/assets/flags/1x1/um.svg +9 -0
- package/assets/flags/1x1/un.svg +16 -0
- package/assets/flags/1x1/us.svg +9 -0
- package/assets/flags/1x1/uy.svg +28 -0
- package/assets/flags/1x1/uz.svg +30 -0
- package/assets/flags/1x1/va.svg +190 -0
- package/assets/flags/1x1/vc.svg +8 -0
- package/assets/flags/1x1/ve.svg +26 -0
- package/assets/flags/1x1/vg.svg +59 -0
- package/assets/flags/1x1/vi.svg +28 -0
- package/assets/flags/1x1/vn.svg +11 -0
- package/assets/flags/1x1/vu.svg +21 -0
- package/assets/flags/1x1/wf.svg +5 -0
- package/assets/flags/1x1/ws.svg +7 -0
- package/assets/flags/1x1/xk.svg +5 -0
- package/assets/flags/1x1/xx.svg +4 -0
- package/assets/flags/1x1/ye.svg +7 -0
- package/assets/flags/1x1/yt.svg +5 -0
- package/assets/flags/1x1/za.svg +17 -0
- package/assets/flags/1x1/zm.svg +27 -0
- package/assets/flags/1x1/zw.svg +21 -0
- package/assets/flags/LICENSE +23 -0
- package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
- package/cjs/components/autocomplete/AutocompleteDocs.js +1 -1
- package/cjs/components/autocomplete/AutocompleteDocs.js.map +1 -1
- package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +2 -2
- package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
- package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +2 -2
- package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.css +2 -2
- package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.min.css +1 -1
- package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -2
- package/cjs/components/card/Card.d.ts +2 -1
- package/cjs/components/card/Card.js +3 -1
- package/cjs/components/card/Card.js.map +1 -1
- package/cjs/components/card/CardDocs.js +5 -0
- package/cjs/components/card/CardDocs.js.map +1 -1
- package/cjs/components/card/style/dnb-card.css +17 -10
- package/cjs/components/card/style/dnb-card.min.css +1 -1
- package/cjs/components/card/style/dnb-card.scss +26 -7
- package/cjs/components/country-flag/style/dnb-country-flag-icons.css +280 -272
- package/cjs/components/country-flag/style/dnb-country-flag-icons.min.css +1 -1
- package/cjs/components/country-flag/style/dnb-country-flag-icons.scss +280 -272
- package/cjs/components/dropdown/Dropdown.js.map +1 -1
- package/cjs/components/help-button/HelpButtonInline.d.ts +3 -0
- package/cjs/components/help-button/HelpButtonInline.js +8 -4
- package/cjs/components/help-button/HelpButtonInline.js.map +1 -1
- package/cjs/components/help-button/style/dnb-help-button-inline.css +6 -5
- package/cjs/components/help-button/style/dnb-help-button-inline.min.css +1 -1
- package/cjs/components/help-button/style/dnb-help-button-inline.scss +6 -11
- package/cjs/components/help-button/style/dnb-help-button.css +6 -5
- package/cjs/components/help-button/style/dnb-help-button.min.css +1 -1
- package/cjs/components/icon/Icon.js +5 -0
- package/cjs/components/icon/Icon.js.map +1 -1
- package/cjs/components/modal/parts/ModalHeader.d.ts +2 -1
- package/cjs/components/modal/parts/ModalHeader.js.map +1 -1
- package/cjs/components/section/Section.d.ts +5 -0
- package/cjs/components/section/Section.js +4 -3
- package/cjs/components/section/Section.js.map +1 -1
- package/cjs/components/section/SectionDocs.d.ts +2 -0
- package/cjs/components/section/SectionDocs.js +65 -0
- package/cjs/components/section/SectionDocs.js.map +1 -0
- package/cjs/components/section/style/dnb-section.css +12 -0
- package/cjs/components/section/style/dnb-section.min.css +3 -3
- package/cjs/components/section/style/dnb-section.scss +22 -0
- package/cjs/core/jest/jestSetupScreenshots.css +11 -1
- package/cjs/elements/lib.d.ts +10 -1
- package/cjs/elements/span/Span.d.ts +13 -4
- package/cjs/elements/span/Span.js +3 -3
- package/cjs/elements/span/Span.js.map +1 -1
- package/cjs/elements/span/SpanDocs.d.ts +2 -0
- package/cjs/elements/span/SpanDocs.js +15 -0
- package/cjs/elements/span/SpanDocs.js.map +1 -0
- package/cjs/elements/typography/Ingress.js +1 -1
- package/cjs/elements/typography/Ingress.js.map +1 -1
- package/cjs/elements/typography/P.d.ts +10 -16
- package/cjs/elements/typography/P.js +54 -24
- package/cjs/elements/typography/P.js.map +1 -1
- package/cjs/elements/typography/PDocs.js +14 -23
- package/cjs/elements/typography/PDocs.js.map +1 -1
- package/cjs/elements/typography/Typography.d.ts +55 -0
- package/cjs/elements/typography/Typography.js +37 -0
- package/cjs/elements/typography/Typography.js.map +1 -0
- package/cjs/elements/typography/TypographyDocs.d.ts +2 -0
- package/cjs/elements/typography/TypographyDocs.js +55 -0
- package/cjs/elements/typography/TypographyDocs.js.map +1 -0
- package/cjs/elements/typography/style/_dnb-t.scss +93 -0
- package/cjs/elements/typography/style/dnb-typography.scss +2 -1
- package/cjs/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +0 -1
- package/cjs/elements/typography/style/typography-mixins.scss +25 -15
- package/cjs/extensions/forms/DataContext/Provider/Provider.js +1 -1
- package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
- package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +3 -2
- package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/Option/Option.js +1 -1
- package/cjs/extensions/forms/Field/Option/Option.js.map +1 -1
- package/cjs/extensions/forms/Field/Option/OptionDocs.js +9 -4
- package/cjs/extensions/forms/Field/Option/OptionDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
- package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +2 -1
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +8 -10
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
- package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +1 -0
- package/cjs/extensions/forms/Field/Selection/Selection.d.ts +12 -2
- package/cjs/extensions/forms/Field/Selection/Selection.js +9 -5
- package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
- package/cjs/extensions/forms/Field/Upload/Upload.d.ts +1 -1
- package/cjs/extensions/forms/Field/Upload/Upload.js +17 -8
- package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
- package/cjs/extensions/forms/Field/Upload/UploadDocs.js +7 -1
- package/cjs/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlock.js +15 -6
- package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlockContext.d.ts +3 -2
- package/cjs/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +16 -6
- package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
- package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +32 -20
- package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +4 -6
- package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
- package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +17 -9
- package/cjs/extensions/forms/Form/Card/Card.d.ts +6 -0
- package/cjs/extensions/forms/Form/Card/Card.js +20 -0
- package/cjs/extensions/forms/Form/Card/Card.js.map +1 -0
- package/cjs/extensions/forms/Form/Card/CardDocs.d.ts +2 -0
- package/cjs/extensions/forms/Form/Card/CardDocs.js +27 -0
- package/cjs/extensions/forms/Form/Card/CardDocs.js.map +1 -0
- package/cjs/extensions/forms/Form/Card/index.d.ts +2 -0
- package/cjs/extensions/forms/Form/Card/index.js +27 -0
- package/cjs/extensions/forms/Form/Card/index.js.map +1 -0
- package/cjs/extensions/forms/Form/index.d.ts +1 -0
- package/cjs/extensions/forms/Form/index.js +7 -0
- package/cjs/extensions/forms/Form/index.js.map +1 -1
- package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +1 -1
- package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/cjs/extensions/forms/Iterate/Array/types.d.ts +1 -1
- package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/cjs/extensions/forms/Value/Provider/useValueProvider.d.ts +1 -0
- package/cjs/extensions/forms/Value/SummaryList/SummaryList.d.ts +1 -1
- package/cjs/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
- package/cjs/extensions/forms/Value/ValueDocs.js +5 -0
- package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
- package/cjs/extensions/forms/ValueBlock/ValueBlock.js +4 -2
- package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
- package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
- package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
- package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
- package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +2 -7
- package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
- package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js +1 -1
- package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/cjs/extensions/forms/hooks/useFieldProps.js +50 -36
- package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/cjs/extensions/forms/style/dnb-forms.css +22 -14
- package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
- package/cjs/extensions/forms/types.d.ts +4 -0
- package/cjs/extensions/forms/types.js.map +1 -1
- package/cjs/extensions/payment-card/style/dnb-payment-card.css +1 -1
- package/cjs/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
- package/cjs/fragments/drawer-list/DrawerList.d.ts +22 -21
- package/cjs/fragments/drawer-list/DrawerList.js +14 -5
- package/cjs/fragments/drawer-list/DrawerList.js.map +1 -1
- package/cjs/fragments/drawer-list/DrawerListDocs.d.ts +1 -0
- package/cjs/fragments/drawer-list/DrawerListDocs.js +39 -6
- package/cjs/fragments/drawer-list/DrawerListDocs.js.map +1 -1
- package/cjs/fragments/drawer-list/DrawerListHelpers.js +13 -6
- package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
- package/cjs/fragments/drawer-list/DrawerListProvider.js +3 -0
- package/cjs/fragments/drawer-list/DrawerListProvider.js.map +1 -1
- package/cjs/fragments/drawer-list/style/dnb-drawer-list.scss +11 -0
- package/cjs/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +26 -19
- package/cjs/shared/Eufemia.d.ts +1 -1
- package/cjs/shared/Eufemia.js +2 -2
- package/cjs/shared/Eufemia.js.map +1 -1
- package/cjs/shared/VisibilityByTheme.d.ts +5 -2
- package/cjs/shared/VisibilityByTheme.js +12 -0
- package/cjs/shared/VisibilityByTheme.js.map +1 -1
- package/cjs/style/core/scopes.scss +1 -1
- package/cjs/style/dnb-ui-basis.css +1 -1
- package/cjs/style/dnb-ui-basis.min.css +1 -1
- package/cjs/style/dnb-ui-body.css +1 -1
- package/cjs/style/dnb-ui-body.min.css +1 -1
- package/cjs/style/dnb-ui-components.css +352 -306
- package/cjs/style/dnb-ui-components.min.css +6 -4
- package/cjs/style/dnb-ui-core.css +1 -1
- package/cjs/style/dnb-ui-core.min.css +1 -1
- package/cjs/style/dnb-ui-elements.css +91 -6
- package/cjs/style/dnb-ui-elements.min.css +1 -1
- package/cjs/style/dnb-ui-extensions.css +23 -15
- package/cjs/style/dnb-ui-extensions.min.css +1 -1
- package/cjs/style/dnb-ui-forms.css +22 -14
- package/cjs/style/dnb-ui-forms.min.css +1 -1
- package/cjs/style/dnb-ui-fragments.css +9 -0
- package/cjs/style/dnb-ui-fragments.min.css +3 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +92 -6
- package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +376 -322
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +8 -6
- package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +91 -6
- package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +23 -15
- package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +22 -14
- package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/properties.d.ts +2 -1
- package/cjs/style/themes/theme-eiendom/properties.js +2 -1
- package/cjs/style/themes/theme-eiendom/properties.js.map +1 -1
- package/cjs/style/themes/theme-sbanken/fonts.scss +7 -3
- package/cjs/style/themes/theme-sbanken/properties.d.ts +2 -1
- package/cjs/style/themes/theme-sbanken/properties.js +2 -1
- package/cjs/style/themes/theme-sbanken/properties.js.map +1 -1
- package/cjs/style/themes/theme-sbanken/properties.scss +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +101 -10
- package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +2 -2
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +396 -339
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +9 -7
- package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +91 -7
- package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +23 -15
- package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +22 -14
- package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/theme-mapping.scss +1 -0
- package/cjs/style/themes/theme-ui/properties.d.ts +2 -1
- package/cjs/style/themes/theme-ui/properties.js +2 -1
- package/cjs/style/themes/theme-ui/properties.js.map +1 -1
- package/cjs/style/themes/theme-ui/properties.scss +1 -0
- package/cjs/style/themes/theme-ui/ui-theme-basis.css +92 -6
- package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-components.css +376 -322
- package/cjs/style/themes/theme-ui/ui-theme-components.min.css +8 -6
- package/cjs/style/themes/theme-ui/ui-theme-elements.css +91 -6
- package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-extensions.css +23 -15
- package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-forms.css +22 -14
- package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-properties.css +1 -0
- package/cjs/style/themes/theme-ui/ui-theme-properties.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-tags.css +9 -5
- package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
- package/components/autocomplete/Autocomplete.js.map +1 -1
- package/components/autocomplete/AutocompleteDocs.js +1 -1
- package/components/autocomplete/AutocompleteDocs.js.map +1 -1
- package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +2 -2
- package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
- package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +2 -2
- package/components/avatar/style/themes/dnb-avatar-theme-sbanken.css +2 -2
- package/components/avatar/style/themes/dnb-avatar-theme-sbanken.min.css +1 -1
- package/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -2
- package/components/card/Card.d.ts +2 -1
- package/components/card/Card.js +3 -1
- package/components/card/Card.js.map +1 -1
- package/components/card/CardDocs.js +5 -0
- package/components/card/CardDocs.js.map +1 -1
- package/components/card/style/dnb-card.css +17 -10
- package/components/card/style/dnb-card.min.css +1 -1
- package/components/card/style/dnb-card.scss +26 -7
- package/components/country-flag/style/dnb-country-flag-icons.css +280 -272
- package/components/country-flag/style/dnb-country-flag-icons.min.css +1 -1
- package/components/country-flag/style/dnb-country-flag-icons.scss +280 -272
- package/components/dropdown/Dropdown.js.map +1 -1
- package/components/help-button/HelpButtonInline.d.ts +3 -0
- package/components/help-button/HelpButtonInline.js +8 -4
- package/components/help-button/HelpButtonInline.js.map +1 -1
- package/components/help-button/style/dnb-help-button-inline.css +6 -5
- package/components/help-button/style/dnb-help-button-inline.min.css +1 -1
- package/components/help-button/style/dnb-help-button-inline.scss +6 -11
- package/components/help-button/style/dnb-help-button.css +6 -5
- package/components/help-button/style/dnb-help-button.min.css +1 -1
- package/components/icon/Icon.js +5 -0
- package/components/icon/Icon.js.map +1 -1
- package/components/modal/parts/ModalHeader.d.ts +2 -1
- package/components/modal/parts/ModalHeader.js.map +1 -1
- package/components/section/Section.d.ts +5 -0
- package/components/section/Section.js +4 -3
- package/components/section/Section.js.map +1 -1
- package/components/section/SectionDocs.d.ts +2 -0
- package/components/section/SectionDocs.js +58 -0
- package/components/section/SectionDocs.js.map +1 -0
- package/components/section/style/dnb-section.css +12 -0
- package/components/section/style/dnb-section.min.css +3 -3
- package/components/section/style/dnb-section.scss +22 -0
- package/core/jest/jestSetupScreenshots.css +11 -1
- package/elements/lib.d.ts +10 -1
- package/elements/span/Span.d.ts +13 -4
- package/elements/span/Span.js +3 -3
- package/elements/span/Span.js.map +1 -1
- package/elements/span/SpanDocs.d.ts +2 -0
- package/elements/span/SpanDocs.js +6 -0
- package/elements/span/SpanDocs.js.map +1 -0
- package/elements/typography/Ingress.js +1 -1
- package/elements/typography/Ingress.js.map +1 -1
- package/elements/typography/P.d.ts +10 -16
- package/elements/typography/P.js +52 -24
- package/elements/typography/P.js.map +1 -1
- package/elements/typography/PDocs.js +12 -23
- package/elements/typography/PDocs.js.map +1 -1
- package/elements/typography/Typography.d.ts +55 -0
- package/elements/typography/Typography.js +28 -0
- package/elements/typography/Typography.js.map +1 -0
- package/elements/typography/TypographyDocs.d.ts +2 -0
- package/elements/typography/TypographyDocs.js +48 -0
- package/elements/typography/TypographyDocs.js.map +1 -0
- package/elements/typography/style/_dnb-t.scss +93 -0
- package/elements/typography/style/dnb-typography.scss +2 -1
- package/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +0 -1
- package/elements/typography/style/typography-mixins.scss +25 -15
- package/es/components/autocomplete/Autocomplete.js.map +1 -1
- package/es/components/autocomplete/AutocompleteDocs.js +1 -1
- package/es/components/autocomplete/AutocompleteDocs.js.map +1 -1
- package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +2 -2
- package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
- package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +2 -2
- package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.css +2 -2
- package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.min.css +1 -1
- package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -2
- package/es/components/card/Card.d.ts +2 -1
- package/es/components/card/Card.js +3 -1
- package/es/components/card/Card.js.map +1 -1
- package/es/components/card/CardDocs.js +5 -0
- package/es/components/card/CardDocs.js.map +1 -1
- package/es/components/card/style/dnb-card.css +17 -10
- package/es/components/card/style/dnb-card.min.css +1 -1
- package/es/components/card/style/dnb-card.scss +26 -7
- package/es/components/country-flag/style/dnb-country-flag-icons.css +280 -272
- package/es/components/country-flag/style/dnb-country-flag-icons.min.css +1 -1
- package/es/components/country-flag/style/dnb-country-flag-icons.scss +280 -272
- package/es/components/dropdown/Dropdown.js.map +1 -1
- package/es/components/help-button/HelpButtonInline.d.ts +3 -0
- package/es/components/help-button/HelpButtonInline.js +8 -4
- package/es/components/help-button/HelpButtonInline.js.map +1 -1
- package/es/components/help-button/style/dnb-help-button-inline.css +6 -5
- package/es/components/help-button/style/dnb-help-button-inline.min.css +1 -1
- package/es/components/help-button/style/dnb-help-button-inline.scss +6 -11
- package/es/components/help-button/style/dnb-help-button.css +6 -5
- package/es/components/help-button/style/dnb-help-button.min.css +1 -1
- package/es/components/icon/Icon.js +5 -0
- package/es/components/icon/Icon.js.map +1 -1
- package/es/components/modal/parts/ModalHeader.d.ts +2 -1
- package/es/components/modal/parts/ModalHeader.js.map +1 -1
- package/es/components/section/Section.d.ts +5 -0
- package/es/components/section/Section.js +4 -3
- package/es/components/section/Section.js.map +1 -1
- package/es/components/section/SectionDocs.d.ts +2 -0
- package/es/components/section/SectionDocs.js +58 -0
- package/es/components/section/SectionDocs.js.map +1 -0
- package/es/components/section/style/dnb-section.css +12 -0
- package/es/components/section/style/dnb-section.min.css +3 -3
- package/es/components/section/style/dnb-section.scss +22 -0
- package/es/core/jest/jestSetupScreenshots.css +11 -1
- package/es/elements/lib.d.ts +10 -1
- package/es/elements/span/Span.d.ts +13 -4
- package/es/elements/span/Span.js +3 -3
- package/es/elements/span/Span.js.map +1 -1
- package/es/elements/span/SpanDocs.d.ts +2 -0
- package/es/elements/span/SpanDocs.js +6 -0
- package/es/elements/span/SpanDocs.js.map +1 -0
- package/es/elements/typography/Ingress.js +1 -1
- package/es/elements/typography/Ingress.js.map +1 -1
- package/es/elements/typography/P.d.ts +10 -16
- package/es/elements/typography/P.js +52 -24
- package/es/elements/typography/P.js.map +1 -1
- package/es/elements/typography/PDocs.js +12 -23
- package/es/elements/typography/PDocs.js.map +1 -1
- package/es/elements/typography/Typography.d.ts +55 -0
- package/es/elements/typography/Typography.js +28 -0
- package/es/elements/typography/Typography.js.map +1 -0
- package/es/elements/typography/TypographyDocs.d.ts +2 -0
- package/es/elements/typography/TypographyDocs.js +48 -0
- package/es/elements/typography/TypographyDocs.js.map +1 -0
- package/es/elements/typography/style/_dnb-t.scss +93 -0
- package/es/elements/typography/style/dnb-typography.scss +2 -1
- package/es/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +0 -1
- package/es/elements/typography/style/typography-mixins.scss +25 -15
- package/es/extensions/forms/DataContext/Provider/Provider.js +1 -1
- package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
- package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
- package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +3 -2
- package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
- package/es/extensions/forms/Field/Option/Option.js +1 -1
- package/es/extensions/forms/Field/Option/Option.js.map +1 -1
- package/es/extensions/forms/Field/Option/OptionDocs.js +9 -4
- package/es/extensions/forms/Field/Option/OptionDocs.js.map +1 -1
- package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
- package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +2 -1
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +9 -11
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
- package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +1 -0
- package/es/extensions/forms/Field/Selection/Selection.d.ts +12 -2
- package/es/extensions/forms/Field/Selection/Selection.js +9 -5
- package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
- package/es/extensions/forms/Field/Upload/Upload.d.ts +1 -1
- package/es/extensions/forms/Field/Upload/Upload.js +16 -8
- package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
- package/es/extensions/forms/Field/Upload/UploadDocs.js +7 -1
- package/es/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
- package/es/extensions/forms/FieldBlock/FieldBlock.js +15 -6
- package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/es/extensions/forms/FieldBlock/FieldBlockContext.d.ts +3 -2
- package/es/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
- package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +16 -6
- package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
- package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +32 -20
- package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +4 -6
- package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
- package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +17 -9
- package/es/extensions/forms/Form/Card/Card.d.ts +6 -0
- package/es/extensions/forms/Form/Card/Card.js +12 -0
- package/es/extensions/forms/Form/Card/Card.js.map +1 -0
- package/es/extensions/forms/Form/Card/CardDocs.d.ts +2 -0
- package/es/extensions/forms/Form/Card/CardDocs.js +18 -0
- package/es/extensions/forms/Form/Card/CardDocs.js.map +1 -0
- package/es/extensions/forms/Form/Card/index.d.ts +2 -0
- package/es/extensions/forms/Form/Card/index.js +3 -0
- package/es/extensions/forms/Form/Card/index.js.map +1 -0
- package/es/extensions/forms/Form/index.d.ts +1 -0
- package/es/extensions/forms/Form/index.js +1 -0
- package/es/extensions/forms/Form/index.js.map +1 -1
- package/es/extensions/forms/Iterate/Array/ArrayDocs.js +1 -1
- package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/es/extensions/forms/Iterate/Array/types.d.ts +1 -1
- package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/es/extensions/forms/Value/Provider/useValueProvider.d.ts +1 -0
- package/es/extensions/forms/Value/SummaryList/SummaryList.d.ts +1 -1
- package/es/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
- package/es/extensions/forms/Value/ValueDocs.js +5 -0
- package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
- package/es/extensions/forms/ValueBlock/ValueBlock.js +4 -2
- package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
- package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
- package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
- package/es/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
- package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +2 -7
- package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
- package/es/extensions/forms/hooks/DataValueWritePropsDocs.js +1 -1
- package/es/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/es/extensions/forms/hooks/useFieldProps.js +50 -36
- package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/es/extensions/forms/style/dnb-forms.css +22 -14
- package/es/extensions/forms/style/dnb-forms.min.css +1 -1
- package/es/extensions/forms/types.d.ts +4 -0
- package/es/extensions/forms/types.js.map +1 -1
- package/es/extensions/payment-card/style/dnb-payment-card.css +1 -1
- package/es/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
- package/es/fragments/drawer-list/DrawerList.d.ts +22 -21
- package/es/fragments/drawer-list/DrawerList.js +14 -5
- package/es/fragments/drawer-list/DrawerList.js.map +1 -1
- package/es/fragments/drawer-list/DrawerListDocs.d.ts +1 -0
- package/es/fragments/drawer-list/DrawerListDocs.js +37 -5
- package/es/fragments/drawer-list/DrawerListDocs.js.map +1 -1
- package/es/fragments/drawer-list/DrawerListHelpers.js +13 -6
- package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
- package/es/fragments/drawer-list/DrawerListProvider.js +3 -0
- package/es/fragments/drawer-list/DrawerListProvider.js.map +1 -1
- package/es/fragments/drawer-list/style/dnb-drawer-list.scss +11 -0
- package/es/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +26 -19
- package/es/shared/Eufemia.d.ts +1 -1
- package/es/shared/Eufemia.js +2 -2
- package/es/shared/Eufemia.js.map +1 -1
- package/es/shared/VisibilityByTheme.d.ts +5 -2
- package/es/shared/VisibilityByTheme.js +12 -0
- package/es/shared/VisibilityByTheme.js.map +1 -1
- package/es/style/core/scopes.scss +1 -1
- package/es/style/dnb-ui-basis.css +1 -1
- package/es/style/dnb-ui-basis.min.css +1 -1
- package/es/style/dnb-ui-body.css +1 -1
- package/es/style/dnb-ui-body.min.css +1 -1
- package/es/style/dnb-ui-components.css +352 -306
- package/es/style/dnb-ui-components.min.css +6 -4
- package/es/style/dnb-ui-core.css +1 -1
- package/es/style/dnb-ui-core.min.css +1 -1
- package/es/style/dnb-ui-elements.css +91 -6
- package/es/style/dnb-ui-elements.min.css +1 -1
- package/es/style/dnb-ui-extensions.css +23 -15
- package/es/style/dnb-ui-extensions.min.css +1 -1
- package/es/style/dnb-ui-forms.css +22 -14
- package/es/style/dnb-ui-forms.min.css +1 -1
- package/es/style/dnb-ui-fragments.css +9 -0
- package/es/style/dnb-ui-fragments.min.css +3 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +92 -6
- package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-components.css +376 -322
- package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +8 -6
- package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +91 -6
- package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +23 -15
- package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +22 -14
- package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
- package/es/style/themes/theme-eiendom/properties.d.ts +2 -1
- package/es/style/themes/theme-eiendom/properties.js +2 -1
- package/es/style/themes/theme-eiendom/properties.js.map +1 -1
- package/es/style/themes/theme-sbanken/fonts.scss +7 -3
- package/es/style/themes/theme-sbanken/properties.d.ts +2 -1
- package/es/style/themes/theme-sbanken/properties.js +2 -1
- package/es/style/themes/theme-sbanken/properties.js.map +1 -1
- package/es/style/themes/theme-sbanken/properties.scss +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +101 -10
- package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +2 -2
- package/es/style/themes/theme-sbanken/sbanken-theme-components.css +396 -339
- package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +9 -7
- package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +91 -7
- package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +23 -15
- package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +22 -14
- package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
- package/es/style/themes/theme-sbanken/theme-mapping.scss +1 -0
- package/es/style/themes/theme-ui/properties.d.ts +2 -1
- package/es/style/themes/theme-ui/properties.js +2 -1
- package/es/style/themes/theme-ui/properties.js.map +1 -1
- package/es/style/themes/theme-ui/properties.scss +1 -0
- package/es/style/themes/theme-ui/ui-theme-basis.css +92 -6
- package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-components.css +376 -322
- package/es/style/themes/theme-ui/ui-theme-components.min.css +8 -6
- package/es/style/themes/theme-ui/ui-theme-elements.css +91 -6
- package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-extensions.css +23 -15
- package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-forms.css +22 -14
- package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-properties.css +1 -0
- package/es/style/themes/theme-ui/ui-theme-properties.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-tags.css +9 -5
- package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
- package/esm/dnb-ui-basis.min.mjs +1 -1
- package/esm/dnb-ui-components.min.mjs +1 -1
- package/esm/dnb-ui-elements.min.mjs +1 -1
- package/esm/dnb-ui-extensions.min.mjs +3 -3
- package/esm/dnb-ui-lib.min.mjs +1 -1
- package/extensions/forms/DataContext/Provider/Provider.js +1 -1
- package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
- package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
- package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +3 -2
- package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
- package/extensions/forms/Field/Option/Option.js +1 -1
- package/extensions/forms/Field/Option/Option.js.map +1 -1
- package/extensions/forms/Field/Option/OptionDocs.js +9 -4
- package/extensions/forms/Field/Option/OptionDocs.js.map +1 -1
- package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
- package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +2 -1
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +9 -11
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
- package/extensions/forms/Field/Provider/useFieldProvider.d.ts +1 -0
- package/extensions/forms/Field/Selection/Selection.d.ts +12 -2
- package/extensions/forms/Field/Selection/Selection.js +9 -5
- package/extensions/forms/Field/Selection/Selection.js.map +1 -1
- package/extensions/forms/Field/Upload/Upload.d.ts +1 -1
- package/extensions/forms/Field/Upload/Upload.js +17 -8
- package/extensions/forms/Field/Upload/Upload.js.map +1 -1
- package/extensions/forms/Field/Upload/UploadDocs.js +7 -1
- package/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
- package/extensions/forms/FieldBlock/FieldBlock.js +15 -6
- package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/extensions/forms/FieldBlock/FieldBlockContext.d.ts +3 -2
- package/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
- package/extensions/forms/FieldBlock/style/dnb-field-block.css +16 -6
- package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
- package/extensions/forms/FieldBlock/style/dnb-field-block.scss +32 -20
- package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +4 -6
- package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
- package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +17 -9
- package/extensions/forms/Form/Card/Card.d.ts +6 -0
- package/extensions/forms/Form/Card/Card.js +12 -0
- package/extensions/forms/Form/Card/Card.js.map +1 -0
- package/extensions/forms/Form/Card/CardDocs.d.ts +2 -0
- package/extensions/forms/Form/Card/CardDocs.js +18 -0
- package/extensions/forms/Form/Card/CardDocs.js.map +1 -0
- package/extensions/forms/Form/Card/index.d.ts +2 -0
- package/extensions/forms/Form/Card/index.js +3 -0
- package/extensions/forms/Form/Card/index.js.map +1 -0
- package/extensions/forms/Form/index.d.ts +1 -0
- package/extensions/forms/Form/index.js +1 -0
- package/extensions/forms/Form/index.js.map +1 -1
- package/extensions/forms/Iterate/Array/ArrayDocs.js +1 -1
- package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/extensions/forms/Iterate/Array/types.d.ts +1 -1
- package/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/extensions/forms/Value/Provider/useValueProvider.d.ts +1 -0
- package/extensions/forms/Value/SummaryList/SummaryList.d.ts +1 -1
- package/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
- package/extensions/forms/Value/ValueDocs.js +5 -0
- package/extensions/forms/Value/ValueDocs.js.map +1 -1
- package/extensions/forms/ValueBlock/ValueBlock.js +4 -2
- package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
- package/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
- package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
- package/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
- package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +2 -7
- package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
- package/extensions/forms/hooks/DataValueWritePropsDocs.js +1 -1
- package/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/extensions/forms/hooks/useFieldProps.js +50 -36
- package/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/extensions/forms/style/dnb-forms.css +22 -14
- package/extensions/forms/style/dnb-forms.min.css +1 -1
- package/extensions/forms/types.d.ts +4 -0
- package/extensions/forms/types.js.map +1 -1
- package/extensions/payment-card/style/dnb-payment-card.css +1 -1
- package/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
- package/fragments/drawer-list/DrawerList.d.ts +22 -21
- package/fragments/drawer-list/DrawerList.js +14 -5
- package/fragments/drawer-list/DrawerList.js.map +1 -1
- package/fragments/drawer-list/DrawerListDocs.d.ts +1 -0
- package/fragments/drawer-list/DrawerListDocs.js +37 -5
- package/fragments/drawer-list/DrawerListDocs.js.map +1 -1
- package/fragments/drawer-list/DrawerListHelpers.js +13 -6
- package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
- package/fragments/drawer-list/DrawerListProvider.js +3 -0
- package/fragments/drawer-list/DrawerListProvider.js.map +1 -1
- package/fragments/drawer-list/style/dnb-drawer-list.scss +11 -0
- package/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +26 -19
- package/package.json +1 -2
- package/shared/Eufemia.d.ts +1 -1
- package/shared/Eufemia.js +2 -2
- package/shared/Eufemia.js.map +1 -1
- package/shared/VisibilityByTheme.d.ts +5 -2
- package/shared/VisibilityByTheme.js +12 -0
- package/shared/VisibilityByTheme.js.map +1 -1
- package/style/core/scopes.scss +1 -1
- package/style/dnb-ui-basis.css +1 -1
- package/style/dnb-ui-basis.min.css +1 -1
- package/style/dnb-ui-body.css +1 -1
- package/style/dnb-ui-body.min.css +1 -1
- package/style/dnb-ui-components.css +352 -306
- package/style/dnb-ui-components.min.css +6 -4
- package/style/dnb-ui-core.css +1 -1
- package/style/dnb-ui-core.min.css +1 -1
- package/style/dnb-ui-elements.css +91 -6
- package/style/dnb-ui-elements.min.css +1 -1
- package/style/dnb-ui-extensions.css +23 -15
- package/style/dnb-ui-extensions.min.css +1 -1
- package/style/dnb-ui-forms.css +22 -14
- package/style/dnb-ui-forms.min.css +1 -1
- package/style/dnb-ui-fragments.css +9 -0
- package/style/dnb-ui-fragments.min.css +3 -1
- package/style/themes/theme-eiendom/eiendom-theme-basis.css +92 -6
- package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-components.css +376 -322
- package/style/themes/theme-eiendom/eiendom-theme-components.min.css +8 -6
- package/style/themes/theme-eiendom/eiendom-theme-elements.css +91 -6
- package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-extensions.css +23 -15
- package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-forms.css +22 -14
- package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
- package/style/themes/theme-eiendom/properties.d.ts +2 -1
- package/style/themes/theme-eiendom/properties.js +2 -1
- package/style/themes/theme-eiendom/properties.js.map +1 -1
- package/style/themes/theme-sbanken/fonts.scss +7 -3
- package/style/themes/theme-sbanken/properties.d.ts +2 -1
- package/style/themes/theme-sbanken/properties.js +2 -1
- package/style/themes/theme-sbanken/properties.js.map +1 -1
- package/style/themes/theme-sbanken/properties.scss +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-basis.css +101 -10
- package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +2 -2
- package/style/themes/theme-sbanken/sbanken-theme-components.css +396 -339
- package/style/themes/theme-sbanken/sbanken-theme-components.min.css +9 -7
- package/style/themes/theme-sbanken/sbanken-theme-elements.css +91 -7
- package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-extensions.css +23 -15
- package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-forms.css +22 -14
- package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
- package/style/themes/theme-sbanken/theme-mapping.scss +1 -0
- package/style/themes/theme-ui/properties.d.ts +2 -1
- package/style/themes/theme-ui/properties.js +2 -1
- package/style/themes/theme-ui/properties.js.map +1 -1
- package/style/themes/theme-ui/properties.scss +1 -0
- package/style/themes/theme-ui/ui-theme-basis.css +92 -6
- package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-components.css +376 -322
- package/style/themes/theme-ui/ui-theme-components.min.css +8 -6
- package/style/themes/theme-ui/ui-theme-elements.css +91 -6
- package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-extensions.css +23 -15
- package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-forms.css +22 -14
- package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-properties.css +1 -0
- package/style/themes/theme-ui/ui-theme-properties.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-tags.css +9 -5
- package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
- package/umd/dnb-ui-basis.min.js +1 -1
- package/umd/dnb-ui-components.min.js +1 -1
- package/umd/dnb-ui-elements.min.js +1 -1
- package/umd/dnb-ui-extensions.min.js +1 -1
- package/umd/dnb-ui-lib.min.js +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Upload.js","names":["React","useCallback","useEffect","useMemo","classnames","FieldBlock","useFieldProps","useTranslation","useFormsTranslation","Upload","useUpload","pickSpacingProps","HelpButtonInline","HelpButtonInlineContent","useSharedTranslation","FormError","validateRequired","value","required","isChanged","error","hasError","some","file","errorMessage","hasFiles","length","undefined","updateFileLoadingState","files","isLoading","map","_objectSpread","UploadComponent","props","sharedTr","formsTr","errorMessages","errorRequired","preparedProps","_useFieldProps","executeOnChangeRegardlessOfError","id","className","width","widthProp","label","labelDescription","help","htmlAttributes","handleChange","handleFocus","handleBlur","asyncFileHandler","rest","_objectWithoutProperties","_excluded","title","text","acceptedFileTypes","filesAmountLimit","fileMaxSize","skeleton","onFileDelete","fileContext","setFiles","handleChangeAsync","existingFileIds","newFiles","filter","includes","uploadedFiles","changeHandler","fieldBlockProps","forId","labelSrOnly","createElement","_extends","onChange","Fragment","contentId","left","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Upload/Upload.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo } from 'react'\nimport classnames from 'classnames'\nimport FieldBlock, {\n Props as FieldBlockProps,\n FieldBlockWidth,\n} from '../../FieldBlock'\nimport {\n useFieldProps,\n useTranslation as useFormsTranslation,\n} from '../../hooks'\nimport { FieldProps } from '../../types'\nimport Upload, {\n UploadFile,\n UploadFileNative,\n UploadProps,\n} from '../../../../components/Upload'\nimport useUpload from '../../../../components/upload/useUpload'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n} from '../../../../components/help-button/HelpButtonInline'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport { SpacingProps } from '../../../../shared/types'\nimport { FormError } from '../../utils'\n\nexport type UploadValue = Array<UploadFile | UploadFileNative>\nexport type Props = Omit<\n FieldProps<UploadValue, UploadValue | undefined>,\n 'name'\n> &\n SpacingProps & {\n width?: Omit<FieldBlockWidth, 'medium' | 'small'>\n } & Pick<\n Partial<UploadProps>,\n | 'title'\n | 'text'\n | 'acceptedFileTypes'\n | 'filesAmountLimit'\n | 'fileMaxSize'\n | 'onFileDelete'\n | 'skeleton'\n > & {\n asyncFileHandler?: (newFiles: UploadValue) => Promise<UploadValue>\n }\n\nconst validateRequired = (\n value: UploadValue,\n { required, isChanged, error }\n) => {\n const hasError = value?.some((file) => file.errorMessage)\n if (hasError) {\n return new FormError('Upload.errorInvalidFiles')\n }\n\n const hasFiles = value?.length > 0\n if (required && ((!isChanged && !hasFiles) || !hasFiles)) {\n return error\n }\n\n return undefined\n}\n\nconst updateFileLoadingState = (\n files: UploadValue,\n isLoading: boolean\n) => {\n return files.map((file) => ({ ...file, isLoading }))\n}\n\nfunction UploadComponent(props: Props) {\n const sharedTr = useSharedTranslation().Upload\n const formsTr = useFormsTranslation().Upload\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': formsTr.errorRequired,\n }),\n [formsTr.errorRequired]\n )\n\n const preparedProps = {\n errorMessages,\n validateRequired,\n ...props,\n }\n\n const {\n id,\n className,\n width: widthProp = 'stretch',\n value,\n label,\n labelDescription,\n help,\n htmlAttributes,\n handleChange,\n handleFocus,\n handleBlur,\n asyncFileHandler,\n ...rest\n } = useFieldProps(preparedProps, {\n executeOnChangeRegardlessOfError: true,\n })\n\n // Upload props\n const {\n title = sharedTr.title,\n text = sharedTr.text,\n acceptedFileTypes = ['pdf', 'png', 'jpg', 'jpeg'],\n filesAmountLimit = 100,\n fileMaxSize = 5,\n skeleton,\n onFileDelete,\n } = rest\n\n const { files: fileContext, setFiles } = useUpload(id)\n\n useEffect(() => {\n setFiles(value)\n }, [setFiles, value])\n\n const handleChangeAsync = useCallback(\n async (files: UploadValue) => {\n // Filter out existing files\n const existingFileIds = fileContext?.map((file) => file.id) || []\n const newFiles = files.filter(\n (file) => !existingFileIds.includes(file.id)\n )\n\n if (newFiles.length > 0) {\n // Set loading\n setFiles([\n ...fileContext,\n ...updateFileLoadingState(newFiles, true),\n ])\n\n const uploadedFiles = updateFileLoadingState(\n await asyncFileHandler(newFiles),\n false\n )\n\n handleChange([...fileContext, ...uploadedFiles])\n } else {\n handleChange(files)\n }\n },\n [fileContext, asyncFileHandler, setFiles, updateFileLoadingState]\n )\n\n const changeHandler = useCallback(\n ({ files }: { files: UploadValue }) => {\n // Prevents the form-status from showing up\n handleBlur()\n handleFocus()\n\n if (asyncFileHandler) {\n handleChangeAsync(files)\n } else {\n handleChange(files)\n }\n },\n [handleBlur, handleChange, handleFocus, asyncFileHandler, fileContext]\n )\n\n const width = widthProp as FieldBlockWidth\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input`,\n labelSrOnly: true,\n className: classnames('dnb-forms-field-upload', className),\n width,\n help: undefined,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <Upload\n id={id}\n acceptedFileTypes={acceptedFileTypes}\n filesAmountLimit={filesAmountLimit}\n fileMaxSize={fileMaxSize}\n skeleton={skeleton}\n onChange={changeHandler}\n onFileDelete={onFileDelete}\n title={label ?? title}\n text={\n help ? (\n <>\n {labelDescription ?? text}\n <HelpButtonInline\n contentId={`${id}-help`}\n left={text ? 'x-small' : false}\n help={help}\n />\n </>\n ) : (\n labelDescription ?? text\n )\n }\n {...htmlAttributes}\n >\n {help && (\n <HelpButtonInlineContent contentId={`${id}-help`} help={help} />\n )}\n </Upload>\n </FieldBlock>\n )\n}\n\nexport default UploadComponent\n\nUploadComponent._supportsSpacingProps = true\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Upload.js","names":["React","useCallback","useEffect","useMemo","classnames","FieldBlock","useFieldProps","useTranslation","useFormsTranslation","Upload","useUpload","pickSpacingProps","HelpButtonInline","HelpButtonInlineContent","useSharedTranslation","FormError","validateRequired","value","required","isChanged","error","hasError","some","file","errorMessage","hasFiles","length","undefined","updateFileLoadingState","files","isLoading","map","_objectSpread","UploadComponent","props","sharedTr","formsTr","errorMessages","errorRequired","preparedProps","_useFieldProps","executeOnChangeRegardlessOfError","id","className","width","widthProp","label","labelDescription","help","htmlAttributes","handleChange","handleFocus","handleBlur","fileHandler","rest","_objectWithoutProperties","_excluded","title","text","acceptedFileTypes","filesAmountLimit","fileMaxSize","skeleton","onFileDelete","fileContext","setFiles","handleChangeAsync","existingFileIds","newFiles","filter","includes","uploadedFiles","changeHandler","fieldBlockProps","forId","labelSrOnly","createElement","_extends","onChange","Fragment","contentId","left","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Upload/Upload.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo } from 'react'\nimport classnames from 'classnames'\nimport FieldBlock, {\n Props as FieldBlockProps,\n FieldBlockWidth,\n} from '../../FieldBlock'\nimport {\n useFieldProps,\n useTranslation as useFormsTranslation,\n} from '../../hooks'\nimport { FieldProps } from '../../types'\nimport Upload, {\n UploadFile,\n UploadFileNative,\n UploadProps,\n} from '../../../../components/Upload'\nimport useUpload from '../../../../components/upload/useUpload'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n} from '../../../../components/help-button/HelpButtonInline'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport { SpacingProps } from '../../../../shared/types'\nimport { FormError } from '../../utils'\n\nexport type UploadValue = Array<UploadFile | UploadFileNative>\nexport type Props = Omit<\n FieldProps<UploadValue, UploadValue | undefined>,\n 'name'\n> &\n SpacingProps & {\n width?: Omit<FieldBlockWidth, 'medium' | 'small'>\n } & Pick<\n Partial<UploadProps>,\n | 'title'\n | 'text'\n | 'acceptedFileTypes'\n | 'filesAmountLimit'\n | 'fileMaxSize'\n | 'onFileDelete'\n | 'skeleton'\n > & {\n fileHandler?: (\n newFiles: UploadValue\n ) => UploadValue | Promise<UploadValue>\n }\n\nconst validateRequired = (\n value: UploadValue,\n { required, isChanged, error }\n) => {\n const hasError = value?.some((file) => file.errorMessage)\n if (hasError) {\n return new FormError('Upload.errorInvalidFiles')\n }\n\n const hasFiles = value?.length > 0\n if (required && ((!isChanged && !hasFiles) || !hasFiles)) {\n return error\n }\n\n return undefined\n}\n\nconst updateFileLoadingState = (\n files: UploadValue,\n { isLoading } = { isLoading: false }\n) => {\n return files.map((file) => ({ ...file, isLoading }))\n}\n\nfunction UploadComponent(props: Props) {\n const sharedTr = useSharedTranslation().Upload\n const formsTr = useFormsTranslation().Upload\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': formsTr.errorRequired,\n }),\n [formsTr.errorRequired]\n )\n\n const preparedProps = {\n errorMessages,\n validateRequired,\n ...props,\n }\n\n const {\n id,\n className,\n width: widthProp = 'stretch',\n value,\n label,\n labelDescription,\n help,\n htmlAttributes,\n handleChange,\n handleFocus,\n handleBlur,\n fileHandler,\n ...rest\n } = useFieldProps(preparedProps, {\n executeOnChangeRegardlessOfError: true,\n })\n\n // Upload props\n const {\n title = sharedTr.title,\n text = sharedTr.text,\n acceptedFileTypes = ['pdf', 'png', 'jpg', 'jpeg'],\n filesAmountLimit = 100,\n fileMaxSize = 5,\n skeleton,\n onFileDelete,\n } = rest\n\n const { files: fileContext, setFiles } = useUpload(id)\n\n useEffect(() => {\n setFiles(value)\n }, [setFiles, value])\n\n const handleChangeAsync = useCallback(\n async (files: UploadValue) => {\n // Filter out existing files\n const existingFileIds = fileContext?.map((file) => file.id) || []\n const newFiles = files.filter(\n (file) => !existingFileIds.includes(file.id)\n )\n\n if (newFiles.length > 0) {\n // Set loading\n setFiles([\n ...fileContext,\n ...updateFileLoadingState(newFiles, { isLoading: true }),\n ])\n\n const uploadedFiles = updateFileLoadingState(\n await fileHandler(newFiles),\n { isLoading: false }\n )\n\n // Set error, if any\n handleChange([...fileContext, ...uploadedFiles])\n } else {\n handleChange(files)\n }\n },\n [fileContext, setFiles, fileHandler, handleChange]\n )\n\n const changeHandler = useCallback(\n ({ files }: { files: UploadValue }) => {\n // Prevents the form-status from showing up\n handleBlur()\n handleFocus()\n\n if (fileHandler) {\n handleChangeAsync(files)\n } else {\n handleChange(files)\n }\n },\n [handleBlur, handleFocus, fileHandler, handleChangeAsync, handleChange]\n )\n\n const width = widthProp as FieldBlockWidth\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input`,\n labelSrOnly: true,\n className: classnames('dnb-forms-field-upload', className),\n width,\n help: undefined,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <Upload\n id={id}\n acceptedFileTypes={acceptedFileTypes}\n filesAmountLimit={filesAmountLimit}\n fileMaxSize={fileMaxSize}\n skeleton={skeleton}\n onChange={changeHandler}\n onFileDelete={onFileDelete}\n title={label ?? title}\n text={\n help ? (\n <>\n {labelDescription ?? text}\n <HelpButtonInline\n contentId={`${id}-help`}\n left={text ? 'x-small' : false}\n help={help}\n />\n </>\n ) : (\n labelDescription ?? text\n )\n }\n {...htmlAttributes}\n >\n {help && (\n <HelpButtonInlineContent contentId={`${id}-help`} help={help} />\n )}\n </Upload>\n </FieldBlock>\n )\n}\n\nexport default UploadComponent\n\nUploadComponent._supportsSpacingProps = true\n"],"mappings":"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"}
|
|
@@ -2,7 +2,13 @@ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
|
2
2
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
3
3
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
4
4
|
import { UploadEvents, UploadProperties } from '../../../../components/upload/UploadDocs';
|
|
5
|
-
export const UploadFieldProperties = _objectSpread(_objectSpread({
|
|
5
|
+
export const UploadFieldProperties = _objectSpread(_objectSpread({
|
|
6
|
+
fileHandler: {
|
|
7
|
+
doc: 'File handler function that takes newly added files (`newFiles: UploadValue`) as a parameter and returns the processed files. The function can either be synchronous or asynchronous. It returns a promise (`Promise<UploadValue>`) containing the processed files when asynchronous.',
|
|
8
|
+
type: 'function',
|
|
9
|
+
status: 'optional'
|
|
10
|
+
}
|
|
11
|
+
}, UploadProperties), {}, {
|
|
6
12
|
title: undefined,
|
|
7
13
|
text: undefined
|
|
8
14
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UploadDocs.js","names":["UploadEvents","UploadProperties","UploadFieldProperties","_objectSpread","title","undefined","text","UploadFieldEvents"],"sources":["../../../../../../src/extensions/forms/Field/Upload/UploadDocs.ts"],"sourcesContent":["import {\n UploadEvents,\n UploadProperties,\n} from '../../../../components/upload/UploadDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const UploadFieldProperties: PropertiesTableProps = {\n ...UploadProperties,\n title: undefined,\n text: undefined,\n}\n\nexport const UploadFieldEvents: PropertiesTableProps = {\n ...UploadEvents,\n}\n"],"mappings":";;;AAAA,SACEA,YAAY,EACZC,gBAAgB,QACX,0CAA0C;AAGjD,OAAO,MAAMC,qBAA2C,GAAAC,aAAA,CAAAA,aAAA,
|
|
1
|
+
{"version":3,"file":"UploadDocs.js","names":["UploadEvents","UploadProperties","UploadFieldProperties","_objectSpread","fileHandler","doc","type","status","title","undefined","text","UploadFieldEvents"],"sources":["../../../../../../src/extensions/forms/Field/Upload/UploadDocs.ts"],"sourcesContent":["import {\n UploadEvents,\n UploadProperties,\n} from '../../../../components/upload/UploadDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const UploadFieldProperties: PropertiesTableProps = {\n fileHandler: {\n doc: 'File handler function that takes newly added files (`newFiles: UploadValue`) as a parameter and returns the processed files. The function can either be synchronous or asynchronous. It returns a promise (`Promise<UploadValue>`) containing the processed files when asynchronous.',\n type: 'function',\n status: 'optional',\n },\n ...UploadProperties,\n title: undefined,\n text: undefined,\n}\n\nexport const UploadFieldEvents: PropertiesTableProps = {\n ...UploadEvents,\n}\n"],"mappings":";;;AAAA,SACEA,YAAY,EACZC,gBAAgB,QACX,0CAA0C;AAGjD,OAAO,MAAMC,qBAA2C,GAAAC,aAAA,CAAAA,aAAA;EACtDC,WAAW,EAAE;IACXC,GAAG,EAAE,sRAAsR;IAC3RC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AAAC,GACEN,gBAAgB;EACnBO,KAAK,EAAEC,SAAS;EAChBC,IAAI,EAAED;AAAS,EAChB;AAED,OAAO,MAAME,iBAAuC,GAAAR,aAAA,KAC/CH,YAAY,CAChB"}
|
|
@@ -66,6 +66,7 @@ function FieldBlock(props) {
|
|
|
66
66
|
const blockId = useId(props.id);
|
|
67
67
|
const [wasUpdated, forceUpdate] = useReducer(() => ({}), {});
|
|
68
68
|
const mountedFieldsRef = useRef({});
|
|
69
|
+
const fieldStateRef = useRef(null);
|
|
69
70
|
const stateRecordRef = useRef({});
|
|
70
71
|
const fieldStateIdsRef = useRef(null);
|
|
71
72
|
const contentsRef = useRef(null);
|
|
@@ -122,14 +123,20 @@ function FieldBlock(props) {
|
|
|
122
123
|
stateRecordRef.current[identifier].push(props);
|
|
123
124
|
}
|
|
124
125
|
}, []);
|
|
125
|
-
const
|
|
126
|
+
const setBlockRecord = useCallback(props => {
|
|
126
127
|
if (nestedFieldBlockContext) {
|
|
127
|
-
nestedFieldBlockContext.
|
|
128
|
+
nestedFieldBlockContext.setBlockRecord(props);
|
|
128
129
|
return;
|
|
129
130
|
}
|
|
130
131
|
setInternalRecord(props);
|
|
131
132
|
forceUpdate();
|
|
132
133
|
}, [nestedFieldBlockContext, setInternalRecord]);
|
|
134
|
+
const setFieldState = useCallback((identifier, fieldState) => {
|
|
135
|
+
if (fieldState !== fieldStateRef.current) {
|
|
136
|
+
fieldStateRef.current = fieldState;
|
|
137
|
+
forceUpdate();
|
|
138
|
+
}
|
|
139
|
+
}, []);
|
|
133
140
|
const showFieldError = useCallback((identifier, show) => {
|
|
134
141
|
if (nestedFieldBlockContext) {
|
|
135
142
|
nestedFieldBlockContext.showFieldError(identifier, show);
|
|
@@ -250,7 +257,7 @@ function FieldBlock(props) {
|
|
|
250
257
|
mountedFieldsRef.current = {};
|
|
251
258
|
stateRecordRef.current = {};
|
|
252
259
|
}, []);
|
|
253
|
-
const mainClasses = classnames('dnb-forms-field-block', className, width && `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`, contentWidth && `dnb-forms-field-block--content-width-${hasCustomContentWidth ? 'custom' : contentWidth}`, labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`);
|
|
260
|
+
const mainClasses = classnames('dnb-forms-field-block', className, composition && `dnb-forms-field-block__composition dnb-forms-field-block__composition--${composition === true ? 'horizontal' : composition}`, width && `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`, contentWidth && `dnb-forms-field-block--content-width-${hasCustomContentWidth ? 'custom' : contentWidth}`, labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`);
|
|
254
261
|
const gridClasses = `dnb-forms-field-block__grid dnb-forms-field-block--layout-${layout}`;
|
|
255
262
|
const enableFieldset = useEnableFieldset({
|
|
256
263
|
label,
|
|
@@ -294,6 +301,7 @@ function FieldBlock(props) {
|
|
|
294
301
|
const hasHelp = (help === null || help === void 0 ? void 0 : help.title) || (help === null || help === void 0 ? void 0 : help.content);
|
|
295
302
|
return React.createElement(FieldBlockContext.Provider, {
|
|
296
303
|
value: {
|
|
304
|
+
setBlockRecord,
|
|
297
305
|
setFieldState,
|
|
298
306
|
showFieldError,
|
|
299
307
|
hasErrorProp: Boolean(errorProp),
|
|
@@ -319,14 +327,15 @@ function FieldBlock(props) {
|
|
|
319
327
|
contentId: `${id}-help`,
|
|
320
328
|
className: "dnb-forms-field-block__help",
|
|
321
329
|
help: help,
|
|
322
|
-
breakout: layout === 'vertical' && !(nestedFieldBlockContext !== null && nestedFieldBlockContext !== void 0 && nestedFieldBlockContext.composition)
|
|
330
|
+
breakout: layout === 'vertical' && !(nestedFieldBlockContext !== null && nestedFieldBlockContext !== void 0 && nestedFieldBlockContext.composition),
|
|
331
|
+
outset: layout !== 'horizontal'
|
|
323
332
|
}), React.createElement("div", {
|
|
324
333
|
className: 'dnb-forms-field-block__status' + (contentWidth && contentWidth !== 'small' && contentWidth !== 'medium' && !(parseFloat(contentWidth) <= 11) ? ` dnb-forms-field-block__contents--width-${hasCustomContentWidth ? 'custom' : contentWidth}` : "")
|
|
325
334
|
}, React.createElement(FormStatus, statusContent === null || statusContent === void 0 ? void 0 : statusContent.error), React.createElement(FormStatus, statusContent === null || statusContent === void 0 ? void 0 : statusContent.warning), React.createElement(FormStatus, statusContent === null || statusContent === void 0 ? void 0 : statusContent.info)), React.createElement("div", {
|
|
326
|
-
className: classnames('dnb-forms-field-block__contents', contentClassName, contentWidth && `dnb-forms-field-block__contents--width-${hasCustomContentWidth ? 'custom' : contentWidth}`, align && `dnb-forms-field-block__contents--align-${align}
|
|
335
|
+
className: classnames('dnb-forms-field-block__contents', contentClassName, contentWidth && `dnb-forms-field-block__contents--width-${hasCustomContentWidth ? 'custom' : contentWidth}`, align && `dnb-forms-field-block__contents--align-${align}`),
|
|
327
336
|
ref: contentsRef
|
|
328
337
|
}, children), React.createElement(SubmitIndicator, {
|
|
329
|
-
state: fieldState,
|
|
338
|
+
state: fieldState !== null && fieldState !== void 0 ? fieldState : fieldStateRef.current,
|
|
330
339
|
className: "dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap"
|
|
331
340
|
}))));
|
|
332
341
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FieldBlock.js","names":["React","useMemo","useContext","useCallback","useRef","useReducer","useEffect","classnames","FieldBlockContext","DataContext","IterateElementContext","Space","FormLabel","FormStatus","Ul","Li","convertJsxToString","findElementInChildren","useId","HelpButtonInline","HelpButtonInlineContent","SubmitIndicator","createSharedState","useTranslation","FormError","states","FieldBlock","props","_props$id","dataContext","fieldBlockContext","nestedFieldBlockContext","disableStatusSummary","id","forId","sharedData","_Object$assign","Object","assign","data","className","layout","layoutOptions","composition","label","labelProp","labelDescription","labelSuffix","labelSrOnly","help","asFieldset","required","info","warning","error","errorProp","fieldState","disabled","width","contentWidth","labelHeight","align","labelSize","contentClassName","children","rest","_objectWithoutProperties","_excluded","hasCustomWidth","test","String","hasCustomContentWidth","iterateItemContext","index","iterateIndex","blockId","wasUpdated","forceUpdate","mountedFieldsRef","stateRecordRef","fieldStateIdsRef","contentsRef","hasInitiallyErrorProp","Boolean","optionalLabelSuffix","Field","labelSuffixText","content","undefined","replace","includes","isValidElement","createElement","Fragment","setInternalRecord","stateId","identifier","type","current","existingIndex","findIndex","item","_objectSpread","push","setFieldState","showFieldError","show","map","showInitially","statusContent","statesWithMessages","entries","flatMap","reduce","acc","cur","existing","find","messages","getMessagesFromError","message","state","width_element","no_animation","process","env","NODE_ENV","globalThis","IS_TEST","found","msg","filter","i","arr","length","CombineMessages","mainClasses","gridClasses","enableFieldset","useEnableFieldset","labelProps","element","srOnly","space","size","mainStyle","_lO$minWidth","_lO$maxWidth","style","lO","min","getFieldWidth","minWidth","max","maxWidth","prerenderFieldProps","hasLabelDescription","isFragment","fragmentHasChildren","fragmentHasOnlyUndefinedChildren","hasHelp","title","Provider","value","hasErrorProp","_extends","contentId","breakout","parseFloat","ref","result","count","child","_child$props","_child$type","translations","errorSummary","stateSummary","key","Array","isArray","errors","Error","toString","fragment","Children","isUndefined","toArray","every","_supportsSpacingProps"],"sources":["../../../../../src/extensions/forms/FieldBlock/FieldBlock.tsx"],"sourcesContent":["import React, {\n useMemo,\n useContext,\n useCallback,\n useRef,\n useReducer,\n useEffect,\n} from 'react'\nimport classnames from 'classnames'\nimport FieldBlockContext, {\n StateWithMessage,\n StatesWithMessages,\n FieldErrorIdsRef,\n MountedFieldsRef,\n StateRecord,\n StateMessage,\n StateTypes,\n StatusContent,\n FieldBlockContextProps,\n StateBasis,\n} from './FieldBlockContext'\nimport DataContext from '../DataContext/Context'\nimport IterateElementContext from '../Iterate/IterateItemContext'\nimport { Space, FormLabel, FormStatus } from '../../../components'\nimport { Ul, Li } from '../../../elements'\nimport {\n convertJsxToString,\n findElementInChildren,\n} from '../../../shared/component-helper'\nimport useId from '../../../shared/helpers/useId'\nimport {\n ComponentProps,\n FieldProps,\n SubmitState,\n Identifier,\n} from '../types'\nimport type { FormLabelAllProps } from '../../../components/FormLabel'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n HelpProps,\n} from '../../../components/help-button/HelpButtonInline'\nimport SubmitIndicator from '../Form/SubmitIndicator/SubmitIndicator'\nimport { createSharedState } from '../../../shared/helpers/useSharedState'\nimport useTranslation from '../hooks/useTranslation'\nimport { FormError } from '../utils'\n\nexport const states: Array<StateTypes> = ['error', 'info', 'warning']\n\n/**\n * The width of a field block\n */\nexport type CustomWidth = `${number}rem`\nexport type FieldBlockWidth =\n | false\n | 'small'\n | 'medium'\n | 'large'\n | 'stretch'\n | CustomWidth\nexport type FieldBlockHorizontalLabelWidth =\n | 'small'\n | 'medium'\n | 'large'\n | CustomWidth\nexport type FieldBlockHorizontalLabelHeight =\n | 'default'\n | 'small'\n | 'medium'\n | 'large'\n\nexport type SharedFieldBlockProps = {\n /**\n * The layout of the field block\n */\n layout?: 'vertical' | 'horizontal'\n /** Use this to set additional options for the layout */\n layoutOptions?: {\n width?: FieldBlockHorizontalLabelWidth\n minWidth?: FieldBlockHorizontalLabelWidth\n maxWidth?: FieldBlockHorizontalLabelWidth\n }\n /**\n * Main label text for the field\n */\n label?: React.ReactNode\n /**\n * Will append an additional text to the label, like \"(optional)\" or \"(recommended)\"\n */\n labelSuffix?: React.ReactNode\n /**\n * A more discreet text displayed beside the label\n */\n labelDescription?: React.ReactNode\n /**\n * Width of outer block element\n */\n width?: FieldBlockWidth\n /**\n * Width of contents block, while label etc can be wider if space is available\n */\n contentWidth?: FieldBlockWidth\n /**\n * Provide help content for the field.\n */\n help?: HelpProps\n}\n\nexport type Props = SharedFieldBlockProps &\n Pick<\n FieldProps,\n keyof ComponentProps | 'info' | 'warning' | 'error' | 'disabled'\n > & {\n /** The id to link a element with */\n forId?: string\n /** Use true if you have more than one form element */\n asFieldset?: boolean\n /** use `true` to make the label only readable by screen readers. */\n labelSrOnly?: boolean\n /** Defines the layout of nested fields */\n composition?: FieldBlockContextProps['composition']\n /** For composition only: Align the contents vertically */\n align?: 'center' | 'bottom'\n /** Class name for the contents block */\n contentClassName?: string\n /** To show the SubmitIndicator during async validation */\n fieldState?: SubmitState\n /** Typography size */\n labelSize?: 'medium' | 'large'\n /** Defines the height of an component (size prop), so the label can be aligned correctly */\n labelHeight?: FieldBlockHorizontalLabelHeight\n /** Disable the error summary for this field block */\n disableStatusSummary?: boolean\n /** For internal use only */\n required?: boolean\n children?: React.ReactNode\n } & React.HTMLAttributes<HTMLDivElement>\n\nfunction FieldBlock(props: Props) {\n const dataContext = useContext(DataContext)\n const fieldBlockContext = useContext(FieldBlockContext)\n const nestedFieldBlockContext = !fieldBlockContext?.disableStatusSummary\n ? fieldBlockContext\n : null\n\n const id = useId(props.id ?? props.forId)\n const sharedData = createSharedState<Props>('field-block-props-' + id)\n const {\n className,\n forId,\n layout = 'vertical',\n layoutOptions,\n composition,\n label: labelProp,\n labelDescription,\n labelSuffix,\n labelSrOnly,\n help,\n asFieldset,\n required,\n info,\n warning,\n error: errorProp,\n disableStatusSummary,\n fieldState,\n disabled,\n width,\n contentWidth,\n labelHeight,\n align,\n labelSize,\n contentClassName,\n children,\n ...rest\n } = Object.assign({}, sharedData.data, props)\n const hasCustomWidth = /\\d(rem)$/.test(String(width))\n const hasCustomContentWidth = /\\d(rem)$/.test(String(contentWidth))\n\n const iterateItemContext = useContext(IterateElementContext)\n const { index: iterateIndex } = iterateItemContext ?? {}\n\n const blockId = useId(props.id)\n const [wasUpdated, forceUpdate] = useReducer(() => ({}), {})\n const mountedFieldsRef = useRef<MountedFieldsRef>({})\n const stateRecordRef = useRef<StateRecord>({})\n const fieldStateIdsRef = useRef<FieldErrorIdsRef>(null)\n const contentsRef = useRef<HTMLDivElement>(null)\n const hasInitiallyErrorProp = useMemo(() => {\n return Boolean(errorProp)\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n const { optionalLabelSuffix } = useTranslation().Field\n const labelSuffixText = useMemo(() => {\n if (required === false || typeof labelSuffix !== 'undefined') {\n return labelSuffix ?? optionalLabelSuffix\n }\n return ''\n }, [required, labelSuffix, optionalLabelSuffix])\n\n const label = useMemo(() => {\n let content = labelProp\n\n if (iterateIndex !== undefined) {\n content = convertJsxToString(labelProp).replace(\n '{itemNo}',\n String(iterateIndex + 1)\n )\n }\n\n if (labelSuffixText) {\n if (convertJsxToString(content).includes(optionalLabelSuffix)) {\n return content\n }\n\n if (typeof content === 'string') {\n return content + ' ' + labelSuffixText\n }\n\n if (React.isValidElement(content)) {\n return (\n <>\n {content}\n {' '}\n {labelSuffixText}\n </>\n )\n }\n }\n\n return content\n }, [iterateIndex, labelProp, labelSuffixText, optionalLabelSuffix])\n\n const setInternalRecord = useCallback((props: StateBasis) => {\n const { stateId, identifier, type } = props\n\n if (!stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = []\n }\n\n fieldStateIdsRef.current = { error: null, warning: null, info: null }\n\n const existingIndex = stateRecordRef.current[identifier].findIndex(\n (item) => {\n return item.stateId === stateId && item.type === type\n }\n )\n\n if (existingIndex > -1) {\n stateRecordRef.current[identifier][existingIndex] = {\n ...stateRecordRef.current[identifier][existingIndex],\n ...props,\n }\n } else {\n stateRecordRef.current[identifier].push(props)\n }\n }, [])\n\n const setFieldState = useCallback(\n (props: StateBasis) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.setFieldState(props)\n return\n }\n\n setInternalRecord(props)\n\n forceUpdate()\n },\n [nestedFieldBlockContext, setInternalRecord]\n )\n\n const showFieldError = useCallback(\n (identifier: Identifier, show: boolean) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.showFieldError(identifier, show)\n return\n }\n\n if (stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = stateRecordRef.current[\n identifier\n ].map((item) => {\n if (item.showInitially) {\n return item\n }\n\n return {\n ...item,\n show,\n }\n })\n\n forceUpdate()\n }\n },\n [nestedFieldBlockContext]\n )\n\n const statusContent = useMemo(() => {\n if (typeof errorProp !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: hasInitiallyErrorProp,\n type: 'error',\n content: errorProp,\n })\n }\n\n if (typeof warning !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'warning',\n content: warning,\n })\n }\n\n if (typeof info !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'info',\n content: info,\n })\n }\n\n const statesWithMessages: Array<StatesWithMessages> =\n // 1. Prepare the states for later use\n Object.entries(stateRecordRef.current)\n .flatMap(([identifier, states]) =>\n states.map((props) => {\n return {\n identifier,\n ...props,\n }\n })\n )\n\n // 2. Take states and group the same type together\n .reduce((acc, cur) => {\n const existing = acc.find((item) => {\n return item.type === cur.type\n })\n\n const messages = getMessagesFromError(cur).map((message) => {\n return {\n ...cur,\n message,\n }\n })\n\n if (existing) {\n existing.messages.push(...messages)\n } else {\n acc.push({\n ...cur,\n content: undefined,\n messages,\n })\n }\n\n return acc\n }, [] as Array<StatesWithMessages>)\n\n // 3. Return the grouped states/messages\n return states.reduce((acc, type) => {\n const id = `${props.id || forId || blockId}-form-status--${type}`\n acc[type] = {\n id,\n label,\n state: type === 'warning' ? 'warn' : type,\n width_element: contentsRef,\n\n // Enable animation only in the browser and not in tests\n no_animation:\n process.env.NODE_ENV === 'test'\n ? true\n : typeof globalThis !== 'undefined'\n ? globalThis.IS_TEST === true\n : false,\n }\n\n const found = statesWithMessages.find((item) => {\n return item.type === type\n })\n\n if (found?.messages) {\n // Hide/remove messages that should be hidden and are not marked as to be shown initially\n const messages = found.messages\n .map((msg) => {\n if (msg.type === 'error') {\n if (!msg.showInitially && !msg.show) {\n msg.message = null\n }\n }\n\n return msg\n })\n .filter(({ message }) => message)\n .reduce((acc, msg, i, arr) => {\n const existingIndex = arr.findIndex((item) => {\n return (\n convertJsxToString(item.message) ===\n convertJsxToString(msg.message)\n )\n })\n\n // Remove duplicates, use the first found message\n if (existingIndex === i) {\n acc.push(msg)\n }\n\n return acc\n }, [])\n\n // Combine the messages and put them in an ul/li list\n if (messages.length > 0) {\n acc[type] = {\n ...acc[type],\n children: <CombineMessages type={type} messages={messages} />,\n }\n\n fieldStateIdsRef.current[type] = id\n } else {\n fieldStateIdsRef.current[type] = undefined\n }\n }\n\n return acc\n }, {}) as StatusContent\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n info,\n warning,\n errorProp,\n nestedFieldBlockContext,\n setInternalRecord,\n blockId,\n wasUpdated, // wasUpdated is needed to get the current errors\n ])\n\n // Handle the error prop from outside\n useEffect(() => {\n if (!nestedFieldBlockContext) {\n showFieldError(blockId, Boolean(errorProp))\n }\n }, [errorProp, blockId, showFieldError, nestedFieldBlockContext])\n\n useEffect(\n () => () => {\n mountedFieldsRef.current = {}\n stateRecordRef.current = {}\n },\n []\n )\n\n const mainClasses = classnames(\n 'dnb-forms-field-block',\n width &&\n `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`,\n contentWidth &&\n `dnb-forms-field-block--content-width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`,\n className\n )\n const gridClasses = classnames(\n 'dnb-forms-field-block__grid',\n `dnb-forms-field-block--layout-${layout}`\n )\n\n // A child component with a label was found, use fieldset/legend instead of div/label\n const enableFieldset = useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n })\n\n const labelProps: FormLabelAllProps = {\n className: 'dnb-forms-field-block__label',\n element: enableFieldset ? 'legend' : 'label',\n forId: enableFieldset ? undefined : forId,\n srOnly: labelSrOnly,\n space: 0, // Use CSS for spacing, but we need to reset space for doing so\n size: labelSize,\n disabled,\n }\n\n const mainStyle = useMemo(() => {\n const style: React.CSSProperties = {}\n\n if (hasCustomWidth) {\n style['--dnb-forms-field-block-width'] = width\n }\n\n if (hasCustomContentWidth) {\n style['--dnb-forms-field-block-content-width'] = contentWidth\n }\n\n const lO = layoutOptions || {}\n const min = getFieldWidth(lO.minWidth ?? lO.width)\n const max = getFieldWidth(lO.maxWidth ?? lO.width)\n\n if (typeof min === 'string') {\n style['--dnb-forms-field-block-layout-width-min'] = min\n }\n if (typeof max === 'string') {\n style['--dnb-forms-field-block-layout-width-max'] = max\n }\n\n return style\n }, [\n contentWidth,\n hasCustomContentWidth,\n hasCustomWidth,\n layoutOptions,\n width,\n ])\n\n if (dataContext?.prerenderFieldProps) {\n return null\n }\n\n const hasLabelDescription = isFragment(labelDescription)\n ? fragmentHasChildren(labelDescription) &&\n !fragmentHasOnlyUndefinedChildren(labelDescription)\n : labelDescription\n const hasHelp = help?.title || help?.content\n\n return (\n <FieldBlockContext.Provider\n value={{\n setFieldState,\n showFieldError,\n hasErrorProp: Boolean(errorProp),\n fieldStateIdsRef,\n mountedFieldsRef,\n composition,\n disableStatusSummary,\n }}\n >\n <Space\n element={enableFieldset ? 'fieldset' : 'div'} // use fieldset and legend to enhance a11y\n style={mainStyle}\n className={mainClasses}\n {...rest}\n >\n <div className={gridClasses}>\n {(label || labelDescription || hasHelp) && (\n <FormLabel {...labelProps}>\n <span>\n {label && (\n <span className=\"dnb-forms-field-block__label__content\">\n {label}\n </span>\n )}\n\n {hasLabelDescription && (\n <span className=\"dnb-forms-field-block__label__description\">\n {labelDescription}\n </span>\n )}\n\n {hasHelp && (\n <HelpButtonInline contentId={`${id}-help`} help={help} />\n )}\n </span>\n </FormLabel>\n )}\n\n {hasHelp && (\n <HelpButtonInlineContent\n contentId={`${id}-help`}\n className=\"dnb-forms-field-block__help\"\n help={help}\n breakout={\n layout === 'vertical' &&\n !nestedFieldBlockContext?.composition\n }\n />\n )}\n\n <div\n className={classnames(\n 'dnb-forms-field-block__status',\n\n // Handle the width of the status messages\n contentWidth &&\n contentWidth !== 'small' &&\n contentWidth !== 'medium' &&\n !(parseFloat(contentWidth) <= 11) &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`\n )}\n >\n <FormStatus {...statusContent?.error} />\n <FormStatus {...statusContent?.warning} />\n <FormStatus {...statusContent?.info} />\n </div>\n\n <div\n className={classnames(\n 'dnb-forms-field-block__contents',\n contentWidth &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n align && `dnb-forms-field-block__contents--align-${align}`,\n composition &&\n `dnb-forms-field-block__contents__composition--${\n composition === true ? 'horizontal' : composition\n }`,\n contentClassName\n )}\n ref={contentsRef}\n >\n {children}\n </div>\n\n <SubmitIndicator\n state={fieldState}\n className=\"dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap\"\n />\n </div>\n </Space>\n </FieldBlockContext.Provider>\n )\n}\n\nfunction useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n}) {\n return useMemo(() => {\n if (asFieldset === false) {\n return false\n }\n\n let result = asFieldset\n\n if (label && !result && !nestedFieldBlockContext) {\n let count = 0\n\n findElementInChildren(children, (child: React.ReactElement) => {\n if (\n child?.props?.label ||\n child?.type?.['_formElement'] === true\n ) {\n count++\n }\n if (count > 1) {\n return (result = true)\n }\n })\n }\n\n return Boolean(result)\n }, [asFieldset, children, label, nestedFieldBlockContext])\n}\n\nfunction CombineMessages({\n type,\n messages,\n}: {\n type: StateTypes\n messages: Array<StateWithMessage>\n}) {\n const translations = useTranslation().Field\n\n if (messages.length === 1) {\n return <>{messages[0].message}</>\n }\n\n return (\n <>\n {type === 'error'\n ? translations.errorSummary\n : translations.stateSummary}\n <Ul>\n {messages.map(({ message }, i) => {\n return <Li key={i}>{message}</Li>\n })}\n </Ul>\n </>\n )\n}\n\nexport function getMessagesFromError(\n item: Partial<StateWithMessage>\n): Array<StateMessage> {\n const { content } = item\n\n if (content instanceof FormError && Array.isArray(content.errors)) {\n return content.errors.map((error) => {\n return error.message\n })\n }\n\n if (Array.isArray(content)) {\n return content.map((content) => {\n return content instanceof FormError || content instanceof Error\n ? content.message\n : content\n })\n }\n\n if (content instanceof FormError || content instanceof Error) {\n return [content.message as StateMessage]\n }\n\n return [\n ((React.isValidElement(content) ? content : content?.toString()) ||\n content) as StateMessage,\n ]\n}\n\nfunction isFragment(fragment: React.ReactNode) {\n return React.isValidElement(fragment) && fragment.type === React.Fragment\n}\n\nfunction fragmentHasChildren(fragment: React.ReactNode) {\n return (\n React.isValidElement(fragment) &&\n React.Children.count(fragment.props.children) > 0\n )\n}\n\nfunction fragmentHasOnlyUndefinedChildren(fragment: React.ReactNode) {\n const isUndefined = (child) => child === undefined\n\n return (\n React.isValidElement(fragment) &&\n React.Children.toArray(fragment.props.children).every(isUndefined)\n )\n}\n\nFieldBlock._supportsSpacingProps = true\n\nexport default FieldBlock\n\nfunction getFieldWidth(width: FieldBlockHorizontalLabelWidth) {\n switch (width) {\n case 'small':\n return 'var(--forms-field-width--small)'\n case 'medium':\n return 'var(--forms-field-width--medium)'\n case 'large':\n return 'var(--forms-field-width--large)'\n }\n\n return width\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"FieldBlock.js","names":["React","useMemo","useContext","useCallback","useRef","useReducer","useEffect","classnames","FieldBlockContext","DataContext","IterateElementContext","Space","FormLabel","FormStatus","Ul","Li","convertJsxToString","findElementInChildren","useId","HelpButtonInline","HelpButtonInlineContent","SubmitIndicator","createSharedState","useTranslation","FormError","states","FieldBlock","props","_props$id","dataContext","fieldBlockContext","nestedFieldBlockContext","disableStatusSummary","id","forId","sharedData","_Object$assign","Object","assign","data","className","layout","layoutOptions","composition","label","labelProp","labelDescription","labelSuffix","labelSrOnly","help","asFieldset","required","info","warning","error","errorProp","fieldState","disabled","width","contentWidth","labelHeight","align","labelSize","contentClassName","children","rest","_objectWithoutProperties","_excluded","hasCustomWidth","test","String","hasCustomContentWidth","iterateItemContext","index","iterateIndex","blockId","wasUpdated","forceUpdate","mountedFieldsRef","fieldStateRef","stateRecordRef","fieldStateIdsRef","contentsRef","hasInitiallyErrorProp","Boolean","optionalLabelSuffix","Field","labelSuffixText","content","undefined","replace","includes","isValidElement","createElement","Fragment","setInternalRecord","stateId","identifier","type","current","existingIndex","findIndex","item","_objectSpread","push","setBlockRecord","setFieldState","showFieldError","show","map","showInitially","statusContent","statesWithMessages","entries","flatMap","reduce","acc","cur","existing","find","messages","getMessagesFromError","message","state","width_element","no_animation","process","env","NODE_ENV","globalThis","IS_TEST","found","msg","filter","i","arr","length","CombineMessages","mainClasses","gridClasses","enableFieldset","useEnableFieldset","labelProps","element","srOnly","space","size","mainStyle","_lO$minWidth","_lO$maxWidth","style","lO","min","getFieldWidth","minWidth","max","maxWidth","prerenderFieldProps","hasLabelDescription","isFragment","fragmentHasChildren","fragmentHasOnlyUndefinedChildren","hasHelp","title","Provider","value","hasErrorProp","_extends","contentId","breakout","outset","parseFloat","ref","result","count","child","_child$props","_child$type","translations","errorSummary","stateSummary","key","Array","isArray","errors","Error","toString","fragment","Children","isUndefined","toArray","every","_supportsSpacingProps"],"sources":["../../../../../src/extensions/forms/FieldBlock/FieldBlock.tsx"],"sourcesContent":["import React, {\n useMemo,\n useContext,\n useCallback,\n useRef,\n useReducer,\n useEffect,\n} from 'react'\nimport classnames from 'classnames'\nimport FieldBlockContext, {\n StateWithMessage,\n StatesWithMessages,\n FieldErrorIdsRef,\n MountedFieldsRef,\n StateRecord,\n StateMessage,\n StateTypes,\n StatusContent,\n FieldBlockContextProps,\n StateBasis,\n} from './FieldBlockContext'\nimport DataContext from '../DataContext/Context'\nimport IterateElementContext from '../Iterate/IterateItemContext'\nimport { Space, FormLabel, FormStatus } from '../../../components'\nimport { Ul, Li } from '../../../elements'\nimport {\n convertJsxToString,\n findElementInChildren,\n} from '../../../shared/component-helper'\nimport useId from '../../../shared/helpers/useId'\nimport {\n ComponentProps,\n FieldProps,\n SubmitState,\n Identifier,\n} from '../types'\nimport type { FormLabelAllProps } from '../../../components/FormLabel'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n HelpProps,\n} from '../../../components/help-button/HelpButtonInline'\nimport SubmitIndicator from '../Form/SubmitIndicator/SubmitIndicator'\nimport { createSharedState } from '../../../shared/helpers/useSharedState'\nimport useTranslation from '../hooks/useTranslation'\nimport { FormError } from '../utils'\n\nexport const states: Array<StateTypes> = ['error', 'info', 'warning']\n\n/**\n * The width of a field block\n */\nexport type CustomWidth = `${number}rem`\nexport type FieldBlockWidth =\n | false\n | 'small'\n | 'medium'\n | 'large'\n | 'stretch'\n | CustomWidth\nexport type FieldBlockHorizontalLabelWidth =\n | 'small'\n | 'medium'\n | 'large'\n | CustomWidth\nexport type FieldBlockHorizontalLabelHeight =\n | 'default'\n | 'small'\n | 'medium'\n | 'large'\n\nexport type SharedFieldBlockProps = {\n /**\n * The layout of the field block\n */\n layout?: 'vertical' | 'horizontal'\n /** Use this to set additional options for the layout */\n layoutOptions?: {\n width?: FieldBlockHorizontalLabelWidth\n minWidth?: FieldBlockHorizontalLabelWidth\n maxWidth?: FieldBlockHorizontalLabelWidth\n }\n /**\n * Main label text for the field\n */\n label?: React.ReactNode\n /**\n * Will append an additional text to the label, like \"(optional)\" or \"(recommended)\"\n */\n labelSuffix?: React.ReactNode\n /**\n * A more discreet text displayed beside the label\n */\n labelDescription?: React.ReactNode\n /**\n * Width of outer block element\n */\n width?: FieldBlockWidth\n /**\n * Width of contents block, while label etc can be wider if space is available\n */\n contentWidth?: FieldBlockWidth\n /**\n * Provide help content for the field.\n */\n help?: HelpProps\n}\n\nexport type Props = SharedFieldBlockProps &\n Pick<\n FieldProps,\n keyof ComponentProps | 'info' | 'warning' | 'error' | 'disabled'\n > & {\n /** The id to link a element with */\n forId?: string\n /** Use true if you have more than one form element */\n asFieldset?: boolean\n /** use `true` to make the label only readable by screen readers. */\n labelSrOnly?: boolean\n /** Defines the layout of nested fields */\n composition?: FieldBlockContextProps['composition']\n /** For composition only: Align the contents vertically */\n align?: 'center' | 'bottom'\n /** Class name for the contents block */\n contentClassName?: string\n /** To show the SubmitIndicator during async validation */\n fieldState?: SubmitState\n /** Typography size */\n labelSize?: 'medium' | 'large'\n /** Defines the height of an component (size prop), so the label can be aligned correctly */\n labelHeight?: FieldBlockHorizontalLabelHeight\n /** Disable the error summary for this field block */\n disableStatusSummary?: boolean\n /** For internal use only */\n required?: boolean\n children?: React.ReactNode\n } & React.HTMLAttributes<HTMLDivElement>\n\nfunction FieldBlock(props: Props) {\n const dataContext = useContext(DataContext)\n const fieldBlockContext = useContext(FieldBlockContext)\n const nestedFieldBlockContext = !fieldBlockContext?.disableStatusSummary\n ? fieldBlockContext\n : null\n\n const id = useId(props.id ?? props.forId)\n const sharedData = createSharedState<Props>('field-block-props-' + id)\n const {\n className,\n forId,\n layout = 'vertical',\n layoutOptions,\n composition,\n label: labelProp,\n labelDescription,\n labelSuffix,\n labelSrOnly,\n help,\n asFieldset,\n required,\n info,\n warning,\n error: errorProp,\n disableStatusSummary,\n fieldState,\n disabled,\n width,\n contentWidth,\n labelHeight,\n align,\n labelSize,\n contentClassName,\n children,\n ...rest\n } = Object.assign({}, sharedData.data, props)\n const hasCustomWidth = /\\d(rem)$/.test(String(width))\n const hasCustomContentWidth = /\\d(rem)$/.test(String(contentWidth))\n\n const iterateItemContext = useContext(IterateElementContext)\n const { index: iterateIndex } = iterateItemContext ?? {}\n\n const blockId = useId(props.id)\n const [wasUpdated, forceUpdate] = useReducer(() => ({}), {})\n const mountedFieldsRef = useRef<MountedFieldsRef>({})\n const fieldStateRef = useRef<SubmitState>(null)\n const stateRecordRef = useRef<StateRecord>({})\n const fieldStateIdsRef = useRef<FieldErrorIdsRef>(null)\n const contentsRef = useRef<HTMLDivElement>(null)\n const hasInitiallyErrorProp = useMemo(() => {\n return Boolean(errorProp)\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n const { optionalLabelSuffix } = useTranslation().Field\n const labelSuffixText = useMemo(() => {\n if (required === false || typeof labelSuffix !== 'undefined') {\n return labelSuffix ?? optionalLabelSuffix\n }\n return ''\n }, [required, labelSuffix, optionalLabelSuffix])\n\n const label = useMemo(() => {\n let content = labelProp\n\n if (iterateIndex !== undefined) {\n content = convertJsxToString(labelProp).replace(\n '{itemNo}',\n String(iterateIndex + 1)\n )\n }\n\n if (labelSuffixText) {\n if (convertJsxToString(content).includes(optionalLabelSuffix)) {\n return content\n }\n\n if (typeof content === 'string') {\n return content + ' ' + labelSuffixText\n }\n\n if (React.isValidElement(content)) {\n return (\n <>\n {content}\n {' '}\n {labelSuffixText}\n </>\n )\n }\n }\n\n return content\n }, [iterateIndex, labelProp, labelSuffixText, optionalLabelSuffix])\n\n const setInternalRecord = useCallback((props: StateBasis) => {\n const { stateId, identifier, type } = props\n\n if (!stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = []\n }\n\n fieldStateIdsRef.current = { error: null, warning: null, info: null }\n\n const existingIndex = stateRecordRef.current[identifier].findIndex(\n (item) => {\n return item.stateId === stateId && item.type === type\n }\n )\n\n if (existingIndex > -1) {\n stateRecordRef.current[identifier][existingIndex] = {\n ...stateRecordRef.current[identifier][existingIndex],\n ...props,\n }\n } else {\n stateRecordRef.current[identifier].push(props)\n }\n }, [])\n\n const setBlockRecord = useCallback(\n (props: StateBasis) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.setBlockRecord(props)\n return\n }\n\n setInternalRecord(props)\n\n forceUpdate()\n },\n [nestedFieldBlockContext, setInternalRecord]\n )\n\n const setFieldState = useCallback(\n (identifier: Identifier, fieldState: SubmitState) => {\n if (fieldState !== fieldStateRef.current) {\n fieldStateRef.current = fieldState\n\n forceUpdate()\n }\n },\n []\n )\n\n const showFieldError = useCallback(\n (identifier: Identifier, show: boolean) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.showFieldError(identifier, show)\n return\n }\n\n if (stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = stateRecordRef.current[\n identifier\n ].map((item) => {\n if (item.showInitially) {\n return item\n }\n\n return {\n ...item,\n show,\n }\n })\n\n forceUpdate()\n }\n },\n [nestedFieldBlockContext]\n )\n\n const statusContent = useMemo(() => {\n if (typeof errorProp !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: hasInitiallyErrorProp,\n type: 'error',\n content: errorProp,\n })\n }\n\n if (typeof warning !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'warning',\n content: warning,\n })\n }\n\n if (typeof info !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'info',\n content: info,\n })\n }\n\n const statesWithMessages: Array<StatesWithMessages> =\n // 1. Prepare the states for later use\n Object.entries(stateRecordRef.current)\n .flatMap(([identifier, states]) =>\n states.map((props) => {\n return {\n identifier,\n ...props,\n }\n })\n )\n\n // 2. Take states and group the same type together\n .reduce((acc, cur) => {\n const existing = acc.find((item) => {\n return item.type === cur.type\n })\n\n const messages = getMessagesFromError(cur).map((message) => {\n return {\n ...cur,\n message,\n }\n })\n\n if (existing) {\n existing.messages.push(...messages)\n } else {\n acc.push({\n ...cur,\n content: undefined,\n messages,\n })\n }\n\n return acc\n }, [] as Array<StatesWithMessages>)\n\n // 3. Return the grouped states/messages\n return states.reduce((acc, type) => {\n const id = `${props.id || forId || blockId}-form-status--${type}`\n acc[type] = {\n id,\n label,\n state: type === 'warning' ? 'warn' : type,\n width_element: contentsRef,\n\n // Enable animation only in the browser and not in tests\n no_animation:\n process.env.NODE_ENV === 'test'\n ? true\n : typeof globalThis !== 'undefined'\n ? globalThis.IS_TEST === true\n : false,\n }\n\n const found = statesWithMessages.find((item) => {\n return item.type === type\n })\n\n if (found?.messages) {\n // Hide/remove messages that should be hidden and are not marked as to be shown initially\n const messages = found.messages\n .map((msg) => {\n if (msg.type === 'error') {\n if (!msg.showInitially && !msg.show) {\n msg.message = null\n }\n }\n\n return msg\n })\n .filter(({ message }) => message)\n .reduce((acc, msg, i, arr) => {\n const existingIndex = arr.findIndex((item) => {\n return (\n convertJsxToString(item.message) ===\n convertJsxToString(msg.message)\n )\n })\n\n // Remove duplicates, use the first found message\n if (existingIndex === i) {\n acc.push(msg)\n }\n\n return acc\n }, [])\n\n // Combine the messages and put them in an ul/li list\n if (messages.length > 0) {\n acc[type] = {\n ...acc[type],\n children: <CombineMessages type={type} messages={messages} />,\n }\n\n fieldStateIdsRef.current[type] = id\n } else {\n fieldStateIdsRef.current[type] = undefined\n }\n }\n\n return acc\n }, {}) as StatusContent\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n info,\n warning,\n errorProp,\n nestedFieldBlockContext,\n setInternalRecord,\n blockId,\n wasUpdated, // wasUpdated is needed to get the current errors\n ])\n\n // Handle the error prop from outside\n useEffect(() => {\n if (!nestedFieldBlockContext) {\n showFieldError(blockId, Boolean(errorProp))\n }\n }, [errorProp, blockId, showFieldError, nestedFieldBlockContext])\n\n useEffect(\n () => () => {\n mountedFieldsRef.current = {}\n stateRecordRef.current = {}\n },\n []\n )\n\n const mainClasses = classnames(\n 'dnb-forms-field-block',\n width &&\n `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`,\n contentWidth &&\n `dnb-forms-field-block--content-width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`,\n composition && 'dnb-forms-field-block__composition',\n composition &&\n `dnb-forms-field-block__composition--${\n composition === true ? 'horizontal' : composition\n }`,\n className\n )\n const gridClasses = classnames(\n 'dnb-forms-field-block__grid',\n `dnb-forms-field-block--layout-${layout}`\n )\n\n // A child component with a label was found, use fieldset/legend instead of div/label\n const enableFieldset = useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n })\n\n const labelProps: FormLabelAllProps = {\n className: 'dnb-forms-field-block__label',\n element: enableFieldset ? 'legend' : 'label',\n forId: enableFieldset ? undefined : forId,\n srOnly: labelSrOnly,\n space: 0, // Use CSS for spacing, but we need to reset space for doing so\n size: labelSize,\n disabled,\n }\n\n const mainStyle = useMemo(() => {\n const style: React.CSSProperties = {}\n\n if (hasCustomWidth) {\n style['--dnb-forms-field-block-width'] = width\n }\n\n if (hasCustomContentWidth) {\n style['--dnb-forms-field-block-content-width'] = contentWidth\n }\n\n const lO = layoutOptions || {}\n const min = getFieldWidth(lO.minWidth ?? lO.width)\n const max = getFieldWidth(lO.maxWidth ?? lO.width)\n\n if (typeof min === 'string') {\n style['--dnb-forms-field-block-layout-width-min'] = min\n }\n if (typeof max === 'string') {\n style['--dnb-forms-field-block-layout-width-max'] = max\n }\n\n return style\n }, [\n contentWidth,\n hasCustomContentWidth,\n hasCustomWidth,\n layoutOptions,\n width,\n ])\n\n if (dataContext?.prerenderFieldProps) {\n return null\n }\n\n const hasLabelDescription = isFragment(labelDescription)\n ? fragmentHasChildren(labelDescription) &&\n !fragmentHasOnlyUndefinedChildren(labelDescription)\n : labelDescription\n const hasHelp = help?.title || help?.content\n\n return (\n <FieldBlockContext.Provider\n value={{\n setBlockRecord,\n setFieldState,\n showFieldError,\n hasErrorProp: Boolean(errorProp),\n fieldStateIdsRef,\n mountedFieldsRef,\n composition,\n disableStatusSummary,\n }}\n >\n <Space\n element={enableFieldset ? 'fieldset' : 'div'} // use fieldset and legend to enhance a11y\n style={mainStyle}\n className={mainClasses}\n {...rest}\n >\n <div className={gridClasses}>\n {(label || labelDescription || hasHelp) && (\n <FormLabel {...labelProps}>\n <span>\n {label && (\n <span className=\"dnb-forms-field-block__label__content\">\n {label}\n </span>\n )}\n\n {hasLabelDescription && (\n <span className=\"dnb-forms-field-block__label__description\">\n {labelDescription}\n </span>\n )}\n\n {hasHelp && (\n <HelpButtonInline contentId={`${id}-help`} help={help} />\n )}\n </span>\n </FormLabel>\n )}\n\n {hasHelp && (\n <HelpButtonInlineContent\n contentId={`${id}-help`}\n className=\"dnb-forms-field-block__help\"\n help={help}\n breakout={\n layout === 'vertical' &&\n !nestedFieldBlockContext?.composition\n }\n outset={layout !== 'horizontal'}\n />\n )}\n\n <div\n className={classnames(\n 'dnb-forms-field-block__status',\n\n // Handle the width of the status messages\n contentWidth &&\n contentWidth !== 'small' &&\n contentWidth !== 'medium' &&\n !(parseFloat(contentWidth) <= 11) &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`\n )}\n >\n <FormStatus {...statusContent?.error} />\n <FormStatus {...statusContent?.warning} />\n <FormStatus {...statusContent?.info} />\n </div>\n\n <div\n className={classnames(\n 'dnb-forms-field-block__contents',\n contentWidth &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n align && `dnb-forms-field-block__contents--align-${align}`,\n contentClassName\n )}\n ref={contentsRef}\n >\n {children}\n </div>\n\n <SubmitIndicator\n state={fieldState ?? fieldStateRef.current}\n className=\"dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap\"\n />\n </div>\n </Space>\n </FieldBlockContext.Provider>\n )\n}\n\nfunction useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n}) {\n return useMemo(() => {\n if (asFieldset === false) {\n return false\n }\n\n let result = asFieldset\n\n if (label && !result && !nestedFieldBlockContext) {\n let count = 0\n\n findElementInChildren(children, (child: React.ReactElement) => {\n if (\n child?.props?.label ||\n child?.type?.['_formElement'] === true\n ) {\n count++\n }\n if (count > 1) {\n return (result = true)\n }\n })\n }\n\n return Boolean(result)\n }, [asFieldset, children, label, nestedFieldBlockContext])\n}\n\nfunction CombineMessages({\n type,\n messages,\n}: {\n type: StateTypes\n messages: Array<StateWithMessage>\n}) {\n const translations = useTranslation().Field\n\n if (messages.length === 1) {\n return <>{messages[0].message}</>\n }\n\n return (\n <>\n {type === 'error'\n ? translations.errorSummary\n : translations.stateSummary}\n <Ul>\n {messages.map(({ message }, i) => {\n return <Li key={i}>{message}</Li>\n })}\n </Ul>\n </>\n )\n}\n\nexport function getMessagesFromError(\n item: Partial<StateWithMessage>\n): Array<StateMessage> {\n const { content } = item\n\n if (content instanceof FormError && Array.isArray(content.errors)) {\n return content.errors.map((error) => {\n return error.message\n })\n }\n\n if (Array.isArray(content)) {\n return content.map((content) => {\n return content instanceof FormError || content instanceof Error\n ? content.message\n : content\n })\n }\n\n if (content instanceof FormError || content instanceof Error) {\n return [content.message as StateMessage]\n }\n\n return [\n ((React.isValidElement(content) ? content : content?.toString()) ||\n content) as StateMessage,\n ]\n}\n\nfunction isFragment(fragment: React.ReactNode) {\n return React.isValidElement(fragment) && fragment.type === React.Fragment\n}\n\nfunction fragmentHasChildren(fragment: React.ReactNode) {\n return (\n React.isValidElement(fragment) &&\n React.Children.count(fragment.props.children) > 0\n )\n}\n\nfunction fragmentHasOnlyUndefinedChildren(fragment: React.ReactNode) {\n const isUndefined = (child) => child === undefined\n\n return (\n React.isValidElement(fragment) &&\n React.Children.toArray(fragment.props.children).every(isUndefined)\n )\n}\n\nFieldBlock._supportsSpacingProps = true\n\nexport default FieldBlock\n\nfunction getFieldWidth(width: FieldBlockHorizontalLabelWidth) {\n switch (width) {\n case 'small':\n return 'var(--forms-field-width--small)'\n case 'medium':\n return 'var(--forms-field-width--medium)'\n case 'large':\n return 'var(--forms-field-width--large)'\n }\n\n return width\n}\n"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import type { FieldProps, Identifier } from '../types';
|
|
2
|
+
import type { FieldProps, Identifier, SubmitState } from '../types';
|
|
3
3
|
export type FieldErrorIdsRef = Record<StateTypes, string>;
|
|
4
4
|
export type MountedFieldsRef = Record<Identifier, boolean>;
|
|
5
5
|
export type StateTypes = 'error' | 'warning' | 'info';
|
|
@@ -30,7 +30,8 @@ export type StatusContent = {
|
|
|
30
30
|
info: StatusContentState;
|
|
31
31
|
};
|
|
32
32
|
export type FieldBlockContextProps = {
|
|
33
|
-
|
|
33
|
+
setBlockRecord?: ({ identifier, type, stateId, content, showInitially, show, }: StateBasis) => void;
|
|
34
|
+
setFieldState?: (identifier: Identifier, fieldState: SubmitState) => void;
|
|
34
35
|
showFieldError?: (identifier: Identifier, showError: boolean) => void;
|
|
35
36
|
hasErrorProp?: boolean;
|
|
36
37
|
composition?: true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FieldBlockContext.js","names":["React","FieldBlockContext","createContext","undefined"],"sources":["../../../../../src/extensions/forms/FieldBlock/FieldBlockContext.ts"],"sourcesContent":["import React from 'react'\nimport type { FieldProps, Identifier } from '../types'\n\nexport type FieldErrorIdsRef = Record<StateTypes, string>\nexport type MountedFieldsRef = Record<Identifier, boolean>\nexport type StateTypes = 'error' | 'warning' | 'info'\nexport type StateContent =\n | FieldProps<unknown>['error']\n | FieldProps<unknown>['warning']\n | FieldProps<unknown>['info']\nexport type StateBasis = {\n identifier: Identifier\n type: StateTypes\n content: StateContent\n stateId?: string\n showInitially?: boolean\n show?: boolean\n}\nexport type StateRecord = Record<\n Identifier,\n Array<Omit<StateBasis, 'identifier'>>\n>\nexport type StateMessage = string\nexport type StateWithMessage = StateBasis & {\n message: StateMessage\n}\nexport type StatesWithMessages = StateBasis & {\n messages: Array<StateWithMessage>\n}\nexport type StatusContentState = { id: string; text: React.ReactNode }\nexport type StatusContent = {\n error: StatusContentState\n warning: StatusContentState\n info: StatusContentState\n}\n\nexport type FieldBlockContextProps = {\n
|
|
1
|
+
{"version":3,"file":"FieldBlockContext.js","names":["React","FieldBlockContext","createContext","undefined"],"sources":["../../../../../src/extensions/forms/FieldBlock/FieldBlockContext.ts"],"sourcesContent":["import React from 'react'\nimport type { FieldProps, Identifier, SubmitState } from '../types'\n\nexport type FieldErrorIdsRef = Record<StateTypes, string>\nexport type MountedFieldsRef = Record<Identifier, boolean>\nexport type StateTypes = 'error' | 'warning' | 'info'\nexport type StateContent =\n | FieldProps<unknown>['error']\n | FieldProps<unknown>['warning']\n | FieldProps<unknown>['info']\nexport type StateBasis = {\n identifier: Identifier\n type: StateTypes\n content: StateContent\n stateId?: string\n showInitially?: boolean\n show?: boolean\n}\nexport type StateRecord = Record<\n Identifier,\n Array<Omit<StateBasis, 'identifier'>>\n>\nexport type StateMessage = string\nexport type StateWithMessage = StateBasis & {\n message: StateMessage\n}\nexport type StatesWithMessages = StateBasis & {\n messages: Array<StateWithMessage>\n}\nexport type StatusContentState = { id: string; text: React.ReactNode }\nexport type StatusContent = {\n error: StatusContentState\n warning: StatusContentState\n info: StatusContentState\n}\n\nexport type FieldBlockContextProps = {\n setBlockRecord?: ({\n identifier,\n type,\n stateId,\n content,\n showInitially,\n show,\n }: StateBasis) => void\n setFieldState?: (identifier: Identifier, fieldState: SubmitState) => void\n showFieldError?: (identifier: Identifier, showError: boolean) => void\n hasErrorProp?: boolean\n composition?: true\n disableStatusSummary?: boolean\n fieldStateIdsRef?: React.MutableRefObject<FieldErrorIdsRef>\n mountedFieldsRef?: React.MutableRefObject<MountedFieldsRef>\n}\n\nconst FieldBlockContext = React.createContext<\n FieldBlockContextProps | undefined\n>(undefined)\n\nexport default FieldBlockContext\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAsDzB,MAAMC,iBAAiB,GAAGD,KAAK,CAACE,aAAa,CAE3CC,SAAS,CAAC;AAEZ,eAAeF,iBAAiB"}
|
|
@@ -163,28 +163,38 @@ fieldset.dnb-forms-field-block:not([class*=space__left]) {
|
|
|
163
163
|
width: var(--forms-field-width--large);
|
|
164
164
|
}
|
|
165
165
|
}
|
|
166
|
-
.dnb-forms-field-
|
|
166
|
+
.dnb-forms-field-block__composition--vertical .dnb-forms-field-block__contents {
|
|
167
167
|
display: flex;
|
|
168
168
|
flex-flow: column;
|
|
169
|
-
row-gap: var(--spacing-small);
|
|
169
|
+
row-gap: var(--spacing-x-small);
|
|
170
170
|
}
|
|
171
|
-
.dnb-forms-field-
|
|
171
|
+
.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents {
|
|
172
172
|
display: flex;
|
|
173
173
|
flex-flow: row;
|
|
174
174
|
-moz-column-gap: var(--spacing-small);
|
|
175
175
|
column-gap: var(--spacing-small);
|
|
176
176
|
}
|
|
177
177
|
@media screen and (min-width: 25.00625em) {
|
|
178
|
-
.dnb-forms-field-
|
|
178
|
+
.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents {
|
|
179
179
|
align-items: flex-end;
|
|
180
180
|
}
|
|
181
|
-
.dnb-forms-field-
|
|
181
|
+
.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents[class*=align-center] {
|
|
182
182
|
align-items: center;
|
|
183
183
|
}
|
|
184
184
|
}
|
|
185
185
|
@media screen and (max-width: 25em) {
|
|
186
|
-
.dnb-forms-field-
|
|
186
|
+
.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents {
|
|
187
187
|
row-gap: var(--spacing-x-small);
|
|
188
188
|
flex-flow: column;
|
|
189
189
|
}
|
|
190
|
+
}
|
|
191
|
+
@media screen and (max-width: 25em) {
|
|
192
|
+
.dnb-forms-field-block__composition > .dnb-forms-field-block__grid > .dnb-forms-submit-indicator {
|
|
193
|
+
display: none;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
@media screen and (min-width: 25.00625em) {
|
|
197
|
+
.dnb-forms-field-block__composition > .dnb-forms-field-block__grid > .dnb-forms-field-block__contents .dnb-forms-submit-indicator {
|
|
198
|
+
display: none;
|
|
199
|
+
}
|
|
190
200
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
:root{--forms-field-width--small:5rem;--forms-field-width--medium:11rem;--forms-field-width--large:21rem}fieldset.dnb-forms-field-block{border:none;padding:0}fieldset.dnb-forms-field-block:not([class*=space__top]){margin-top:0}fieldset.dnb-forms-field-block:not([class*=space__right]){margin-right:0}fieldset.dnb-forms-field-block:not([class*=space__bottom]){margin-bottom:0}fieldset.dnb-forms-field-block:not([class*=space__left]){margin-left:0}.dnb-forms-field-block{--label-margin:0.25rem;--max-width:var(--forms-field-width--large)}.dnb-forms-field-block__grid{display:grid;grid-template-areas:"label" "help" "contents" "indicator" "status";grid-template-columns:minmax(min-content,var(--block-content-width,auto))}.dnb-forms-field-block--label-height-small{--label-margin:0}.dnb-forms-field-block--label-height-medium{--label-margin:0.5rem}.dnb-forms-field-block--label-height-large{--label-margin:0.7rem}.dnb-forms-field-block--width-stretch{flex-grow:1}@media screen and (min-width:25.00625em){.dnb-forms-field-block--width-custom{width:calc(var(--dnb-forms-field-block-width))}.dnb-forms-field-block--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block:not([class*="--content-width"]){--max-width:60ch}.dnb-forms-field-block__label,.dnb-forms-field-block__label.dnb-form-label{align-items:center;display:flex;grid-area:label;margin-right:0;max-width:var(--max-width)}.dnb-forms-field-block__label.dnb-form-label__description,.dnb-forms-field-block__label__description{margin-left:.3em}.dnb-forms-field-block__label.dnb-form-label__content:has(+.dnb-help-button),.dnb-forms-field-block__label.dnb-form-label__description:has(+.dnb-help-button),.dnb-forms-field-block__label__content:has(+.dnb-help-button),.dnb-forms-field-block__label__description:has(+.dnb-help-button){margin-right:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical{flex-wrap:wrap}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical>.dnb-form-label{margin-bottom:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__label{margin-right:1rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:var(--label-margin);margin-top:var(--label-margin)}@media screen and (max-width:40em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:calc(var(--label-margin) + .5rem)}}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal{grid-template-areas:"label contents" ". help" ". indicator" ". status";grid-template-columns:minmax(var(--dnb-forms-field-block-layout-width-min,min-content),var(--dnb-forms-field-block-layout-width-max,max-content)) auto}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content{--help-button-indent-width:0}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content .dnb-section{--rounded-corner:0.25rem;align-self:flex-start}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__contents{align-self:end}}.dnb-forms-field-block__indicator{grid-area:indicator}.dnb-forms-field-block__help{display:flex;flex-flow:column;grid-area:help}.dnb-forms-field-block__help .dnb-section{margin-bottom:1rem}.dnb-forms-field-block__help .dnb-section>.dnb-p--lead{margin-bottom:.5rem}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__help .dnb-section{margin-bottom:0;margin-top:.5rem}}.dnb-forms-field-block__status{grid-area:status}.dnb-forms-field-block__status .dnb-form-status__shell{margin-top:.5rem;max-width:60ch}@media screen and (max-width:15em){.dnb-forms-field-block__status{width:90%}}.dnb-forms-field-block__contents{display:flex;grid-area:contents;width:100%}.dnb-forms-field-block__contents--width-stretch{width:100%}@media screen and (min-width:25.00625em){.dnb-forms-field-block__contents--width-custom{width:calc(var(--dnb-forms-field-block-content-width))}.dnb-forms-field-block__contents--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block__contents--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block__contents--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-
|
|
1
|
+
:root{--forms-field-width--small:5rem;--forms-field-width--medium:11rem;--forms-field-width--large:21rem}fieldset.dnb-forms-field-block{border:none;padding:0}fieldset.dnb-forms-field-block:not([class*=space__top]){margin-top:0}fieldset.dnb-forms-field-block:not([class*=space__right]){margin-right:0}fieldset.dnb-forms-field-block:not([class*=space__bottom]){margin-bottom:0}fieldset.dnb-forms-field-block:not([class*=space__left]){margin-left:0}.dnb-forms-field-block{--label-margin:0.25rem;--max-width:var(--forms-field-width--large)}.dnb-forms-field-block__grid{display:grid;grid-template-areas:"label" "help" "contents" "indicator" "status";grid-template-columns:minmax(min-content,var(--block-content-width,auto))}.dnb-forms-field-block--label-height-small{--label-margin:0}.dnb-forms-field-block--label-height-medium{--label-margin:0.5rem}.dnb-forms-field-block--label-height-large{--label-margin:0.7rem}.dnb-forms-field-block--width-stretch{flex-grow:1}@media screen and (min-width:25.00625em){.dnb-forms-field-block--width-custom{width:calc(var(--dnb-forms-field-block-width))}.dnb-forms-field-block--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block:not([class*="--content-width"]){--max-width:60ch}.dnb-forms-field-block__label,.dnb-forms-field-block__label.dnb-form-label{align-items:center;display:flex;grid-area:label;margin-right:0;max-width:var(--max-width)}.dnb-forms-field-block__label.dnb-form-label__description,.dnb-forms-field-block__label__description{margin-left:.3em}.dnb-forms-field-block__label.dnb-form-label__content:has(+.dnb-help-button),.dnb-forms-field-block__label.dnb-form-label__description:has(+.dnb-help-button),.dnb-forms-field-block__label__content:has(+.dnb-help-button),.dnb-forms-field-block__label__description:has(+.dnb-help-button){margin-right:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical{flex-wrap:wrap}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical>.dnb-form-label{margin-bottom:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__label{margin-right:1rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:var(--label-margin);margin-top:var(--label-margin)}@media screen and (max-width:40em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:calc(var(--label-margin) + .5rem)}}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal{grid-template-areas:"label contents" ". help" ". indicator" ". status";grid-template-columns:minmax(var(--dnb-forms-field-block-layout-width-min,min-content),var(--dnb-forms-field-block-layout-width-max,max-content)) auto}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content{--help-button-indent-width:0}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content .dnb-section{--rounded-corner:0.25rem;align-self:flex-start}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__contents{align-self:end}}.dnb-forms-field-block__indicator{grid-area:indicator}.dnb-forms-field-block__help{display:flex;flex-flow:column;grid-area:help}.dnb-forms-field-block__help .dnb-section{margin-bottom:1rem}.dnb-forms-field-block__help .dnb-section>.dnb-p--lead{margin-bottom:.5rem}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__help .dnb-section{margin-bottom:0;margin-top:.5rem}}.dnb-forms-field-block__status{grid-area:status}.dnb-forms-field-block__status .dnb-form-status__shell{margin-top:.5rem;max-width:60ch}@media screen and (max-width:15em){.dnb-forms-field-block__status{width:90%}}.dnb-forms-field-block__contents{display:flex;grid-area:contents;width:100%}.dnb-forms-field-block__contents--width-stretch{width:100%}@media screen and (min-width:25.00625em){.dnb-forms-field-block__contents--width-custom{width:calc(var(--dnb-forms-field-block-content-width))}.dnb-forms-field-block__contents--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block__contents--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block__contents--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block__composition--vertical .dnb-forms-field-block__contents{display:flex;flex-flow:column;row-gap:var(--spacing-x-small)}.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{-moz-column-gap:var(--spacing-small);column-gap:var(--spacing-small);display:flex;flex-flow:row}@media screen and (min-width:25.00625em){.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{align-items:flex-end}.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents[class*=align-center]{align-items:center}}@media screen and (max-width:25em){.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{flex-flow:column;row-gap:var(--spacing-x-small)}.dnb-forms-field-block__composition>.dnb-forms-field-block__grid>.dnb-forms-submit-indicator{display:none}}@media screen and (min-width:25.00625em){.dnb-forms-field-block__composition>.dnb-forms-field-block__grid>.dnb-forms-field-block__contents .dnb-forms-submit-indicator{display:none}}
|
|
@@ -169,6 +169,7 @@ fieldset.dnb-forms-field-block {
|
|
|
169
169
|
|
|
170
170
|
&__status {
|
|
171
171
|
grid-area: status;
|
|
172
|
+
|
|
172
173
|
.dnb-form-status__shell {
|
|
173
174
|
margin-top: 0.5rem; // set margin-top on shell, so we can animate the height
|
|
174
175
|
max-width: 60ch; // to enhance readability
|
|
@@ -204,31 +205,42 @@ fieldset.dnb-forms-field-block {
|
|
|
204
205
|
}
|
|
205
206
|
}
|
|
206
207
|
}
|
|
208
|
+
}
|
|
207
209
|
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
}
|
|
210
|
+
&__composition--vertical &__contents {
|
|
211
|
+
display: flex;
|
|
212
|
+
flex-flow: column;
|
|
213
|
+
row-gap: var(--spacing-x-small);
|
|
214
|
+
}
|
|
214
215
|
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
216
|
+
&__composition--horizontal &__contents {
|
|
217
|
+
display: flex;
|
|
218
|
+
flex-flow: row;
|
|
219
|
+
column-gap: var(--spacing-small);
|
|
219
220
|
|
|
220
|
-
|
|
221
|
-
|
|
221
|
+
@include allAbove(x-small) {
|
|
222
|
+
align-items: flex-end; // To support fields with labels of different size
|
|
222
223
|
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
@include allBelow(x-small) {
|
|
228
|
-
row-gap: var(--spacing-x-small);
|
|
229
|
-
flex-flow: column;
|
|
230
|
-
}
|
|
224
|
+
&[class*='align-center'] {
|
|
225
|
+
align-items: center; // To support fields without labels, but different heights
|
|
231
226
|
}
|
|
232
227
|
}
|
|
228
|
+
@include allBelow(x-small) {
|
|
229
|
+
row-gap: var(--spacing-x-small);
|
|
230
|
+
flex-flow: column;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
// Because we want to hide / show the indicator responsively,
|
|
235
|
+
// we render both, but hide the one we don't want to show.
|
|
236
|
+
@include allBelow(x-small) {
|
|
237
|
+
&__composition > &__grid > .dnb-forms-submit-indicator {
|
|
238
|
+
display: none;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
@include allAbove(x-small) {
|
|
242
|
+
&__composition > &__grid > &__contents .dnb-forms-submit-indicator {
|
|
243
|
+
display: none;
|
|
244
|
+
}
|
|
233
245
|
}
|
|
234
246
|
}
|
|
@@ -8,17 +8,15 @@
|
|
|
8
8
|
gap: var(--spacing-small);
|
|
9
9
|
}
|
|
10
10
|
|
|
11
|
-
.dnb-card + .dnb-forms-button-row:not([class*=space__top]),
|
|
12
|
-
.dnb-card + .dnb-button--primary:not([class*=space__top]) {
|
|
11
|
+
.dnb-card + .dnb-forms-button-row:not([class*=space__top]), .dnb-card + .dnb-button--primary:not([class*=space__top]) {
|
|
13
12
|
margin-top: var(--spacing-small);
|
|
14
13
|
}
|
|
15
|
-
.dnb-card + .dnb-forms-button-row:not([class*=space__top]) .dnb-button[class*=space__top],
|
|
16
|
-
.dnb-card + .dnb-button--primary:not([class*=space__top]) .dnb-button[class*=space__top] {
|
|
14
|
+
.dnb-card + .dnb-forms-button-row:not([class*=space__top]) .dnb-button[class*=space__top], .dnb-card + .dnb-button--primary:not([class*=space__top]) .dnb-button[class*=space__top] {
|
|
17
15
|
margin-top: 0;
|
|
18
16
|
}
|
|
17
|
+
|
|
19
18
|
@media screen and (min-width: 40.00625em) {
|
|
20
|
-
.dnb-card + .dnb-forms-button-row:not([class*=space__left]),
|
|
21
|
-
.dnb-card + .dnb-button--primary:not([class*=space__left]) {
|
|
19
|
+
.dnb-card:not([style*="--outset"]) + .dnb-forms-button-row:not([class*=space__left]), .dnb-card:not([style*="--outset"]) + .dnb-button--primary:not([class*=space__left]) {
|
|
22
20
|
margin-left: var(--spacing-medium);
|
|
23
21
|
}
|
|
24
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.dnb-forms-button-row{display:flex;flex-flow:row;flex-wrap:wrap;gap:var(--spacing-small)}.dnb-card+.dnb-button--primary:not([class*=space__top]),.dnb-card+.dnb-forms-button-row:not([class*=space__top]){margin-top:var(--spacing-small)}.dnb-card+.dnb-button--primary:not([class*=space__top]) .dnb-button[class*=space__top],.dnb-card+.dnb-forms-button-row:not([class*=space__top]) .dnb-button[class*=space__top]{margin-top:0}@media screen and (min-width:40.00625em){.dnb-card+.dnb-button--primary:not([class*=space__left]),.dnb-card+.dnb-forms-button-row:not([class*=space__left]){margin-left:var(--spacing-medium)}}
|
|
1
|
+
.dnb-forms-button-row{display:flex;flex-flow:row;flex-wrap:wrap;gap:var(--spacing-small)}.dnb-card+.dnb-button--primary:not([class*=space__top]),.dnb-card+.dnb-forms-button-row:not([class*=space__top]){margin-top:var(--spacing-small)}.dnb-card+.dnb-button--primary:not([class*=space__top]) .dnb-button[class*=space__top],.dnb-card+.dnb-forms-button-row:not([class*=space__top]) .dnb-button[class*=space__top]{margin-top:0}@media screen and (min-width:40.00625em){.dnb-card:not([style*="--outset"])+.dnb-button--primary:not([class*=space__left]),.dnb-card:not([style*="--outset"])+.dnb-forms-button-row:not([class*=space__left]){margin-left:var(--spacing-medium)}}
|
|
@@ -7,19 +7,27 @@
|
|
|
7
7
|
gap: var(--spacing-small);
|
|
8
8
|
}
|
|
9
9
|
|
|
10
|
-
.dnb-card
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
10
|
+
.dnb-card {
|
|
11
|
+
& + .dnb-forms-button-row,
|
|
12
|
+
& + .dnb-button--primary {
|
|
13
|
+
&:not([class*='space__top']) {
|
|
14
|
+
margin-top: var(--spacing-small);
|
|
14
15
|
|
|
15
|
-
|
|
16
|
-
|
|
16
|
+
.dnb-button[class*='space__top'] {
|
|
17
|
+
margin-top: 0;
|
|
18
|
+
}
|
|
17
19
|
}
|
|
18
20
|
}
|
|
21
|
+
}
|
|
19
22
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
+
// Deprecated – can be removed in v11 (its handled by the outset prop)
|
|
24
|
+
.dnb-card:not([style*='--outset']) {
|
|
25
|
+
& + .dnb-forms-button-row,
|
|
26
|
+
& + .dnb-button--primary {
|
|
27
|
+
@include allAbove(small) {
|
|
28
|
+
&:not([class*='space__left']) {
|
|
29
|
+
margin-left: var(--spacing-medium);
|
|
30
|
+
}
|
|
23
31
|
}
|
|
24
32
|
}
|
|
25
33
|
}
|