@commercetools-uikit/notifications 16.1.1 → 16.2.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/README.md +11 -0
- package/dist/commercetools-uikit-notifications.cjs.dev.js +23 -36
- package/dist/commercetools-uikit-notifications.cjs.prod.js +21 -36
- package/dist/commercetools-uikit-notifications.esm.js +23 -37
- package/dist/declarations/src/content-notification/content-notification.d.ts +2 -1
- package/package.json +5 -4
package/README.md
CHANGED
|
@@ -61,3 +61,14 @@ export const Error = () => (
|
|
|
61
61
|
| `type` | `union`<br/>Possible values:<br/>`'error' , 'info' , 'warning' , 'success'` | ✅ | | Determines the color/type of notification. |
|
|
62
62
|
| `intlMessage` | `MessageDescriptor` | | | An `intl` message object that will be rendered with `FormattedMessage`.
<br />
Required if `children` is not provided. |
|
|
63
63
|
| `children` | `ReactNode` | | | The content of the notification.
<br />
Required if `intlMessage` is not provided. |
|
|
64
|
+
| `onRemove` | `Function`<br/>[See signature.](#signature-onRemove) | | | When provided, a close icon will be rendered and this callback will be called when it is clicked. |
|
|
65
|
+
|
|
66
|
+
## Signatures
|
|
67
|
+
|
|
68
|
+
### Signature `onRemove`
|
|
69
|
+
|
|
70
|
+
```ts
|
|
71
|
+
(
|
|
72
|
+
event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>
|
|
73
|
+
) => void
|
|
74
|
+
```
|
|
@@ -15,6 +15,7 @@ var _pt = require('prop-types');
|
|
|
15
15
|
var react$1 = require('react');
|
|
16
16
|
var reactIntl = require('react-intl');
|
|
17
17
|
var react = require('@emotion/react');
|
|
18
|
+
var AccessibleButton = require('@commercetools-uikit/accessible-button');
|
|
18
19
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
19
20
|
var icons = require('@commercetools-uikit/icons');
|
|
20
21
|
var utils = require('@commercetools-uikit/utils');
|
|
@@ -31,6 +32,7 @@ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_O
|
|
|
31
32
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
32
33
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
33
34
|
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
35
|
+
var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
|
|
34
36
|
|
|
35
37
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
36
38
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
@@ -39,20 +41,6 @@ const warnIfMissingContent = props => {
|
|
|
39
41
|
process.env.NODE_ENV !== "production" ? utils.warning(hasContent, ['Warning: Failed prop type:', "The prop `intlMessage` is marked as required in `Link`", 'but its value is `undefined`'].join(' ')) : void 0;
|
|
40
42
|
process.env.NODE_ENV !== "production" ? utils.warning(hasContent, ['Warning: Failed prop type:', "The prop `children` is marked as required in `Link`", 'but its value is `undefined`'].join(' ')) : void 0;
|
|
41
43
|
};
|
|
42
|
-
const getIconContainerBackgroundColour = props => {
|
|
43
|
-
switch (props.type) {
|
|
44
|
-
case 'error':
|
|
45
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenError;
|
|
46
|
-
case 'info':
|
|
47
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenInfo;
|
|
48
|
-
case 'warning':
|
|
49
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenWarning;
|
|
50
|
-
case 'success':
|
|
51
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenSuccess;
|
|
52
|
-
default:
|
|
53
|
-
return '';
|
|
54
|
-
}
|
|
55
|
-
};
|
|
56
44
|
const getIconByType = props => {
|
|
57
45
|
switch (props.type) {
|
|
58
46
|
case 'error':
|
|
@@ -65,20 +53,6 @@ const getIconByType = props => {
|
|
|
65
53
|
return icons.CheckBoldIcon;
|
|
66
54
|
}
|
|
67
55
|
};
|
|
68
|
-
const getIconContainerBorderColor = props => {
|
|
69
|
-
switch (props.type) {
|
|
70
|
-
case 'error':
|
|
71
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenError;
|
|
72
|
-
case 'info':
|
|
73
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenInfo;
|
|
74
|
-
case 'warning':
|
|
75
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenWarning;
|
|
76
|
-
case 'success':
|
|
77
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenSuccess;
|
|
78
|
-
default:
|
|
79
|
-
return '';
|
|
80
|
-
}
|
|
81
|
-
};
|
|
82
56
|
const getIconColor = props => {
|
|
83
57
|
switch (props.type) {
|
|
84
58
|
case 'error':
|
|
@@ -93,21 +67,31 @@ const getIconColor = props => {
|
|
|
93
67
|
return '';
|
|
94
68
|
}
|
|
95
69
|
};
|
|
96
|
-
const
|
|
70
|
+
const NotificationTypeIcon = props => {
|
|
97
71
|
const Icon = getIconByType(props);
|
|
98
72
|
return jsxRuntime.jsx("div", {
|
|
99
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:center;
|
|
73
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;fill:", getIconColor(props), ";svg{margin:0 -3px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:NotificationTypeIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AA0Gc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
100
74
|
children: jsxRuntime.jsx(Icon, {})
|
|
101
75
|
});
|
|
102
76
|
};
|
|
103
|
-
|
|
77
|
+
NotificationTypeIcon.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
104
78
|
type: _pt__default["default"].oneOf(['error', 'info', 'warning', 'success']).isRequired,
|
|
105
79
|
intlMessage: _pt__default["default"].oneOfType([_pt__default["default"].any, _pt__default["default"].shape({
|
|
106
80
|
values: _pt__default["default"].objectOf(_pt__default["default"].node)
|
|
107
81
|
})]),
|
|
82
|
+
onRemove: _pt__default["default"].func,
|
|
108
83
|
children: _pt__default["default"].node
|
|
109
84
|
} : {};
|
|
110
|
-
|
|
85
|
+
NotificationTypeIcon.displayName = 'NotificationTypeIcon';
|
|
86
|
+
const NotificationCloseIcon = props => jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
87
|
+
label: "Remove",
|
|
88
|
+
onClick: props.onRemove,
|
|
89
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;fill:", designSystem.designTokens.colorSolid, ";&:hover{fill:", designSystem.designTokens.colorNeutral40, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:NotificationCloseIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AA+HY","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
90
|
+
children: jsxRuntime.jsx(icons.CloseBoldIcon, {
|
|
91
|
+
size: "medium"
|
|
92
|
+
})
|
|
93
|
+
});
|
|
94
|
+
NotificationCloseIcon.displayName = 'NotificationCloseIcon';
|
|
111
95
|
const getContentBorderColor = props => {
|
|
112
96
|
switch (props.type) {
|
|
113
97
|
case 'error':
|
|
@@ -139,14 +123,16 @@ const getContainerBackgroundColor = props => {
|
|
|
139
123
|
const ContentNotification = props => {
|
|
140
124
|
warnIfMissingContent(props);
|
|
141
125
|
return jsxRuntime.jsxs("div", _objectSpread(_objectSpread({}, utils.filterDataAttributes(props)), {}, {
|
|
142
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designSystem.designTokens.fontSizeForContentNotification, ";color:", designSystem.designTokens.fontColorForContentNotification, ";font-family:inherit;" + (process.env.NODE_ENV === "production" ? "" : ";label:ContentNotification;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
143
|
-
children: [jsxRuntime.jsx(
|
|
126
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designSystem.designTokens.fontSizeForContentNotification, ";color:", designSystem.designTokens.fontColorForContentNotification, ";font-family:inherit;background-color:", getContainerBackgroundColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForContentNotification, ";border-width:1px;border-style:solid;border-color:", getContentBorderColor(props), ";padding:", designSystem.designTokens.paddingForContentNotification, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ContentNotification;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AAiLc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
127
|
+
children: [jsxRuntime.jsx(NotificationTypeIcon, {
|
|
144
128
|
type: props.type
|
|
145
129
|
}), jsxRuntime.jsx("div", {
|
|
146
|
-
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.
|
|
130
|
+
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.paddingForContentNotificationMessage, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ContentNotification;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AAoMgB","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
147
131
|
children: props.intlMessage ? jsxRuntime.jsx("div", {
|
|
148
132
|
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread({}, props.intlMessage))
|
|
149
133
|
}) : props.children
|
|
134
|
+
}), props.onRemove && jsxRuntime.jsx(NotificationCloseIcon, {
|
|
135
|
+
onRemove: props.onRemove
|
|
150
136
|
})]
|
|
151
137
|
}));
|
|
152
138
|
};
|
|
@@ -155,13 +141,14 @@ ContentNotification.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
155
141
|
intlMessage: _pt__default["default"].oneOfType([_pt__default["default"].any, _pt__default["default"].shape({
|
|
156
142
|
values: _pt__default["default"].objectOf(_pt__default["default"].node)
|
|
157
143
|
})]),
|
|
144
|
+
onRemove: _pt__default["default"].func,
|
|
158
145
|
children: _pt__default["default"].node
|
|
159
146
|
} : {};
|
|
160
147
|
ContentNotification.displayName = 'ContentNotification';
|
|
161
148
|
var ContentNotification$1 = ContentNotification;
|
|
162
149
|
|
|
163
150
|
// NOTE: This string will be replaced on build time with the package version.
|
|
164
|
-
var version = "16.
|
|
151
|
+
var version = "16.2.0";
|
|
165
152
|
|
|
166
153
|
exports.ContentNotification = ContentNotification$1;
|
|
167
154
|
exports.version = version;
|
|
@@ -15,6 +15,7 @@ require('prop-types');
|
|
|
15
15
|
var react$1 = require('react');
|
|
16
16
|
var reactIntl = require('react-intl');
|
|
17
17
|
var react = require('@emotion/react');
|
|
18
|
+
var AccessibleButton = require('@commercetools-uikit/accessible-button');
|
|
18
19
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
19
20
|
var icons = require('@commercetools-uikit/icons');
|
|
20
21
|
var utils = require('@commercetools-uikit/utils');
|
|
@@ -30,26 +31,13 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
|
|
|
30
31
|
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
31
32
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
32
33
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
34
|
+
var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
|
|
33
35
|
|
|
34
36
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
35
37
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
36
38
|
const warnIfMissingContent = props => {
|
|
37
39
|
Boolean(props.intlMessage) || Boolean(react$1.Children.count(props.children));
|
|
38
40
|
};
|
|
39
|
-
const getIconContainerBackgroundColour = props => {
|
|
40
|
-
switch (props.type) {
|
|
41
|
-
case 'error':
|
|
42
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenError;
|
|
43
|
-
case 'info':
|
|
44
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenInfo;
|
|
45
|
-
case 'warning':
|
|
46
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenWarning;
|
|
47
|
-
case 'success':
|
|
48
|
-
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenSuccess;
|
|
49
|
-
default:
|
|
50
|
-
return '';
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
41
|
const getIconByType = props => {
|
|
54
42
|
switch (props.type) {
|
|
55
43
|
case 'error':
|
|
@@ -62,20 +50,6 @@ const getIconByType = props => {
|
|
|
62
50
|
return icons.CheckBoldIcon;
|
|
63
51
|
}
|
|
64
52
|
};
|
|
65
|
-
const getIconContainerBorderColor = props => {
|
|
66
|
-
switch (props.type) {
|
|
67
|
-
case 'error':
|
|
68
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenError;
|
|
69
|
-
case 'info':
|
|
70
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenInfo;
|
|
71
|
-
case 'warning':
|
|
72
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenWarning;
|
|
73
|
-
case 'success':
|
|
74
|
-
return designSystem.designTokens.borderColorForContentNotificationWhenSuccess;
|
|
75
|
-
default:
|
|
76
|
-
return '';
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
53
|
const getIconColor = props => {
|
|
80
54
|
switch (props.type) {
|
|
81
55
|
case 'error':
|
|
@@ -90,15 +64,24 @@ const getIconColor = props => {
|
|
|
90
64
|
return '';
|
|
91
65
|
}
|
|
92
66
|
};
|
|
93
|
-
const
|
|
67
|
+
const NotificationTypeIcon = props => {
|
|
94
68
|
const Icon = getIconByType(props);
|
|
95
69
|
return jsxRuntime.jsx("div", {
|
|
96
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:center;
|
|
70
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;fill:", getIconColor(props), ";svg{margin:0 -3px;}" + ("" ), "" ),
|
|
97
71
|
children: jsxRuntime.jsx(Icon, {})
|
|
98
72
|
});
|
|
99
73
|
};
|
|
100
|
-
|
|
101
|
-
|
|
74
|
+
NotificationTypeIcon.propTypes = {};
|
|
75
|
+
NotificationTypeIcon.displayName = 'NotificationTypeIcon';
|
|
76
|
+
const NotificationCloseIcon = props => jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
77
|
+
label: "Remove",
|
|
78
|
+
onClick: props.onRemove,
|
|
79
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;fill:", designSystem.designTokens.colorSolid, ";&:hover{fill:", designSystem.designTokens.colorNeutral40, ";}" + ("" ), "" ),
|
|
80
|
+
children: jsxRuntime.jsx(icons.CloseBoldIcon, {
|
|
81
|
+
size: "medium"
|
|
82
|
+
})
|
|
83
|
+
});
|
|
84
|
+
NotificationCloseIcon.displayName = 'NotificationCloseIcon';
|
|
102
85
|
const getContentBorderColor = props => {
|
|
103
86
|
switch (props.type) {
|
|
104
87
|
case 'error':
|
|
@@ -130,14 +113,16 @@ const getContainerBackgroundColor = props => {
|
|
|
130
113
|
const ContentNotification = props => {
|
|
131
114
|
warnIfMissingContent(props);
|
|
132
115
|
return jsxRuntime.jsxs("div", _objectSpread(_objectSpread({}, utils.filterDataAttributes(props)), {}, {
|
|
133
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designSystem.designTokens.fontSizeForContentNotification, ";color:", designSystem.designTokens.fontColorForContentNotification, ";font-family:inherit;" + ("" ), "" ),
|
|
134
|
-
children: [jsxRuntime.jsx(
|
|
116
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designSystem.designTokens.fontSizeForContentNotification, ";color:", designSystem.designTokens.fontColorForContentNotification, ";font-family:inherit;background-color:", getContainerBackgroundColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForContentNotification, ";border-width:1px;border-style:solid;border-color:", getContentBorderColor(props), ";padding:", designSystem.designTokens.paddingForContentNotification, ";" + ("" ), "" ),
|
|
117
|
+
children: [jsxRuntime.jsx(NotificationTypeIcon, {
|
|
135
118
|
type: props.type
|
|
136
119
|
}), jsxRuntime.jsx("div", {
|
|
137
|
-
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.
|
|
120
|
+
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.paddingForContentNotificationMessage, ";" + ("" ), "" ),
|
|
138
121
|
children: props.intlMessage ? jsxRuntime.jsx("div", {
|
|
139
122
|
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread({}, props.intlMessage))
|
|
140
123
|
}) : props.children
|
|
124
|
+
}), props.onRemove && jsxRuntime.jsx(NotificationCloseIcon, {
|
|
125
|
+
onRemove: props.onRemove
|
|
141
126
|
})]
|
|
142
127
|
}));
|
|
143
128
|
};
|
|
@@ -146,7 +131,7 @@ ContentNotification.displayName = 'ContentNotification';
|
|
|
146
131
|
var ContentNotification$1 = ContentNotification;
|
|
147
132
|
|
|
148
133
|
// NOTE: This string will be replaced on build time with the package version.
|
|
149
|
-
var version = "16.
|
|
134
|
+
var version = "16.2.0";
|
|
150
135
|
|
|
151
136
|
exports.ContentNotification = ContentNotification$1;
|
|
152
137
|
exports.version = version;
|
|
@@ -11,8 +11,9 @@ import _pt from 'prop-types';
|
|
|
11
11
|
import { Children } from 'react';
|
|
12
12
|
import { FormattedMessage } from 'react-intl';
|
|
13
13
|
import { css } from '@emotion/react';
|
|
14
|
+
import AccessibleButton from '@commercetools-uikit/accessible-button';
|
|
14
15
|
import { designTokens } from '@commercetools-uikit/design-system';
|
|
15
|
-
import { CheckBoldIcon, WarningIcon, InformationIcon, ErrorIcon } from '@commercetools-uikit/icons';
|
|
16
|
+
import { CloseBoldIcon, CheckBoldIcon, WarningIcon, InformationIcon, ErrorIcon } from '@commercetools-uikit/icons';
|
|
16
17
|
import { filterDataAttributes, warning } from '@commercetools-uikit/utils';
|
|
17
18
|
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
18
19
|
|
|
@@ -23,20 +24,6 @@ const warnIfMissingContent = props => {
|
|
|
23
24
|
process.env.NODE_ENV !== "production" ? warning(hasContent, ['Warning: Failed prop type:', "The prop `intlMessage` is marked as required in `Link`", 'but its value is `undefined`'].join(' ')) : void 0;
|
|
24
25
|
process.env.NODE_ENV !== "production" ? warning(hasContent, ['Warning: Failed prop type:', "The prop `children` is marked as required in `Link`", 'but its value is `undefined`'].join(' ')) : void 0;
|
|
25
26
|
};
|
|
26
|
-
const getIconContainerBackgroundColour = props => {
|
|
27
|
-
switch (props.type) {
|
|
28
|
-
case 'error':
|
|
29
|
-
return designTokens.backgroundColorForContentNotificationIconWhenError;
|
|
30
|
-
case 'info':
|
|
31
|
-
return designTokens.backgroundColorForContentNotificationIconWhenInfo;
|
|
32
|
-
case 'warning':
|
|
33
|
-
return designTokens.backgroundColorForContentNotificationIconWhenWarning;
|
|
34
|
-
case 'success':
|
|
35
|
-
return designTokens.backgroundColorForContentNotificationIconWhenSuccess;
|
|
36
|
-
default:
|
|
37
|
-
return '';
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
27
|
const getIconByType = props => {
|
|
41
28
|
switch (props.type) {
|
|
42
29
|
case 'error':
|
|
@@ -49,20 +36,6 @@ const getIconByType = props => {
|
|
|
49
36
|
return CheckBoldIcon;
|
|
50
37
|
}
|
|
51
38
|
};
|
|
52
|
-
const getIconContainerBorderColor = props => {
|
|
53
|
-
switch (props.type) {
|
|
54
|
-
case 'error':
|
|
55
|
-
return designTokens.borderColorForContentNotificationWhenError;
|
|
56
|
-
case 'info':
|
|
57
|
-
return designTokens.borderColorForContentNotificationWhenInfo;
|
|
58
|
-
case 'warning':
|
|
59
|
-
return designTokens.borderColorForContentNotificationWhenWarning;
|
|
60
|
-
case 'success':
|
|
61
|
-
return designTokens.borderColorForContentNotificationWhenSuccess;
|
|
62
|
-
default:
|
|
63
|
-
return '';
|
|
64
|
-
}
|
|
65
|
-
};
|
|
66
39
|
const getIconColor = props => {
|
|
67
40
|
switch (props.type) {
|
|
68
41
|
case 'error':
|
|
@@ -77,21 +50,31 @@ const getIconColor = props => {
|
|
|
77
50
|
return '';
|
|
78
51
|
}
|
|
79
52
|
};
|
|
80
|
-
const
|
|
53
|
+
const NotificationTypeIcon = props => {
|
|
81
54
|
const Icon = getIconByType(props);
|
|
82
55
|
return jsx("div", {
|
|
83
|
-
css: /*#__PURE__*/css("display:flex;align-items:center;
|
|
56
|
+
css: /*#__PURE__*/css("display:flex;align-items:center;fill:", getIconColor(props), ";svg{margin:0 -3px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:NotificationTypeIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AA0Gc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
84
57
|
children: jsx(Icon, {})
|
|
85
58
|
});
|
|
86
59
|
};
|
|
87
|
-
|
|
60
|
+
NotificationTypeIcon.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
88
61
|
type: _pt.oneOf(['error', 'info', 'warning', 'success']).isRequired,
|
|
89
62
|
intlMessage: _pt.oneOfType([_pt.any, _pt.shape({
|
|
90
63
|
values: _pt.objectOf(_pt.node)
|
|
91
64
|
})]),
|
|
65
|
+
onRemove: _pt.func,
|
|
92
66
|
children: _pt.node
|
|
93
67
|
} : {};
|
|
94
|
-
|
|
68
|
+
NotificationTypeIcon.displayName = 'NotificationTypeIcon';
|
|
69
|
+
const NotificationCloseIcon = props => jsx(AccessibleButton, {
|
|
70
|
+
label: "Remove",
|
|
71
|
+
onClick: props.onRemove,
|
|
72
|
+
css: /*#__PURE__*/css("display:flex;align-items:center;fill:", designTokens.colorSolid, ";&:hover{fill:", designTokens.colorNeutral40, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:NotificationCloseIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AA+HY","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
73
|
+
children: jsx(CloseBoldIcon, {
|
|
74
|
+
size: "medium"
|
|
75
|
+
})
|
|
76
|
+
});
|
|
77
|
+
NotificationCloseIcon.displayName = 'NotificationCloseIcon';
|
|
95
78
|
const getContentBorderColor = props => {
|
|
96
79
|
switch (props.type) {
|
|
97
80
|
case 'error':
|
|
@@ -123,14 +106,16 @@ const getContainerBackgroundColor = props => {
|
|
|
123
106
|
const ContentNotification = props => {
|
|
124
107
|
warnIfMissingContent(props);
|
|
125
108
|
return jsxs("div", _objectSpread(_objectSpread({}, filterDataAttributes(props)), {}, {
|
|
126
|
-
css: /*#__PURE__*/css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designTokens.fontSizeForContentNotification, ";color:", designTokens.fontColorForContentNotification, ";font-family:inherit;" + (process.env.NODE_ENV === "production" ? "" : ";label:ContentNotification;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
127
|
-
children: [jsx(
|
|
109
|
+
css: /*#__PURE__*/css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designTokens.fontSizeForContentNotification, ";color:", designTokens.fontColorForContentNotification, ";font-family:inherit;background-color:", getContainerBackgroundColor(props), ";border-radius:", designTokens.borderRadiusForContentNotification, ";border-width:1px;border-style:solid;border-color:", getContentBorderColor(props), ";padding:", designTokens.paddingForContentNotification, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ContentNotification;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AAiLc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
110
|
+
children: [jsx(NotificationTypeIcon, {
|
|
128
111
|
type: props.type
|
|
129
112
|
}), jsx("div", {
|
|
130
|
-
css: /*#__PURE__*/css("flex-grow:1;display:flex;align-items:center;padding:", designTokens.
|
|
113
|
+
css: /*#__PURE__*/css("flex-grow:1;display:flex;align-items:center;padding:", designTokens.paddingForContentNotificationMessage, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ContentNotification;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AAoMgB","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport {\n  Children,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  CheckBoldIcon,\n  CloseBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\nexport type TContentNotificationProps = {\n  /**\n   * Determines the color/type of notification.\n   */\n  type: 'error' | 'info' | 'warning' | 'success';\n\n  /**\n   * An `intl` message object that will be rendered with `FormattedMessage`.\n   * <br />\n   * Required if `children` is not provided.\n   */\n  intlMessage?: MessageDescriptor & {\n    values?: Record<string, ReactNode>;\n  };\n\n  /**\n   * When provided, a close button will be rendered and this callback will be\n   * called when it is clicked.\n   */\n  onRemove?: (\n    event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>\n  ) => void;\n\n  /**\n   * The content of the notification.\n   * <br />\n   * Required if `intlMessage` is not provided.\n   */\n  children?: ReactNode;\n};\n\nconst warnIfMissingContent = (props: TContentNotificationProps) => {\n  const hasContent =\n    Boolean(props.intlMessage) || Boolean(Children.count(props.children));\n\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`intlMessage\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n  warning(\n    hasContent,\n    [\n      'Warning: Failed prop type:',\n      `The prop \\`children\\` is marked as required in \\`Link\\``,\n      'but its value is `undefined`',\n    ].join(' ')\n  );\n};\n\nconst getIconByType = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return InformationIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.fontColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.fontColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.fontColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.fontColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst NotificationTypeIcon = (props: TContentNotificationProps) => {\n  const Icon = getIconByType(props);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationTypeIcon.displayName = 'NotificationTypeIcon';\n\nconst NotificationCloseIcon = (\n  props: Pick<TContentNotificationProps, 'onRemove'>\n) => (\n  <AccessibleButton\n    label=\"Remove\"\n    onClick={props.onRemove}\n    css={css`\n      display: flex;\n      align-items: center;\n      fill: ${designTokens.colorSolid};\n      &:hover {\n        fill: ${designTokens.colorNeutral40};\n      }\n    `}\n  >\n    <CloseBoldIcon size=\"medium\" />\n  </AccessibleButton>\n);\nNotificationCloseIcon.displayName = 'NotificationCloseIcon';\n\nconst getContentBorderColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.borderColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.borderColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.borderColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.borderColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getContainerBackgroundColor = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst ContentNotification = (props: TContentNotificationProps) => {\n  warnIfMissingContent(props);\n\n  return (\n    <div\n      {...filterDataAttributes(props)}\n      css={css`\n        display: flex;\n        align-items: stretch;\n        text-align: left;\n        word-break: break-word;\n        hyphens: auto;\n        font-size: ${designTokens.fontSizeForContentNotification};\n        color: ${designTokens.fontColorForContentNotification};\n        font-family: inherit;\n        background-color: ${getContainerBackgroundColor(props)};\n        border-radius: ${designTokens.borderRadiusForContentNotification};\n        border-width: 1px;\n        border-style: solid;\n        border-color: ${getContentBorderColor(props)};\n        padding: ${designTokens.paddingForContentNotification};\n      `}\n    >\n      <NotificationTypeIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotificationMessage};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n      {props.onRemove && <NotificationCloseIcon onRemove={props.onRemove} />}\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
131
114
|
children: props.intlMessage ? jsx("div", {
|
|
132
115
|
children: jsx(FormattedMessage, _objectSpread({}, props.intlMessage))
|
|
133
116
|
}) : props.children
|
|
117
|
+
}), props.onRemove && jsx(NotificationCloseIcon, {
|
|
118
|
+
onRemove: props.onRemove
|
|
134
119
|
})]
|
|
135
120
|
}));
|
|
136
121
|
};
|
|
@@ -139,12 +124,13 @@ ContentNotification.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
139
124
|
intlMessage: _pt.oneOfType([_pt.any, _pt.shape({
|
|
140
125
|
values: _pt.objectOf(_pt.node)
|
|
141
126
|
})]),
|
|
127
|
+
onRemove: _pt.func,
|
|
142
128
|
children: _pt.node
|
|
143
129
|
} : {};
|
|
144
130
|
ContentNotification.displayName = 'ContentNotification';
|
|
145
131
|
var ContentNotification$1 = ContentNotification;
|
|
146
132
|
|
|
147
133
|
// NOTE: This string will be replaced on build time with the package version.
|
|
148
|
-
var version = "16.
|
|
134
|
+
var version = "16.2.0";
|
|
149
135
|
|
|
150
136
|
export { ContentNotification$1 as ContentNotification, version };
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import type { MessageDescriptor } from 'react-intl';
|
|
2
|
-
import { ReactNode } from 'react';
|
|
2
|
+
import { type ReactNode, type MouseEvent, type KeyboardEvent } from 'react';
|
|
3
3
|
export type TContentNotificationProps = {
|
|
4
4
|
type: 'error' | 'info' | 'warning' | 'success';
|
|
5
5
|
intlMessage?: MessageDescriptor & {
|
|
6
6
|
values?: Record<string, ReactNode>;
|
|
7
7
|
};
|
|
8
|
+
onRemove?: (event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>) => void;
|
|
8
9
|
children?: ReactNode;
|
|
9
10
|
};
|
|
10
11
|
declare const ContentNotification: {
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/notifications",
|
|
3
3
|
"description": "Notification components.",
|
|
4
|
-
"version": "16.
|
|
4
|
+
"version": "16.2.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,9 +21,10 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/
|
|
25
|
-
"@commercetools-uikit/
|
|
26
|
-
"@commercetools-uikit/
|
|
24
|
+
"@commercetools-uikit/accessible-button": "16.2.0",
|
|
25
|
+
"@commercetools-uikit/design-system": "16.2.0",
|
|
26
|
+
"@commercetools-uikit/icons": "16.2.0",
|
|
27
|
+
"@commercetools-uikit/utils": "16.2.0",
|
|
27
28
|
"@emotion/react": "^11.10.5",
|
|
28
29
|
"prop-types": "15.8.1"
|
|
29
30
|
},
|