@jobber/components 4.91.2-implement-.13 → 4.91.2-retheme-fe.2
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/dist/Autocomplete/index.js +10 -11
- package/dist/Avatar/index.js +1 -1
- package/dist/{Avatar-76a799fa.js → Avatar-a5a90da9.js} +1 -1
- package/dist/Banner/index.js +11 -30
- package/dist/Button/index.js +2 -2
- package/dist/Button-bb77a513.js +57 -0
- package/dist/ButtonDismiss/index.js +3 -3
- package/dist/{ButtonDismiss-a3ba1de2.js → ButtonDismiss-a1df8656.js} +1 -1
- package/dist/Card/index.js +6 -7
- package/dist/{Card-01d6ba19.js → Card-69212ecd.js} +6 -6
- package/dist/Checkbox/index.js +3 -3
- package/dist/Checkbox-2ea61ab4.js +63 -0
- package/dist/Chip/index.js +4 -4
- package/dist/{Chip-76f18555.js → Chip-b67ae770.js} +4 -4
- package/dist/Chips/index.js +8 -8
- package/dist/Combobox/index.js +9 -9
- package/dist/{Combobox-6d864202.js → Combobox-faa6bffe.js} +10 -10
- package/dist/ConfirmationModal/index.js +9 -11
- package/dist/{ConfirmationModal-b7da32ac.js → ConfirmationModal-289df9ad.js} +2 -2
- package/dist/DataDump/index.js +7 -8
- package/dist/DataList/index.js +23 -24
- package/dist/DataTable/index.js +14 -14
- package/dist/DatePicker/index.js +3 -3
- package/dist/{DatePicker-305a5b82.js → DatePicker-8392951f.js} +3 -3
- package/dist/DescriptionList/index.js +2 -2
- package/dist/Disclosure/index.js +2 -2
- package/dist/Drawer/index.js +6 -8
- package/dist/Emphasis/index.js +2 -2
- package/dist/{Emphasis-a77d8ee9.js → Emphasis-2bbe4da6.js} +1 -1
- package/dist/FeatureSwitch/index.js +7 -9
- package/dist/FormField/FormFieldTypes.d.ts +0 -8
- package/dist/FormField/FormFieldWrapper.d.ts +1 -1
- package/dist/FormField/index.js +8 -8
- package/dist/FormField-5134bf0e.js +253 -0
- package/dist/FormatFile/index.js +12 -14
- package/dist/{FormatFile-b771c7fd.js → FormatFile-7e432b0d.js} +7 -7
- package/dist/Gallery/index.js +13 -15
- package/dist/Glimmer/index.js +1 -1
- package/dist/{Glimmer-84dee1ed.js → Glimmer-156bb2d1.js} +1 -1
- package/dist/Heading/index.js +2 -4
- package/dist/{Heading-23d382a1.js → Heading-d025ffbb.js} +5 -7
- package/dist/InlineLabel/index.js +2 -2
- package/dist/InlineLabel-d092e45a.js +28 -0
- package/dist/InputAvatar/index.js +8 -8
- package/dist/InputDate/index.js +9 -9
- package/dist/InputEmail/index.js +8 -8
- package/dist/InputFile/index.js +5 -5
- package/dist/{InputFile-20b9074a.js → InputFile-5458fb6e.js} +4 -4
- package/dist/InputNumber/index.js +9 -9
- package/dist/{InputNumber-d085fb59.js → InputNumber-0cc0d204.js} +1 -1
- package/dist/InputPassword/index.js +8 -8
- package/dist/InputPhoneNumber/index.js +8 -8
- package/dist/InputText/InputText.d.ts +0 -4
- package/dist/InputText/index.js +9 -9
- package/dist/{InputText-ce8cf268.js → InputText-8af32879.js} +3 -5
- package/dist/InputTime/index.js +8 -8
- package/dist/InputValidation/index.js +3 -3
- package/dist/{InputValidation-a92bb519.js → InputValidation-9c582130.js} +2 -2
- package/dist/LightBox/index.js +4 -4
- package/dist/{LightBox-7efe8932.js → LightBox-ddbda5c6.js} +3 -3
- package/dist/List/index.js +8 -10
- package/dist/Markdown/index.js +5 -7
- package/dist/{Markdown-0f24de70.js → Markdown-8150d535.js} +3 -3
- package/dist/Menu/index.js +3 -3
- package/dist/{Menu-d6dd673e.js → Menu-f9fb99bb.js} +7 -8
- package/dist/Modal/index.js +5 -7
- package/dist/Modal-4f48de3a.js +74 -0
- package/dist/MultiSelect/index.js +5 -5
- package/dist/{Option-754131da.js → Option-8faed3bf.js} +1 -1
- package/dist/Page/index.js +8 -9
- package/dist/Popover/index.js +4 -4
- package/dist/ProgressBar/index.js +1 -1
- package/dist/{ProgressBar-b68edc8f.js → ProgressBar-e4bb029e.js} +1 -1
- package/dist/RadioGroup/index.js +3 -3
- package/dist/RadioGroup-c31c2e81.js +46 -0
- package/dist/RecurringSelect/index.js +15 -15
- package/dist/Select/index.js +9 -9
- package/dist/Spinner/index.js +1 -1
- package/dist/{Spinner-9d8fc7ff.js → Spinner-e15a3ae0.js} +1 -1
- package/dist/StatusIndicator/index.js +1 -1
- package/dist/{StatusIndicator-7b5258ea.js → StatusIndicator-dd1f0fd5.js} +1 -1
- package/dist/StatusLabel/index.js +3 -3
- package/dist/Switch/index.js +2 -2
- package/dist/Switch-57fbf575.js +56 -0
- package/dist/Table/index.js +1 -1
- package/dist/Tabs/index.js +2 -2
- package/dist/Text/index.js +2 -2
- package/dist/{Text-fbeaaca6.js → Text-fdc65f0b.js} +1 -1
- package/dist/Toast/index.js +5 -6
- package/dist/Tooltip/index.js +1 -1
- package/dist/{Tooltip-b9de6e57.js → Tooltip-1e3abeb6.js} +1 -1
- package/dist/Typography/css/TextColors.css.d.ts +1 -0
- package/dist/Typography/index.js +1 -1
- package/dist/{Typography-e2a23b7e.js → Typography-018e1471.js} +3 -3
- package/package.json +3 -3
- package/dist/Button-6b922fc1.js +0 -57
- package/dist/Checkbox-e481a4b1.js +0 -63
- package/dist/FormField/hooks/useFormFieldFocus.d.ts +0 -7
- package/dist/FormField/hooks/useToolbar.d.ts +0 -16
- package/dist/FormField-8eea4d86.js +0 -309
- package/dist/InlineLabel-c8fc28f0.js +0 -28
- package/dist/Modal-4ce1ec79.js +0 -74
- package/dist/RadioGroup-678f4932.js +0 -46
- package/dist/Switch-eac89586.js +0 -56
- package/dist/useAtlantisConfig-ed0bee66.js +0 -16
|
@@ -1,309 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var tslib_es6 = require('./tslib.es6-754e2961.js');
|
|
4
|
-
var React = require('react');
|
|
5
|
-
var reactHookForm = require('react-hook-form');
|
|
6
|
-
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
7
|
-
var classnames = require('classnames');
|
|
8
|
-
var useShowClear = require('@jobber/hooks/useShowClear');
|
|
9
|
-
var framerMotion = require('framer-motion');
|
|
10
|
-
var design = require('@jobber/design');
|
|
11
|
-
var Button = require('./Button-6b922fc1.js');
|
|
12
|
-
var Icon = require('./Icon-405a216c.js');
|
|
13
|
-
var Text = require('./Text-fbeaaca6.js');
|
|
14
|
-
var InputValidation = require('./InputValidation-a92bb519.js');
|
|
15
|
-
var Spinner = require('./Spinner-9d8fc7ff.js');
|
|
16
|
-
|
|
17
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
18
|
-
|
|
19
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
20
|
-
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
21
|
-
|
|
22
|
-
var css_248z$1 = ":root {\n /**\n * These `--public-field` properties are used in other components such\n * as InputGroup, therefore they must stay on :root\n **/\n --public-field--top-left-radius: var(--radius-base);\n --public-field--top-right-radius: var(--radius-base);\n --public-field--bottom-left-radius: var(--radius-base);\n --public-field--bottom-right-radius: var(--radius-base);\n\n --field--placeholder-color: var(--color-greyBlue--light);\n --field--value-color: var(--color-heading);\n --field--border-color: var(--color-border);\n}\n\n.geR7qBhrMfk- {\n width: 100%;\n}\n\n/**\n * Wrapper\n **/\n\n.nPGhTEEzsoU- {\n --field--placeholder-offset: 50%;\n --field--placeholder-transform: -50%;\n\n --field--textAlign: left;\n\n --field--height: var(--space-largest);\n\n --field--padding-top: calc(var(--space-base) - var(--space-smallest));\n --field--padding-bottom: calc(var(--space-base) - var(--space-smallest));\n --field--padding-left: var(--space-base);\n --field--padding-right: var(--space-base);\n\n --field--value-lineHeight: calc(var(--base-unit) * 1.25);\n\n --field--background-color: var(--color-surface);\n\n --field--base-elevation: var(--elevation-base);\n --field--label-elevation: calc(var(--field--base-elevation) + 1);\n --field--postfix-elevation: calc(var(--field--base-elevation) - 1);\n --field--postfix-action-elevation: calc(var(--field--base-elevation) + 2);\n\n display: -ms-flexbox;\n\n display: flex;\n width: 100%;\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--field--border-color);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n border-top-right-radius: calc(16px / 8);\n border-top-right-radius: var(--public-field--top-right-radius);\n border-bottom-right-radius: calc(16px / 8);\n border-bottom-right-radius: var(--public-field--bottom-right-radius);\n border-bottom-left-radius: calc(16px / 8);\n border-bottom-left-radius: var(--public-field--bottom-left-radius);\n border-top-left-radius: calc(16px / 8);\n border-top-left-radius: var(--public-field--top-left-radius);\n color: rgb(1, 41, 57);\n color: var(--field--value-color);\n font-size: calc((16px * 1) * 0.875);\n font-size: calc(calc(16px * 1) * 0.875);\n font-size: var(--typography--fontSize-base);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--field--background-color);\n}\n\n.nPGhTEEzsoU- * {\n box-sizing: border-box;\n}\n\n.nPGhTEEzsoU-:focus-within {\n position: relative;\n z-index: var(--field--base-elevation);\n box-shadow: 0px 0px 0px calc(16px / 8) rgba(255, 255, 255, 1),\n 0px 0px 0px calc(16px / 4) rgb(147, 161, 169);\n box-shadow: var(--shadow-focus);\n}\n\n.YhserUiOeFE-:not(:focus-within) input {\n color: var(--field--background-color);\n -webkit-text-fill-color: var(--field--background-color);\n}\n\n.YhserUiOeFE-:focus-within,\n.UIZq8hTmJVU- {\n --field--placeholder-color: var(--color-text--secondary);\n --field--placeholder-offset: var(--space-smallest);\n --field--placeholder-transform: 0;\n --field--padding-top: calc(var(--space-base) + var(--space-smaller));\n --field--padding-bottom: var(--space-small);\n}\n\n.YhserUiOeFE-.Ku8sWS0mLew-:focus-within,\n.UIZq8hTmJVU-.Ku8sWS0mLew- {\n --field--padding-top: calc(var(--space-large) + var(--space-smaller));\n}\n\n.nPGhTEEzsoU-.e4VYDAkWHAg- {\n --field--placeholder-offset: 0;\n --field--placeholder-transform: 0;\n height: auto;\n min-height: auto;\n}\n\n.gJ-15M615eY-,\n.gJ-15M615eY-:focus-within {\n --field--border-color: var(--color-critical);\n position: relative;\n}\n\n._1rsTLm5GwcM- {\n --field--placeholder-color: var(--color-disabled);\n --field--value-color: var(--color-disabled);\n --field--background-color: var(--color-surface--background);\n --field--border-color: var(--color-disabled--secondary);\n}\n\n/* override iOS default styling for disabled input */\n\n._1rsTLm5GwcM- :disabled {\n -webkit-text-fill-color: rgb(1, 41, 57);\n -webkit-text-fill-color: var(--field--value-color);\n opacity: 1;\n}\n\n.o8D-H-lKfDk- {\n --field--padding-left: calc(var(--space-base) - var(--space-smaller));\n --field--padding-right: calc(var(--space-base) - var(--space-smaller));\n --field--padding-top: var(--space-small);\n --field--padding-bottom: var(--space-small);\n --field--height: calc(var(--space-larger) + var(--space-smaller));\n}\n\n.Ku8sWS0mLew- {\n --field--padding-left: var(--space-large);\n --field--padding-right: var(--space-large);\n --field--height: calc(var(--space-extravagant));\n}\n\n._5Hu2F3cBvng- {\n display: inline-block;\n width: auto;\n}\n\n.s1WLQs6ffD8- {\n --field--textAlign: center;\n}\n\n.a2r4QheWYIA- {\n --field--textAlign: right;\n}\n\n/**\n * The custom property --formField-maxLength is getting defined inside the\n * component.\n */\n\n.KdAnXK1gClo- {\n width: calc(\n (16px * var(--formField-maxLength)) + var(--field--padding-left) +\n var(--field--padding-right)\n );\n width: calc(\n (var(--base-unit) * var(--formField-maxLength)) + var(--field--padding-left) +\n var(--field--padding-right)\n );\n}\n\n/**\n * Input Wrapper\n **/\n\n.iQFhpFYnz-8- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex: 1;\n flex: 1;\n position: relative;\n /* Ensure input stays with the rest of the element stack */\n z-index: 0;\n z-index: var(--elevation-default);\n}\n\n.Yo2Wi9dpa-Y- {\n position: relative;\n -ms-flex: 1;\n flex: 1;\n}\n\n/**\n * Input\n **/\n\n.LSHPV7PwOTg- {\n position: relative;\n z-index: var(--field--base-elevation);\n width: 100%;\n padding-top: var(--field--padding-top);\n padding-bottom: var(--field--padding-bottom);\n padding-left: var(--field--padding-left);\n padding-right: var(--field--padding-right);\n border: none;\n border-radius: 0;\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n line-height: var(--field--value-lineHeight);\n text-align: var(--field--textAlign);\n background: transparent;\n -webkit-appearance: none;\n appearance: none;\n}\n\n.LSHPV7PwOTg-:focus {\n outline: none;\n}\n\n.mgPacJ6Z71Y- .Yo2Wi9dpa-Y- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-direction: column;\n flex-direction: column;\n min-height: var(--field--height);\n resize: vertical;\n overflow: auto;\n}\n\n.mgPacJ6Z71Y- .LSHPV7PwOTg- {\n -ms-flex: 1;\n flex: 1;\n resize: none;\n scroll-padding-bottom: calc(16px * 1);\n scroll-padding-bottom: var(--space-base);\n}\n\n.i31GQXcMz54- .LSHPV7PwOTg- {\n z-index: var(--field--label-elevation);\n}\n\n.LSHPV7PwOTg-:-webkit-autofill,\n.LSHPV7PwOTg-:-webkit-autofill:hover,\n.LSHPV7PwOTg-:-webkit-autofill:focus,\n.LSHPV7PwOTg-:-webkit-autofill:active {\n -webkit-box-shadow: 0 0 0 30px rgba(255, 255, 255, 1) inset !important;\n -webkit-box-shadow: 0 0 0 30px var(--color-surface) inset !important;\n}\n\n/**\n * Label\n **/\n\n._3xREbTN5pPg- {\n position: absolute;\n top: var(--field--placeholder-offset);\n z-index: var(--field--label-elevation);\n width: 100%;\n padding-left: var(--field--padding-left);\n padding-right: var(--field--padding-right);\n overflow: hidden;\n color: rgb(147, 161, 169);\n color: var(--field--placeholder-color);\n line-height: var(--field--value-lineHeight);\n text-align: var(--field--textAlign);\n text-overflow: ellipsis;\n white-space: nowrap;\n pointer-events: none;\n -webkit-transform: translateY(var(--field--placeholder-transform));\n transform: translateY(var(--field--placeholder-transform));\n transition: all 100ms;\n transition: all var(--timing-quick);\n}\n\n.e4VYDAkWHAg- ._3xREbTN5pPg- {\n padding-top: var(--field--padding-top);\n -webkit-transform: translateY(var(--field--placeholder-transform));\n transform: translateY(var(--field--placeholder-transform));\n}\n\n.mgPacJ6Z71Y- ._3xREbTN5pPg- {\n /* Changes the width so that the scrollbar on the textarea doesn't get cut off */\n width: calc(100% - var(--field--padding-right));\n /* Remove padding on right to make use of the entire width */\n padding-right: 0;\n}\n\n.UIZq8hTmJVU- ._3xREbTN5pPg-,\n.YhserUiOeFE-:focus-within ._3xREbTN5pPg- {\n font-size: calc((16px * 1) * 0.75);\n font-size: calc(calc(16px * 1) * 0.75);\n font-size: var(--typography--fontSize-small);\n}\n\n.e4VYDAkWHAg-.UIZq8hTmJVU- ._3xREbTN5pPg- {\n padding-top: calc(16px / 8);\n padding-top: var(--space-smallest);\n background-color: var(--field--background-color);\n}\n\n.o8D-H-lKfDk-.UIZq8hTmJVU- ._3xREbTN5pPg-,\n.YhserUiOeFE-.o8D-H-lKfDk-.UIZq8hTmJVU-:focus-within ._3xREbTN5pPg- {\n display: none;\n}\n\n/**This is valid cascading order **/\n\n/* stylelint-disable-next-line no-descending-specificity */\n\n.Ku8sWS0mLew-.UIZq8hTmJVU- ._3xREbTN5pPg-,\n.YhserUiOeFE-.Ku8sWS0mLew-.UIZq8hTmJVU-:focus-within ._3xREbTN5pPg- {\n padding-top: calc(16px / 2);\n padding-top: var(--space-small);\n}\n\n/**\n * Postfix\n **/\n\n.VtnAk1HYMMk- {\n position: absolute;\n top: 50%;\n right: calc(16px * 1);\n right: var(--space-base);\n z-index: var(--field--postfix-elevation);\n -webkit-transform: translateY(-50%);\n transform: translateY(-50%);\n}\n\n/**\n * Affix\n **/\n\n.uPLklxvtfJw- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-align: center;\n align-items: center;\n -ms-flex-pack: center;\n justify-content: center;\n margin: 0 calc(var(--field--padding-left) * -1) 0 0;\n padding: 0 var(--field--padding-right) 0 var(--field--padding-left);\n}\n\n@supports (aspect-ratio: 1/1) {\n .uPLklxvtfJw- {\n /*\n * disabling property-no-unknown here as this is a real property\n * that stylelint just doesn't know about. We may be able to remove\n * this when we update our stylelint to not care about IE11.\n */\n /* stylelint-disable-next-line property-no-unknown */\n aspect-ratio: 1/1;\n padding: 0;\n }\n}\n\n.uPLklxvtfJw-.pYqqDvv57JE- {\n margin: 0 0 0 calc(var(--field--padding-right) * -1);\n}\n\n.uPLklxvtfJw-.eI44oQpuVlk- {\n position: relative;\n z-index: var(--field--postfix-action-elevation);\n}\n\n.jO8P2iSHilM- {\n display: -ms-flexbox;\n display: flex;\n margin: 0 calc((var(--field--padding-left) - calc(16px / 8)) * -1) 0 0;\n margin: 0 calc((var(--field--padding-left) - var(--space-smallest)) * -1) 0 0;\n padding: 0 0 0 var(--field--padding-left);\n line-height: var(--field--value-lineHeight);\n -ms-flex-align: center;\n align-items: center;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n}\n\n.jO8P2iSHilM-.pYqqDvv57JE- {\n margin: 0 0 0 calc((var(--field--padding-left) - calc(16px / 8)) * -1);\n margin: 0 0 0 calc((var(--field--padding-left) - var(--space-smallest)) * -1);\n padding: 0 var(--field--padding-left) 0 0;\n}\n\n.UIZq8hTmJVU-:not(.o8D-H-lKfDk-) .jO8P2iSHilM- {\n padding-top: var(--field--padding-top);\n padding-bottom: var(--field--padding-bottom);\n}\n\n._2GfgzNnLOSI- {\n margin-top: calc(16px / 4);\n margin-top: var(--space-smaller);\n}\n\n._3GtIRFCkZMg- {\n display: -ms-flexbox;\n display: flex;\n position: relative;\n margin: calc(16px / 2) var(--field--padding-right) calc(16px / 2)\n var(--field--padding-left);\n margin: var(--space-small) var(--field--padding-right) var(--space-small)\n var(--field--padding-left);\n}\n\n._3GtIRFCkZMg-::before {\n content: \"\";\n display: block;\n position: absolute;\n top: calc(-1.25 * (16px * 1));\n top: calc(-1.25 * calc(16px * 1));\n top: calc(-1.25 * var(--space-base));\n right: 0;\n left: 0;\n z-index: 2;\n height: calc(16px * 1);\n height: var(--space-base);\n background: linear-gradient(to bottom, transparent, rgba(255, 255, 255, 1) 60%);\n background: linear-gradient(to bottom, transparent, var(--color-surface) 60%);\n}\n";
|
|
23
|
-
var styles$1 = {"container":"geR7qBhrMfk-","wrapper":"nPGhTEEzsoU-","timeInputLabel":"YhserUiOeFE-","miniLabel":"UIZq8hTmJVU-","large":"Ku8sWS0mLew-","text":"e4VYDAkWHAg-","invalid":"gJ-15M615eY-","disabled":"_1rsTLm5GwcM-","small":"o8D-H-lKfDk-","inline":"_5Hu2F3cBvng-","center":"s1WLQs6ffD8-","right":"a2r4QheWYIA-","maxLength":"KdAnXK1gClo-","inputWrapper":"iQFhpFYnz-8-","childrenWrapper":"Yo2Wi9dpa-Y-","input":"LSHPV7PwOTg-","textarea":"mgPacJ6Z71Y-","select":"i31GQXcMz54-","label":"_3xREbTN5pPg-","postfix":"VtnAk1HYMMk-","affixIcon":"uPLklxvtfJw-","suffix":"pYqqDvv57JE-","hasAction":"eI44oQpuVlk-","affixLabel":"jO8P2iSHilM-","description":"_2GfgzNnLOSI-","toolbar":"_3GtIRFCkZMg-"};
|
|
24
|
-
styleInject_es.styleInject(css_248z$1);
|
|
25
|
-
|
|
26
|
-
function AffixLabel({ label, variation = "prefix", labelRef, }) {
|
|
27
|
-
const affixLabelClass = classnames__default["default"](styles$1.affixLabel, {
|
|
28
|
-
[styles$1.suffix]: variation === "suffix",
|
|
29
|
-
});
|
|
30
|
-
return (React__default["default"].createElement("div", { ref: labelRef, className: affixLabelClass }, label));
|
|
31
|
-
}
|
|
32
|
-
function AffixIcon({ icon, onClick, ariaLabel, variation = "prefix", size, }) {
|
|
33
|
-
const affixIconClass = classnames__default["default"](styles$1.affixIcon, {
|
|
34
|
-
[styles$1.suffix]: variation === "suffix",
|
|
35
|
-
[styles$1.hasAction]: onClick,
|
|
36
|
-
});
|
|
37
|
-
const iconSize = size === "small" ? "small" : "base";
|
|
38
|
-
if (!icon)
|
|
39
|
-
return React__default["default"].createElement(React__default["default"].Fragment, null);
|
|
40
|
-
return (React__default["default"].createElement("div", { className: affixIconClass }, onClick ? (React__default["default"].createElement(Button.Button
|
|
41
|
-
/**
|
|
42
|
-
* We can cast the ariaLabel here as a `Suffix`
|
|
43
|
-
* requires an ariaLabel if there is an action
|
|
44
|
-
*/
|
|
45
|
-
, {
|
|
46
|
-
/**
|
|
47
|
-
* We can cast the ariaLabel here as a `Suffix`
|
|
48
|
-
* requires an ariaLabel if there is an action
|
|
49
|
-
*/
|
|
50
|
-
ariaLabel: ariaLabel, icon: icon, onClick: onClick, variation: "subtle", type: "tertiary", size: iconSize })) : (React__default["default"].createElement(Icon.Icon, { name: icon, size: iconSize, color: "greyBlue" }))));
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
function FormFieldDescription({ id, description, }) {
|
|
54
|
-
return (React__default["default"].createElement("div", { id: id, className: styles$1.description },
|
|
55
|
-
React__default["default"].createElement(Text.Text, { size: "small", variation: "subdued" }, description)));
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
var css_248z = ".t1fFX8kDJh8- {\n display: -ms-flexbox;\n display: flex;\n position: absolute;\n right: calc(16px / 2);\n right: var(--space-small);\n z-index: 1002;\n z-index: var(--elevation-tooltip);\n width: calc(16px * 1.5);\n width: var(--space-large);\n height: calc(16px * 1.5);\n height: var(--space-large);\n padding: 0;\n border: none;\n border-radius: 100%;\n border-radius: var(--radius-circle);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n cursor: pointer;\n -ms-flex-pack: center;\n justify-content: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-transform: translateY(50%);\n transform: translateY(50%);\n}\n\n.t1fFX8kDJh8-:focus {\n outline: none;\n}\n\n.t1fFX8kDJh8-:hover,\n.t1fFX8kDJh8-:focus-visible {\n outline: none;\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n}\n\n.t1fFX8kDJh8-:focus-visible {\n box-shadow: 0px 0px 0px calc(16px / 8) rgba(255, 255, 255, 1),\n 0px 0px 0px calc(16px / 4) rgb(147, 161, 169);\n box-shadow: var(--shadow-focus);\n}\n";
|
|
59
|
-
var styles = {"clearInput":"t1fFX8kDJh8-"};
|
|
60
|
-
styleInject_es.styleInject(css_248z);
|
|
61
|
-
|
|
62
|
-
function ClearAction({ onClick }) {
|
|
63
|
-
return (React__default["default"].createElement("button", { className: styles.clearInput, onClick: onClick, type: "button", "aria-label": "Clear input" },
|
|
64
|
-
React__default["default"].createElement(Icon.Icon, { name: "remove", size: "small" })));
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
function useToolbar(props) {
|
|
68
|
-
const isToolbarVisible = props.toolbar !== undefined &&
|
|
69
|
-
(props.toolbarVisibility === "always" || props.focused);
|
|
70
|
-
const animationInitial = props.toolbarVisibility === "always" ? false : { opacity: 0, height: 0 };
|
|
71
|
-
return {
|
|
72
|
-
isToolbarVisible,
|
|
73
|
-
animationInitial,
|
|
74
|
-
};
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
function useFormFieldFocus() {
|
|
78
|
-
const [focused, setFocused] = React.useState(false);
|
|
79
|
-
const inputWrapperRef = React.useRef(null);
|
|
80
|
-
React.useEffect(() => {
|
|
81
|
-
var _a, _b;
|
|
82
|
-
function handleFocusIn() {
|
|
83
|
-
setFocused(true);
|
|
84
|
-
}
|
|
85
|
-
function handleFocusOut() {
|
|
86
|
-
setTimeout(() => {
|
|
87
|
-
var _a;
|
|
88
|
-
const focusedElementWithinWrapper = (_a = inputWrapperRef.current) === null || _a === void 0 ? void 0 : _a.contains(document.activeElement);
|
|
89
|
-
if (!focusedElementWithinWrapper) {
|
|
90
|
-
setFocused(false);
|
|
91
|
-
}
|
|
92
|
-
}, 1);
|
|
93
|
-
}
|
|
94
|
-
(_a = inputWrapperRef.current) === null || _a === void 0 ? void 0 : _a.addEventListener("focusin", handleFocusIn);
|
|
95
|
-
(_b = inputWrapperRef.current) === null || _b === void 0 ? void 0 : _b.addEventListener("focusout", handleFocusOut);
|
|
96
|
-
return () => {
|
|
97
|
-
var _a, _b;
|
|
98
|
-
(_a = inputWrapperRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener("focusin", handleFocusIn);
|
|
99
|
-
(_b = inputWrapperRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener("focusout", handleFocusOut);
|
|
100
|
-
};
|
|
101
|
-
}, [inputWrapperRef.current]);
|
|
102
|
-
return {
|
|
103
|
-
focused,
|
|
104
|
-
inputWrapperRef,
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
function FormFieldWrapper({ align, description, descriptionIdentifier, placeholder, value, children, invalid, error, size, prefix, suffix, max, maxLength, type, disabled, inline, identifier, clearable, onClear, toolbar, toolbarVisibility = "while-editing", }) {
|
|
109
|
-
const wrapperClasses = classnames__default["default"](styles$1.wrapper, size && styles$1[size], align && styles$1[align], {
|
|
110
|
-
[styles$1.miniLabel]: (placeholder && value !== "") ||
|
|
111
|
-
(placeholder && type === "select") ||
|
|
112
|
-
// Naively assume that if the the type is tel, it is the InputPhoneNumber
|
|
113
|
-
(placeholder && type === "tel"),
|
|
114
|
-
[styles$1.text]: type === "textarea" || type === "text",
|
|
115
|
-
[styles$1.textarea]: type === "textarea",
|
|
116
|
-
[styles$1.select]: type === "select",
|
|
117
|
-
[styles$1.invalid]: invalid !== null && invalid !== void 0 ? invalid : error,
|
|
118
|
-
[styles$1.disabled]: disabled,
|
|
119
|
-
[styles$1.maxLength]: maxLength,
|
|
120
|
-
[styles$1.timeInputLabel]: placeholder && type === "time" && placeholder && value === "",
|
|
121
|
-
});
|
|
122
|
-
const containerClasses = classnames__default["default"](styles$1.container, {
|
|
123
|
-
[styles$1.inline]: inline,
|
|
124
|
-
});
|
|
125
|
-
const wrapperInlineStyle = {
|
|
126
|
-
["--formField-maxLength"]: maxLength || max,
|
|
127
|
-
};
|
|
128
|
-
const prefixRef = React.useRef();
|
|
129
|
-
const suffixRef = React.useRef();
|
|
130
|
-
const [labelStyle, setLabelStyle] = React.useState({
|
|
131
|
-
paddingLeft: undefined,
|
|
132
|
-
paddingRight: undefined,
|
|
133
|
-
});
|
|
134
|
-
React.useEffect(() => {
|
|
135
|
-
setLabelStyle(getAffixPaddding);
|
|
136
|
-
}, [value]);
|
|
137
|
-
const { focused, inputWrapperRef } = useFormFieldFocus();
|
|
138
|
-
const showClear = useShowClear.useShowClear({
|
|
139
|
-
clearable,
|
|
140
|
-
multiline: type === "textarea",
|
|
141
|
-
focused,
|
|
142
|
-
hasValue: Boolean(value),
|
|
143
|
-
disabled,
|
|
144
|
-
});
|
|
145
|
-
const { isToolbarVisible, animationInitial } = useToolbar({
|
|
146
|
-
focused,
|
|
147
|
-
toolbar,
|
|
148
|
-
toolbarVisibility,
|
|
149
|
-
});
|
|
150
|
-
return (React__default["default"].createElement("div", { className: containerClasses },
|
|
151
|
-
React__default["default"].createElement("div", { className: wrapperClasses, style: wrapperInlineStyle, "data-testid": "Form-Field-Wrapper" },
|
|
152
|
-
(prefix === null || prefix === void 0 ? void 0 : prefix.icon) && React__default["default"].createElement(AffixIcon, Object.assign({}, prefix, { size: size })),
|
|
153
|
-
React__default["default"].createElement("div", { ref: inputWrapperRef, className: styles$1.inputWrapper },
|
|
154
|
-
placeholder && (React__default["default"].createElement("label", { className: styles$1.label, htmlFor: identifier, style: (prefixRef === null || prefixRef === void 0 ? void 0 : prefixRef.current) || (suffixRef === null || suffixRef === void 0 ? void 0 : suffixRef.current)
|
|
155
|
-
? labelStyle
|
|
156
|
-
: undefined }, placeholder)),
|
|
157
|
-
(prefix === null || prefix === void 0 ? void 0 : prefix.label) && React__default["default"].createElement(AffixLabel, Object.assign({}, prefix, { labelRef: prefixRef })),
|
|
158
|
-
React__default["default"].createElement("div", { className: styles$1.childrenWrapper, tabIndex: -1 },
|
|
159
|
-
children,
|
|
160
|
-
React__default["default"].createElement(framerMotion.AnimatePresence, null, isToolbarVisible && (React__default["default"].createElement(framerMotion.motion.div, { key: "toolbar", initial: animationInitial, animate: {
|
|
161
|
-
opacity: 1,
|
|
162
|
-
height: "auto",
|
|
163
|
-
}, exit: { opacity: 0, height: 0 }, transition: {
|
|
164
|
-
duration: design.tokens["timing-base"] / 1000,
|
|
165
|
-
ease: "easeInOut",
|
|
166
|
-
}, tabIndex: -1, className: styles$1.toolbar }, toolbar)))),
|
|
167
|
-
(suffix === null || suffix === void 0 ? void 0 : suffix.label) && (React__default["default"].createElement(AffixLabel, Object.assign({}, suffix, { labelRef: suffixRef, variation: "suffix" })))),
|
|
168
|
-
showClear && React__default["default"].createElement(ClearAction, { onClick: onClear }),
|
|
169
|
-
(suffix === null || suffix === void 0 ? void 0 : suffix.icon) && (React__default["default"].createElement(AffixIcon, Object.assign({}, suffix, { variation: "suffix", size: size })))),
|
|
170
|
-
description && !inline && (React__default["default"].createElement(FormFieldDescription, { id: descriptionIdentifier, description: description })),
|
|
171
|
-
error && !inline && React__default["default"].createElement(InputValidation.InputValidation, { message: error })));
|
|
172
|
-
function getAffixPaddding() {
|
|
173
|
-
const hasValue = value !== "";
|
|
174
|
-
const newPadding = {
|
|
175
|
-
paddingLeft: undefined,
|
|
176
|
-
paddingRight: undefined,
|
|
177
|
-
};
|
|
178
|
-
// Naively assume that if the the type is tel, it is the InputPhoneNumber
|
|
179
|
-
if (type === "tel")
|
|
180
|
-
return newPadding;
|
|
181
|
-
if ((prefixRef === null || prefixRef === void 0 ? void 0 : prefixRef.current) && !hasValue) {
|
|
182
|
-
const { offsetWidth } = prefixRef.current;
|
|
183
|
-
newPadding.paddingLeft = offset(offsetWidth);
|
|
184
|
-
}
|
|
185
|
-
if ((suffixRef === null || suffixRef === void 0 ? void 0 : suffixRef.current) && !hasValue) {
|
|
186
|
-
const { offsetWidth } = suffixRef.current;
|
|
187
|
-
newPadding.paddingRight = offset(offsetWidth);
|
|
188
|
-
}
|
|
189
|
-
function offset(width) {
|
|
190
|
-
return `calc(${width}px + var(--space-smallest)`;
|
|
191
|
-
}
|
|
192
|
-
return newPadding;
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
function FormFieldPostFix({ variation }) {
|
|
197
|
-
return (React__default["default"].createElement("span", { className: styles$1.postfix }, variation === "select" ? (React__default["default"].createElement(Icon.Icon, { name: "arrowDown" })) : (React__default["default"].createElement(Spinner.Spinner, { size: "small" }))));
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
// Added 13th statement to accommodate getErrorMessage function
|
|
201
|
-
/*eslint max-statements: ["error", 13]*/
|
|
202
|
-
function FormField(props) {
|
|
203
|
-
var _a, _b;
|
|
204
|
-
const { actionsRef, autocomplete = true, children, defaultValue, description, disabled, inputRef, inline, keyboard, max, maxLength, min, name, readonly, rows, loading, type = "text", validations, value, onChange, onEnter, onFocus, onBlur, onValidation, onKeyUp, clearable = "never", } = props;
|
|
205
|
-
const { control, formState: { errors }, setValue, watch, } = reactHookForm.useFormContext() != undefined
|
|
206
|
-
? reactHookForm.useFormContext()
|
|
207
|
-
: // If there isn't a Form Context being provided, get a form for this field.
|
|
208
|
-
reactHookForm.useForm({ mode: "onTouched" });
|
|
209
|
-
const [identifier] = React.useState(React.useId());
|
|
210
|
-
const [descriptionIdentifier] = React.useState(`descriptionUUID--${React.useId()}`);
|
|
211
|
-
/**
|
|
212
|
-
* Generate a name if one is not supplied, this is the name
|
|
213
|
-
* that will be used for react-hook-form and not neccessarily
|
|
214
|
-
* attached to the DOM
|
|
215
|
-
*/
|
|
216
|
-
const [controlledName] = React.useState(name ? name : `generatedName--${identifier}`);
|
|
217
|
-
React.useEffect(() => {
|
|
218
|
-
if (value != undefined) {
|
|
219
|
-
setValue(controlledName, value);
|
|
220
|
-
}
|
|
221
|
-
}, [value, watch(controlledName)]);
|
|
222
|
-
React.useImperativeHandle(actionsRef, () => ({
|
|
223
|
-
setValue: newValue => {
|
|
224
|
-
setValue(controlledName, newValue, { shouldValidate: true });
|
|
225
|
-
},
|
|
226
|
-
}));
|
|
227
|
-
const message = (_a = errors[controlledName]) === null || _a === void 0 ? void 0 : _a.message;
|
|
228
|
-
const error = getErrorMessage();
|
|
229
|
-
React.useEffect(() => handleValidation(), [error]);
|
|
230
|
-
return (React__default["default"].createElement(reactHookForm.Controller, { control: control, name: controlledName, rules: Object.assign({}, validations), defaultValue: (_b = value !== null && value !== void 0 ? value : defaultValue) !== null && _b !== void 0 ? _b : "", render: (_a) => {
|
|
231
|
-
var _b = _a.field, { onChange: onControllerChange, onBlur: onControllerBlur, name: controllerName } = _b, rest = tslib_es6.__rest(_b, ["onChange", "onBlur", "name"]);
|
|
232
|
-
const fieldProps = Object.assign(Object.assign(Object.assign({}, rest), { id: identifier, className: styles$1.input, name: (validations || name) && controllerName, disabled: disabled, readOnly: readonly, inputMode: keyboard, onChange: handleChange, onBlur: handleBlur, onFocus: handleFocus }), (description &&
|
|
233
|
-
!inline && { "aria-describedby": descriptionIdentifier }));
|
|
234
|
-
const textFieldProps = Object.assign(Object.assign({}, fieldProps), { onKeyDown: handleKeyDown });
|
|
235
|
-
return (React__default["default"].createElement(FormFieldWrapper, Object.assign({}, props, { value: rest.value, error: error, identifier: identifier, descriptionIdentifier: descriptionIdentifier, clearable: clearable, onClear: handleClear }), renderField()));
|
|
236
|
-
function renderField() {
|
|
237
|
-
switch (type) {
|
|
238
|
-
case "select":
|
|
239
|
-
return (React__default["default"].createElement(React__default["default"].Fragment, null,
|
|
240
|
-
React__default["default"].createElement("select", Object.assign({}, fieldProps), children),
|
|
241
|
-
React__default["default"].createElement(FormFieldPostFix, { variation: "select" })));
|
|
242
|
-
case "textarea":
|
|
243
|
-
return (React__default["default"].createElement("textarea", Object.assign({}, textFieldProps, { rows: rows, ref: inputRef })));
|
|
244
|
-
default:
|
|
245
|
-
return (React__default["default"].createElement("div", { style: { position: "relative" } },
|
|
246
|
-
React__default["default"].createElement("input", Object.assign({}, textFieldProps, { autoComplete: setAutocomplete(autocomplete), type: type, maxLength: maxLength, max: max, min: min, ref: inputRef, onKeyUp: onKeyUp })),
|
|
247
|
-
loading && React__default["default"].createElement(FormFieldPostFix, { variation: "spinner" }),
|
|
248
|
-
children));
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
function handleClear() {
|
|
252
|
-
var _a;
|
|
253
|
-
handleBlur();
|
|
254
|
-
setValue(controlledName, undefined, { shouldValidate: true });
|
|
255
|
-
onChange && onChange("");
|
|
256
|
-
(_a = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
257
|
-
}
|
|
258
|
-
function handleChange(event) {
|
|
259
|
-
let newValue;
|
|
260
|
-
newValue = event.currentTarget.value;
|
|
261
|
-
if (type === "number" && newValue.length > 0) {
|
|
262
|
-
newValue = parseFloat(newValue);
|
|
263
|
-
}
|
|
264
|
-
onChange && onChange(newValue, event);
|
|
265
|
-
onControllerChange(event);
|
|
266
|
-
}
|
|
267
|
-
function handleKeyDown(event) {
|
|
268
|
-
if (!onEnter)
|
|
269
|
-
return;
|
|
270
|
-
if (event.key !== "Enter")
|
|
271
|
-
return;
|
|
272
|
-
if (event.shiftKey || event.ctrlKey)
|
|
273
|
-
return;
|
|
274
|
-
event.preventDefault();
|
|
275
|
-
onEnter && onEnter(event);
|
|
276
|
-
}
|
|
277
|
-
function handleFocus(event) {
|
|
278
|
-
const target = event.currentTarget;
|
|
279
|
-
if (target.select) {
|
|
280
|
-
setTimeout(() => readonly && target.select());
|
|
281
|
-
}
|
|
282
|
-
onFocus && onFocus();
|
|
283
|
-
}
|
|
284
|
-
function handleBlur() {
|
|
285
|
-
onBlur && onBlur();
|
|
286
|
-
onControllerBlur();
|
|
287
|
-
}
|
|
288
|
-
} }));
|
|
289
|
-
function getErrorMessage() {
|
|
290
|
-
if (typeof message === "string") {
|
|
291
|
-
return message;
|
|
292
|
-
}
|
|
293
|
-
return "";
|
|
294
|
-
}
|
|
295
|
-
function handleValidation() {
|
|
296
|
-
onValidation && onValidation(error);
|
|
297
|
-
}
|
|
298
|
-
}
|
|
299
|
-
function setAutocomplete(autocompleteSetting) {
|
|
300
|
-
if (autocompleteSetting === true) {
|
|
301
|
-
return undefined;
|
|
302
|
-
}
|
|
303
|
-
else if (autocompleteSetting === false) {
|
|
304
|
-
return "off";
|
|
305
|
-
}
|
|
306
|
-
return autocompleteSetting;
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
exports.FormField = FormField;
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var React = require('react');
|
|
4
|
-
var classnames = require('classnames');
|
|
5
|
-
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
6
|
-
var Typography = require('./Typography-e2a23b7e.js');
|
|
7
|
-
|
|
8
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
9
|
-
|
|
10
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
11
|
-
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
12
|
-
|
|
13
|
-
var css_248z = ".S72WkdRbhc0- {\n display: -ms-inline-flexbox;\n display: inline-flex;\n}\n\n.bMWuAXJHkbw- {\n padding: calc((16px / 4) * 1.5) calc((16px / 2) * 1.25);\n padding: calc(calc(16px / 4) * 1.5) calc(calc(16px / 2) * 1.25);\n padding: calc(var(--space-smaller) * 1.5) calc(var(--space-small) * 1.25);\n border-radius: calc(16px / 4);\n border-radius: var(--radius-large);\n}\n\n.bMWuAXJHkbw- span {\n line-height: 0.75rem;\n}\n\n.ui07veHjPII- {\n padding: calc((16px / 2) * 1.25) calc((16px / 2) * 1.5);\n padding: calc(calc(16px / 2) * 1.25) calc(calc(16px / 2) * 1.5);\n padding: calc(var(--space-small) * 1.25) calc(var(--space-small) * 1.5);\n border-radius: calc(16px / 2);\n border-radius: var(--radius-larger);\n}\n\n.ui07veHjPII- span {\n line-height: 1rem;\n}\n\n.WIXhLSQ7z8A- {\n padding: calc((16px / 2) * 1.5) calc((16px * 1));\n padding: calc(calc(16px / 2) * 1.5) calc(calc(16px * 1));\n padding: calc(var(--space-small) * 1.5) calc(var(--space-base));\n border-radius: calc(16px / 2);\n border-radius: var(--radius-larger);\n}\n\n.WIXhLSQ7z8A- span {\n line-height: 1rem;\n}\n\n._8RuKvOhj-Ro- {\n color: rgb(66, 78, 86);\n color: var(--color-greyBlue--dark);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-greyBlue--lightest);\n}\n\n._2vEF1nvVWm8- {\n color: rgb(128, 25, 0);\n color: var(--color-red--dark);\n background-color: rgb(255, 226, 219);\n background-color: var(--color-red--lightest);\n}\n\n.Wt305sIAeoE- {\n color: rgb(158, 98, 23);\n color: var(--color-orange--dark);\n background-color: rgb(253, 239, 222);\n background-color: var(--color-orange--lightest);\n}\n\n.F8KkNxz8W3A- {\n color: rgb(81, 114, 9);\n color: var(--color-green--dark);\n background-color: rgb(236, 243, 219);\n background-color: var(--color-green--lightest);\n}\n\n.URZZoKSX4So- {\n color: rgb(1, 27, 37);\n color: var(--color-blue--dark);\n background-color: rgb(217, 223, 225);\n background-color: var(--color-blue--lightest);\n}\n\n.OeLBV-9i0Rs- {\n color: rgb(49, 69, 98);\n color: var(--color-navy--dark);\n background-color: rgb(228, 233, 239);\n background-color: var(--color-navy--lightest);\n}\n\n._2Xwx5tarf1w- {\n color: rgb(144, 127, 10);\n color: var(--color-yellow--dark);\n background-color: rgb(250, 246, 219);\n background-color: var(--color-yellow--lightest);\n}\n\n.iCqIjI7GkEk- {\n color: rgb(99, 125, 46);\n color: var(--color-lime--dark);\n background-color: rgb(240, 246, 227);\n background-color: var(--color-lime--lightest);\n}\n\n._4iEIjiZj9oA- {\n color: rgb(88, 73, 127);\n color: var(--color-purple--dark);\n background-color: rgb(237, 234, 246);\n background-color: var(--color-purple--lightest);\n}\n\n.JRW9QFSjLTA- {\n color: rgb(116, 62, 98);\n color: var(--color-pink--dark);\n background-color: rgb(244, 231, 239);\n background-color: var(--color-pink--lightest);\n}\n\n.fbhprd-Gl8k- {\n color: rgb(40, 112, 95);\n color: var(--color-teal--dark);\n background-color: rgb(226, 243, 239);\n background-color: var(--color-teal--lightest);\n}\n\n.yrF9aZSaTdw- {\n color: rgb(122, 128, 21);\n color: var(--color-yellowGreen--dark);\n background-color: rgb(245, 246, 222);\n background-color: var(--color-yellowGreen--lightest);\n}\n\n.RPvjah0FdjI- {\n color: rgba(255, 255, 255, 1);\n color: var(--color-white);\n background-color: rgb(77, 105, 116);\n background-color: var(--color-blue--light);\n}\n\n.apwauWJ6ITc- {\n color: rgb(39, 105, 146);\n color: var(--color-lightBlue--dark);\n background-color: rgb(226, 241, 250);\n background-color: var(--color-lightBlue--lightest);\n}\n\n.n8qJynvE-n0- {\n color: rgb(55, 69, 132);\n color: var(--color-indigo--dark);\n background-color: rgb(230, 233, 247);\n background-color: var(--color-indigo--lightest);\n}\n";
|
|
14
|
-
var styles = {"inlineLabel":"S72WkdRbhc0-","base":"bMWuAXJHkbw-","large":"ui07veHjPII-","larger":"WIXhLSQ7z8A-","greyBlue":"_8RuKvOhj-Ro-","red":"_2vEF1nvVWm8-","orange":"Wt305sIAeoE-","green":"F8KkNxz8W3A-","blue":"URZZoKSX4So-","navy":"OeLBV-9i0Rs-","yellow":"_2Xwx5tarf1w-","lime":"iCqIjI7GkEk-","purple":"_4iEIjiZj9oA-","pink":"JRW9QFSjLTA-","teal":"fbhprd-Gl8k-","yellowGreen":"yrF9aZSaTdw-","blueDark":"RPvjah0FdjI-","lightBlue":"apwauWJ6ITc-","indigo":"n8qJynvE-n0-"};
|
|
15
|
-
styleInject_es.styleInject(css_248z);
|
|
16
|
-
|
|
17
|
-
function InlineLabel({ size = "base", color = "greyBlue", children, }) {
|
|
18
|
-
const className = classnames__default["default"](styles.inlineLabel, styles[size], styles[color]);
|
|
19
|
-
const sizeMapper = {
|
|
20
|
-
base: "small",
|
|
21
|
-
large: "large",
|
|
22
|
-
larger: "large",
|
|
23
|
-
};
|
|
24
|
-
return (React__default["default"].createElement("span", { className: className },
|
|
25
|
-
React__default["default"].createElement(Typography.Typography, { element: "span", size: sizeMapper[size] }, children)));
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
exports.InlineLabel = InlineLabel;
|
package/dist/Modal-4ce1ec79.js
DELETED
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var React = require('react');
|
|
4
|
-
var ReactDOM = require('react-dom');
|
|
5
|
-
var classnames = require('classnames');
|
|
6
|
-
var framerMotion = require('framer-motion');
|
|
7
|
-
var useRefocusOnActivator = require('@jobber/hooks/useRefocusOnActivator');
|
|
8
|
-
var useOnKeyDown = require('@jobber/hooks/useOnKeyDown');
|
|
9
|
-
var useFocusTrap = require('@jobber/hooks/useFocusTrap');
|
|
10
|
-
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
11
|
-
var Heading = require('./Heading-23d382a1.js');
|
|
12
|
-
var Button = require('./Button-6b922fc1.js');
|
|
13
|
-
var ButtonDismiss = require('./ButtonDismiss-a3ba1de2.js');
|
|
14
|
-
|
|
15
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
|
-
|
|
17
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
18
|
-
var ReactDOM__default = /*#__PURE__*/_interopDefaultLegacy(ReactDOM);
|
|
19
|
-
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
20
|
-
|
|
21
|
-
var css_248z$1 = ":root {\n --modal--width: calc(var(--base-unit) * 37.5);\n --modal--padding-horizontal: var(--space-base);\n --modal--padding-vertical: var(--space-base);\n --modal--padding: var(--modal--padding-vertical)\n var(--modal--padding-horizontal);\n}\n\n@media (min-width: 768px) {\n\n:root {\n --modal--padding-horizontal: var(--space-large);\n}\n }\n\n@media (--medium-screens-and-up) {\n\n:root {\n --modal--padding-horizontal: var(--space-large);\n}\n }\n\n:root .jobber-retheme {\n --modal--shadow: var(--shadow-base);\n}\n\n@media (min-width: 768px) {\n\n:root .jobber-retheme {\n --modal--padding-horizontal: var(--space-large);\n --modal--padding-vertical: var(--space-large);\n --modal--padding: var(--modal--padding-vertical)\n var(--modal--padding-horizontal);\n}\n }\n\n@media (--medium-screens-and-up) {\n\n:root .jobber-retheme {\n --modal--padding-horizontal: var(--space-large);\n --modal--padding-vertical: var(--space-large);\n --modal--padding: var(--modal--padding-vertical)\n var(--modal--padding-horizontal);\n}\n }\n\n.QGRLFHPoV5E- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-direction: column;\n flex-direction: column;\n z-index: 1001;\n z-index: var(--elevation-modal);\n padding: calc(16px / 2);\n padding: var(--space-small);\n overflow: auto;\n}\n\n.QGRLFHPoV5E-,\n._4WzGOMUGj5I- {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n}\n\n._4WzGOMUGj5I- {\n background-color: rgba(0, 0, 0, 0.32);\n background-color: var(--color-overlay);\n}\n\n.WLId2NJBQcQ- {\n position: relative;\n width: 100%;\n max-width: calc(16px * 37.5);\n max-width: var(--modal--width);\n box-shadow: var(--modal--shadow);\n margin: auto;\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n outline-color: rgb(147, 161, 169);\n outline-color: var(--color-focus);\n}\n\n/* Adjust `Content` and `Tab` components public padding to match the modal */\n\n.WLId2NJBQcQ- > * {\n --public-content--padding: var(--modal--padding);\n --public-tab--inset: var(--modal--padding-horizontal);\n}\n\n/* Remove the nested `Content` components public padding */\n\n.WLId2NJBQcQ- > * > * {\n --public-content--padding: 0;\n}\n\n.wjrPpIUNNrk- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-pack: justify;\n justify-content: space-between;\n padding: calc(16px * 1)\n calc(16px * 1);\n padding: var(--modal--padding);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n}\n\n.jobber-retheme .wjrPpIUNNrk- {\n background-color: transparent;\n}\n\n.jobber-retheme .wjrPpIUNNrk- h3 {\n font-family: \"Inter\", Helvetica, Arial, sans-serif;\n font-family: var(--typography--fontFamily-normal);\n font-size: calc((16px * 1) * 1.5);\n font-size: calc(calc(16px * 1) * 1.5);\n font-size: var(--typography--fontSize-largest);\n}\n\n/**\n * Ensure there's no extra padding top on the next element. This mostly negates\n * the <Content /> padding\n */\n\n.jobber-retheme .wjrPpIUNNrk- + * {\n padding-top: 0;\n}\n\n.rKvigUnOyYE- {\n margin-top: -6px;\n margin-right: -6px;\n}\n\n._62c8HLZFwvs- {\n display: -ms-flexbox;\n display: flex;\n padding: calc(16px * 1)\n calc(16px * 1);\n padding: var(--modal--padding);\n padding-top: 0;\n -ms-flex: 1 1 100%;\n flex: 1 1 100%;\n -ms-flex-pack: end;\n justify-content: flex-end;\n}\n\n/**\n * 1. Use CSS `order` to adjust the buttons position on the UI\n */\n\n.Xl1Ptn-P9Ew- {\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n -ms-flex-order: 1;\n order: 1; /* 1 */\n}\n\n.p2s7GtpoZz0- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n -ms-flex-order: 2;\n order: 2; /* 1 */\n}\n\n/* This is in a correct position and order */\n\n/* stylelint-disable-next-line no-descending-specificity */\n\n.p2s7GtpoZz0- > * {\n margin-left: calc(16px / 2);\n margin-left: var(--space-small);\n}\n\n.p2s7GtpoZz0- > *:first-child {\n -ms-flex-order: 2;\n order: 2; /* 1 */\n}\n\n.p2s7GtpoZz0- > *:nth-child(2) {\n -ms-flex-order: 1;\n order: 1; /* 1 */\n}\n";
|
|
22
|
-
var styles = {"container":"QGRLFHPoV5E-","overlay":"_4WzGOMUGj5I-","modal":"WLId2NJBQcQ-","header":"wjrPpIUNNrk-","closeButton":"rKvigUnOyYE-","actionBar":"_62c8HLZFwvs-","leftAction":"Xl1Ptn-P9Ew-","rightAction":"p2s7GtpoZz0-"};
|
|
23
|
-
styleInject_es.styleInject(css_248z$1);
|
|
24
|
-
|
|
25
|
-
var css_248z = "._65IpUjOZiBg- {\n --modal--padding: var(--space-base);\n --public-tab--inset: var(--space-base);\n max-width: calc(16px * 25);\n max-width: calc(var(--base-unit) * 25);\n}\n\n.Cpwnmw65caA- {\n max-width: calc(16px * 58.75);\n max-width: calc(var(--base-unit) * 58.75);\n}\n";
|
|
26
|
-
var sizes = {"small":"_65IpUjOZiBg-","large":"Cpwnmw65caA-"};
|
|
27
|
-
styleInject_es.styleInject(css_248z);
|
|
28
|
-
|
|
29
|
-
function Modal({ open = false, title, size, dismissible = true, children, primaryAction, secondaryAction, tertiaryAction, onRequestClose, }) {
|
|
30
|
-
const modalClassName = classnames__default["default"](styles.modal, size && sizes[size]);
|
|
31
|
-
useRefocusOnActivator.useRefocusOnActivator(open);
|
|
32
|
-
const modalRef = useFocusTrap.useFocusTrap(open);
|
|
33
|
-
useOnKeyDown.useOnKeyDown(handleRequestClose, "Escape");
|
|
34
|
-
const template = (React__default["default"].createElement(framerMotion.AnimatePresence, null, open && (React__default["default"].createElement("div", { ref: modalRef, role: "dialog", className: styles.container, tabIndex: 0 },
|
|
35
|
-
React__default["default"].createElement(framerMotion.motion.div, { key: styles.overlay, className: styles.overlay, onClick: onRequestClose, initial: { opacity: 0 }, animate: { opacity: 0.8 }, exit: { opacity: 0 }, transition: { duration: 0.2 } }),
|
|
36
|
-
React__default["default"].createElement(framerMotion.motion.div, { key: styles.modal, className: modalClassName, initial: { scale: 0.9, opacity: 0 }, animate: { scale: 1, opacity: 1 }, exit: { scale: 0.9, opacity: 0 }, transition: {
|
|
37
|
-
duration: 0.2,
|
|
38
|
-
ease: "easeInOut",
|
|
39
|
-
} },
|
|
40
|
-
title != undefined && (React__default["default"].createElement(Header, { title: title, dismissible: dismissible, onRequestClose: onRequestClose })),
|
|
41
|
-
children,
|
|
42
|
-
React__default["default"].createElement(Actions, { primary: primaryAction, secondary: secondaryAction, tertiary: tertiaryAction }))))));
|
|
43
|
-
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
44
|
-
? ReactDOM__default["default"].createPortal(template, document.body)
|
|
45
|
-
: template;
|
|
46
|
-
function handleRequestClose() {
|
|
47
|
-
if (open && onRequestClose) {
|
|
48
|
-
onRequestClose();
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
function Header({ title, dismissible, onRequestClose }) {
|
|
53
|
-
return (React__default["default"].createElement("div", { className: styles.header, "data-testid": "modal-header" },
|
|
54
|
-
React__default["default"].createElement(Heading.Heading, { level: 3 }, title),
|
|
55
|
-
dismissible && (React__default["default"].createElement("div", { className: styles.closeButton },
|
|
56
|
-
React__default["default"].createElement(ButtonDismiss.ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close modal" })))));
|
|
57
|
-
}
|
|
58
|
-
function Actions({ primary, secondary, tertiary }) {
|
|
59
|
-
const shouldShow = primary != undefined || secondary != undefined || tertiary != undefined;
|
|
60
|
-
if (secondary != undefined) {
|
|
61
|
-
secondary = Object.assign({ type: "primary", variation: "subtle" }, secondary);
|
|
62
|
-
}
|
|
63
|
-
if (tertiary != undefined) {
|
|
64
|
-
tertiary = Object.assign({ type: "secondary", variation: "destructive" }, tertiary);
|
|
65
|
-
}
|
|
66
|
-
return (React__default["default"].createElement(React__default["default"].Fragment, null, shouldShow && (React__default["default"].createElement("div", { className: styles.actionBar },
|
|
67
|
-
React__default["default"].createElement("div", { className: styles.rightAction },
|
|
68
|
-
primary && React__default["default"].createElement(Button.Button, Object.assign({}, primary)),
|
|
69
|
-
secondary && React__default["default"].createElement(Button.Button, Object.assign({}, secondary))),
|
|
70
|
-
tertiary && (React__default["default"].createElement("div", { className: styles.leftAction },
|
|
71
|
-
React__default["default"].createElement(Button.Button, Object.assign({}, tertiary))))))));
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
exports.Modal = Modal;
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var React = require('react');
|
|
4
|
-
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
5
|
-
var Text = require('./Text-fbeaaca6.js');
|
|
6
|
-
|
|
7
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
8
|
-
|
|
9
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
10
|
-
|
|
11
|
-
var css_248z = "._5P8wEHDUdKY- {\n --radio--checked-thickness: var(--border-thicker);\n --radio-diameter: var(--space-base);\n --radio--checked-shadow: 0px 0px 0px var(--space-minuscule)\n var(--color-interactive--hover);\n display: -ms-inline-flexbox;\n display: inline-flex;\n -ms-flex-direction: column;\n flex-direction: column;\n}\n\n.jobber-retheme ._5P8wEHDUdKY- {\n --radio--checked-thickness: calc(\n var(--border-thicker) + var(--space-smallest)\n );\n --radio-diameter: calc(var(--space-base) + var(--space-smaller));\n --radio--checked-shadow: 0px 0px 0px var(--space-minuscule) transparent;\n}\n\n._08ZPdlE98Ko- {\n /* Hide checkbox on UI but not screen readers and still allow focus state */\n position: absolute;\n left: -999vw;\n}\n\n.-PUoLXltVlQ- {\n display: -ms-inline-flexbox;\n display: inline-flex;\n font-size: calc((16px * 1) * 0.875);\n font-size: calc(calc(16px * 1) * 0.875);\n font-size: var(--typography--fontSize-base);\n cursor: pointer;\n -ms-flex-align: start;\n align-items: flex-start;\n}\n\n._08ZPdlE98Ko- + .-PUoLXltVlQ-::before {\n content: \"\";\n display: block;\n width: var(--radio-diameter);\n height: var(--radio-diameter);\n box-sizing: border-box;\n margin: calc(16px / 8) calc(16px / 2) 0 0;\n margin: var(--space-smallest) var(--space-small) 0 0;\n border: calc(16px / 8) solid rgb(125, 176, 14);\n border: var(--border-thick) solid var(--color-interactive);\n border-radius: 100%;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n transition: all 100ms ease-out;\n transition: all var(--timing-quick) ease-out;\n -ms-flex-negative: 0;\n flex-shrink: 0;\n}\n\n.jobber-retheme ._08ZPdlE98Ko- + .-PUoLXltVlQ-::before {\n margin-top: 0;\n border-color: rgb(217, 223, 225);\n border-color: var(--color-border);\n}\n\n._08ZPdlE98Ko-:hover + .-PUoLXltVlQ-::before {\n border-color: rgb(125, 176, 14);\n border-color: var(--color-interactive);\n}\n\n._08ZPdlE98Ko-:checked + .-PUoLXltVlQ-::before {\n box-shadow: var(--radio--checked-shadow);\n border-color: rgb(81, 114, 9);\n border-color: var(--color-interactive--hover);\n border-width: var(--radio--checked-thickness);\n background-color: rgb(125, 176, 14);\n background-color: var(--color-interactive);\n}\n\n._08ZPdlE98Ko-:focus-visible:checked + .-PUoLXltVlQ-:before {\n box-shadow: var(--radio--checked-shadow), 0px 0px 0px calc(16px / 8) rgba(255, 255, 255, 1),\n 0px 0px 0px calc(16px / 4) rgb(147, 161, 169);\n box-shadow: var(--radio--checked-shadow), var(--shadow-focus);\n}\n\n._08ZPdlE98Ko-[disabled] + .-PUoLXltVlQ- {\n color: rgb(181, 181, 181);\n color: var(--color-disabled);\n cursor: not-allowed;\n}\n\n._08ZPdlE98Ko-[disabled] + .-PUoLXltVlQ-::before {\n border-color: rgb(225, 225, 225);\n border-color: var(--color-disabled--secondary);\n}\n\n.jobber-retheme ._08ZPdlE98Ko-:checked + .-PUoLXltVlQ-::before {\n border-color: rgb(125, 176, 14);\n border-color: var(--color-interactive);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n._08ZPdlE98Ko-[disabled]:checked + .-PUoLXltVlQ-::before {\n --radio--checked-shadow: 0px 0px 0px var(--space-minuscule)\n var(--color-disabled);\n border-color: rgb(181, 181, 181);\n border-color: var(--color-disabled);\n}\n\n._8r6qT-6S9EI-,\n.C5SzbO1epLk- {\n margin-bottom: calc(16px / 2);\n margin-bottom: var(--space-small);\n padding-left: calc(var(--radio-diameter) + (16px / 2));\n padding-left: calc(var(--radio-diameter) + calc(16px / 2));\n padding-left: calc(var(--radio-diameter) + var(--space-small));\n}\n\n.jobber-retheme ._8r6qT-6S9EI-,\n.jobber-retheme .C5SzbO1epLk- {\n margin-top: calc((16px / 4) * -1);\n margin-top: calc(calc(16px / 4) * -1);\n margin-top: calc(var(--space-smaller) * -1);\n}\n\n._08ZPdlE98Ko-[disabled] + .-PUoLXltVlQ- + ._8r6qT-6S9EI- > p {\n color: rgb(181, 181, 181);\n color: var(--color-disabled);\n}\n";
|
|
12
|
-
var styles = {"radioGroup":"_5P8wEHDUdKY-","input":"_08ZPdlE98Ko-","label":"-PUoLXltVlQ-","description":"_8r6qT-6S9EI-","children":"C5SzbO1epLk-"};
|
|
13
|
-
styleInject_es.styleInject(css_248z);
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* For rendering props only. To make updates to
|
|
17
|
-
* the real RadioOption, look at InternalRadioOption
|
|
18
|
-
*/
|
|
19
|
-
function RadioOption({ children }) {
|
|
20
|
-
return React__default["default"].createElement(React__default["default"].Fragment, null, children);
|
|
21
|
-
}
|
|
22
|
-
function InternalRadioOption({ value, name, label, description, disabled, checked, children, onChange, }) {
|
|
23
|
-
const inputId = `${value.toString()}_${React.useId()}`;
|
|
24
|
-
const shouldRenderIndependentChildren = label && children;
|
|
25
|
-
return (React__default["default"].createElement("div", null,
|
|
26
|
-
React__default["default"].createElement("input", { onChange: handleChange, type: "radio", name: name, value: value, disabled: disabled, checked: checked, id: inputId, className: styles.input, "aria-describedby": description ? `${inputId}_description` : undefined }),
|
|
27
|
-
React__default["default"].createElement("label", { className: styles.label, htmlFor: inputId }, label ? label : children),
|
|
28
|
-
description && (React__default["default"].createElement("div", { className: styles.description, id: `${inputId}_description` },
|
|
29
|
-
React__default["default"].createElement(Text.Text, { variation: "subdued", size: "small" }, description))),
|
|
30
|
-
shouldRenderIndependentChildren && (React__default["default"].createElement("div", { className: styles.children, id: `${inputId}_children` }, children))));
|
|
31
|
-
function handleChange() {
|
|
32
|
-
onChange(value);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function RadioGroup({ children, value, ariaLabel, onChange, name = React.useId(), }) {
|
|
37
|
-
return (React__default["default"].createElement("div", { role: "radiogroup", "aria-label": ariaLabel, className: styles.radioGroup }, React__default["default"].Children.map(children, option => (React__default["default"].createElement(InternalRadioOption, Object.assign({ checked: value === option.props.value, name: name, onChange: handleChange }, option.props), option.props.children)))));
|
|
38
|
-
function handleChange(newValue) {
|
|
39
|
-
if (newValue !== value) {
|
|
40
|
-
onChange(newValue);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
exports.RadioGroup = RadioGroup;
|
|
46
|
-
exports.RadioOption = RadioOption;
|
package/dist/Switch-eac89586.js
DELETED
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var React = require('react');
|
|
4
|
-
var classnames = require('classnames');
|
|
5
|
-
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
6
|
-
var Typography = require('./Typography-e2a23b7e.js');
|
|
7
|
-
|
|
8
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
9
|
-
|
|
10
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
11
|
-
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
12
|
-
|
|
13
|
-
var css_248z = ":root {\n --switch--pipSize: calc(var(--space-base) * 1.875);\n --switch--labelWidth: calc(var(--switch--pipSize) * 1.3);\n --switch--borderOffset: calc(var(--border-base) * 2);\n}\n\n:root .jobber-retheme {\n --switch--pipSize: var(--space-base);\n}\n\n.NaSI2jsLI0c-,\n.NaSI2jsLI0c- * {\n box-sizing: border-box;\n transition: all 200ms;\n transition: all var(--timing-base);\n}\n\n.NaSI2jsLI0c- {\n display: -ms-inline-flexbox;\n display: inline-flex;\n width: calc((((16px * 1) * 1.875) * 1.3) + ((16px * 1) * 1.875));\n width: calc(calc(calc(calc(16px * 1) * 1.875) * 1.3) + calc(calc(16px * 1) * 1.875));\n width: calc(var(--switch--labelWidth) + var(--switch--pipSize));\n padding: 0;\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc((16px * 1) * 1.875);\n border-radius: calc(calc(16px * 1) * 1.875);\n border-radius: var(--switch--pipSize);\n overflow: hidden;\n line-height: normal;\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n cursor: pointer;\n -webkit-appearance: none;\n appearance: none;\n}\n\n.jobber-retheme .NaSI2jsLI0c- {\n width: calc(16px * 3);\n width: var(--space-largest);\n height: calc(16px * 1.5);\n height: var(--space-large);\n border-color: rgb(217, 223, 225);\n border-color: var(--color-border);\n border-width: calc(16px / 8);\n border-width: var(--border-thick);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n -ms-flex-align: center;\n align-items: center;\n}\n\n.NaSI2jsLI0c-:focus-visible {\n box-shadow: 0px 0px 0px calc(16px / 8) rgba(255, 255, 255, 1),\n 0px 0px 0px calc(16px / 4) rgb(147, 161, 169);\n box-shadow: var(--shadow-focus);\n outline: none;\n}\n\n.jobber-retheme .NaSI2jsLI0c-:hover,\n.jobber-retheme .NaSI2jsLI0c-:focus-visible {\n border-color: rgb(125, 176, 14);\n border-color: var(--color-interactive);\n}\n\n.HbAoDMJhkwY-,\n.jobber-retheme .HbAoDMJhkwY- {\n border-color: rgb(125, 176, 14);\n border-color: var(--color-interactive);\n background-color: rgb(125, 176, 14);\n background-color: var(--color-interactive);\n}\n\n.cc259FtdxeE- {\n display: -ms-flexbox;\n display: flex;\n position: relative;\n margin-left: calc(-1 * (((16px * 1) * 1.875) * 1.3));\n margin-left: calc(-1 * calc(calc(calc(16px * 1) * 1.875) * 1.3));\n margin-left: calc(-1 * var(--switch--labelWidth));\n pointer-events: none;\n -ms-flex: 1 1 100%;\n flex: 1 1 100%;\n -ms-flex-align: center;\n align-items: center;\n}\n\n.jobber-retheme .cc259FtdxeE- {\n margin-left: -37px;\n}\n\n.HbAoDMJhkwY- .cc259FtdxeE- {\n margin-left: calc(-1 * ((16px / 16) * 2));\n margin-left: calc(-1 * calc(calc(16px / 16) * 2));\n margin-left: calc(-1 * var(--switch--borderOffset));\n}\n\n.jobber-retheme .HbAoDMJhkwY- .cc259FtdxeE- {\n margin-left: -13px;\n}\n\n.YZ-HIehHOBA- {\n display: -ms-flexbox;\n display: flex;\n position: relative;\n min-width: calc(((16px * 1) * 1.875) * 1.3);\n min-width: calc(calc(calc(16px * 1) * 1.875) * 1.3);\n min-width: var(--switch--labelWidth);\n margin-top: calc(16px / 16);\n margin-top: var(--space-minuscule);\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none;\n pointer-events: none;\n -ms-flex-align: center;\n align-items: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n\n.YZ-HIehHOBA-:first-of-type {\n padding-left: calc(16px / 2);\n padding-left: var(--space-small);\n}\n\n.YZ-HIehHOBA-:last-of-type {\n padding-right: calc(16px / 2);\n padding-right: var(--space-small);\n}\n\n.jobber-retheme .YZ-HIehHOBA- {\n opacity: 0;\n}\n\n._2hxova2FHpM- {\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n width: calc((16px * 1) * 1.875);\n width: calc(calc(16px * 1) * 1.875);\n width: var(--switch--pipSize);\n height: calc((16px * 1) * 1.875);\n height: calc(calc(16px * 1) * 1.875);\n height: var(--switch--pipSize);\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: 100%;\n border-radius: var(--radius-circle);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n transition: all 100ms ease-out;\n transition: all var(--timing-quick) ease-out;\n}\n\n.jobber-retheme ._2hxova2FHpM- {\n border: none;\n background-color: rgba(101, 120, 132, 1);\n background-color: var(--color-interactive--subtle);\n}\n\n.HbAoDMJhkwY- ._2hxova2FHpM- {\n border-color: rgb(125, 176, 14);\n border-color: var(--color-green);\n}\n\n.jobber-retheme .HbAoDMJhkwY- ._2hxova2FHpM- {\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n/* Moving this up overwrites disabled styling */\n\n/* stylelint-disable-next-line no-descending-specificity */\n\n._6hWvJHjyLlk- ._2hxova2FHpM- {\n border-color: rgb(225, 225, 225);\n border-color: var(--color-disabled--secondary);\n}\n\n.jobber-retheme ._6hWvJHjyLlk- ._2hxova2FHpM- {\n background-color: rgb(181, 181, 181);\n background-color: var(--color-disabled);\n}\n\n._6hWvJHjyLlk- {\n border-color: rgb(225, 225, 225);\n border-color: var(--color-disabled--secondary);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n cursor: not-allowed;\n}\n\n.jobber-retheme ._6hWvJHjyLlk- {\n border-color: rgb(181, 181, 181);\n border-color: var(--color-disabled);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n cursor: not-allowed;\n}\n\n.jobber-retheme .HbAoDMJhkwY-._6hWvJHjyLlk- {\n background-color: rgb(181, 181, 181);\n background-color: var(--color-disabled);\n}\n\n.jobber-retheme .HbAoDMJhkwY-._6hWvJHjyLlk- ._2hxova2FHpM- {\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n.jobber-retheme ._6hWvJHjyLlk-:hover {\n border-color: rgb(181, 181, 181);\n border-color: var(--color-disabled);\n}\n";
|
|
14
|
-
var styles = {"track":"NaSI2jsLI0c-","isChecked":"HbAoDMJhkwY-","toggle":"cc259FtdxeE-","label":"YZ-HIehHOBA-","pip":"_2hxova2FHpM-","disabled":"_6hWvJHjyLlk-"};
|
|
15
|
-
styleInject_es.styleInject(css_248z);
|
|
16
|
-
|
|
17
|
-
function Switch({ value: providedValue, ariaLabel, name, disabled, onChange, }) {
|
|
18
|
-
const [statefulValue, setValue] = React.useState(false);
|
|
19
|
-
const value = providedValue != undefined ? providedValue : statefulValue;
|
|
20
|
-
const toggleSwitch = () => {
|
|
21
|
-
if (disabled) {
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
const newValue = !value;
|
|
25
|
-
onChange && onChange(newValue);
|
|
26
|
-
if (providedValue == undefined) {
|
|
27
|
-
setValue(newValue);
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
const className = classnames__default["default"](styles.track, {
|
|
31
|
-
[styles.isChecked]: value,
|
|
32
|
-
[styles.disabled]: disabled,
|
|
33
|
-
});
|
|
34
|
-
return (React__default["default"].createElement(React__default["default"].Fragment, null,
|
|
35
|
-
React__default["default"].createElement("button", { id: name, type: "button", role: "switch", "aria-checked": value, "aria-label": ariaLabel, className: className, onClick: toggleSwitch, disabled: disabled },
|
|
36
|
-
React__default["default"].createElement("span", { className: styles.toggle },
|
|
37
|
-
React__default["default"].createElement(Label, { as: "On", disabled: disabled }),
|
|
38
|
-
React__default["default"].createElement("span", { className: styles.pip }),
|
|
39
|
-
React__default["default"].createElement(Label, { as: "Off", disabled: disabled }))),
|
|
40
|
-
React__default["default"].createElement("input", { name: name, type: "hidden", value: String(value) })));
|
|
41
|
-
}
|
|
42
|
-
function Label({ as, disabled }) {
|
|
43
|
-
const getTextColor = () => {
|
|
44
|
-
if (disabled) {
|
|
45
|
-
return "grey";
|
|
46
|
-
}
|
|
47
|
-
else if (as === "On") {
|
|
48
|
-
return "white";
|
|
49
|
-
}
|
|
50
|
-
return "greyBlue";
|
|
51
|
-
};
|
|
52
|
-
return (React__default["default"].createElement("span", { className: styles.label },
|
|
53
|
-
React__default["default"].createElement(Typography.Typography, { element: "span", textColor: getTextColor(), size: "small", fontWeight: "bold", textCase: "uppercase" }, as)));
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
exports.Switch = Switch;
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var useSafeLayoutEffect = require('@jobber/hooks/useSafeLayoutEffect');
|
|
4
|
-
var React = require('react');
|
|
5
|
-
|
|
6
|
-
// For retheme purposes only.
|
|
7
|
-
// This will be removed once the retheme is out of the experiment.
|
|
8
|
-
function useAtlantisConfig() {
|
|
9
|
-
const [JOBBER_RETHEME, setJOBBER_RETHEME] = React.useState(false);
|
|
10
|
-
useSafeLayoutEffect.useSafeLayoutEffect(() => {
|
|
11
|
-
setJOBBER_RETHEME(document.body.classList.contains("jobber-retheme"));
|
|
12
|
-
}, []);
|
|
13
|
-
return { JOBBER_RETHEME };
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
exports.useAtlantisConfig = useAtlantisConfig;
|