@ultraviolet/ui 1.85.2 → 1.86.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/dist/components/Badge/index.cjs +1 -1
- package/dist/components/Badge/index.d.ts +1 -0
- package/dist/components/Badge/index.js +1 -1
- package/dist/components/DateInput/Context.cjs +3 -1
- package/dist/components/DateInput/Context.d.ts +3 -0
- package/dist/components/DateInput/Context.js +3 -1
- package/dist/components/DateInput/components/CalendarContent.cjs +77 -0
- package/dist/components/DateInput/components/CalendarContent.d.ts +1 -0
- package/dist/components/DateInput/components/CalendarContent.js +75 -0
- package/dist/components/DateInput/components/CalendarDaily.cjs +51 -41
- package/dist/components/DateInput/components/CalendarDaily.d.ts +1 -3
- package/dist/components/DateInput/components/CalendarDaily.js +51 -41
- package/dist/components/DateInput/components/CalendarMonthly.cjs +48 -56
- package/dist/components/DateInput/components/CalendarMonthly.d.ts +1 -3
- package/dist/components/DateInput/components/CalendarMonthly.js +46 -54
- package/dist/components/DateInput/components/Popup.cjs +8 -80
- package/dist/components/DateInput/components/Popup.d.ts +2 -1
- package/dist/components/DateInput/components/Popup.js +9 -81
- package/dist/components/DateInput/constants.cjs +0 -4
- package/dist/components/DateInput/constants.d.ts +0 -2
- package/dist/components/DateInput/constants.js +0 -4
- package/dist/components/DateInput/helpers.cjs +11 -4
- package/dist/components/DateInput/helpers.d.ts +5 -3
- package/dist/components/DateInput/helpers.js +12 -5
- package/dist/components/DateInput/index.cjs +30 -7
- package/dist/components/DateInput/index.d.ts +5 -1
- package/dist/components/DateInput/index.js +31 -8
- package/dist/components/Link/index.cjs +23 -11
- package/dist/components/Link/index.js +23 -11
- package/dist/components/List/Row.cjs +21 -9
- package/dist/components/List/Row.d.ts +4 -1
- package/dist/components/List/Row.js +22 -10
- package/dist/components/List/index.d.ts +1 -0
- package/dist/components/Separator/index.cjs +21 -22
- package/dist/components/Separator/index.d.ts +10 -2
- package/dist/components/Separator/index.js +21 -22
- package/dist/components/Table/Cell.cjs +1 -1
- package/dist/components/Table/Cell.d.ts +2 -2
- package/dist/components/Table/Cell.js +1 -1
- package/dist/components/Table/index.d.ts +1 -1
- package/package.json +2 -2
|
@@ -77,7 +77,7 @@ const StyledSpan = /* @__PURE__ */ _styled__default.default(index.Text, process.
|
|
|
77
77
|
theme
|
|
78
78
|
}) => theme.sizing[SIZES[size]], ";text-transform:uppercase;", ({
|
|
79
79
|
sentimentStyles
|
|
80
|
-
}) => sentimentStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0JhZGdlL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRkUiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvQmFkZ2UvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcbmltcG9ydCB7IFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgSWNvbk5hbWUgPSBDb21wb25lbnRQcm9wczx0eXBlb2YgSWNvbj5bJ25hbWUnXVxuXG5leHBvcnQgY29uc3QgU0laRVMgPSB7XG4gIGxhcmdlOiAnNDAwJywgLy8gc2l6aW5nIHRva2VuIGZyb20gdGhlbWVcbiAgbWVkaXVtOiAnMzAwJyxcbiAgc21hbGw6ICcyMDAnLFxufSBhcyBjb25zdFxuXG5leHBvcnQgY29uc3QgUFJPTUlORU5DRVMgPSB7XG4gIGRlZmF1bHQ6ICdkZWZhdWx0JyxcbiAgc3Ryb25nOiAnc3Ryb25nJyxcbn1cblxuZXhwb3J0IGNvbnN0IFRFWFRfVkFSSUFOVCA9IHtcbiAgbGFyZ2U6ICdib2R5U21hbGwnLFxuICBtZWRpdW06ICdjYXB0aW9uJyxcbiAgc21hbGw6ICdjYXB0aW9uU21hbGwnLFxufSBhcyBjb25zdFxuXG4vKipcbiAqIEdlbmVyYXRlIGFsbCBzdHlsZXMgYXZhaWxhYmxlIGZvciBiYWRnZSBiYXNlZCBvbiBwcm9taW5lbmNlIGFuZCBzZW50aW1lbnRzXG4gKi9cbmNvbnN0IGdlbmVyYXRlU3R5bGVzID0gKHtcbiAgcHJvbWluZW5jZSxcbiAgdGhlbWUsXG59OiB7XG4gIHByb21pbmVuY2U6IHN0cmluZ1xuICB0aGVtZTogVGhlbWVcbn0pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBkaXNhYmxlZDogYFxuICAgICAgY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFdlYWt9O1xuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAgIGJvcmRlcjogbm9uZTtcbiAgICBgLFxuICAgIG5ldXRyYWw6IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICBwcm9taW5lbmNlID09PSBQUk9NSU5FTkNFUy5zdHJvbmdcbiAgICAgICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmdlclxuICAgICAgICAgIDogdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFxuICAgICAgfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ2VyXG4gICAgICAgICAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha1xuICAgICAgfTtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyU3Ryb25nZXJcbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlclxuICAgICAgfTtcbiAgICBgLFxuICB9XG59XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ3NlbnRpbWVudFN0eWxlcycsICdzaXplJywgJ2ZvbnRTaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNpemU6IGtleW9mIHR5cGVvZiBTSVpFU1xuICBzZW50aW1lbnRTdHlsZXM6IHN0cmluZ1xufT5gXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS54bGFyZ2V9O1xuICBwYWRkaW5nOiAwXG4gICAgJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PiB7XG4gICAgICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykgcmV0dXJuIHRoZW1lLnNwYWNlWycxJ11cbiAgICAgIGlmIChzaXplID09PSAnbGFyZ2UnKSByZXR1cm4gdGhlbWUuc3BhY2VbJzInXVxuXG4gICAgICByZXR1cm4gdGhlbWUuc3BhY2VbJzEuNSddXG4gICAgfX07XG4gIGdhcDogJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PlxuICAgIHNpemUgPT09ICdzbWFsbCcgPyB0aGVtZS5zcGFjZVsnMC41J10gOiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgd2lkdGg6IGZpdC1jb250ZW50O1xuICBoZWlnaHQ6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nW1NJWkVTW3NpemVdXX07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gICR7KHsgc2VudGltZW50U3R5bGVzIH0pID0+IHNlbnRpbWVudFN0eWxlc31cbmBcblxudHlwZSBCYWRnZVByb3BzID0ge1xuICBzZW50aW1lbnQ/OiBDb2xvclxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIHByb21pbmVuY2U/
|
|
80
|
+
}) => sentimentStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0JhZGdlL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRkUiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvQmFkZ2UvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcbmltcG9ydCB7IFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgSWNvbk5hbWUgPSBDb21wb25lbnRQcm9wczx0eXBlb2YgSWNvbj5bJ25hbWUnXVxuXG5leHBvcnQgY29uc3QgU0laRVMgPSB7XG4gIGxhcmdlOiAnNDAwJywgLy8gc2l6aW5nIHRva2VuIGZyb20gdGhlbWVcbiAgbWVkaXVtOiAnMzAwJyxcbiAgc21hbGw6ICcyMDAnLFxufSBhcyBjb25zdFxuXG5leHBvcnQgY29uc3QgUFJPTUlORU5DRVMgPSB7XG4gIGRlZmF1bHQ6ICdkZWZhdWx0JyxcbiAgc3Ryb25nOiAnc3Ryb25nJyxcbn1cblxuZXhwb3J0IGNvbnN0IFRFWFRfVkFSSUFOVCA9IHtcbiAgbGFyZ2U6ICdib2R5U21hbGwnLFxuICBtZWRpdW06ICdjYXB0aW9uJyxcbiAgc21hbGw6ICdjYXB0aW9uU21hbGwnLFxufSBhcyBjb25zdFxuXG4vKipcbiAqIEdlbmVyYXRlIGFsbCBzdHlsZXMgYXZhaWxhYmxlIGZvciBiYWRnZSBiYXNlZCBvbiBwcm9taW5lbmNlIGFuZCBzZW50aW1lbnRzXG4gKi9cbmNvbnN0IGdlbmVyYXRlU3R5bGVzID0gKHtcbiAgcHJvbWluZW5jZSxcbiAgdGhlbWUsXG59OiB7XG4gIHByb21pbmVuY2U6IHN0cmluZ1xuICB0aGVtZTogVGhlbWVcbn0pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBkaXNhYmxlZDogYFxuICAgICAgY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFdlYWt9O1xuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAgIGJvcmRlcjogbm9uZTtcbiAgICBgLFxuICAgIG5ldXRyYWw6IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICBwcm9taW5lbmNlID09PSBQUk9NSU5FTkNFUy5zdHJvbmdcbiAgICAgICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmdlclxuICAgICAgICAgIDogdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFxuICAgICAgfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ2VyXG4gICAgICAgICAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha1xuICAgICAgfTtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyU3Ryb25nZXJcbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlclxuICAgICAgfTtcbiAgICBgLFxuICB9XG59XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ3NlbnRpbWVudFN0eWxlcycsICdzaXplJywgJ2ZvbnRTaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNpemU6IGtleW9mIHR5cGVvZiBTSVpFU1xuICBzZW50aW1lbnRTdHlsZXM6IHN0cmluZ1xufT5gXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS54bGFyZ2V9O1xuICBwYWRkaW5nOiAwXG4gICAgJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PiB7XG4gICAgICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykgcmV0dXJuIHRoZW1lLnNwYWNlWycxJ11cbiAgICAgIGlmIChzaXplID09PSAnbGFyZ2UnKSByZXR1cm4gdGhlbWUuc3BhY2VbJzInXVxuXG4gICAgICByZXR1cm4gdGhlbWUuc3BhY2VbJzEuNSddXG4gICAgfX07XG4gIGdhcDogJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PlxuICAgIHNpemUgPT09ICdzbWFsbCcgPyB0aGVtZS5zcGFjZVsnMC41J10gOiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgd2lkdGg6IGZpdC1jb250ZW50O1xuICBoZWlnaHQ6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nW1NJWkVTW3NpemVdXX07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gICR7KHsgc2VudGltZW50U3R5bGVzIH0pID0+IHNlbnRpbWVudFN0eWxlc31cbmBcblxudHlwZSBCYWRnZVByb3BzID0ge1xuICBzZW50aW1lbnQ/OiBDb2xvclxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIHByb21pbmVuY2U/OiBrZXlvZiB0eXBlb2YgUFJPTUlORU5DRVNcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkOiBVc2UgdGhlIGljb24gZGlyZWN0bHkgaW4gY2hpbGRyZW5cbiAgICogRGVmaW5lcyBpY29uIHRvIGRpc3BsYXkgb24gbGVmdCBzaWRlIG9mIGJhZGdlLiAqKk9ubHkgYXZhaWxhYmxlIG9uIG1lZGl1bSBhbmQgbGFyZ2Ugc2l6ZXMqKi5cbiAgICovXG4gIGljb24/OiBJY29uTmFtZVxuICBkaXNhYmxlZD86IGJvb2xlYW5cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xufVxuXG4vKipcbiAqIEJhZGdlIGNvbXBvbmVudCBpcyB1c2VkIHRvIGRpc3BsYXkgYSBzdGF0dXMgb3IgYSBsYWJlbCBpbiBhIHNtYWxsIGNvbnRhaW5lci5cbiAqL1xuZXhwb3J0IGNvbnN0IEJhZGdlID0gKHtcbiAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICBzaXplID0gJ21lZGl1bScsXG4gIHByb21pbmVuY2UgPSAnZGVmYXVsdCcsXG4gIGljb24sXG4gIGRpc2FibGVkID0gZmFsc2UsXG4gIGNsYXNzTmFtZSxcbiAgY2hpbGRyZW4sXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBCYWRnZVByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuXG4gIC8qKlxuICAgKiBCYWRnZSBzaG91bGQgZGlzcGxheSBhbiBhcmlhLWxhYmVsIGlmIHRoZSBzdGF0dXMgaXMgbm90IG5ldXRyYWwgb3IgcHJpbWFyeVxuICAgKi9cbiAgY29uc3QgYXJpYUxhYmVsID0gdXNlTWVtbyhcbiAgICAoKSA9PlxuICAgICAgWyduZXV0cmFsJywgJ3ByaW1hcnknXS5zb21lKGJhc2VTZW50aW1lbnQgPT4gYmFzZVNlbnRpbWVudCA9PT0gc2VudGltZW50KVxuICAgICAgICA/IHVuZGVmaW5lZFxuICAgICAgICA6IHNlbnRpbWVudCxcbiAgICBbc2VudGltZW50XSxcbiAgKVxuXG4gIGNvbnN0IGdlbmVyYXRlZFN0eWxlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gZ2VuZXJhdGVTdHlsZXMoeyBwcm9taW5lbmNlLCB0aGVtZSB9KSxcbiAgICBbcHJvbWluZW5jZSwgdGhlbWVdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkU3BhblxuICAgICAgYXJpYS1sYWJlbD17YXJpYUxhYmVsfVxuICAgICAgc2VudGltZW50U3R5bGVzPXtcbiAgICAgICAgZGlzYWJsZWQgPyBnZW5lcmF0ZWRTdHlsZXNbJ2Rpc2FibGVkJ10gOiBnZW5lcmF0ZWRTdHlsZXNbc2VudGltZW50XVxuICAgICAgfVxuICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgIHZhcmlhbnQ9e1RFWFRfVkFSSUFOVFtzaXplXX1cbiAgICAgIGFzPVwic3BhblwiXG4gICAgICBwcm9taW5lbmNlPXtkaXNhYmxlZCA/ICd3ZWFrJyA6ICdkZWZhdWx0J31cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICB3aGl0ZVNwYWNlPVwibm93cmFwXCJcbiAgICA+XG4gICAgICB7aWNvbiAmJiBzaXplICE9PSAnc21hbGwnID8gPEljb24gbmFtZT17aWNvbn0gc2l6ZT17MTZ9IC8+IDogbnVsbH1cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZFNwYW4+XG4gIClcbn1cbiJdfQ== */"));
|
|
81
81
|
const Badge = ({
|
|
82
82
|
sentiment = "neutral",
|
|
83
83
|
size = "medium",
|
|
@@ -21,6 +21,7 @@ type BadgeProps = {
|
|
|
21
21
|
size?: keyof typeof SIZES;
|
|
22
22
|
prominence?: keyof typeof PROMINENCES;
|
|
23
23
|
/**
|
|
24
|
+
* @deprecated: Use the icon directly in children
|
|
24
25
|
* Defines icon to display on left side of badge. **Only available on medium and large sizes**.
|
|
25
26
|
*/
|
|
26
27
|
icon?: IconName;
|
|
@@ -73,7 +73,7 @@ const StyledSpan = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
|
|
|
73
73
|
theme
|
|
74
74
|
}) => theme.sizing[SIZES[size]], ";text-transform:uppercase;", ({
|
|
75
75
|
sentimentStyles
|
|
76
|
-
}) => sentimentStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0JhZGdlL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRkUiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvQmFkZ2UvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcbmltcG9ydCB7IFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgSWNvbk5hbWUgPSBDb21wb25lbnRQcm9wczx0eXBlb2YgSWNvbj5bJ25hbWUnXVxuXG5leHBvcnQgY29uc3QgU0laRVMgPSB7XG4gIGxhcmdlOiAnNDAwJywgLy8gc2l6aW5nIHRva2VuIGZyb20gdGhlbWVcbiAgbWVkaXVtOiAnMzAwJyxcbiAgc21hbGw6ICcyMDAnLFxufSBhcyBjb25zdFxuXG5leHBvcnQgY29uc3QgUFJPTUlORU5DRVMgPSB7XG4gIGRlZmF1bHQ6ICdkZWZhdWx0JyxcbiAgc3Ryb25nOiAnc3Ryb25nJyxcbn1cblxuZXhwb3J0IGNvbnN0IFRFWFRfVkFSSUFOVCA9IHtcbiAgbGFyZ2U6ICdib2R5U21hbGwnLFxuICBtZWRpdW06ICdjYXB0aW9uJyxcbiAgc21hbGw6ICdjYXB0aW9uU21hbGwnLFxufSBhcyBjb25zdFxuXG4vKipcbiAqIEdlbmVyYXRlIGFsbCBzdHlsZXMgYXZhaWxhYmxlIGZvciBiYWRnZSBiYXNlZCBvbiBwcm9taW5lbmNlIGFuZCBzZW50aW1lbnRzXG4gKi9cbmNvbnN0IGdlbmVyYXRlU3R5bGVzID0gKHtcbiAgcHJvbWluZW5jZSxcbiAgdGhlbWUsXG59OiB7XG4gIHByb21pbmVuY2U6IHN0cmluZ1xuICB0aGVtZTogVGhlbWVcbn0pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBkaXNhYmxlZDogYFxuICAgICAgY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFdlYWt9O1xuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAgIGJvcmRlcjogbm9uZTtcbiAgICBgLFxuICAgIG5ldXRyYWw6IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICBwcm9taW5lbmNlID09PSBQUk9NSU5FTkNFUy5zdHJvbmdcbiAgICAgICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmdlclxuICAgICAgICAgIDogdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFxuICAgICAgfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ2VyXG4gICAgICAgICAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha1xuICAgICAgfTtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyU3Ryb25nZXJcbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlclxuICAgICAgfTtcbiAgICBgLFxuICB9XG59XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ3NlbnRpbWVudFN0eWxlcycsICdzaXplJywgJ2ZvbnRTaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNpemU6IGtleW9mIHR5cGVvZiBTSVpFU1xuICBzZW50aW1lbnRTdHlsZXM6IHN0cmluZ1xufT5gXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS54bGFyZ2V9O1xuICBwYWRkaW5nOiAwXG4gICAgJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PiB7XG4gICAgICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykgcmV0dXJuIHRoZW1lLnNwYWNlWycxJ11cbiAgICAgIGlmIChzaXplID09PSAnbGFyZ2UnKSByZXR1cm4gdGhlbWUuc3BhY2VbJzInXVxuXG4gICAgICByZXR1cm4gdGhlbWUuc3BhY2VbJzEuNSddXG4gICAgfX07XG4gIGdhcDogJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PlxuICAgIHNpemUgPT09ICdzbWFsbCcgPyB0aGVtZS5zcGFjZVsnMC41J10gOiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgd2lkdGg6IGZpdC1jb250ZW50O1xuICBoZWlnaHQ6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nW1NJWkVTW3NpemVdXX07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gICR7KHsgc2VudGltZW50U3R5bGVzIH0pID0+IHNlbnRpbWVudFN0eWxlc31cbmBcblxudHlwZSBCYWRnZVByb3BzID0ge1xuICBzZW50aW1lbnQ/OiBDb2xvclxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIHByb21pbmVuY2U/
|
|
76
|
+
}) => sentimentStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0JhZGdlL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRkUiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvQmFkZ2UvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcbmltcG9ydCB7IFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgSWNvbk5hbWUgPSBDb21wb25lbnRQcm9wczx0eXBlb2YgSWNvbj5bJ25hbWUnXVxuXG5leHBvcnQgY29uc3QgU0laRVMgPSB7XG4gIGxhcmdlOiAnNDAwJywgLy8gc2l6aW5nIHRva2VuIGZyb20gdGhlbWVcbiAgbWVkaXVtOiAnMzAwJyxcbiAgc21hbGw6ICcyMDAnLFxufSBhcyBjb25zdFxuXG5leHBvcnQgY29uc3QgUFJPTUlORU5DRVMgPSB7XG4gIGRlZmF1bHQ6ICdkZWZhdWx0JyxcbiAgc3Ryb25nOiAnc3Ryb25nJyxcbn1cblxuZXhwb3J0IGNvbnN0IFRFWFRfVkFSSUFOVCA9IHtcbiAgbGFyZ2U6ICdib2R5U21hbGwnLFxuICBtZWRpdW06ICdjYXB0aW9uJyxcbiAgc21hbGw6ICdjYXB0aW9uU21hbGwnLFxufSBhcyBjb25zdFxuXG4vKipcbiAqIEdlbmVyYXRlIGFsbCBzdHlsZXMgYXZhaWxhYmxlIGZvciBiYWRnZSBiYXNlZCBvbiBwcm9taW5lbmNlIGFuZCBzZW50aW1lbnRzXG4gKi9cbmNvbnN0IGdlbmVyYXRlU3R5bGVzID0gKHtcbiAgcHJvbWluZW5jZSxcbiAgdGhlbWUsXG59OiB7XG4gIHByb21pbmVuY2U6IHN0cmluZ1xuICB0aGVtZTogVGhlbWVcbn0pOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBkaXNhYmxlZDogYFxuICAgICAgY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFdlYWt9O1xuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAgIGJvcmRlcjogbm9uZTtcbiAgICBgLFxuICAgIG5ldXRyYWw6IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICBwcm9taW5lbmNlID09PSBQUk9NSU5FTkNFUy5zdHJvbmdcbiAgICAgICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmdlclxuICAgICAgICAgIDogdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFxuICAgICAgfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ2VyXG4gICAgICAgICAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha1xuICAgICAgfTtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICR7XG4gICAgICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZ1xuICAgICAgICAgID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyU3Ryb25nZXJcbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlclxuICAgICAgfTtcbiAgICBgLFxuICB9XG59XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ3NlbnRpbWVudFN0eWxlcycsICdzaXplJywgJ2ZvbnRTaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNpemU6IGtleW9mIHR5cGVvZiBTSVpFU1xuICBzZW50aW1lbnRTdHlsZXM6IHN0cmluZ1xufT5gXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS54bGFyZ2V9O1xuICBwYWRkaW5nOiAwXG4gICAgJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PiB7XG4gICAgICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykgcmV0dXJuIHRoZW1lLnNwYWNlWycxJ11cbiAgICAgIGlmIChzaXplID09PSAnbGFyZ2UnKSByZXR1cm4gdGhlbWUuc3BhY2VbJzInXVxuXG4gICAgICByZXR1cm4gdGhlbWUuc3BhY2VbJzEuNSddXG4gICAgfX07XG4gIGdhcDogJHsoeyB0aGVtZSwgc2l6ZSB9KSA9PlxuICAgIHNpemUgPT09ICdzbWFsbCcgPyB0aGVtZS5zcGFjZVsnMC41J10gOiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgd2lkdGg6IGZpdC1jb250ZW50O1xuICBoZWlnaHQ6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nW1NJWkVTW3NpemVdXX07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gICR7KHsgc2VudGltZW50U3R5bGVzIH0pID0+IHNlbnRpbWVudFN0eWxlc31cbmBcblxudHlwZSBCYWRnZVByb3BzID0ge1xuICBzZW50aW1lbnQ/OiBDb2xvclxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIHByb21pbmVuY2U/OiBrZXlvZiB0eXBlb2YgUFJPTUlORU5DRVNcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkOiBVc2UgdGhlIGljb24gZGlyZWN0bHkgaW4gY2hpbGRyZW5cbiAgICogRGVmaW5lcyBpY29uIHRvIGRpc3BsYXkgb24gbGVmdCBzaWRlIG9mIGJhZGdlLiAqKk9ubHkgYXZhaWxhYmxlIG9uIG1lZGl1bSBhbmQgbGFyZ2Ugc2l6ZXMqKi5cbiAgICovXG4gIGljb24/OiBJY29uTmFtZVxuICBkaXNhYmxlZD86IGJvb2xlYW5cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xufVxuXG4vKipcbiAqIEJhZGdlIGNvbXBvbmVudCBpcyB1c2VkIHRvIGRpc3BsYXkgYSBzdGF0dXMgb3IgYSBsYWJlbCBpbiBhIHNtYWxsIGNvbnRhaW5lci5cbiAqL1xuZXhwb3J0IGNvbnN0IEJhZGdlID0gKHtcbiAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICBzaXplID0gJ21lZGl1bScsXG4gIHByb21pbmVuY2UgPSAnZGVmYXVsdCcsXG4gIGljb24sXG4gIGRpc2FibGVkID0gZmFsc2UsXG4gIGNsYXNzTmFtZSxcbiAgY2hpbGRyZW4sXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBCYWRnZVByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuXG4gIC8qKlxuICAgKiBCYWRnZSBzaG91bGQgZGlzcGxheSBhbiBhcmlhLWxhYmVsIGlmIHRoZSBzdGF0dXMgaXMgbm90IG5ldXRyYWwgb3IgcHJpbWFyeVxuICAgKi9cbiAgY29uc3QgYXJpYUxhYmVsID0gdXNlTWVtbyhcbiAgICAoKSA9PlxuICAgICAgWyduZXV0cmFsJywgJ3ByaW1hcnknXS5zb21lKGJhc2VTZW50aW1lbnQgPT4gYmFzZVNlbnRpbWVudCA9PT0gc2VudGltZW50KVxuICAgICAgICA/IHVuZGVmaW5lZFxuICAgICAgICA6IHNlbnRpbWVudCxcbiAgICBbc2VudGltZW50XSxcbiAgKVxuXG4gIGNvbnN0IGdlbmVyYXRlZFN0eWxlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gZ2VuZXJhdGVTdHlsZXMoeyBwcm9taW5lbmNlLCB0aGVtZSB9KSxcbiAgICBbcHJvbWluZW5jZSwgdGhlbWVdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkU3BhblxuICAgICAgYXJpYS1sYWJlbD17YXJpYUxhYmVsfVxuICAgICAgc2VudGltZW50U3R5bGVzPXtcbiAgICAgICAgZGlzYWJsZWQgPyBnZW5lcmF0ZWRTdHlsZXNbJ2Rpc2FibGVkJ10gOiBnZW5lcmF0ZWRTdHlsZXNbc2VudGltZW50XVxuICAgICAgfVxuICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgIHZhcmlhbnQ9e1RFWFRfVkFSSUFOVFtzaXplXX1cbiAgICAgIGFzPVwic3BhblwiXG4gICAgICBwcm9taW5lbmNlPXtkaXNhYmxlZCA/ICd3ZWFrJyA6ICdkZWZhdWx0J31cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICB3aGl0ZVNwYWNlPVwibm93cmFwXCJcbiAgICA+XG4gICAgICB7aWNvbiAmJiBzaXplICE9PSAnc21hbGwnID8gPEljb24gbmFtZT17aWNvbn0gc2l6ZT17MTZ9IC8+IDogbnVsbH1cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZFNwYW4+XG4gIClcbn1cbiJdfQ== */"));
|
|
77
77
|
const Badge = ({
|
|
78
78
|
sentiment = "neutral",
|
|
79
79
|
size = "medium",
|
|
@@ -15,6 +15,8 @@ const DateInputContext = React.createContext({
|
|
|
15
15
|
DAYS: {},
|
|
16
16
|
MONTHS_ARR: [],
|
|
17
17
|
selectsRange: false,
|
|
18
|
-
setVisible: () => null
|
|
18
|
+
setVisible: () => null,
|
|
19
|
+
readOnly: false,
|
|
20
|
+
setHoveredDate: () => null
|
|
19
21
|
});
|
|
20
22
|
exports.DateInputContext = DateInputContext;
|
|
@@ -2,6 +2,7 @@ import type { Dispatch, SetStateAction } from 'react';
|
|
|
2
2
|
export type ContextProps = {
|
|
3
3
|
showMonthYearPicker?: boolean;
|
|
4
4
|
disabled: boolean;
|
|
5
|
+
readOnly: boolean;
|
|
5
6
|
/**
|
|
6
7
|
* month to show on popup - NOT selectedValue
|
|
7
8
|
*/
|
|
@@ -33,6 +34,8 @@ export type ContextProps = {
|
|
|
33
34
|
startDate?: Date | null;
|
|
34
35
|
endDate?: Date | null;
|
|
35
36
|
format?: (value?: Date) => string | undefined;
|
|
37
|
+
hoveredDate?: Date | null;
|
|
38
|
+
setHoveredDate: Dispatch<SetStateAction<Date | null>>;
|
|
36
39
|
} & ({
|
|
37
40
|
selectsRange: true;
|
|
38
41
|
onChange?: (date: [Date | null, Date | null], event: React.SyntheticEvent | undefined) => void;
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
4
|
+
const _styled = require("@emotion/styled/base");
|
|
5
|
+
const React = require("react");
|
|
6
|
+
const index$2 = require("../../Button/index.cjs");
|
|
7
|
+
const index$1 = require("../../Stack/index.cjs");
|
|
8
|
+
const index = require("../../Text/index.cjs");
|
|
9
|
+
const Context = require("../Context.cjs");
|
|
10
|
+
const helpers = require("../helpers.cjs");
|
|
11
|
+
const CalendarDaily = require("./CalendarDaily.cjs");
|
|
12
|
+
const CalendarMonthly = require("./CalendarMonthly.cjs");
|
|
13
|
+
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
14
|
+
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
15
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
16
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
17
|
+
}
|
|
18
|
+
const CapitalizedText = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
|
|
19
|
+
target: "e11qichn0"
|
|
20
|
+
} : {
|
|
21
|
+
target: "e11qichn0",
|
|
22
|
+
label: "CapitalizedText"
|
|
23
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
24
|
+
name: "kff9ir",
|
|
25
|
+
styles: "text-transform:capitalize"
|
|
26
|
+
} : {
|
|
27
|
+
name: "kff9ir",
|
|
28
|
+
styles: "text-transform:capitalize/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL0J1dHRvbidcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vVGV4dCdcbmltcG9ydCB7IERhdGVJbnB1dENvbnRleHQgfSBmcm9tICcuLi9Db250ZXh0J1xuaW1wb3J0IHsgZ2V0TmV4dE1vbnRoLCBnZXRQcmV2aW91c01vbnRoIH0gZnJvbSAnLi4vaGVscGVycydcbmltcG9ydCB7IERhaWx5IH0gZnJvbSAnLi9DYWxlbmRhckRhaWx5J1xuaW1wb3J0IHsgTW9udGhseSB9IGZyb20gJy4vQ2FsZW5kYXJNb250aGx5J1xuXG5jb25zdCBDYXBpdGFsaXplZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIHRleHQtdHJhbnNmb3JtOiBjYXBpdGFsaXplO1xuYFxuZXhwb3J0IGNvbnN0IENhbGVuZGFyQ29udGVudCA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIHNob3dNb250aFllYXJQaWNrZXIsXG4gICAgZGlzYWJsZWQsXG4gICAgbW9udGhUb1Nob3csXG4gICAgeWVhclRvU2hvdyxcbiAgICBzZXRNb250aFRvU2hvdyxcbiAgICBzZXRZZWFyVG9TaG93LFxuICAgIG1heERhdGUsXG4gICAgbWluRGF0ZSxcbiAgICBNT05USFNfQVJSLFxuICAgIHJlYWRPbmx5LFxuICB9ID0gdXNlQ29udGV4dChEYXRlSW5wdXRDb250ZXh0KVxuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIGdhcD17Mn0+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgd2lkdGg9XCIxMDAlXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICBpY29uPVwiYXJyb3ctbGVmdFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJwcmV2aW91cy1tb250aFwiXG4gICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICghbWluRGF0ZSB8fFxuICAgICAgICAgICAgICAgIG1pbkRhdGUgPD0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKSkgJiZcbiAgICAgICAgICAgICAgIXJlYWRPbmx5XG4gICAgICAgICAgICApIHtcbiAgICAgICAgICAgICAgaWYgKCFzaG93TW9udGhZZWFyUGlja2VyKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgW3ByZXZNb250aCwgeWVhcl0gPSBnZXRQcmV2aW91c01vbnRoKFxuICAgICAgICAgICAgICAgICAgbW9udGhUb1Nob3csXG4gICAgICAgICAgICAgICAgICB5ZWFyVG9TaG93LFxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICBzZXRNb250aFRvU2hvdyhwcmV2TW9udGgpXG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhclRvU2hvdyAtIDEpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIGRpc2FibGVkPXtcbiAgICAgICAgICAgICEhKG1pbkRhdGUgJiYgbWluRGF0ZSA+IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93IC0gMSwgMCkpIHx8XG4gICAgICAgICAgICBkaXNhYmxlZFxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgICAgPENhcGl0YWxpemVkVGV4dFxuICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgPlxuICAgICAgICAgIHshc2hvd01vbnRoWWVhclBpY2tlciA/IE1PTlRIU19BUlJbbW9udGhUb1Nob3cgLSAxXSA6IG51bGx9Jm5ic3A7XG4gICAgICAgICAge3llYXJUb1Nob3d9XG4gICAgICAgIDwvQ2FwaXRhbGl6ZWRUZXh0PlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LXJpZ2h0XCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD1cIm5leHQtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAoIW1heERhdGUgfHwgbWF4RGF0ZSA+PSBuZXcgRGF0ZSh5ZWFyVG9TaG93LCBtb250aFRvU2hvdywgMSkpICYmXG4gICAgICAgICAgICAgICFyZWFkT25seVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFttb250aE5leHQsIHllYXJdID0gZ2V0TmV4dE1vbnRoKG1vbnRoVG9TaG93LCB5ZWFyVG9TaG93KVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KG1vbnRoTmV4dClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93ICsgMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWF4RGF0ZSAmJiBtYXhEYXRlIDwgbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKSB8fFxuICAgICAgICAgICAgZGlzYWJsZWRcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L1N0YWNrPlxuICAgICAge3Nob3dNb250aFllYXJQaWNrZXIgPyA8TW9udGhseSAvPiA6IDxEYWlseSAvPn1cbiAgICA8L1N0YWNrPlxuICApXG59XG4iXX0= */",
|
|
29
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
30
|
+
});
|
|
31
|
+
const CalendarContent = () => {
|
|
32
|
+
const {
|
|
33
|
+
showMonthYearPicker,
|
|
34
|
+
disabled,
|
|
35
|
+
monthToShow,
|
|
36
|
+
yearToShow,
|
|
37
|
+
setMonthToShow,
|
|
38
|
+
setYearToShow,
|
|
39
|
+
maxDate,
|
|
40
|
+
minDate,
|
|
41
|
+
MONTHS_ARR,
|
|
42
|
+
readOnly
|
|
43
|
+
} = React.useContext(Context.DateInputContext);
|
|
44
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 2, children: [
|
|
45
|
+
/* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { direction: "row", width: "100%", justifyContent: "space-between", children: [
|
|
46
|
+
/* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { icon: "arrow-left", "data-testid": "previous-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
47
|
+
if ((!minDate || minDate <= new Date(yearToShow, monthToShow - 1, 0)) && !readOnly) {
|
|
48
|
+
if (!showMonthYearPicker) {
|
|
49
|
+
const [prevMonth, year] = helpers.getPreviousMonth(monthToShow, yearToShow);
|
|
50
|
+
setMonthToShow(prevMonth);
|
|
51
|
+
setYearToShow(year);
|
|
52
|
+
} else {
|
|
53
|
+
setYearToShow(yearToShow - 1);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}, disabled: !!(minDate && minDate > new Date(yearToShow, monthToShow - 1, 0)) || disabled }),
|
|
57
|
+
/* @__PURE__ */ jsxRuntime.jsxs(CapitalizedText, { as: "span", variant: "bodyStrong", sentiment: "neutral", disabled, children: [
|
|
58
|
+
!showMonthYearPicker ? MONTHS_ARR[monthToShow - 1] : null,
|
|
59
|
+
" ",
|
|
60
|
+
yearToShow
|
|
61
|
+
] }),
|
|
62
|
+
/* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { icon: "arrow-right", "data-testid": "next-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
63
|
+
if ((!maxDate || maxDate >= new Date(yearToShow, monthToShow, 1)) && !readOnly) {
|
|
64
|
+
if (!showMonthYearPicker) {
|
|
65
|
+
const [monthNext, year] = helpers.getNextMonth(monthToShow, yearToShow);
|
|
66
|
+
setMonthToShow(monthNext);
|
|
67
|
+
setYearToShow(year);
|
|
68
|
+
} else {
|
|
69
|
+
setYearToShow(yearToShow + 1);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}, disabled: !!(maxDate && maxDate < new Date(yearToShow, monthToShow, 1)) || disabled })
|
|
73
|
+
] }),
|
|
74
|
+
showMonthYearPicker ? /* @__PURE__ */ jsxRuntime.jsx(CalendarMonthly.Monthly, {}) : /* @__PURE__ */ jsxRuntime.jsx(CalendarDaily.Daily, {})
|
|
75
|
+
] });
|
|
76
|
+
};
|
|
77
|
+
exports.CalendarContent = CalendarContent;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const CalendarContent: () => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
|
+
import { useContext } from "react";
|
|
4
|
+
import { Button } from "../../Button/index.js";
|
|
5
|
+
import { Stack } from "../../Stack/index.js";
|
|
6
|
+
import { Text } from "../../Text/index.js";
|
|
7
|
+
import { DateInputContext } from "../Context.js";
|
|
8
|
+
import { getPreviousMonth, getNextMonth } from "../helpers.js";
|
|
9
|
+
import { Daily } from "./CalendarDaily.js";
|
|
10
|
+
import { Monthly } from "./CalendarMonthly.js";
|
|
11
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
12
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
13
|
+
}
|
|
14
|
+
const CapitalizedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
15
|
+
target: "e11qichn0"
|
|
16
|
+
} : {
|
|
17
|
+
target: "e11qichn0",
|
|
18
|
+
label: "CapitalizedText"
|
|
19
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
20
|
+
name: "kff9ir",
|
|
21
|
+
styles: "text-transform:capitalize"
|
|
22
|
+
} : {
|
|
23
|
+
name: "kff9ir",
|
|
24
|
+
styles: "text-transform:capitalize/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL0J1dHRvbidcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vVGV4dCdcbmltcG9ydCB7IERhdGVJbnB1dENvbnRleHQgfSBmcm9tICcuLi9Db250ZXh0J1xuaW1wb3J0IHsgZ2V0TmV4dE1vbnRoLCBnZXRQcmV2aW91c01vbnRoIH0gZnJvbSAnLi4vaGVscGVycydcbmltcG9ydCB7IERhaWx5IH0gZnJvbSAnLi9DYWxlbmRhckRhaWx5J1xuaW1wb3J0IHsgTW9udGhseSB9IGZyb20gJy4vQ2FsZW5kYXJNb250aGx5J1xuXG5jb25zdCBDYXBpdGFsaXplZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIHRleHQtdHJhbnNmb3JtOiBjYXBpdGFsaXplO1xuYFxuZXhwb3J0IGNvbnN0IENhbGVuZGFyQ29udGVudCA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIHNob3dNb250aFllYXJQaWNrZXIsXG4gICAgZGlzYWJsZWQsXG4gICAgbW9udGhUb1Nob3csXG4gICAgeWVhclRvU2hvdyxcbiAgICBzZXRNb250aFRvU2hvdyxcbiAgICBzZXRZZWFyVG9TaG93LFxuICAgIG1heERhdGUsXG4gICAgbWluRGF0ZSxcbiAgICBNT05USFNfQVJSLFxuICAgIHJlYWRPbmx5LFxuICB9ID0gdXNlQ29udGV4dChEYXRlSW5wdXRDb250ZXh0KVxuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIGdhcD17Mn0+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgd2lkdGg9XCIxMDAlXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICBpY29uPVwiYXJyb3ctbGVmdFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJwcmV2aW91cy1tb250aFwiXG4gICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICghbWluRGF0ZSB8fFxuICAgICAgICAgICAgICAgIG1pbkRhdGUgPD0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKSkgJiZcbiAgICAgICAgICAgICAgIXJlYWRPbmx5XG4gICAgICAgICAgICApIHtcbiAgICAgICAgICAgICAgaWYgKCFzaG93TW9udGhZZWFyUGlja2VyKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgW3ByZXZNb250aCwgeWVhcl0gPSBnZXRQcmV2aW91c01vbnRoKFxuICAgICAgICAgICAgICAgICAgbW9udGhUb1Nob3csXG4gICAgICAgICAgICAgICAgICB5ZWFyVG9TaG93LFxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICBzZXRNb250aFRvU2hvdyhwcmV2TW9udGgpXG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhclRvU2hvdyAtIDEpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIGRpc2FibGVkPXtcbiAgICAgICAgICAgICEhKG1pbkRhdGUgJiYgbWluRGF0ZSA+IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93IC0gMSwgMCkpIHx8XG4gICAgICAgICAgICBkaXNhYmxlZFxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgICAgPENhcGl0YWxpemVkVGV4dFxuICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgPlxuICAgICAgICAgIHshc2hvd01vbnRoWWVhclBpY2tlciA/IE1PTlRIU19BUlJbbW9udGhUb1Nob3cgLSAxXSA6IG51bGx9Jm5ic3A7XG4gICAgICAgICAge3llYXJUb1Nob3d9XG4gICAgICAgIDwvQ2FwaXRhbGl6ZWRUZXh0PlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LXJpZ2h0XCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD1cIm5leHQtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAoIW1heERhdGUgfHwgbWF4RGF0ZSA+PSBuZXcgRGF0ZSh5ZWFyVG9TaG93LCBtb250aFRvU2hvdywgMSkpICYmXG4gICAgICAgICAgICAgICFyZWFkT25seVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFttb250aE5leHQsIHllYXJdID0gZ2V0TmV4dE1vbnRoKG1vbnRoVG9TaG93LCB5ZWFyVG9TaG93KVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KG1vbnRoTmV4dClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93ICsgMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWF4RGF0ZSAmJiBtYXhEYXRlIDwgbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKSB8fFxuICAgICAgICAgICAgZGlzYWJsZWRcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L1N0YWNrPlxuICAgICAge3Nob3dNb250aFllYXJQaWNrZXIgPyA8TW9udGhseSAvPiA6IDxEYWlseSAvPn1cbiAgICA8L1N0YWNrPlxuICApXG59XG4iXX0= */",
|
|
25
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
26
|
+
});
|
|
27
|
+
const CalendarContent = () => {
|
|
28
|
+
const {
|
|
29
|
+
showMonthYearPicker,
|
|
30
|
+
disabled,
|
|
31
|
+
monthToShow,
|
|
32
|
+
yearToShow,
|
|
33
|
+
setMonthToShow,
|
|
34
|
+
setYearToShow,
|
|
35
|
+
maxDate,
|
|
36
|
+
minDate,
|
|
37
|
+
MONTHS_ARR,
|
|
38
|
+
readOnly
|
|
39
|
+
} = useContext(DateInputContext);
|
|
40
|
+
return /* @__PURE__ */ jsxs(Stack, { gap: 2, children: [
|
|
41
|
+
/* @__PURE__ */ jsxs(Stack, { direction: "row", width: "100%", justifyContent: "space-between", children: [
|
|
42
|
+
/* @__PURE__ */ jsx(Button, { icon: "arrow-left", "data-testid": "previous-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
43
|
+
if ((!minDate || minDate <= new Date(yearToShow, monthToShow - 1, 0)) && !readOnly) {
|
|
44
|
+
if (!showMonthYearPicker) {
|
|
45
|
+
const [prevMonth, year] = getPreviousMonth(monthToShow, yearToShow);
|
|
46
|
+
setMonthToShow(prevMonth);
|
|
47
|
+
setYearToShow(year);
|
|
48
|
+
} else {
|
|
49
|
+
setYearToShow(yearToShow - 1);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}, disabled: !!(minDate && minDate > new Date(yearToShow, monthToShow - 1, 0)) || disabled }),
|
|
53
|
+
/* @__PURE__ */ jsxs(CapitalizedText, { as: "span", variant: "bodyStrong", sentiment: "neutral", disabled, children: [
|
|
54
|
+
!showMonthYearPicker ? MONTHS_ARR[monthToShow - 1] : null,
|
|
55
|
+
" ",
|
|
56
|
+
yearToShow
|
|
57
|
+
] }),
|
|
58
|
+
/* @__PURE__ */ jsx(Button, { icon: "arrow-right", "data-testid": "next-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
59
|
+
if ((!maxDate || maxDate >= new Date(yearToShow, monthToShow, 1)) && !readOnly) {
|
|
60
|
+
if (!showMonthYearPicker) {
|
|
61
|
+
const [monthNext, year] = getNextMonth(monthToShow, yearToShow);
|
|
62
|
+
setMonthToShow(monthNext);
|
|
63
|
+
setYearToShow(year);
|
|
64
|
+
} else {
|
|
65
|
+
setYearToShow(yearToShow + 1);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}, disabled: !!(maxDate && maxDate < new Date(yearToShow, monthToShow, 1)) || disabled })
|
|
69
|
+
] }),
|
|
70
|
+
showMonthYearPicker ? /* @__PURE__ */ jsx(Monthly, {}) : /* @__PURE__ */ jsx(Daily, {})
|
|
71
|
+
] });
|
|
72
|
+
};
|
|
73
|
+
export {
|
|
74
|
+
CalendarContent
|
|
75
|
+
};
|
|
@@ -14,24 +14,28 @@ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
|
14
14
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
15
15
|
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
16
16
|
}
|
|
17
|
-
const
|
|
18
|
-
target: "e1ouebol2"
|
|
19
|
-
} : {
|
|
20
|
-
target: "e1ouebol2",
|
|
21
|
-
label: "ButtonDate"
|
|
22
|
-
})("height:", ({
|
|
23
|
-
theme
|
|
24
|
-
}) => theme.sizing["312"], ";width:100%;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAgBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = ({ disabled }: { disabled: boolean }) => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
25
|
-
const RangeButton = /* @__PURE__ */ _styled__default.default(index.Button, process.env.NODE_ENV === "production" ? {
|
|
17
|
+
const Day = /* @__PURE__ */ _styled__default.default(index.Button, process.env.NODE_ENV === "production" ? {
|
|
26
18
|
target: "e1ouebol1"
|
|
27
19
|
} : {
|
|
28
20
|
target: "e1ouebol1",
|
|
29
|
-
label: "
|
|
30
|
-
})("
|
|
21
|
+
label: "Day"
|
|
22
|
+
})("height:", ({
|
|
23
|
+
theme
|
|
24
|
+
}) => theme.sizing["312"], ";width:100%;padding:0;color:", ({
|
|
25
|
+
theme
|
|
26
|
+
}) => theme.colors.neutral.textWeak, ';&[aria-label="in-range"]{color:', ({
|
|
27
|
+
theme
|
|
28
|
+
}) => theme.colors.primary.textHover, ";background-color:", ({
|
|
29
|
+
theme
|
|
30
|
+
}) => theme.colors.primary.background, ';}&[aria-label="in-range"]:hover{color:', ({
|
|
31
31
|
theme
|
|
32
|
-
}) => theme.colors.
|
|
32
|
+
}) => theme.colors.neutral.textStronger, ";background-color:", ({
|
|
33
33
|
theme
|
|
34
|
-
}) => theme.sizing["312"], ";width:100%;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = ({ disabled }: { disabled: boolean }) => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
34
|
+
}) => theme.colors.primary.backgroundStrongHover, ';}&[aria-label="not-current"],:disabled{color:', ({
|
|
35
|
+
theme
|
|
36
|
+
}) => theme.colors.neutral.textDisabled, ';}&[aria-label="selected"]{color:', ({
|
|
37
|
+
theme
|
|
38
|
+
}) => theme.colors.neutral.textStronger, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAgB0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst Day = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n  color: ${({ theme }) => theme.colors.neutral.textWeak};\n\n  &[aria-label=\"in-range\"] {\n    color:  ${({ theme }) => theme.colors.primary.textHover};\n    background-color: ${({ theme }) => theme.colors.primary.background};\n  }\n\n  &[aria-label=\"in-range\"]:hover {\n    color: ${({ theme }) => theme.colors.neutral.textStronger};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n  }\n\n  &[aria-label=\"not-current\"], :disabled {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n\n  &[aria-label=\"selected\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStronger};\n  }\n\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = () => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n    readOnly,\n    disabled,\n    hoveredDate,\n    setHoveredDate,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'end'>(\n    range?.start && !range?.end ? 'end' : 'start',\n  ) // Used when selectsRange is True. The current state of the range: \"start\" when one must select the start-date of the range, \"end\" when start date is selected and one must select the end-date\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n          disabled={disabled}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate &&\n            !range.end) ||\n          (selectsRange &&\n            range?.start &&\n            constructedDate < range.start &&\n            hoveredDate &&\n            constructedDate > hoveredDate &&\n            !range.end) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting the end date\n            if (rangeState === 'end' && isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              // If we click on another date, it will reset the range\n              setRangeState('start')\n              setVisible(false)\n            }\n            // The newDate is before, we swap end & start date\n            else if (\n              rangeState === 'end' &&\n              !isAfterStartDate &&\n              range?.start\n            ) {\n              setRange?.({ start: newDate, end: range.start })\n              onChange?.([newDate, range.start], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: range.start },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n              setVisible(false)\n            }\n            // Selecting the start date\n            else {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('end')\n            }\n          }\n        }\n\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const dayState = () => {\n          if (isSelected) return 'selected'\n          if (isInHoveredRange) return 'in-range'\n          if (data.month !== 0) return 'not-current'\n\n          return 'neutral'\n        }\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange && !readOnly) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            aria-label={dayState()}\n            data-testid={createTestId()}\n          >\n            {data.day}\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
35
39
|
const CapitalizedText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
|
|
36
40
|
target: "e1ouebol0"
|
|
37
41
|
} : {
|
|
@@ -42,12 +46,10 @@ const CapitalizedText = /* @__PURE__ */ _styled__default.default(index$1.Text, p
|
|
|
42
46
|
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}"
|
|
43
47
|
} : {
|
|
44
48
|
name: "88dib2",
|
|
45
|
-
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AA6BoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = ({ disabled }: { disabled: boolean }) => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */",
|
|
49
|
+
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AA0CoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst Day = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n  color: ${({ theme }) => theme.colors.neutral.textWeak};\n\n  &[aria-label=\"in-range\"] {\n    color:  ${({ theme }) => theme.colors.primary.textHover};\n    background-color: ${({ theme }) => theme.colors.primary.background};\n  }\n\n  &[aria-label=\"in-range\"]:hover {\n    color: ${({ theme }) => theme.colors.neutral.textStronger};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n  }\n\n  &[aria-label=\"not-current\"], :disabled {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n\n  &[aria-label=\"selected\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStronger};\n  }\n\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = () => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n    readOnly,\n    disabled,\n    hoveredDate,\n    setHoveredDate,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'end'>(\n    range?.start && !range?.end ? 'end' : 'start',\n  ) // Used when selectsRange is True. The current state of the range: \"start\" when one must select the start-date of the range, \"end\" when start date is selected and one must select the end-date\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n          disabled={disabled}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate &&\n            !range.end) ||\n          (selectsRange &&\n            range?.start &&\n            constructedDate < range.start &&\n            hoveredDate &&\n            constructedDate > hoveredDate &&\n            !range.end) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting the end date\n            if (rangeState === 'end' && isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              // If we click on another date, it will reset the range\n              setRangeState('start')\n              setVisible(false)\n            }\n            // The newDate is before, we swap end & start date\n            else if (\n              rangeState === 'end' &&\n              !isAfterStartDate &&\n              range?.start\n            ) {\n              setRange?.({ start: newDate, end: range.start })\n              onChange?.([newDate, range.start], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: range.start },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n              setVisible(false)\n            }\n            // Selecting the start date\n            else {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('end')\n            }\n          }\n        }\n\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const dayState = () => {\n          if (isSelected) return 'selected'\n          if (isInHoveredRange) return 'in-range'\n          if (data.month !== 0) return 'not-current'\n\n          return 'neutral'\n        }\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange && !readOnly) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            aria-label={dayState()}\n            data-testid={createTestId()}\n          >\n            {data.day}\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */",
|
|
46
50
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
51
|
});
|
|
48
|
-
const Daily = ({
|
|
49
|
-
disabled
|
|
50
|
-
}) => {
|
|
52
|
+
const Daily = () => {
|
|
51
53
|
const {
|
|
52
54
|
value,
|
|
53
55
|
yearToShow,
|
|
@@ -65,10 +67,13 @@ const Daily = ({
|
|
|
65
67
|
setRange,
|
|
66
68
|
setInputValue,
|
|
67
69
|
format,
|
|
68
|
-
setVisible
|
|
70
|
+
setVisible,
|
|
71
|
+
readOnly,
|
|
72
|
+
disabled,
|
|
73
|
+
hoveredDate,
|
|
74
|
+
setHoveredDate
|
|
69
75
|
} = React.useContext(Context.DateInputContext);
|
|
70
|
-
const [rangeState, setRangeState] = React.useState(range?.start ? "
|
|
71
|
-
const [hoveredDate, setHoveredDate] = React.useState(null);
|
|
76
|
+
const [rangeState, setRangeState] = React.useState(range?.start && !range?.end ? "end" : "start");
|
|
72
77
|
const monthDays = new Date(yearToShow, monthToShow, 0).getDate();
|
|
73
78
|
const daysFromPreviousMonth = helpers.getMonthFirstDay(monthToShow, yearToShow);
|
|
74
79
|
const daysFromNextMonth = constants.CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays);
|
|
@@ -95,14 +100,14 @@ const Daily = ({
|
|
|
95
100
|
}));
|
|
96
101
|
const allDaysToShow = [...prevMonthDates, ...currentMonthDates, ...nextMonthDates];
|
|
97
102
|
return /* @__PURE__ */ jsxRuntime.jsxs(index$2.Row, { templateColumns: "repeat(7, 1fr)", gap: 1, children: [
|
|
98
|
-
Object.entries(DAYS).map((day) => /* @__PURE__ */ jsxRuntime.jsx(CapitalizedText, { as: "p", variant: "bodyStrong", sentiment: "neutral", children: day[1] }, day[0])),
|
|
103
|
+
Object.entries(DAYS).map((day) => /* @__PURE__ */ jsxRuntime.jsx(CapitalizedText, { as: "p", variant: "bodyStrong", sentiment: "neutral", disabled, children: day[1] }, day[0])),
|
|
99
104
|
allDaysToShow.map((data) => {
|
|
100
105
|
const constructedDate = new Date(yearToShow, monthToShow - 1 + data.month, data.day);
|
|
101
106
|
const isExcluded = excludeDates ? excludeDates.map((date) => helpers.isSameDay(constructedDate, date)).includes(true) : false;
|
|
102
107
|
const isOutsideRange = !!(minDate && constructedDate < minDate) || !!(maxDate && constructedDate > maxDate);
|
|
103
108
|
const isSelected = value && helpers.isSameDay(constructedDate, new Date(value)) || range?.end && helpers.isSameDay(constructedDate, range.end) || range?.start && helpers.isSameDay(constructedDate, range.start);
|
|
104
109
|
const isAfterStartDate = selectsRange && range?.start && constructedDate > range.start;
|
|
105
|
-
const isInHoveredRange = selectsRange && range?.start && constructedDate > range.start && hoveredDate && constructedDate < hoveredDate || range?.start && range.end && constructedDate < range.end && constructedDate > range.start;
|
|
110
|
+
const isInHoveredRange = selectsRange && range?.start && constructedDate > range.start && hoveredDate && constructedDate < hoveredDate && !range.end || selectsRange && range?.start && constructedDate < range.start && hoveredDate && constructedDate > hoveredDate && !range.end || range?.start && range.end && constructedDate < range.end && constructedDate > range.start;
|
|
106
111
|
const getNewDate = () => {
|
|
107
112
|
if (data.month !== 0 && data.day > 15) {
|
|
108
113
|
setMonthToShow(previousMonth);
|
|
@@ -118,18 +123,7 @@ const Daily = ({
|
|
|
118
123
|
};
|
|
119
124
|
const onClickRange = (event, newDate) => {
|
|
120
125
|
if (selectsRange) {
|
|
121
|
-
if (rangeState === "
|
|
122
|
-
setRange?.({
|
|
123
|
-
start: newDate,
|
|
124
|
-
end: null
|
|
125
|
-
});
|
|
126
|
-
onChange?.([newDate, null], event);
|
|
127
|
-
setInputValue(helpers.formatValue(null, {
|
|
128
|
-
start: newDate,
|
|
129
|
-
end: null
|
|
130
|
-
}, false, true, format));
|
|
131
|
-
setRangeState("start");
|
|
132
|
-
} else if (isAfterStartDate) {
|
|
126
|
+
if (rangeState === "end" && isAfterStartDate) {
|
|
133
127
|
setRange?.({
|
|
134
128
|
start: range.start,
|
|
135
129
|
end: newDate
|
|
@@ -139,18 +133,31 @@ const Daily = ({
|
|
|
139
133
|
start: range.start,
|
|
140
134
|
end: newDate
|
|
141
135
|
}, false, true, format));
|
|
136
|
+
setRangeState("start");
|
|
137
|
+
setVisible(false);
|
|
138
|
+
} else if (rangeState === "end" && !isAfterStartDate && range?.start) {
|
|
139
|
+
setRange?.({
|
|
140
|
+
start: newDate,
|
|
141
|
+
end: range.start
|
|
142
|
+
});
|
|
143
|
+
onChange?.([newDate, range.start], event);
|
|
144
|
+
setInputValue(helpers.formatValue(null, {
|
|
145
|
+
start: newDate,
|
|
146
|
+
end: range.start
|
|
147
|
+
}, false, true, format));
|
|
148
|
+
setRangeState("start");
|
|
142
149
|
setVisible(false);
|
|
143
|
-
setRangeState("done");
|
|
144
150
|
} else {
|
|
145
151
|
setRange?.({
|
|
146
152
|
start: newDate,
|
|
147
153
|
end: null
|
|
148
154
|
});
|
|
155
|
+
onChange?.([newDate, null], event);
|
|
149
156
|
setInputValue(helpers.formatValue(null, {
|
|
150
157
|
start: newDate,
|
|
151
158
|
end: null
|
|
152
159
|
}, false, true, format));
|
|
153
|
-
|
|
160
|
+
setRangeState("end");
|
|
154
161
|
}
|
|
155
162
|
}
|
|
156
163
|
};
|
|
@@ -160,9 +167,14 @@ const Daily = ({
|
|
|
160
167
|
if (data.month === 1) return "dayNextMonth";
|
|
161
168
|
return void 0;
|
|
162
169
|
};
|
|
163
|
-
const
|
|
170
|
+
const dayState = () => {
|
|
171
|
+
if (isSelected) return "selected";
|
|
172
|
+
if (isInHoveredRange) return "in-range";
|
|
173
|
+
if (data.month !== 0) return "not-current";
|
|
174
|
+
return "neutral";
|
|
175
|
+
};
|
|
164
176
|
return /* @__PURE__ */ jsxRuntime.jsx(Day, { variant: isSelected || isInHoveredRange ? "filled" : "ghost", sentiment: isSelected || isInHoveredRange ? "primary" : "neutral", disabled: disabled || isExcluded || isOutsideRange, onClick: (event) => {
|
|
165
|
-
if (!isExcluded && !isOutsideRange) {
|
|
177
|
+
if (!isExcluded && !isOutsideRange && !readOnly) {
|
|
166
178
|
const newDate = getNewDate();
|
|
167
179
|
if (selectsRange) {
|
|
168
180
|
onClickRange(event, newDate);
|
|
@@ -175,9 +187,7 @@ const Daily = ({
|
|
|
175
187
|
}
|
|
176
188
|
}, onMouseEnter: () => {
|
|
177
189
|
if (selectsRange && range?.start) setHoveredDate(constructedDate);
|
|
178
|
-
},
|
|
179
|
-
if (selectsRange && range?.start) setHoveredDate(null);
|
|
180
|
-
}, children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "span", variant: "bodyStrong", prominence: isSelected && !isInHoveredRange ? "strong" : "weak", sentiment: isSelected || isInHoveredRange ? "primary" : "neutral", disabled: disabled || data.month !== 0 || isExcluded || isOutsideRange, "data-testid": createTestId(), children: data.day }) }, `${data.month}-${data.day}`);
|
|
190
|
+
}, "aria-label": dayState(), "data-testid": createTestId(), children: data.day }, `${data.month}-${data.day}`);
|
|
181
191
|
})
|
|
182
192
|
] });
|
|
183
193
|
};
|