@flodesk/grain 11.46.0 → 11.47.0
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/es/components/autocomplete2.js +51 -33
- package/es/components/button.js +31 -13
- package/es/components/progress.js +5 -5
- package/es/components/select.js +48 -31
- package/es/components/text-input.js +27 -15
- package/es/foundational/field.js +30 -21
- package/es/styles/foundational.js +3 -3
- package/package.json +1 -1
|
@@ -19,7 +19,7 @@ import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
|
19
19
|
const background = getColor('fade1');
|
|
20
20
|
const fill = getColor('content');
|
|
21
21
|
const height = '4px';
|
|
22
|
-
const
|
|
22
|
+
const flow = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n 0% { transform: translateX(-100%) }\n 100% { transform: translateX(100%) }\n"])));
|
|
23
23
|
|
|
24
24
|
const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
25
25
|
target: "e665t821"
|
|
@@ -30,20 +30,20 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
30
30
|
let {
|
|
31
31
|
variant
|
|
32
32
|
} = _ref;
|
|
33
|
-
return variant === 'determinate' && /*#__PURE__*/css("width:var(--value);transition:", getTransition('fast'), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Root;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
return variant === 'determinate' && /*#__PURE__*/css("width:var(--value);transition:", getTransition('fast'), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Root;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3Byb2dyZXNzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ1MiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJvZ3Jlc3MuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsga2V5ZnJhbWVzLCBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmNvbnN0IGJhY2tncm91bmQgPSBnZXRDb2xvcignZmFkZTEnKTtcbmNvbnN0IGZpbGwgPSBnZXRDb2xvcignY29udGVudCcpO1xuY29uc3QgaGVpZ2h0ID0gJzRweCc7XG5cbmNvbnN0IGZsb3cgPSBrZXlmcmFtZXNgXG4gIDAlIHsgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKSB9XG4gIDEwMCUgeyB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoMTAwJSkgfVxuYDtcblxuY29uc3QgUm9vdCA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuXG4gICY6OmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgYmFja2dyb3VuZDogJHtmaWxsfTtcbiAgICBib3JkZXItcmFkaXVzOiAke2hlaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRvcDogMDtcbiAgICBsZWZ0OiAwO1xuXG4gICAgJHsoeyB2YXJpYW50IH0pID0+XG4gICAgICB2YXJpYW50ID09PSAnZGV0ZXJtaW5hdGUnICYmXG4gICAgICBjc3NgXG4gICAgICAgIHdpZHRoOiB2YXIoLS12YWx1ZSk7XG4gICAgICAgIHRyYW5zaXRpb246ICR7Z2V0VHJhbnNpdGlvbignZmFzdCcpfTtcbiAgICAgIGB9O1xuXG4gICAgJHsoeyB2YXJpYW50IH0pID0+XG4gICAgICB2YXJpYW50ID09PSAnaW5kZXRlcm1pbmF0ZScgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGFuaW1hdGlvbjogJHtmbG93fSAycyBpbmZpbml0ZTtcbiAgICAgIGB9O1xuICB9XG5gO1xuXG5jb25zdCBQcm9ncmVzc1Jvb3QgPSBzdHlsZWQucHJvZ3Jlc3NgXG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6ICR7aGVpZ2h0fTtcbiAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuICBib3JkZXI6IG5vbmU7XG5cbiAgJjo6LXdlYmtpdC1wcm9ncmVzcy1iYXIge1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICB9XG4gICY6Oi1tb3otcHJvZ3Jlc3MtYmFyIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuICAmOjotd2Via2l0LXByb2dyZXNzLXZhbHVlIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFByb2dyZXNzID0gZm9yd2FyZFJlZihcbiAgKHsgbWF4ID0gMTAwLCB2YWx1ZSwgdmFyaWFudCA9ICdkZXRlcm1pbmF0ZScsIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICAgIGNvbnN0IHZhbHVlU3RyaW5nID0gYCR7KHZhbHVlIC8gbWF4KSAqIDEwMH0lYDtcbiAgICByZXR1cm4gKFxuICAgICAgPFJvb3Qgc3R5bGU9e3sgJy0tdmFsdWUnOiB2YWx1ZVN0cmluZyB9fSB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPFByb2dyZXNzUm9vdCByZWY9e3JlZn0gdmFsdWU9e3ZhbHVlfSBtYXg9e21heH0gey4uLnByb3BzfSAvPlxuICAgICAgPC9Sb290PlxuICAgICk7XG4gIH0sXG4pO1xuXG5Qcm9ncmVzcy5wcm9wVHlwZXMgPSB7XG4gIG1heDogUHJvcFR5cGVzLm51bWJlcixcbiAgdmFsdWU6IFByb3BUeXBlcy5udW1iZXIsXG4gIHZhcmlhbnQ6IFByb3BUeXBlcy5vbmVPZihbJ2RldGVybWluYXRlJywgJ2luZGV0ZXJtaW5hdGUnXSksXG59O1xuIl19 */");
|
|
34
34
|
}, ";", _ref2 => {
|
|
35
35
|
let {
|
|
36
36
|
variant
|
|
37
37
|
} = _ref2;
|
|
38
|
-
return variant === 'indeterminate' && /*#__PURE__*/css("width:100%;animation:",
|
|
39
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
38
|
+
return variant === 'indeterminate' && /*#__PURE__*/css("width:100%;animation:", flow, " 2s infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:Root;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3Byb2dyZXNzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q1MiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJvZ3Jlc3MuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsga2V5ZnJhbWVzLCBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmNvbnN0IGJhY2tncm91bmQgPSBnZXRDb2xvcignZmFkZTEnKTtcbmNvbnN0IGZpbGwgPSBnZXRDb2xvcignY29udGVudCcpO1xuY29uc3QgaGVpZ2h0ID0gJzRweCc7XG5cbmNvbnN0IGZsb3cgPSBrZXlmcmFtZXNgXG4gIDAlIHsgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKSB9XG4gIDEwMCUgeyB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoMTAwJSkgfVxuYDtcblxuY29uc3QgUm9vdCA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuXG4gICY6OmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgYmFja2dyb3VuZDogJHtmaWxsfTtcbiAgICBib3JkZXItcmFkaXVzOiAke2hlaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRvcDogMDtcbiAgICBsZWZ0OiAwO1xuXG4gICAgJHsoeyB2YXJpYW50IH0pID0+XG4gICAgICB2YXJpYW50ID09PSAnZGV0ZXJtaW5hdGUnICYmXG4gICAgICBjc3NgXG4gICAgICAgIHdpZHRoOiB2YXIoLS12YWx1ZSk7XG4gICAgICAgIHRyYW5zaXRpb246ICR7Z2V0VHJhbnNpdGlvbignZmFzdCcpfTtcbiAgICAgIGB9O1xuXG4gICAgJHsoeyB2YXJpYW50IH0pID0+XG4gICAgICB2YXJpYW50ID09PSAnaW5kZXRlcm1pbmF0ZScgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGFuaW1hdGlvbjogJHtmbG93fSAycyBpbmZpbml0ZTtcbiAgICAgIGB9O1xuICB9XG5gO1xuXG5jb25zdCBQcm9ncmVzc1Jvb3QgPSBzdHlsZWQucHJvZ3Jlc3NgXG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6ICR7aGVpZ2h0fTtcbiAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuICBib3JkZXI6IG5vbmU7XG5cbiAgJjo6LXdlYmtpdC1wcm9ncmVzcy1iYXIge1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICB9XG4gICY6Oi1tb3otcHJvZ3Jlc3MtYmFyIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuICAmOjotd2Via2l0LXByb2dyZXNzLXZhbHVlIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFByb2dyZXNzID0gZm9yd2FyZFJlZihcbiAgKHsgbWF4ID0gMTAwLCB2YWx1ZSwgdmFyaWFudCA9ICdkZXRlcm1pbmF0ZScsIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICAgIGNvbnN0IHZhbHVlU3RyaW5nID0gYCR7KHZhbHVlIC8gbWF4KSAqIDEwMH0lYDtcbiAgICByZXR1cm4gKFxuICAgICAgPFJvb3Qgc3R5bGU9e3sgJy0tdmFsdWUnOiB2YWx1ZVN0cmluZyB9fSB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPFByb2dyZXNzUm9vdCByZWY9e3JlZn0gdmFsdWU9e3ZhbHVlfSBtYXg9e21heH0gey4uLnByb3BzfSAvPlxuICAgICAgPC9Sb290PlxuICAgICk7XG4gIH0sXG4pO1xuXG5Qcm9ncmVzcy5wcm9wVHlwZXMgPSB7XG4gIG1heDogUHJvcFR5cGVzLm51bWJlcixcbiAgdmFsdWU6IFByb3BUeXBlcy5udW1iZXIsXG4gIHZhcmlhbnQ6IFByb3BUeXBlcy5vbmVPZihbJ2RldGVybWluYXRlJywgJ2luZGV0ZXJtaW5hdGUnXSksXG59O1xuIl19 */");
|
|
39
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3Byb2dyZXNzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFldUIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJvZ3Jlc3MuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsga2V5ZnJhbWVzLCBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmNvbnN0IGJhY2tncm91bmQgPSBnZXRDb2xvcignZmFkZTEnKTtcbmNvbnN0IGZpbGwgPSBnZXRDb2xvcignY29udGVudCcpO1xuY29uc3QgaGVpZ2h0ID0gJzRweCc7XG5cbmNvbnN0IGZsb3cgPSBrZXlmcmFtZXNgXG4gIDAlIHsgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKSB9XG4gIDEwMCUgeyB0cmFuc2Zvcm06IHRyYW5zbGF0ZVgoMTAwJSkgfVxuYDtcblxuY29uc3QgUm9vdCA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuXG4gICY6OmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgYmFja2dyb3VuZDogJHtmaWxsfTtcbiAgICBib3JkZXItcmFkaXVzOiAke2hlaWdodH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHRvcDogMDtcbiAgICBsZWZ0OiAwO1xuXG4gICAgJHsoeyB2YXJpYW50IH0pID0+XG4gICAgICB2YXJpYW50ID09PSAnZGV0ZXJtaW5hdGUnICYmXG4gICAgICBjc3NgXG4gICAgICAgIHdpZHRoOiB2YXIoLS12YWx1ZSk7XG4gICAgICAgIHRyYW5zaXRpb246ICR7Z2V0VHJhbnNpdGlvbignZmFzdCcpfTtcbiAgICAgIGB9O1xuXG4gICAgJHsoeyB2YXJpYW50IH0pID0+XG4gICAgICB2YXJpYW50ID09PSAnaW5kZXRlcm1pbmF0ZScgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGFuaW1hdGlvbjogJHtmbG93fSAycyBpbmZpbml0ZTtcbiAgICAgIGB9O1xuICB9XG5gO1xuXG5jb25zdCBQcm9ncmVzc1Jvb3QgPSBzdHlsZWQucHJvZ3Jlc3NgXG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJhY2tncm91bmQ6ICR7YmFja2dyb3VuZH07XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6ICR7aGVpZ2h0fTtcbiAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuICBib3JkZXI6IG5vbmU7XG5cbiAgJjo6LXdlYmtpdC1wcm9ncmVzcy1iYXIge1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICB9XG4gICY6Oi1tb3otcHJvZ3Jlc3MtYmFyIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuICAmOjotd2Via2l0LXByb2dyZXNzLXZhbHVlIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFByb2dyZXNzID0gZm9yd2FyZFJlZihcbiAgKHsgbWF4ID0gMTAwLCB2YWx1ZSwgdmFyaWFudCA9ICdkZXRlcm1pbmF0ZScsIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICAgIGNvbnN0IHZhbHVlU3RyaW5nID0gYCR7KHZhbHVlIC8gbWF4KSAqIDEwMH0lYDtcbiAgICByZXR1cm4gKFxuICAgICAgPFJvb3Qgc3R5bGU9e3sgJy0tdmFsdWUnOiB2YWx1ZVN0cmluZyB9fSB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPFByb2dyZXNzUm9vdCByZWY9e3JlZn0gdmFsdWU9e3ZhbHVlfSBtYXg9e21heH0gey4uLnByb3BzfSAvPlxuICAgICAgPC9Sb290PlxuICAgICk7XG4gIH0sXG4pO1xuXG5Qcm9ncmVzcy5wcm9wVHlwZXMgPSB7XG4gIG1heDogUHJvcFR5cGVzLm51bWJlcixcbiAgdmFsdWU6IFByb3BUeXBlcy5udW1iZXIsXG4gIHZhcmlhbnQ6IFByb3BUeXBlcy5vbmVPZihbJ2RldGVybWluYXRlJywgJ2luZGV0ZXJtaW5hdGUnXSksXG59O1xuIl19 */"));
|
|
40
40
|
|
|
41
41
|
const ProgressRoot = /*#__PURE__*/_styled("progress", process.env.NODE_ENV === "production" ? {
|
|
42
42
|
target: "e665t820"
|
|
43
43
|
} : {
|
|
44
44
|
target: "e665t820",
|
|
45
45
|
label: "ProgressRoot"
|
|
46
|
-
})("appearance:none;margin:0;display:block;background:", background, ";width:100%;height:", height, ";border-radius:", height, ";border:none;&::-webkit-progress-bar{background:transparent;}&::-moz-progress-bar{background:transparent;}&::-webkit-progress-value{background:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
46
|
+
})("appearance:none;margin:0;display:block;background:", background, ";width:100%;height:", height, ";border-radius:", height, ";border:none;&::-webkit-progress-bar{background:transparent;}&::-moz-progress-bar{background:transparent;}&::-webkit-progress-value{background:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3Byb2dyZXNzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Q29DIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL3Byb2dyZXNzLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGdldENvbG9yLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IGtleWZyYW1lcywgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5jb25zdCBiYWNrZ3JvdW5kID0gZ2V0Q29sb3IoJ2ZhZGUxJyk7XG5jb25zdCBmaWxsID0gZ2V0Q29sb3IoJ2NvbnRlbnQnKTtcbmNvbnN0IGhlaWdodCA9ICc0cHgnO1xuXG5jb25zdCBmbG93ID0ga2V5ZnJhbWVzYFxuICAwJSB7IHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtMTAwJSkgfVxuICAxMDAlIHsgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKDEwMCUpIH1cbmA7XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGJvcmRlci1yYWRpdXM6ICR7aGVpZ2h0fTtcblxuICAmOjphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgaGVpZ2h0OiAxMDAlO1xuICAgIGJhY2tncm91bmQ6ICR7ZmlsbH07XG4gICAgYm9yZGVyLXJhZGl1czogJHtoZWlnaHR9O1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICB0b3A6IDA7XG4gICAgbGVmdDogMDtcblxuICAgICR7KHsgdmFyaWFudCB9KSA9PlxuICAgICAgdmFyaWFudCA9PT0gJ2RldGVybWluYXRlJyAmJlxuICAgICAgY3NzYFxuICAgICAgICB3aWR0aDogdmFyKC0tdmFsdWUpO1xuICAgICAgICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG4gICAgICBgfTtcblxuICAgICR7KHsgdmFyaWFudCB9KSA9PlxuICAgICAgdmFyaWFudCA9PT0gJ2luZGV0ZXJtaW5hdGUnICYmXG4gICAgICBjc3NgXG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICBhbmltYXRpb246ICR7Zmxvd30gMnMgaW5maW5pdGU7XG4gICAgICBgfTtcbiAgfVxuYDtcblxuY29uc3QgUHJvZ3Jlc3NSb290ID0gc3R5bGVkLnByb2dyZXNzYFxuICBhcHBlYXJhbmNlOiBub25lO1xuICBtYXJnaW46IDA7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBiYWNrZ3JvdW5kOiAke2JhY2tncm91bmR9O1xuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAke2hlaWdodH07XG4gIGJvcmRlci1yYWRpdXM6ICR7aGVpZ2h0fTtcbiAgYm9yZGVyOiBub25lO1xuXG4gICY6Oi13ZWJraXQtcHJvZ3Jlc3MtYmFyIHtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgfVxuICAmOjotbW96LXByb2dyZXNzLWJhciB7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIH1cbiAgJjo6LXdlYmtpdC1wcm9ncmVzcy12YWx1ZSB7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQcm9ncmVzcyA9IGZvcndhcmRSZWYoXG4gICh7IG1heCA9IDEwMCwgdmFsdWUsIHZhcmlhbnQgPSAnZGV0ZXJtaW5hdGUnLCAuLi5wcm9wcyB9LCByZWYpID0+IHtcbiAgICBjb25zdCB2YWx1ZVN0cmluZyA9IGAkeyh2YWx1ZSAvIG1heCkgKiAxMDB9JWA7XG4gICAgcmV0dXJuIChcbiAgICAgIDxSb290IHN0eWxlPXt7ICctLXZhbHVlJzogdmFsdWVTdHJpbmcgfX0gdmFyaWFudD17dmFyaWFudH0+XG4gICAgICAgIDxQcm9ncmVzc1Jvb3QgcmVmPXtyZWZ9IHZhbHVlPXt2YWx1ZX0gbWF4PXttYXh9IHsuLi5wcm9wc30gLz5cbiAgICAgIDwvUm9vdD5cbiAgICApO1xuICB9LFxuKTtcblxuUHJvZ3Jlc3MucHJvcFR5cGVzID0ge1xuICBtYXg6IFByb3BUeXBlcy5udW1iZXIsXG4gIHZhbHVlOiBQcm9wVHlwZXMubnVtYmVyLFxuICB2YXJpYW50OiBQcm9wVHlwZXMub25lT2YoWydkZXRlcm1pbmF0ZScsICdpbmRldGVybWluYXRlJ10pLFxufTtcbiJdfQ== */"));
|
|
47
47
|
|
|
48
48
|
export const Progress = /*#__PURE__*/forwardRef((_ref3, ref) => {
|
|
49
49
|
let {
|
package/es/components/select.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
|
-
const _excluded = ["children", "variant", "backgroundColor", "onClear", "hasClearButton"],
|
|
2
|
+
const _excluded = ["children", "variant", "backgroundColor", "onClear", "hasClearButton", "size"],
|
|
3
3
|
_excluded2 = ["option", "isSelected", "menuItemsHaveEllipsis", "allowMultiple"],
|
|
4
4
|
_excluded3 = ["children", "floating", "hasPortal", "isOpen"];
|
|
5
5
|
import "core-js/modules/web.dom-collections.iterator.js";
|
|
@@ -34,12 +34,22 @@ const TriggerButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "p
|
|
|
34
34
|
backgroundColor
|
|
35
35
|
} = _ref;
|
|
36
36
|
return getColor(backgroundColor ? backgroundColor : 'transparent');
|
|
37
|
-
}, ";padding:0 var(--grn-field-paddingX);border:1px solid var(--grn-field-border-color);font-weight:", getWeight('normal'), ";min-height:var(--grn-textbox-height-m);border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{border-color:var(--grn-field-border-color-hover);}&[disabled]{", fieldDisabledStyles, ";cursor:default;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAqBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n  padding: 0 var(--grn-field-paddingX);\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(\n  ({ children, variant = 'box', backgroundColor, onClear, hasClearButton, ...props }, ref) => (\n    <>\n      {variant === 'box' && (\n        <TriggerButton ref={ref} type=\"button\" backgroundColor={backgroundColor} {...props}>\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  ),\n);\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
|
|
37
|
+
}, ";padding-block:0;padding-inline:", _ref2 => {
|
|
38
|
+
let {
|
|
39
|
+
size
|
|
40
|
+
} = _ref2;
|
|
41
|
+
return "var(--grn-field-paddingX-".concat(size, ")");
|
|
42
|
+
}, ";border:1px solid var(--grn-field-border-color);font-weight:", getWeight('normal'), ";min-height:", _ref3 => {
|
|
43
|
+
let {
|
|
44
|
+
size
|
|
45
|
+
} = _ref3;
|
|
46
|
+
return "var(--grn-textbox-height-".concat(size, ")");
|
|
47
|
+
}, ";border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{border-color:var(--grn-field-border-color-hover);}&[disabled]{", fieldDisabledStyles, ";cursor:default;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAqBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n  padding-block: 0;\n  padding-inline: ${({ size }) => `var(--grn-field-paddingX-${size})`};\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: ${({ size }) => `var(--grn-textbox-height-${size})`};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(\n  (\n    { children, variant = 'box', backgroundColor, onClear, hasClearButton, size, ...props },\n    ref,\n  ) => (\n    <>\n      {variant === 'box' && (\n        <TriggerButton\n          ref={ref}\n          type=\"button\"\n          backgroundColor={backgroundColor}\n          size={size}\n          {...props}\n        >\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  ),\n);\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n  size,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          size={size}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n  size = 'm',\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n              size={size}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
38
48
|
|
|
39
|
-
const ClearButton =
|
|
49
|
+
const ClearButton = _ref4 => {
|
|
40
50
|
let {
|
|
41
51
|
onClick
|
|
42
|
-
} =
|
|
52
|
+
} = _ref4;
|
|
43
53
|
|
|
44
54
|
const handleClear = e => {
|
|
45
55
|
e.stopPropagation();
|
|
@@ -52,20 +62,22 @@ const ClearButton = _ref2 => {
|
|
|
52
62
|
});
|
|
53
63
|
};
|
|
54
64
|
|
|
55
|
-
const Trigger = /*#__PURE__*/forwardRef((
|
|
65
|
+
const Trigger = /*#__PURE__*/forwardRef((_ref5, ref) => {
|
|
56
66
|
let {
|
|
57
67
|
children,
|
|
58
68
|
variant = 'box',
|
|
59
69
|
backgroundColor,
|
|
60
70
|
onClear,
|
|
61
|
-
hasClearButton
|
|
62
|
-
|
|
63
|
-
|
|
71
|
+
hasClearButton,
|
|
72
|
+
size
|
|
73
|
+
} = _ref5,
|
|
74
|
+
props = _objectWithoutProperties(_ref5, _excluded);
|
|
64
75
|
|
|
65
76
|
return ___EmotionJSX(React.Fragment, null, variant === 'box' && ___EmotionJSX(TriggerButton, _extends({
|
|
66
77
|
ref: ref,
|
|
67
78
|
type: "button",
|
|
68
|
-
backgroundColor: backgroundColor
|
|
79
|
+
backgroundColor: backgroundColor,
|
|
80
|
+
size: size
|
|
69
81
|
}, props), ___EmotionJSX(Text, {
|
|
70
82
|
hasEllipsis: true
|
|
71
83
|
}, children), ___EmotionJSX(Arrange, {
|
|
@@ -97,7 +109,7 @@ const getTriggerContent = (isMultiple, selected, placeholder) => {
|
|
|
97
109
|
return selected.content;
|
|
98
110
|
};
|
|
99
111
|
|
|
100
|
-
const SelectButton =
|
|
112
|
+
const SelectButton = _ref6 => {
|
|
101
113
|
let {
|
|
102
114
|
customTrigger,
|
|
103
115
|
variant,
|
|
@@ -105,8 +117,9 @@ const SelectButton = _ref4 => {
|
|
|
105
117
|
selected,
|
|
106
118
|
placeholder,
|
|
107
119
|
backgroundColor,
|
|
108
|
-
onClear
|
|
109
|
-
|
|
120
|
+
onClear,
|
|
121
|
+
size
|
|
122
|
+
} = _ref6;
|
|
110
123
|
const props = {
|
|
111
124
|
variant,
|
|
112
125
|
children: getTriggerContent(isMultiple, selected, placeholder)
|
|
@@ -119,7 +132,8 @@ const SelectButton = _ref4 => {
|
|
|
119
132
|
}) : ___EmotionJSX(Trigger, _extends({
|
|
120
133
|
backgroundColor: backgroundColor,
|
|
121
134
|
onClear: onClear,
|
|
122
|
-
hasClearButton: hasClearButton
|
|
135
|
+
hasClearButton: hasClearButton,
|
|
136
|
+
size: size
|
|
123
137
|
}, props)));
|
|
124
138
|
};
|
|
125
139
|
|
|
@@ -134,27 +148,27 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
134
148
|
} : {
|
|
135
149
|
name: "wowqs1",
|
|
136
150
|
styles: "min-width:0px",
|
|
137
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAwHuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n  padding: 0 var(--grn-field-paddingX);\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(\n  ({ children, variant = 'box', backgroundColor, onClear, hasClearButton, ...props }, ref) => (\n    <>\n      {variant === 'box' && (\n        <TriggerButton ref={ref} type=\"button\" backgroundColor={backgroundColor} {...props}>\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  ),\n);\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */",
|
|
151
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoIuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n  padding-block: 0;\n  padding-inline: ${({ size }) => `var(--grn-field-paddingX-${size})`};\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: ${({ size }) => `var(--grn-textbox-height-${size})`};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(\n  (\n    { children, variant = 'box', backgroundColor, onClear, hasClearButton, size, ...props },\n    ref,\n  ) => (\n    <>\n      {variant === 'box' && (\n        <TriggerButton\n          ref={ref}\n          type=\"button\"\n          backgroundColor={backgroundColor}\n          size={size}\n          {...props}\n        >\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  ),\n);\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n  size,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          size={size}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n  size = 'm',\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n              size={size}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */",
|
|
138
152
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
139
153
|
});
|
|
140
154
|
|
|
141
|
-
const SelectMenuOption =
|
|
155
|
+
const SelectMenuOption = _ref7 => {
|
|
142
156
|
let {
|
|
143
157
|
option,
|
|
144
158
|
isSelected,
|
|
145
159
|
menuItemsHaveEllipsis,
|
|
146
160
|
allowMultiple
|
|
147
|
-
} =
|
|
148
|
-
props = _objectWithoutProperties(
|
|
161
|
+
} = _ref7,
|
|
162
|
+
props = _objectWithoutProperties(_ref7, _excluded2);
|
|
149
163
|
|
|
150
164
|
return ___EmotionJSX(Listbox.Option, _extends({
|
|
151
165
|
value: option,
|
|
152
166
|
as: Fragment,
|
|
153
167
|
disabled: option.isDisabled
|
|
154
|
-
}, props),
|
|
168
|
+
}, props), _ref8 => {
|
|
155
169
|
let {
|
|
156
170
|
active
|
|
157
|
-
} =
|
|
171
|
+
} = _ref8;
|
|
158
172
|
return ___EmotionJSX(MenuItem, {
|
|
159
173
|
isSelected: isSelected,
|
|
160
174
|
isActive: active,
|
|
@@ -164,11 +178,11 @@ const SelectMenuOption = _ref5 => {
|
|
|
164
178
|
});
|
|
165
179
|
};
|
|
166
180
|
|
|
167
|
-
const SelectInfo =
|
|
181
|
+
const SelectInfo = _ref9 => {
|
|
168
182
|
let {
|
|
169
183
|
label,
|
|
170
184
|
hint
|
|
171
|
-
} =
|
|
185
|
+
} = _ref9;
|
|
172
186
|
return ___EmotionJSX(React.Fragment, null, (label || hint) && ___EmotionJSX(Box, {
|
|
173
187
|
marginBottom: "var(--grn-form-control-label-gap)"
|
|
174
188
|
}, label && ___EmotionJSX(Listbox.Label, {
|
|
@@ -176,14 +190,14 @@ const SelectInfo = _ref7 => {
|
|
|
176
190
|
}, label), hint && ___EmotionJSX(FieldHint, null, hint)));
|
|
177
191
|
};
|
|
178
192
|
|
|
179
|
-
const SelectMenu =
|
|
193
|
+
const SelectMenu = _ref10 => {
|
|
180
194
|
let {
|
|
181
195
|
children,
|
|
182
196
|
floating,
|
|
183
197
|
hasPortal,
|
|
184
198
|
isOpen
|
|
185
|
-
} =
|
|
186
|
-
props = _objectWithoutProperties(
|
|
199
|
+
} = _ref10,
|
|
200
|
+
props = _objectWithoutProperties(_ref10, _excluded3);
|
|
187
201
|
|
|
188
202
|
const Root = hasPortal ? FloatingPortal : Fragment;
|
|
189
203
|
return ___EmotionJSX(Root, null, ___EmotionJSX(MenuCardTransition, null, ___EmotionJSX(Listbox.Options, _extends({
|
|
@@ -204,7 +218,7 @@ const getIsSelected = (isMultiple, option, selected) => {
|
|
|
204
218
|
return option.value === selected.value;
|
|
205
219
|
};
|
|
206
220
|
|
|
207
|
-
export const Select =
|
|
221
|
+
export const Select = _ref11 => {
|
|
208
222
|
let {
|
|
209
223
|
options,
|
|
210
224
|
value,
|
|
@@ -223,8 +237,9 @@ export const Select = _ref9 => {
|
|
|
223
237
|
placeholder,
|
|
224
238
|
isDisabled,
|
|
225
239
|
backgroundColor,
|
|
226
|
-
onClear
|
|
227
|
-
|
|
240
|
+
onClear,
|
|
241
|
+
size = 'm'
|
|
242
|
+
} = _ref11;
|
|
228
243
|
const {
|
|
229
244
|
reference,
|
|
230
245
|
floating,
|
|
@@ -262,10 +277,10 @@ export const Select = _ref9 => {
|
|
|
262
277
|
width: rootWidth,
|
|
263
278
|
multiple: allowMultiple,
|
|
264
279
|
disabled: isDisabled
|
|
265
|
-
},
|
|
280
|
+
}, _ref12 => {
|
|
266
281
|
let {
|
|
267
282
|
open
|
|
268
|
-
} =
|
|
283
|
+
} = _ref12;
|
|
269
284
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(SelectInfo, {
|
|
270
285
|
label: label,
|
|
271
286
|
hint: hint
|
|
@@ -279,7 +294,8 @@ export const Select = _ref9 => {
|
|
|
279
294
|
selected: selected,
|
|
280
295
|
placeholder: placeholder,
|
|
281
296
|
backgroundColor: backgroundColor,
|
|
282
|
-
onClear: onClear
|
|
297
|
+
onClear: onClear,
|
|
298
|
+
size: size
|
|
283
299
|
}), ___EmotionJSX(SelectMenu, {
|
|
284
300
|
placement: menuPlacement,
|
|
285
301
|
maxHeight: menuMaxHeight,
|
|
@@ -324,5 +340,6 @@ Select.propTypes = {
|
|
|
324
340
|
placeholder: PropTypes.string,
|
|
325
341
|
isDisabled: PropTypes.bool,
|
|
326
342
|
backgroundColor: types.color,
|
|
327
|
-
onClear: PropTypes.func
|
|
343
|
+
onClear: PropTypes.func,
|
|
344
|
+
size: PropTypes.oneOf(['m', 'l'])
|
|
328
345
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
|
-
const _excluded = ["children", "internalType", "setInternalType"],
|
|
2
|
+
const _excluded = ["children", "internalType", "setInternalType", "size"],
|
|
3
3
|
_excluded2 = ["children"],
|
|
4
|
-
_excluded3 = ["value", "placeholder", "label", "id", "icon", "hasError", "errorMessage", "isReadOnly", "isDisabled", "type", "hint", "onClear", "backgroundColor"];
|
|
4
|
+
_excluded3 = ["value", "placeholder", "label", "id", "icon", "hasError", "errorMessage", "isReadOnly", "isDisabled", "type", "hint", "onClear", "backgroundColor", "size"];
|
|
5
5
|
import "core-js/modules/web.dom-collections.iterator.js";
|
|
6
6
|
|
|
7
7
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
@@ -27,13 +27,14 @@ const IconSection = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
|
|
|
27
27
|
} : {
|
|
28
28
|
target: "e1o9e51y0",
|
|
29
29
|
label: "IconSection"
|
|
30
|
-
})("position:absolute;margin:auto;left:", iconOffset, ";top:0;bottom:0;height:fit-content;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
30
|
+
})("position:absolute;margin:auto;left:", iconOffset, ";top:0;bottom:0;height:fit-content;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtaW5wdXQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWE4QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy90ZXh0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnLic7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnLi9pY29uJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEZpZWxkQ2xlYXJCdXR0b24sIEZpZWxkSGludCwgRmllbGRMYWJlbCwgSW5wdXRGaWVsZCB9IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IEljb25IaWRlLCBJY29uU2hvdyB9IGZyb20gJy4uL2ljb25zJztcblxuY29uc3QgaWNvbk9mZnNldCA9ICd2YXIoLS1ncm4tZmllbGQtcGFkZGluZ1gpJztcbmNvbnN0IGljb25UZXh0R2FwID0gJ3ZhcigtLWdybi1zcGFjZS1zKSc7XG5cbmNvbnN0IEljb25TZWN0aW9uID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBtYXJnaW46IGF1dG87XG4gIGxlZnQ6ICR7aWNvbk9mZnNldH07XG4gIHRvcDogMDtcbiAgYm90dG9tOiAwO1xuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmNvbnN0IEFjdGlvbkJ1dHRvbldyYXBwZXIgPSAoeyBjaGlsZHJlbiwgc2l6ZSB9KSA9PiB7XG4gIGNvbnN0IHJpZ2h0T2Zmc2V0ID0gYGNhbGMoKHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC0ke3NpemV9KSAtIHZhcigtLWdybi1jbGVhcmJ1dHRvbi1oZWlnaHQpKSAvIDIpYDtcbiAgcmV0dXJuIChcbiAgICA8Qm94XG4gICAgICBwb3NpdGlvbj1cImFic29sdXRlXCJcbiAgICAgIHJpZ2h0PXtyaWdodE9mZnNldH1cbiAgICAgIHRvcD1cIjBcIlxuICAgICAgYm90dG9tPVwiMFwiXG4gICAgICBtYXJnaW49XCJhdXRvXCJcbiAgICAgIGhlaWdodD1cImZpdC1jb250ZW50XCJcbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Cb3g+XG4gICk7XG59O1xuXG5jb25zdCBWaXNpYmlsaXR5QnV0dG9uID0gKHsgY2hpbGRyZW4sIGludGVybmFsVHlwZSwgc2V0SW50ZXJuYWxUeXBlLCBzaXplLCAuLi5wcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHR5cGVBbmRJY29uTWFwID0ge1xuICAgIHBhc3N3b3JkOiA8SWNvblNob3cgLz4sXG4gICAgdGV4dDogPEljb25IaWRlIC8+LFxuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPEFjdGlvbkJ1dHRvbldyYXBwZXIgc2l6ZT17c2l6ZX0+XG4gICAgICA8SWNvbkJ1dHRvblxuICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgIGljb249e3R5cGVBbmRJY29uTWFwW2ludGVybmFsVHlwZV19XG4gICAgICAgIG9uQ2xpY2s9eygpID0+IHNldEludGVybmFsVHlwZShpbnRlcm5hbFR5cGUgPT09ICd0ZXh0JyA/ICdwYXNzd29yZCcgOiAndGV4dCcpfVxuICAgICAgLz5cbiAgICA8L0FjdGlvbkJ1dHRvbldyYXBwZXI+XG4gICk7XG59O1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9ICh7IG9uQ2xpY2ssIHNpemUgfSkgPT4gKFxuICA8QWN0aW9uQnV0dG9uV3JhcHBlciBzaXplPXtzaXplfT5cbiAgICA8RmllbGRDbGVhckJ1dHRvbiBvbkNsaWNrPXtvbkNsaWNrfSAvPlxuICA8L0FjdGlvbkJ1dHRvbldyYXBwZXI+XG4pO1xuXG5leHBvcnQgY29uc3QgVGV4dElucHV0TGFiZWwgPSAoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSkgPT4gKFxuICA8RmllbGRMYWJlbCB7Li4ucHJvcHN9PntjaGlsZHJlbn08L0ZpZWxkTGFiZWw+XG4pO1xuXG5leHBvcnQgY29uc3QgVGV4dElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHZhbHVlLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICBsYWJlbCxcbiAgICAgIGlkLFxuICAgICAgaWNvbixcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgZXJyb3JNZXNzYWdlLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICB0eXBlID0gJ3RleHQnLFxuICAgICAgaGludCxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgICBzaXplID0gJ20nLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgW2ludGVybmFsVHlwZSwgc2V0SW50ZXJuYWxUeXBlXSA9IFJlYWN0LnVzZVN0YXRlKHR5cGUpO1xuXG4gICAgY29uc3QgaWNvbldpZHRoID0gaWNvbj8udHlwZT8udmlld0JveFdpZHRoIC8gMiB8fCAxNjtcbiAgICBjb25zdCBoYXNWaXNpYmlsaXR5QnV0dG9uID0gdHlwZSA9PT0gJ3Bhc3N3b3JkJyAmJiAhaXNSZWFkT25seSAmJiAhaXNEaXNhYmxlZDtcbiAgICBjb25zdCBoYXNDbGVhckJ1dHRvbiA9IG9uQ2xlYXIgJiYgIWlzUmVhZE9ubHkgJiYgIWlzRGlzYWJsZWQ7XG4gICAgY29uc3QgaGFzQnV0dG9uID0gaGFzVmlzaWJpbGl0eUJ1dHRvbiB8fCBoYXNDbGVhckJ1dHRvbjtcbiAgICBjb25zdCBwYWRkaW5nTGVmdCA9IGljb24gPyBgY2FsYygke2ljb25PZmZzZXR9ICsgJHtpY29uV2lkdGh9cHggKyAke2ljb25UZXh0R2FwfSlgIDogdW5kZWZpbmVkO1xuICAgIGNvbnN0IHBhZGRpbmdSaWdodCA9IGhhc0J1dHRvbiA/IGB2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtJHtzaXplfSlgIDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgZmllbGRNYXJnaW5Ub3AgPSBsYWJlbCB8fCBoaW50ID8gJ3ZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKScgOiB1bmRlZmluZWQ7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdj5cbiAgICAgICAge2xhYmVsICYmIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfT57bGFiZWx9PC9GaWVsZExhYmVsPn1cbiAgICAgICAge2hpbnQgJiYgPEZpZWxkSGludD57aGludH08L0ZpZWxkSGludD59XG4gICAgICAgIDxCb3ggcG9zaXRpb249XCJyZWxhdGl2ZVwiIG1hcmdpblRvcD17ZmllbGRNYXJnaW5Ub3B9PlxuICAgICAgICAgIHtpY29uICYmIChcbiAgICAgICAgICAgIDxJY29uU2VjdGlvbj5cbiAgICAgICAgICAgICAgPEljb24gaWNvbj17aWNvbn0gLz5cbiAgICAgICAgICAgIDwvSWNvblNlY3Rpb24+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8SW5wdXRGaWVsZFxuICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICB0eXBlPXtpbnRlcm5hbFR5cGV9XG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgICBwbGFjZWhvbGRlcj17cGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICBwYWRkaW5nTGVmdD17cGFkZGluZ0xlZnR9XG4gICAgICAgICAgICBwYWRkaW5nUmlnaHQ9e3BhZGRpbmdSaWdodH1cbiAgICAgICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgICAgIGlzUmVhZE9ubHk9e2lzUmVhZE9ubHl9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2hhc1Zpc2liaWxpdHlCdXR0b24gJiYgKFxuICAgICAgICAgICAgPFZpc2liaWxpdHlCdXR0b25cbiAgICAgICAgICAgICAgc2V0SW50ZXJuYWxUeXBlPXtzZXRJbnRlcm5hbFR5cGV9XG4gICAgICAgICAgICAgIGludGVybmFsVHlwZT17aW50ZXJuYWxUeXBlfVxuICAgICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtoYXNDbGVhckJ1dHRvbiAmJiB2YWx1ZSAmJiA8Q2xlYXJCdXR0b24gb25DbGljaz17b25DbGVhcn0gc2l6ZT17c2l6ZX0gLz59XG4gICAgICAgIDwvQm94PlxuICAgICAgICB7ZXJyb3JNZXNzYWdlICYmIChcbiAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKVwiPlxuICAgICAgICAgICAgPFRleHQgY29sb3I9XCJkYW5nZXJcIj57ZXJyb3JNZXNzYWdlfTwvVGV4dD5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH0sXG4pO1xuXG5UZXh0SW5wdXQuTGFiZWwgPSBUZXh0SW5wdXRMYWJlbDtcblRleHRJbnB1dC5IaW50ID0gRmllbGRIaW50O1xuXG5UZXh0SW5wdXQucHJvcFR5cGVzID0ge1xuICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBwbGFjZWhvbGRlcjogUHJvcFR5cGVzLnN0cmluZyxcbiAgdmFsdWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5udW1iZXJdKSxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBpY29uOiBQcm9wVHlwZXMubm9kZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBlcnJvck1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlzUmVhZE9ubHk6IFByb3BUeXBlcy5ib29sLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgdHlwZTogdHlwZXMudGV4dElucHV0LFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBiYWNrZ3JvdW5kQ29sb3I6IHR5cGVzLmNvbG9yLFxuICBvbkNsZWFyOiBQcm9wVHlwZXMuZnVuYyxcbiAgc2l6ZTogUHJvcFR5cGVzLm9uZU9mKFsnbScsICdsJ10pLFxufTtcbiJdfQ== */"));
|
|
31
31
|
|
|
32
32
|
const ActionButtonWrapper = _ref => {
|
|
33
33
|
let {
|
|
34
|
-
children
|
|
34
|
+
children,
|
|
35
|
+
size
|
|
35
36
|
} = _ref;
|
|
36
|
-
const rightOffset = "calc((var(--grn-textbox-height-
|
|
37
|
+
const rightOffset = "calc((var(--grn-textbox-height-".concat(size, ") - var(--grn-clearbutton-height)) / 2)");
|
|
37
38
|
return ___EmotionJSX(Box, {
|
|
38
39
|
position: "absolute",
|
|
39
40
|
right: rightOffset,
|
|
@@ -48,7 +49,8 @@ const VisibilityButton = _ref2 => {
|
|
|
48
49
|
let {
|
|
49
50
|
children,
|
|
50
51
|
internalType,
|
|
51
|
-
setInternalType
|
|
52
|
+
setInternalType,
|
|
53
|
+
size
|
|
52
54
|
} = _ref2,
|
|
53
55
|
props = _objectWithoutProperties(_ref2, _excluded);
|
|
54
56
|
|
|
@@ -56,7 +58,9 @@ const VisibilityButton = _ref2 => {
|
|
|
56
58
|
password: ___EmotionJSX(IconShow, null),
|
|
57
59
|
text: ___EmotionJSX(IconHide, null)
|
|
58
60
|
};
|
|
59
|
-
return ___EmotionJSX(ActionButtonWrapper,
|
|
61
|
+
return ___EmotionJSX(ActionButtonWrapper, {
|
|
62
|
+
size: size
|
|
63
|
+
}, ___EmotionJSX(IconButton, _extends({}, props, {
|
|
60
64
|
icon: typeAndIconMap[internalType],
|
|
61
65
|
onClick: () => setInternalType(internalType === 'text' ? 'password' : 'text')
|
|
62
66
|
})));
|
|
@@ -64,9 +68,12 @@ const VisibilityButton = _ref2 => {
|
|
|
64
68
|
|
|
65
69
|
const ClearButton = _ref3 => {
|
|
66
70
|
let {
|
|
67
|
-
onClick
|
|
71
|
+
onClick,
|
|
72
|
+
size
|
|
68
73
|
} = _ref3;
|
|
69
|
-
return ___EmotionJSX(ActionButtonWrapper,
|
|
74
|
+
return ___EmotionJSX(ActionButtonWrapper, {
|
|
75
|
+
size: size
|
|
76
|
+
}, ___EmotionJSX(FieldClearButton, {
|
|
70
77
|
onClick: onClick
|
|
71
78
|
}));
|
|
72
79
|
};
|
|
@@ -95,7 +102,8 @@ export const TextInput = /*#__PURE__*/React.forwardRef((_ref5, ref) => {
|
|
|
95
102
|
type = 'text',
|
|
96
103
|
hint,
|
|
97
104
|
onClear,
|
|
98
|
-
backgroundColor
|
|
105
|
+
backgroundColor,
|
|
106
|
+
size = 'm'
|
|
99
107
|
} = _ref5,
|
|
100
108
|
props = _objectWithoutProperties(_ref5, _excluded3);
|
|
101
109
|
|
|
@@ -105,7 +113,7 @@ export const TextInput = /*#__PURE__*/React.forwardRef((_ref5, ref) => {
|
|
|
105
113
|
const hasClearButton = onClear && !isReadOnly && !isDisabled;
|
|
106
114
|
const hasButton = hasVisibilityButton || hasClearButton;
|
|
107
115
|
const paddingLeft = icon ? "calc(".concat(iconOffset, " + ").concat(iconWidth, "px + ").concat(iconTextGap, ")") : undefined;
|
|
108
|
-
const paddingRight = hasButton ?
|
|
116
|
+
const paddingRight = hasButton ? "var(--grn-textbox-height-".concat(size, ")") : undefined;
|
|
109
117
|
const fieldMarginTop = label || hint ? 'var(--grn-form-control-label-gap)' : undefined;
|
|
110
118
|
return ___EmotionJSX("div", null, label && ___EmotionJSX(FieldLabel, {
|
|
111
119
|
htmlFor: id
|
|
@@ -125,12 +133,15 @@ export const TextInput = /*#__PURE__*/React.forwardRef((_ref5, ref) => {
|
|
|
125
133
|
hasError: hasError,
|
|
126
134
|
isReadOnly: isReadOnly,
|
|
127
135
|
isDisabled: isDisabled,
|
|
128
|
-
backgroundColor: backgroundColor
|
|
136
|
+
backgroundColor: backgroundColor,
|
|
137
|
+
size: size
|
|
129
138
|
}, props)), hasVisibilityButton && ___EmotionJSX(VisibilityButton, {
|
|
130
139
|
setInternalType: setInternalType,
|
|
131
|
-
internalType: internalType
|
|
140
|
+
internalType: internalType,
|
|
141
|
+
size: size
|
|
132
142
|
}), hasClearButton && value && ___EmotionJSX(ClearButton, {
|
|
133
|
-
onClick: onClear
|
|
143
|
+
onClick: onClear,
|
|
144
|
+
size: size
|
|
134
145
|
})), errorMessage && ___EmotionJSX(Box, {
|
|
135
146
|
marginTop: "var(--grn-form-control-label-gap)"
|
|
136
147
|
}, ___EmotionJSX(Text, {
|
|
@@ -152,5 +163,6 @@ TextInput.propTypes = {
|
|
|
152
163
|
type: types.textInput,
|
|
153
164
|
hint: types.hint,
|
|
154
165
|
backgroundColor: types.color,
|
|
155
|
-
onClear: PropTypes.func
|
|
166
|
+
onClear: PropTypes.func,
|
|
167
|
+
size: PropTypes.oneOf(['m', 'l'])
|
|
156
168
|
};
|