@commercetools-uikit/notifications 15.10.0 → 15.11.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -45,29 +45,29 @@ var warnIfMissingContent = function warnIfMissingContent(props) {
|
|
|
45
45
|
var getIconContainerBackgroundColour = function getIconContainerBackgroundColour(props) {
|
|
46
46
|
switch (props.type) {
|
|
47
47
|
case 'error':
|
|
48
|
-
return designSystem.designTokens.
|
|
48
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenError;
|
|
49
49
|
|
|
50
50
|
case 'info':
|
|
51
|
-
return designSystem.designTokens.
|
|
51
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenInfo;
|
|
52
52
|
|
|
53
53
|
case 'warning':
|
|
54
|
-
return designSystem.designTokens.
|
|
54
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenWarning;
|
|
55
55
|
|
|
56
56
|
case 'success':
|
|
57
|
-
return designSystem.designTokens.
|
|
57
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenSuccess;
|
|
58
58
|
|
|
59
59
|
default:
|
|
60
60
|
return '';
|
|
61
61
|
}
|
|
62
62
|
};
|
|
63
63
|
|
|
64
|
-
var getIconByType = function getIconByType(props) {
|
|
64
|
+
var getIconByType = function getIconByType(props, isNewTheme) {
|
|
65
65
|
switch (props.type) {
|
|
66
66
|
case 'error':
|
|
67
67
|
return icons.ErrorIcon;
|
|
68
68
|
|
|
69
69
|
case 'info':
|
|
70
|
-
return icons.InfoIcon;
|
|
70
|
+
return isNewTheme ? icons.InformationIcon : icons.InfoIcon;
|
|
71
71
|
|
|
72
72
|
case 'warning':
|
|
73
73
|
return icons.WarningIcon;
|
|
@@ -77,13 +77,52 @@ var getIconByType = function getIconByType(props) {
|
|
|
77
77
|
}
|
|
78
78
|
};
|
|
79
79
|
|
|
80
|
+
var getIconContainerBorderColor = function getIconContainerBorderColor(props) {
|
|
81
|
+
switch (props.type) {
|
|
82
|
+
case 'error':
|
|
83
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenError;
|
|
84
|
+
|
|
85
|
+
case 'info':
|
|
86
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenInfo;
|
|
87
|
+
|
|
88
|
+
case 'warning':
|
|
89
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenWarning;
|
|
90
|
+
|
|
91
|
+
case 'success':
|
|
92
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenSuccess;
|
|
93
|
+
|
|
94
|
+
default:
|
|
95
|
+
return '';
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
var getIconColor = function getIconColor(props) {
|
|
100
|
+
switch (props.type) {
|
|
101
|
+
case 'error':
|
|
102
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenError;
|
|
103
|
+
|
|
104
|
+
case 'info':
|
|
105
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenInfo;
|
|
106
|
+
|
|
107
|
+
case 'warning':
|
|
108
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenWarning;
|
|
109
|
+
|
|
110
|
+
case 'success':
|
|
111
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenSuccess;
|
|
112
|
+
|
|
113
|
+
default:
|
|
114
|
+
return '';
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
|
|
80
118
|
var NotificationIcon = function NotificationIcon(props) {
|
|
81
|
-
var
|
|
119
|
+
var _useTheme = designSystem.useTheme(),
|
|
120
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
121
|
+
|
|
122
|
+
var Icon = getIconByType(props, isNewTheme);
|
|
82
123
|
return jsxRuntime.jsx("div", {
|
|
83
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:center;border-radius:", designSystem.designTokens.
|
|
84
|
-
children: jsxRuntime.jsx(Icon, {
|
|
85
|
-
color: "surface"
|
|
86
|
-
})
|
|
124
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;border-radius:", designSystem.designTokens.borderRadiusForContentNotificationIcon, ";border-width:", designSystem.designTokens.borderWidthForContentNotificationIcon, ";border-style:solid;border-color:", getIconContainerBorderColor(props), ";border-right:0;padding:", designSystem.designTokens.paddingForContentNotificationIcon, ";background-color:", getIconContainerBackgroundColour(props), ";fill:", getIconColor(props), ";svg{margin:0 -3px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:NotificationIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AA8Hc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport { Children, ReactNode } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  InfoIcon,\n  CheckBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\ntype 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   * 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 getIconContainerBackgroundColour = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getIconByType = (\n  props: TContentNotificationProps,\n  isNewTheme: boolean\n) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return isNewTheme ? InformationIcon : InfoIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconContainerBorderColor = (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 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 NotificationIcon = (props: TContentNotificationProps) => {\n  const { isNewTheme } = useTheme();\n  const Icon = getIconByType(props, isNewTheme);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        border-radius: ${designTokens.borderRadiusForContentNotificationIcon};\n        border-width: ${designTokens.borderWidthForContentNotificationIcon};\n        border-style: solid;\n        border-color: ${getIconContainerBorderColor(props)};\n        border-right: 0;\n        padding: ${designTokens.paddingForContentNotificationIcon};\n        background-color: ${getIconContainerBackgroundColour(props)};\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationIcon.displayName = 'NotificationIcon';\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      `}\n    >\n      <NotificationIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotification};\n          background-color: ${getContainerBackgroundColor(props)};\n          border-radius: ${designTokens.borderRadiusForContentNotification};\n          border-width: 1px;\n          border-style: solid;\n          border-color: ${getContentBorderColor(props)};\n          border-left-width: ${designTokens.borderLeftWidthForContentNotification};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
125
|
+
children: jsxRuntime.jsx(Icon, {})
|
|
87
126
|
});
|
|
88
127
|
};
|
|
89
128
|
|
|
@@ -99,16 +138,35 @@ NotificationIcon.displayName = 'NotificationIcon';
|
|
|
99
138
|
var getContentBorderColor = function getContentBorderColor(props) {
|
|
100
139
|
switch (props.type) {
|
|
101
140
|
case 'error':
|
|
102
|
-
return designSystem.designTokens.
|
|
141
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenError;
|
|
142
|
+
|
|
143
|
+
case 'info':
|
|
144
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenInfo;
|
|
145
|
+
|
|
146
|
+
case 'warning':
|
|
147
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenWarning;
|
|
148
|
+
|
|
149
|
+
case 'success':
|
|
150
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenSuccess;
|
|
151
|
+
|
|
152
|
+
default:
|
|
153
|
+
return '';
|
|
154
|
+
}
|
|
155
|
+
};
|
|
156
|
+
|
|
157
|
+
var getContainerBackgroundColor = function getContainerBackgroundColor(props) {
|
|
158
|
+
switch (props.type) {
|
|
159
|
+
case 'error':
|
|
160
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenError;
|
|
103
161
|
|
|
104
162
|
case 'info':
|
|
105
|
-
return designSystem.designTokens.
|
|
163
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenInfo;
|
|
106
164
|
|
|
107
165
|
case 'warning':
|
|
108
|
-
return designSystem.designTokens.
|
|
166
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenWarning;
|
|
109
167
|
|
|
110
168
|
case 'success':
|
|
111
|
-
return designSystem.designTokens.
|
|
169
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenSuccess;
|
|
112
170
|
|
|
113
171
|
default:
|
|
114
172
|
return '';
|
|
@@ -118,11 +176,11 @@ var getContentBorderColor = function getContentBorderColor(props) {
|
|
|
118
176
|
var ContentNotification = function ContentNotification(props) {
|
|
119
177
|
warnIfMissingContent(props);
|
|
120
178
|
return jsxRuntime.jsxs("div", _objectSpread(_objectSpread({}, utils.filterDataAttributes(props)), {}, {
|
|
121
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designSystem.designTokens.
|
|
179
|
+
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,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AAwLc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport { Children, ReactNode } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  InfoIcon,\n  CheckBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\ntype 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   * 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 getIconContainerBackgroundColour = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getIconByType = (\n  props: TContentNotificationProps,\n  isNewTheme: boolean\n) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return isNewTheme ? InformationIcon : InfoIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconContainerBorderColor = (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 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 NotificationIcon = (props: TContentNotificationProps) => {\n  const { isNewTheme } = useTheme();\n  const Icon = getIconByType(props, isNewTheme);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        border-radius: ${designTokens.borderRadiusForContentNotificationIcon};\n        border-width: ${designTokens.borderWidthForContentNotificationIcon};\n        border-style: solid;\n        border-color: ${getIconContainerBorderColor(props)};\n        border-right: 0;\n        padding: ${designTokens.paddingForContentNotificationIcon};\n        background-color: ${getIconContainerBackgroundColour(props)};\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationIcon.displayName = 'NotificationIcon';\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      `}\n    >\n      <NotificationIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotification};\n          background-color: ${getContainerBackgroundColor(props)};\n          border-radius: ${designTokens.borderRadiusForContentNotification};\n          border-width: 1px;\n          border-style: solid;\n          border-color: ${getContentBorderColor(props)};\n          border-left-width: ${designTokens.borderLeftWidthForContentNotification};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
122
180
|
children: [jsxRuntime.jsx(NotificationIcon, {
|
|
123
181
|
type: props.type
|
|
124
182
|
}), jsxRuntime.jsx("div", {
|
|
125
|
-
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.
|
|
183
|
+
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.paddingForContentNotification, ";background-color:", getContainerBackgroundColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForContentNotification, ";border-width:1px;border-style:solid;border-color:", getContentBorderColor(props), ";border-left-width:", designSystem.designTokens.borderLeftWidthForContentNotification, ";" + (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":"AAqMgB","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport { Children, ReactNode } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  InfoIcon,\n  CheckBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\ntype 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   * 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 getIconContainerBackgroundColour = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getIconByType = (\n  props: TContentNotificationProps,\n  isNewTheme: boolean\n) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return isNewTheme ? InformationIcon : InfoIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconContainerBorderColor = (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 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 NotificationIcon = (props: TContentNotificationProps) => {\n  const { isNewTheme } = useTheme();\n  const Icon = getIconByType(props, isNewTheme);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        border-radius: ${designTokens.borderRadiusForContentNotificationIcon};\n        border-width: ${designTokens.borderWidthForContentNotificationIcon};\n        border-style: solid;\n        border-color: ${getIconContainerBorderColor(props)};\n        border-right: 0;\n        padding: ${designTokens.paddingForContentNotificationIcon};\n        background-color: ${getIconContainerBackgroundColour(props)};\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationIcon.displayName = 'NotificationIcon';\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      `}\n    >\n      <NotificationIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotification};\n          background-color: ${getContainerBackgroundColor(props)};\n          border-radius: ${designTokens.borderRadiusForContentNotification};\n          border-width: 1px;\n          border-style: solid;\n          border-color: ${getContentBorderColor(props)};\n          border-left-width: ${designTokens.borderLeftWidthForContentNotification};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
126
184
|
children: props.intlMessage ? jsxRuntime.jsx("div", {
|
|
127
185
|
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread({}, props.intlMessage))
|
|
128
186
|
}) : props.children
|
|
@@ -141,7 +199,7 @@ ContentNotification.displayName = 'ContentNotification';
|
|
|
141
199
|
var ContentNotification$1 = ContentNotification;
|
|
142
200
|
|
|
143
201
|
// NOTE: This string will be replaced on build time with the package version.
|
|
144
|
-
var version = "15.
|
|
202
|
+
var version = "15.11.1";
|
|
145
203
|
|
|
146
204
|
exports.ContentNotification = ContentNotification$1;
|
|
147
205
|
exports.version = version;
|
|
@@ -42,29 +42,29 @@ var warnIfMissingContent = function warnIfMissingContent(props) {
|
|
|
42
42
|
var getIconContainerBackgroundColour = function getIconContainerBackgroundColour(props) {
|
|
43
43
|
switch (props.type) {
|
|
44
44
|
case 'error':
|
|
45
|
-
return designSystem.designTokens.
|
|
45
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenError;
|
|
46
46
|
|
|
47
47
|
case 'info':
|
|
48
|
-
return designSystem.designTokens.
|
|
48
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenInfo;
|
|
49
49
|
|
|
50
50
|
case 'warning':
|
|
51
|
-
return designSystem.designTokens.
|
|
51
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenWarning;
|
|
52
52
|
|
|
53
53
|
case 'success':
|
|
54
|
-
return designSystem.designTokens.
|
|
54
|
+
return designSystem.designTokens.backgroundColorForContentNotificationIconWhenSuccess;
|
|
55
55
|
|
|
56
56
|
default:
|
|
57
57
|
return '';
|
|
58
58
|
}
|
|
59
59
|
};
|
|
60
60
|
|
|
61
|
-
var getIconByType = function getIconByType(props) {
|
|
61
|
+
var getIconByType = function getIconByType(props, isNewTheme) {
|
|
62
62
|
switch (props.type) {
|
|
63
63
|
case 'error':
|
|
64
64
|
return icons.ErrorIcon;
|
|
65
65
|
|
|
66
66
|
case 'info':
|
|
67
|
-
return icons.InfoIcon;
|
|
67
|
+
return isNewTheme ? icons.InformationIcon : icons.InfoIcon;
|
|
68
68
|
|
|
69
69
|
case 'warning':
|
|
70
70
|
return icons.WarningIcon;
|
|
@@ -74,13 +74,52 @@ var getIconByType = function getIconByType(props) {
|
|
|
74
74
|
}
|
|
75
75
|
};
|
|
76
76
|
|
|
77
|
+
var getIconContainerBorderColor = function getIconContainerBorderColor(props) {
|
|
78
|
+
switch (props.type) {
|
|
79
|
+
case 'error':
|
|
80
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenError;
|
|
81
|
+
|
|
82
|
+
case 'info':
|
|
83
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenInfo;
|
|
84
|
+
|
|
85
|
+
case 'warning':
|
|
86
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenWarning;
|
|
87
|
+
|
|
88
|
+
case 'success':
|
|
89
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenSuccess;
|
|
90
|
+
|
|
91
|
+
default:
|
|
92
|
+
return '';
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
var getIconColor = function getIconColor(props) {
|
|
97
|
+
switch (props.type) {
|
|
98
|
+
case 'error':
|
|
99
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenError;
|
|
100
|
+
|
|
101
|
+
case 'info':
|
|
102
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenInfo;
|
|
103
|
+
|
|
104
|
+
case 'warning':
|
|
105
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenWarning;
|
|
106
|
+
|
|
107
|
+
case 'success':
|
|
108
|
+
return designSystem.designTokens.fontColorForContentNotificationIconWhenSuccess;
|
|
109
|
+
|
|
110
|
+
default:
|
|
111
|
+
return '';
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
|
|
77
115
|
var NotificationIcon = function NotificationIcon(props) {
|
|
78
|
-
var
|
|
116
|
+
var _useTheme = designSystem.useTheme(),
|
|
117
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
118
|
+
|
|
119
|
+
var Icon = getIconByType(props, isNewTheme);
|
|
79
120
|
return jsxRuntime.jsx("div", {
|
|
80
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:center;border-radius:", designSystem.designTokens.
|
|
81
|
-
children: jsxRuntime.jsx(Icon, {
|
|
82
|
-
color: "surface"
|
|
83
|
-
})
|
|
121
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;border-radius:", designSystem.designTokens.borderRadiusForContentNotificationIcon, ";border-width:", designSystem.designTokens.borderWidthForContentNotificationIcon, ";border-style:solid;border-color:", getIconContainerBorderColor(props), ";border-right:0;padding:", designSystem.designTokens.paddingForContentNotificationIcon, ";background-color:", getIconContainerBackgroundColour(props), ";fill:", getIconColor(props), ";svg{margin:0 -3px;}" + ("" ), "" ),
|
|
122
|
+
children: jsxRuntime.jsx(Icon, {})
|
|
84
123
|
});
|
|
85
124
|
};
|
|
86
125
|
|
|
@@ -90,16 +129,35 @@ NotificationIcon.displayName = 'NotificationIcon';
|
|
|
90
129
|
var getContentBorderColor = function getContentBorderColor(props) {
|
|
91
130
|
switch (props.type) {
|
|
92
131
|
case 'error':
|
|
93
|
-
return designSystem.designTokens.
|
|
132
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenError;
|
|
133
|
+
|
|
134
|
+
case 'info':
|
|
135
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenInfo;
|
|
136
|
+
|
|
137
|
+
case 'warning':
|
|
138
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenWarning;
|
|
139
|
+
|
|
140
|
+
case 'success':
|
|
141
|
+
return designSystem.designTokens.borderColorForContentNotificationWhenSuccess;
|
|
142
|
+
|
|
143
|
+
default:
|
|
144
|
+
return '';
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
var getContainerBackgroundColor = function getContainerBackgroundColor(props) {
|
|
149
|
+
switch (props.type) {
|
|
150
|
+
case 'error':
|
|
151
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenError;
|
|
94
152
|
|
|
95
153
|
case 'info':
|
|
96
|
-
return designSystem.designTokens.
|
|
154
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenInfo;
|
|
97
155
|
|
|
98
156
|
case 'warning':
|
|
99
|
-
return designSystem.designTokens.
|
|
157
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenWarning;
|
|
100
158
|
|
|
101
159
|
case 'success':
|
|
102
|
-
return designSystem.designTokens.
|
|
160
|
+
return designSystem.designTokens.backgroundColorForContentNotificationWhenSuccess;
|
|
103
161
|
|
|
104
162
|
default:
|
|
105
163
|
return '';
|
|
@@ -109,11 +167,11 @@ var getContentBorderColor = function getContentBorderColor(props) {
|
|
|
109
167
|
var ContentNotification = function ContentNotification(props) {
|
|
110
168
|
warnIfMissingContent(props);
|
|
111
169
|
return jsxRuntime.jsxs("div", _objectSpread(_objectSpread({}, utils.filterDataAttributes(props)), {}, {
|
|
112
|
-
css: /*#__PURE__*/react.css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designSystem.designTokens.
|
|
170
|
+
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;" + ("" ), "" ),
|
|
113
171
|
children: [jsxRuntime.jsx(NotificationIcon, {
|
|
114
172
|
type: props.type
|
|
115
173
|
}), jsxRuntime.jsx("div", {
|
|
116
|
-
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.
|
|
174
|
+
css: /*#__PURE__*/react.css("flex-grow:1;display:flex;align-items:center;padding:", designSystem.designTokens.paddingForContentNotification, ";background-color:", getContainerBackgroundColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForContentNotification, ";border-width:1px;border-style:solid;border-color:", getContentBorderColor(props), ";border-left-width:", designSystem.designTokens.borderLeftWidthForContentNotification, ";" + ("" ), "" ),
|
|
117
175
|
children: props.intlMessage ? jsxRuntime.jsx("div", {
|
|
118
176
|
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread({}, props.intlMessage))
|
|
119
177
|
}) : props.children
|
|
@@ -126,7 +184,7 @@ ContentNotification.displayName = 'ContentNotification';
|
|
|
126
184
|
var ContentNotification$1 = ContentNotification;
|
|
127
185
|
|
|
128
186
|
// NOTE: This string will be replaced on build time with the package version.
|
|
129
|
-
var version = "15.
|
|
187
|
+
var version = "15.11.1";
|
|
130
188
|
|
|
131
189
|
exports.ContentNotification = ContentNotification$1;
|
|
132
190
|
exports.version = version;
|
|
@@ -11,8 +11,8 @@ 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 { designTokens } from '@commercetools-uikit/design-system';
|
|
15
|
-
import { CheckBoldIcon, WarningIcon, InfoIcon, ErrorIcon } from '@commercetools-uikit/icons';
|
|
14
|
+
import { designTokens, useTheme } from '@commercetools-uikit/design-system';
|
|
15
|
+
import { CheckBoldIcon, WarningIcon, InformationIcon, InfoIcon, ErrorIcon } from '@commercetools-uikit/icons';
|
|
16
16
|
import { filterDataAttributes, warning } from '@commercetools-uikit/utils';
|
|
17
17
|
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
18
18
|
|
|
@@ -29,29 +29,29 @@ var warnIfMissingContent = function warnIfMissingContent(props) {
|
|
|
29
29
|
var getIconContainerBackgroundColour = function getIconContainerBackgroundColour(props) {
|
|
30
30
|
switch (props.type) {
|
|
31
31
|
case 'error':
|
|
32
|
-
return designTokens.
|
|
32
|
+
return designTokens.backgroundColorForContentNotificationIconWhenError;
|
|
33
33
|
|
|
34
34
|
case 'info':
|
|
35
|
-
return designTokens.
|
|
35
|
+
return designTokens.backgroundColorForContentNotificationIconWhenInfo;
|
|
36
36
|
|
|
37
37
|
case 'warning':
|
|
38
|
-
return designTokens.
|
|
38
|
+
return designTokens.backgroundColorForContentNotificationIconWhenWarning;
|
|
39
39
|
|
|
40
40
|
case 'success':
|
|
41
|
-
return designTokens.
|
|
41
|
+
return designTokens.backgroundColorForContentNotificationIconWhenSuccess;
|
|
42
42
|
|
|
43
43
|
default:
|
|
44
44
|
return '';
|
|
45
45
|
}
|
|
46
46
|
};
|
|
47
47
|
|
|
48
|
-
var getIconByType = function getIconByType(props) {
|
|
48
|
+
var getIconByType = function getIconByType(props, isNewTheme) {
|
|
49
49
|
switch (props.type) {
|
|
50
50
|
case 'error':
|
|
51
51
|
return ErrorIcon;
|
|
52
52
|
|
|
53
53
|
case 'info':
|
|
54
|
-
return InfoIcon;
|
|
54
|
+
return isNewTheme ? InformationIcon : InfoIcon;
|
|
55
55
|
|
|
56
56
|
case 'warning':
|
|
57
57
|
return WarningIcon;
|
|
@@ -61,13 +61,52 @@ var getIconByType = function getIconByType(props) {
|
|
|
61
61
|
}
|
|
62
62
|
};
|
|
63
63
|
|
|
64
|
+
var getIconContainerBorderColor = function getIconContainerBorderColor(props) {
|
|
65
|
+
switch (props.type) {
|
|
66
|
+
case 'error':
|
|
67
|
+
return designTokens.borderColorForContentNotificationWhenError;
|
|
68
|
+
|
|
69
|
+
case 'info':
|
|
70
|
+
return designTokens.borderColorForContentNotificationWhenInfo;
|
|
71
|
+
|
|
72
|
+
case 'warning':
|
|
73
|
+
return designTokens.borderColorForContentNotificationWhenWarning;
|
|
74
|
+
|
|
75
|
+
case 'success':
|
|
76
|
+
return designTokens.borderColorForContentNotificationWhenSuccess;
|
|
77
|
+
|
|
78
|
+
default:
|
|
79
|
+
return '';
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
var getIconColor = function getIconColor(props) {
|
|
84
|
+
switch (props.type) {
|
|
85
|
+
case 'error':
|
|
86
|
+
return designTokens.fontColorForContentNotificationIconWhenError;
|
|
87
|
+
|
|
88
|
+
case 'info':
|
|
89
|
+
return designTokens.fontColorForContentNotificationIconWhenInfo;
|
|
90
|
+
|
|
91
|
+
case 'warning':
|
|
92
|
+
return designTokens.fontColorForContentNotificationIconWhenWarning;
|
|
93
|
+
|
|
94
|
+
case 'success':
|
|
95
|
+
return designTokens.fontColorForContentNotificationIconWhenSuccess;
|
|
96
|
+
|
|
97
|
+
default:
|
|
98
|
+
return '';
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
|
|
64
102
|
var NotificationIcon = function NotificationIcon(props) {
|
|
65
|
-
var
|
|
103
|
+
var _useTheme = useTheme(),
|
|
104
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
105
|
+
|
|
106
|
+
var Icon = getIconByType(props, isNewTheme);
|
|
66
107
|
return jsx("div", {
|
|
67
|
-
css: /*#__PURE__*/css("display:flex;align-items:center;border-radius:", designTokens.
|
|
68
|
-
children: jsx(Icon, {
|
|
69
|
-
color: "surface"
|
|
70
|
-
})
|
|
108
|
+
css: /*#__PURE__*/css("display:flex;align-items:center;border-radius:", designTokens.borderRadiusForContentNotificationIcon, ";border-width:", designTokens.borderWidthForContentNotificationIcon, ";border-style:solid;border-color:", getIconContainerBorderColor(props), ";border-right:0;padding:", designTokens.paddingForContentNotificationIcon, ";background-color:", getIconContainerBackgroundColour(props), ";fill:", getIconColor(props), ";svg{margin:0 -3px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:NotificationIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AA8Hc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport { Children, ReactNode } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  InfoIcon,\n  CheckBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\ntype 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   * 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 getIconContainerBackgroundColour = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getIconByType = (\n  props: TContentNotificationProps,\n  isNewTheme: boolean\n) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return isNewTheme ? InformationIcon : InfoIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconContainerBorderColor = (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 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 NotificationIcon = (props: TContentNotificationProps) => {\n  const { isNewTheme } = useTheme();\n  const Icon = getIconByType(props, isNewTheme);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        border-radius: ${designTokens.borderRadiusForContentNotificationIcon};\n        border-width: ${designTokens.borderWidthForContentNotificationIcon};\n        border-style: solid;\n        border-color: ${getIconContainerBorderColor(props)};\n        border-right: 0;\n        padding: ${designTokens.paddingForContentNotificationIcon};\n        background-color: ${getIconContainerBackgroundColour(props)};\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationIcon.displayName = 'NotificationIcon';\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      `}\n    >\n      <NotificationIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotification};\n          background-color: ${getContainerBackgroundColor(props)};\n          border-radius: ${designTokens.borderRadiusForContentNotification};\n          border-width: 1px;\n          border-style: solid;\n          border-color: ${getContentBorderColor(props)};\n          border-left-width: ${designTokens.borderLeftWidthForContentNotification};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
109
|
+
children: jsx(Icon, {})
|
|
71
110
|
});
|
|
72
111
|
};
|
|
73
112
|
|
|
@@ -83,16 +122,35 @@ NotificationIcon.displayName = 'NotificationIcon';
|
|
|
83
122
|
var getContentBorderColor = function getContentBorderColor(props) {
|
|
84
123
|
switch (props.type) {
|
|
85
124
|
case 'error':
|
|
86
|
-
return designTokens.
|
|
125
|
+
return designTokens.borderColorForContentNotificationWhenError;
|
|
126
|
+
|
|
127
|
+
case 'info':
|
|
128
|
+
return designTokens.borderColorForContentNotificationWhenInfo;
|
|
129
|
+
|
|
130
|
+
case 'warning':
|
|
131
|
+
return designTokens.borderColorForContentNotificationWhenWarning;
|
|
132
|
+
|
|
133
|
+
case 'success':
|
|
134
|
+
return designTokens.borderColorForContentNotificationWhenSuccess;
|
|
135
|
+
|
|
136
|
+
default:
|
|
137
|
+
return '';
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
var getContainerBackgroundColor = function getContainerBackgroundColor(props) {
|
|
142
|
+
switch (props.type) {
|
|
143
|
+
case 'error':
|
|
144
|
+
return designTokens.backgroundColorForContentNotificationWhenError;
|
|
87
145
|
|
|
88
146
|
case 'info':
|
|
89
|
-
return designTokens.
|
|
147
|
+
return designTokens.backgroundColorForContentNotificationWhenInfo;
|
|
90
148
|
|
|
91
149
|
case 'warning':
|
|
92
|
-
return designTokens.
|
|
150
|
+
return designTokens.backgroundColorForContentNotificationWhenWarning;
|
|
93
151
|
|
|
94
152
|
case 'success':
|
|
95
|
-
return designTokens.
|
|
153
|
+
return designTokens.backgroundColorForContentNotificationWhenSuccess;
|
|
96
154
|
|
|
97
155
|
default:
|
|
98
156
|
return '';
|
|
@@ -102,11 +160,11 @@ var getContentBorderColor = function getContentBorderColor(props) {
|
|
|
102
160
|
var ContentNotification = function ContentNotification(props) {
|
|
103
161
|
warnIfMissingContent(props);
|
|
104
162
|
return jsxs("div", _objectSpread(_objectSpread({}, filterDataAttributes(props)), {}, {
|
|
105
|
-
css: /*#__PURE__*/css("display:flex;align-items:stretch;text-align:left;word-break:break-word;hyphens:auto;font-size:", designTokens.
|
|
163
|
+
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,{"version":3,"sources":["content-notification.tsx"],"names":[],"mappings":"AAwLc","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport { Children, ReactNode } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  InfoIcon,\n  CheckBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\ntype 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   * 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 getIconContainerBackgroundColour = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getIconByType = (\n  props: TContentNotificationProps,\n  isNewTheme: boolean\n) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return isNewTheme ? InformationIcon : InfoIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconContainerBorderColor = (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 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 NotificationIcon = (props: TContentNotificationProps) => {\n  const { isNewTheme } = useTheme();\n  const Icon = getIconByType(props, isNewTheme);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        border-radius: ${designTokens.borderRadiusForContentNotificationIcon};\n        border-width: ${designTokens.borderWidthForContentNotificationIcon};\n        border-style: solid;\n        border-color: ${getIconContainerBorderColor(props)};\n        border-right: 0;\n        padding: ${designTokens.paddingForContentNotificationIcon};\n        background-color: ${getIconContainerBackgroundColour(props)};\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationIcon.displayName = 'NotificationIcon';\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      `}\n    >\n      <NotificationIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotification};\n          background-color: ${getContainerBackgroundColor(props)};\n          border-radius: ${designTokens.borderRadiusForContentNotification};\n          border-width: 1px;\n          border-style: solid;\n          border-color: ${getContentBorderColor(props)};\n          border-left-width: ${designTokens.borderLeftWidthForContentNotification};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
106
164
|
children: [jsx(NotificationIcon, {
|
|
107
165
|
type: props.type
|
|
108
166
|
}), jsx("div", {
|
|
109
|
-
css: /*#__PURE__*/css("flex-grow:1;display:flex;align-items:center;padding:", designTokens.
|
|
167
|
+
css: /*#__PURE__*/css("flex-grow:1;display:flex;align-items:center;padding:", designTokens.paddingForContentNotification, ";background-color:", getContainerBackgroundColor(props), ";border-radius:", designTokens.borderRadiusForContentNotification, ";border-width:1px;border-style:solid;border-color:", getContentBorderColor(props), ";border-left-width:", designTokens.borderLeftWidthForContentNotification, ";" + (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":"AAqMgB","file":"content-notification.tsx","sourcesContent":["import type { MessageDescriptor } from 'react-intl';\n\nimport { Children, ReactNode } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport {\n  ErrorIcon,\n  WarningIcon,\n  InfoIcon,\n  CheckBoldIcon,\n  InformationIcon,\n} from '@commercetools-uikit/icons';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\n\ntype 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   * 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 getIconContainerBackgroundColour = (props: TContentNotificationProps) => {\n  switch (props.type) {\n    case 'error':\n      return designTokens.backgroundColorForContentNotificationIconWhenError;\n    case 'info':\n      return designTokens.backgroundColorForContentNotificationIconWhenInfo;\n    case 'warning':\n      return designTokens.backgroundColorForContentNotificationIconWhenWarning;\n    case 'success':\n      return designTokens.backgroundColorForContentNotificationIconWhenSuccess;\n    default:\n      return '';\n  }\n};\n\nconst getIconByType = (\n  props: TContentNotificationProps,\n  isNewTheme: boolean\n) => {\n  switch (props.type) {\n    case 'error':\n      return ErrorIcon;\n    case 'info':\n      return isNewTheme ? InformationIcon : InfoIcon;\n    case 'warning':\n      return WarningIcon;\n    default:\n      return CheckBoldIcon;\n  }\n};\n\nconst getIconContainerBorderColor = (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 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 NotificationIcon = (props: TContentNotificationProps) => {\n  const { isNewTheme } = useTheme();\n  const Icon = getIconByType(props, isNewTheme);\n  return (\n    <div\n      css={css`\n        display: flex;\n        align-items: center;\n        border-radius: ${designTokens.borderRadiusForContentNotificationIcon};\n        border-width: ${designTokens.borderWidthForContentNotificationIcon};\n        border-style: solid;\n        border-color: ${getIconContainerBorderColor(props)};\n        border-right: 0;\n        padding: ${designTokens.paddingForContentNotificationIcon};\n        background-color: ${getIconContainerBackgroundColour(props)};\n        fill: ${getIconColor(props)};\n        svg {\n          margin: 0 -3px;\n        }\n      `}\n    >\n      <Icon />\n    </div>\n  );\n};\nNotificationIcon.displayName = 'NotificationIcon';\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      `}\n    >\n      <NotificationIcon type={props.type} />\n      <div\n        css={css`\n          flex-grow: 1;\n          display: flex;\n          align-items: center;\n          padding: ${designTokens.paddingForContentNotification};\n          background-color: ${getContainerBackgroundColor(props)};\n          border-radius: ${designTokens.borderRadiusForContentNotification};\n          border-width: 1px;\n          border-style: solid;\n          border-color: ${getContentBorderColor(props)};\n          border-left-width: ${designTokens.borderLeftWidthForContentNotification};\n        `}\n      >\n        {props.intlMessage ? (\n          <div>\n            <FormattedMessage {...props.intlMessage} />\n          </div>\n        ) : (\n          props.children\n        )}\n      </div>\n    </div>\n  );\n};\nContentNotification.displayName = 'ContentNotification';\n\nexport default ContentNotification;\n"]} */"),
|
|
110
168
|
children: props.intlMessage ? jsx("div", {
|
|
111
169
|
children: jsx(FormattedMessage, _objectSpread({}, props.intlMessage))
|
|
112
170
|
}) : props.children
|
|
@@ -125,6 +183,6 @@ ContentNotification.displayName = 'ContentNotification';
|
|
|
125
183
|
var ContentNotification$1 = ContentNotification;
|
|
126
184
|
|
|
127
185
|
// NOTE: This string will be replaced on build time with the package version.
|
|
128
|
-
var version = "15.
|
|
186
|
+
var version = "15.11.1";
|
|
129
187
|
|
|
130
188
|
export { ContentNotification$1 as ContentNotification, version };
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/notifications",
|
|
3
3
|
"description": "Notification components.",
|
|
4
|
-
"version": "15.
|
|
4
|
+
"version": "15.11.1",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,9 +21,9 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.19.0",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.19.1",
|
|
24
|
-
"@commercetools-uikit/design-system": "15.
|
|
25
|
-
"@commercetools-uikit/icons": "15.
|
|
26
|
-
"@commercetools-uikit/utils": "15.
|
|
24
|
+
"@commercetools-uikit/design-system": "15.11.1",
|
|
25
|
+
"@commercetools-uikit/icons": "15.11.1",
|
|
26
|
+
"@commercetools-uikit/utils": "15.11.1",
|
|
27
27
|
"@emotion/react": "^11.4.0",
|
|
28
28
|
"prop-types": "15.8.1"
|
|
29
29
|
},
|