@commercetools-frontend/application-components 22.38.0 → 22.38.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.
- package/dist/commercetools-frontend-application-components.cjs.dev.js +431 -635
- package/dist/commercetools-frontend-application-components.cjs.prod.js +396 -562
- package/dist/commercetools-frontend-application-components.esm.js +431 -633
- package/dist/custom-views-selector-490b4a72.esm.js +256 -0
- package/dist/custom-views-selector-dacff7f7.cjs.dev.js +278 -0
- package/dist/custom-views-selector-efdd6e55.cjs.prod.js +247 -0
- package/dist/declarations/src/components/custom-views/custom-views-selector/custom-views-selector.d.ts +1 -8
- package/dist/declarations/src/components/custom-views/custom-views-selector/index.d.ts +3 -1
- package/dist/declarations/src/components/custom-views/custom-views-selector/types.d.ts +12 -0
- package/dist/declarations/src/components/detail-pages/tabular-detail-page/tabular-detail-page.d.ts +5 -2
- package/dist/declarations/src/components/main-pages/tabular-main-page/tabular-main-page.d.ts +15 -12
- package/dist/declarations/src/components/modal-pages/tabular-modal-page/tabular-modal-page.d.ts +2 -2
- package/package.json +9 -9
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
4
|
+
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
5
|
+
var _styled = require('@emotion/styled/base');
|
|
6
|
+
var _pt = require('prop-types');
|
|
7
|
+
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
8
|
+
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
9
|
+
var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
10
|
+
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
11
|
+
var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
12
|
+
var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
|
|
13
|
+
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
14
|
+
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
15
|
+
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
16
|
+
var react$1 = require('react');
|
|
17
|
+
var react = require('@emotion/react');
|
|
18
|
+
var sentry = require('@commercetools-frontend/sentry');
|
|
19
|
+
var AccessibleButton = require('@commercetools-uikit/accessible-button');
|
|
20
|
+
var Constraints = require('@commercetools-uikit/constraints');
|
|
21
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
22
|
+
var icons = require('@commercetools-uikit/icons');
|
|
23
|
+
var Spacings = require('@commercetools-uikit/spacings');
|
|
24
|
+
var Text = require('@commercetools-uikit/text');
|
|
25
|
+
var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
26
|
+
var _Object$entries = require('@babel/runtime-corejs3/core-js-stable/object/entries');
|
|
27
|
+
var reactRouterDom = require('react-router-dom');
|
|
28
|
+
var dist_commercetoolsFrontendApplicationComponents = require('./commercetools-frontend-application-components.cjs.dev.js');
|
|
29
|
+
var reactIntl = require('react-intl');
|
|
30
|
+
var reactBroadcast = require('@flopflip/react-broadcast');
|
|
31
|
+
var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
|
|
32
|
+
var constants = require('@commercetools-frontend/constants');
|
|
33
|
+
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
34
|
+
require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
35
|
+
require('@commercetools-uikit/utils');
|
|
36
|
+
require('react-modal');
|
|
37
|
+
require('@commercetools-uikit/card');
|
|
38
|
+
require('@commercetools-uikit/secondary-icon-button');
|
|
39
|
+
require('@commercetools-frontend/i18n');
|
|
40
|
+
require('@commercetools-uikit/primary-button');
|
|
41
|
+
require('@commercetools-uikit/secondary-button');
|
|
42
|
+
require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
|
|
43
|
+
require('lodash/omitBy');
|
|
44
|
+
require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
45
|
+
require('@babel/runtime-corejs3/core-js-stable/set-timeout');
|
|
46
|
+
require('@commercetools-uikit/flat-button');
|
|
47
|
+
require('@commercetools-uikit/icon-button');
|
|
48
|
+
require('@commercetools-frontend/assets/images/page-not-found.svg');
|
|
49
|
+
require('@commercetools-frontend/assets/images/doors-closed.svg');
|
|
50
|
+
require('@commercetools-frontend/actions-global');
|
|
51
|
+
require('@babel/runtime-corejs3/core-js-stable/instance/values');
|
|
52
|
+
require('@commercetools-uikit/stamp');
|
|
53
|
+
require('@react-hook/resize-observer');
|
|
54
|
+
require('@commercetools-uikit/hooks');
|
|
55
|
+
|
|
56
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
57
|
+
|
|
58
|
+
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
59
|
+
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
60
|
+
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
61
|
+
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
62
|
+
var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
|
|
63
|
+
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
64
|
+
var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
|
|
65
|
+
var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
|
|
66
|
+
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
67
|
+
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
68
|
+
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
69
|
+
var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
|
|
70
|
+
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
71
|
+
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
72
|
+
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
73
|
+
var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
|
|
74
|
+
var _Object$entries__default = /*#__PURE__*/_interopDefault(_Object$entries);
|
|
75
|
+
|
|
76
|
+
const pathWithoutSearch = path => typeof path === 'string' ? path.split('?')[0] : path.pathname;
|
|
77
|
+
const useCustomViewLocatorSelector = function () {
|
|
78
|
+
var _context;
|
|
79
|
+
let customViewLocatorCodes = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
80
|
+
const location = reactRouterDom.useLocation();
|
|
81
|
+
if (!customViewLocatorCodes) {
|
|
82
|
+
return {
|
|
83
|
+
currentCustomViewLocatorCode: undefined
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
const customViewLocator = _findInstanceProperty__default["default"](_context = _Object$entries__default["default"](customViewLocatorCodes)).call(_context, _ref => {
|
|
87
|
+
let _ref2 = _slicedToArray(_ref, 2),
|
|
88
|
+
locator = _ref2[1];
|
|
89
|
+
return reactRouterDom.matchPath(location.pathname, {
|
|
90
|
+
// strip the search, otherwise the path won't match
|
|
91
|
+
path: pathWithoutSearch(locator),
|
|
92
|
+
exact: true,
|
|
93
|
+
strict: false
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
return {
|
|
97
|
+
currentCustomViewLocatorCode: customViewLocator?.[0]
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
var messages = reactIntl.defineMessages({
|
|
102
|
+
title: {
|
|
103
|
+
id: "CustomViewsSelector.title",
|
|
104
|
+
defaultMessage: "Custom Views:"
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
var FetchCustomViewsQuery = { kind: "Document", definitions: [{ kind: "OperationDefinition", operation: "query", name: { kind: "Name", value: "FetchCustomViewsByLocator" }, variableDefinitions: [{ kind: "VariableDefinition", variable: { kind: "Variable", name: { kind: "Name", value: "customViewLocatorCode" } }, type: { kind: "NonNullType", type: { kind: "NamedType", name: { kind: "Name", value: "String" } } }, directives: [] }], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "allCustomViewsInstallationsByLocator" }, arguments: [{ kind: "Argument", name: { kind: "Name", value: "locator" }, value: { kind: "Variable", name: { kind: "Name", value: "customViewLocatorCode" } } }], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "id" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "customView" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "id" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "defaultLabel" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "labelAllLocales" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "locale" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "url" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "type" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "typeSettings" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "size" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "locators" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "permissions" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "oAuthScopes" }, arguments: [], directives: [] }] } }] } }] } }] } }], loc: { start: 0, end: 405, source: { body: "query FetchCustomViewsByLocator($customViewLocatorCode: String!) {\n allCustomViewsInstallationsByLocator(locator: $customViewLocatorCode) {\n id\n customView {\n id\n defaultLabel\n labelAllLocales {\n locale\n value\n }\n url\n type\n typeSettings {\n size\n }\n locators\n permissions {\n name\n oAuthScopes\n }\n }\n }\n}\n", name: "GraphQL request", locationOffset: { line: 1, column: 1 } } } };
|
|
109
|
+
const useCustomViewsConnector = _ref => {
|
|
110
|
+
let customViewLocatorCode = _ref.customViewLocatorCode;
|
|
111
|
+
const enableCustomViews = reactBroadcast.useFlagVariation(constants.featureFlags.CUSTOM_VIEWS);
|
|
112
|
+
const areCustomViewsEnabled =
|
|
113
|
+
// @ts-ignore In case it's coming from the MC API, it's an object { value: boolean }.
|
|
114
|
+
(enableCustomViews?.value ?? enableCustomViews) && process.env.DISABLE_CUSTOM_VIEWS_FEATURE !== 'true';
|
|
115
|
+
const _useMcQuery = applicationShellConnectors.useMcQuery(FetchCustomViewsQuery, {
|
|
116
|
+
variables: {
|
|
117
|
+
customViewLocatorCode
|
|
118
|
+
},
|
|
119
|
+
context: {
|
|
120
|
+
target: constants.GRAPHQL_TARGETS.SETTINGS_SERVICE
|
|
121
|
+
},
|
|
122
|
+
skip: !areCustomViewsEnabled
|
|
123
|
+
}),
|
|
124
|
+
data = _useMcQuery.data,
|
|
125
|
+
error = _useMcQuery.error,
|
|
126
|
+
loading = _useMcQuery.loading;
|
|
127
|
+
return {
|
|
128
|
+
customViews: data?.allCustomViewsInstallationsByLocator?.map(installation => installation.customView) || [],
|
|
129
|
+
error,
|
|
130
|
+
loading
|
|
131
|
+
};
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
135
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
136
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
137
|
+
const COMPONENT_HEIGHT = '52px';
|
|
138
|
+
const Wrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
139
|
+
target: "e16cb3zv3"
|
|
140
|
+
} : {
|
|
141
|
+
target: "e16cb3zv3",
|
|
142
|
+
label: "Wrapper"
|
|
143
|
+
})("height:", props => props.shouldRender ? COMPONENT_HEIGHT : '0', ";overflow:hidden;transition:margin 0.3s ease-in-out,height 0.3s ease-in-out;margin:", props => props.shouldRender ? props.margin : '0', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["custom-views-selector.tsx"],"names":[],"mappings":"AAmCyC","file":"custom-views-selector.tsx","sourcesContent":["import {\n  useEffect,\n  useState,\n  Fragment,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CustomViewData } from '@commercetools-frontend/constants';\nimport { reportErrorToSentry } from '@commercetools-frontend/sentry';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { WindowEyeIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport useCustomViewLocatorSelector from '../../../hooks/use-custom-view-locator-selector';\nimport CustomViewLoader from '../custom-view-loader';\nimport messages from './messages';\nimport type { TCustomViewSelectorProps } from './types';\nimport { useCustomViewsConnector } from './use-custom-views-connector';\n\nconst COMPONENT_HEIGHT = '52px';\n\ntype TCustomViewSelectorWithRequiredProps = {\n  customViewLocatorCode: string;\n  margin?: string;\n  onCustomViewsResolved?: TCustomViewSelectorProps['onCustomViewsResolved'];\n};\n\ntype TWrapperProps = {\n  shouldRender: boolean;\n  margin?: string;\n};\nconst Wrapper = styled.div<TWrapperProps>`\n  height: ${(props) => (props.shouldRender ? COMPONENT_HEIGHT : '0')};\n  overflow: hidden;\n  transition: margin 0.3s ease-in-out, height 0.3s ease-in-out;\n  margin: ${(props) => (props.shouldRender ? props.margin : '0')};\n`;\n\nconst Container = styled.div`\n  background-color: ${designTokens.colorNeutral98};\n  padding: 10px ${designTokens.spacing30};\n  border: 1px solid ${designTokens.colorNeutral95};\n  border-radius: ${designTokens.borderRadius8};\n`;\n\nconst hoverAndSelectedStateStyles = css`\n  box-shadow: ${designTokens.shadow1};\n  background-color: ${designTokens.colorSurface};\n  color: ${designTokens.colorPrimary30};\n`;\n\ntype TCustomViewSelectorItemProps = {\n  selected?: boolean;\n  label: string;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n};\n\nconst CustomViewSelectorItem = (props: TCustomViewSelectorItemProps) => {\n  return (\n    <AccessibleButton\n      css={css`\n        display: flex;\n        align-items: center;\n        padding: ${designTokens.spacing20} ${designTokens.spacing25};\n        height: 30px;\n        border-radius: ${designTokens.borderRadius6};\n        color: ${designTokens.colorPrimary};\n        ${props.selected && hoverAndSelectedStateStyles}\n\n        :hover {\n          ${hoverAndSelectedStateStyles};\n        }\n      `}\n      onClick={props.onClick}\n      label={props.label}\n    >\n      <Text.Detail\n        tone=\"inherit\"\n        fontWeight={props.selected ? 'bold' : 'regular'}\n      >\n        {props.label}\n      </Text.Detail>\n    </AccessibleButton>\n  );\n};\n\nconst SelectorLabel = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  div {\n    font-weight: 300;\n  }\n`;\n\nconst Separator = styled.span`\n  width: 1px;\n  height: 18px;\n  background-color: #cccccc;\n`;\n\nfunction CustomViewSelector(props: TCustomViewSelectorWithRequiredProps) {\n  const [selectedCustomView, setSelectedCustomView] =\n    useState<CustomViewData | null>(null);\n  const { customViews, error, loading } = useCustomViewsConnector({\n    customViewLocatorCode: props.customViewLocatorCode,\n  });\n\n  const { onCustomViewsResolved } = props;\n  useEffect(() => {\n    if (!loading && !error && onCustomViewsResolved) {\n      onCustomViewsResolved(customViews);\n    }\n  }, [customViews, error, loading, onCustomViewsResolved]);\n  if (error) {\n    reportErrorToSentry(error, {\n      extra: {\n        customViewLocatorCode: props.customViewLocatorCode,\n      },\n    });\n    return null;\n  }\n\n  return (\n    <Wrapper shouldRender={customViews.length > 0} margin={props.margin || '0'}>\n      <Container>\n        <Constraints.Horizontal max=\"scale\">\n          <Spacings.Inline\n            scale=\"s\"\n            justifyContent=\"flex-start\"\n            alignItems=\"center\"\n          >\n            <SelectorLabel>\n              <WindowEyeIcon size=\"medium\" color=\"neutral60\" />\n              <Text.Detail tone=\"secondary\" intlMessage={messages.title} />\n            </SelectorLabel>\n            {customViews.map((customView, index) => {\n              const isNotLastItem = index !== customViews.length - 1;\n              return (\n                <Fragment key={customView.id}>\n                  <CustomViewSelectorItem\n                    selected={selectedCustomView?.id === customView.id}\n                    onClick={() => {\n                      setSelectedCustomView(customView);\n                    }}\n                    label={customView.defaultLabel}\n                  />\n                  {isNotLastItem && <Separator />}\n                </Fragment>\n              );\n            })}\n          </Spacings.Inline>\n\n          {selectedCustomView && (\n            <CustomViewLoader\n              customView={selectedCustomView}\n              onClose={() => {\n                setSelectedCustomView(null);\n              }}\n            />\n          )}\n        </Constraints.Horizontal>\n      </Container>\n    </Wrapper>\n  );\n}\nCustomViewSelector.displayName = 'CustomViewSelector';\n\nconst CustomViewSelectorOrNothing = (props: TCustomViewSelectorProps) => {\n  const { currentCustomViewLocatorCode } = useCustomViewLocatorSelector(\n    props.customViewLocatorCodes\n  );\n\n  const locatorCode =\n    currentCustomViewLocatorCode ?? props.customViewLocatorCode;\n\n  if (!locatorCode) {\n    return null;\n  }\n\n  return <CustomViewSelector {...props} customViewLocatorCode={locatorCode} />;\n};\n\nexport default CustomViewSelectorOrNothing;\n"]} */"));
|
|
144
|
+
const Container = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
145
|
+
target: "e16cb3zv2"
|
|
146
|
+
} : {
|
|
147
|
+
target: "e16cb3zv2",
|
|
148
|
+
label: "Container"
|
|
149
|
+
})("background-color:", designSystem.designTokens.colorNeutral98, ";padding:10px ", designSystem.designTokens.spacing30, ";border:1px solid ", designSystem.designTokens.colorNeutral95, ";border-radius:", designSystem.designTokens.borderRadius8, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["custom-views-selector.tsx"],"names":[],"mappings":"AA0C4B","file":"custom-views-selector.tsx","sourcesContent":["import {\n  useEffect,\n  useState,\n  Fragment,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CustomViewData } from '@commercetools-frontend/constants';\nimport { reportErrorToSentry } from '@commercetools-frontend/sentry';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { WindowEyeIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport useCustomViewLocatorSelector from '../../../hooks/use-custom-view-locator-selector';\nimport CustomViewLoader from '../custom-view-loader';\nimport messages from './messages';\nimport type { TCustomViewSelectorProps } from './types';\nimport { useCustomViewsConnector } from './use-custom-views-connector';\n\nconst COMPONENT_HEIGHT = '52px';\n\ntype TCustomViewSelectorWithRequiredProps = {\n  customViewLocatorCode: string;\n  margin?: string;\n  onCustomViewsResolved?: TCustomViewSelectorProps['onCustomViewsResolved'];\n};\n\ntype TWrapperProps = {\n  shouldRender: boolean;\n  margin?: string;\n};\nconst Wrapper = styled.div<TWrapperProps>`\n  height: ${(props) => (props.shouldRender ? COMPONENT_HEIGHT : '0')};\n  overflow: hidden;\n  transition: margin 0.3s ease-in-out, height 0.3s ease-in-out;\n  margin: ${(props) => (props.shouldRender ? props.margin : '0')};\n`;\n\nconst Container = styled.div`\n  background-color: ${designTokens.colorNeutral98};\n  padding: 10px ${designTokens.spacing30};\n  border: 1px solid ${designTokens.colorNeutral95};\n  border-radius: ${designTokens.borderRadius8};\n`;\n\nconst hoverAndSelectedStateStyles = css`\n  box-shadow: ${designTokens.shadow1};\n  background-color: ${designTokens.colorSurface};\n  color: ${designTokens.colorPrimary30};\n`;\n\ntype TCustomViewSelectorItemProps = {\n  selected?: boolean;\n  label: string;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n};\n\nconst CustomViewSelectorItem = (props: TCustomViewSelectorItemProps) => {\n  return (\n    <AccessibleButton\n      css={css`\n        display: flex;\n        align-items: center;\n        padding: ${designTokens.spacing20} ${designTokens.spacing25};\n        height: 30px;\n        border-radius: ${designTokens.borderRadius6};\n        color: ${designTokens.colorPrimary};\n        ${props.selected && hoverAndSelectedStateStyles}\n\n        :hover {\n          ${hoverAndSelectedStateStyles};\n        }\n      `}\n      onClick={props.onClick}\n      label={props.label}\n    >\n      <Text.Detail\n        tone=\"inherit\"\n        fontWeight={props.selected ? 'bold' : 'regular'}\n      >\n        {props.label}\n      </Text.Detail>\n    </AccessibleButton>\n  );\n};\n\nconst SelectorLabel = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  div {\n    font-weight: 300;\n  }\n`;\n\nconst Separator = styled.span`\n  width: 1px;\n  height: 18px;\n  background-color: #cccccc;\n`;\n\nfunction CustomViewSelector(props: TCustomViewSelectorWithRequiredProps) {\n  const [selectedCustomView, setSelectedCustomView] =\n    useState<CustomViewData | null>(null);\n  const { customViews, error, loading } = useCustomViewsConnector({\n    customViewLocatorCode: props.customViewLocatorCode,\n  });\n\n  const { onCustomViewsResolved } = props;\n  useEffect(() => {\n    if (!loading && !error && onCustomViewsResolved) {\n      onCustomViewsResolved(customViews);\n    }\n  }, [customViews, error, loading, onCustomViewsResolved]);\n  if (error) {\n    reportErrorToSentry(error, {\n      extra: {\n        customViewLocatorCode: props.customViewLocatorCode,\n      },\n    });\n    return null;\n  }\n\n  return (\n    <Wrapper shouldRender={customViews.length > 0} margin={props.margin || '0'}>\n      <Container>\n        <Constraints.Horizontal max=\"scale\">\n          <Spacings.Inline\n            scale=\"s\"\n            justifyContent=\"flex-start\"\n            alignItems=\"center\"\n          >\n            <SelectorLabel>\n              <WindowEyeIcon size=\"medium\" color=\"neutral60\" />\n              <Text.Detail tone=\"secondary\" intlMessage={messages.title} />\n            </SelectorLabel>\n            {customViews.map((customView, index) => {\n              const isNotLastItem = index !== customViews.length - 1;\n              return (\n                <Fragment key={customView.id}>\n                  <CustomViewSelectorItem\n                    selected={selectedCustomView?.id === customView.id}\n                    onClick={() => {\n                      setSelectedCustomView(customView);\n                    }}\n                    label={customView.defaultLabel}\n                  />\n                  {isNotLastItem && <Separator />}\n                </Fragment>\n              );\n            })}\n          </Spacings.Inline>\n\n          {selectedCustomView && (\n            <CustomViewLoader\n              customView={selectedCustomView}\n              onClose={() => {\n                setSelectedCustomView(null);\n              }}\n            />\n          )}\n        </Constraints.Horizontal>\n      </Container>\n    </Wrapper>\n  );\n}\nCustomViewSelector.displayName = 'CustomViewSelector';\n\nconst CustomViewSelectorOrNothing = (props: TCustomViewSelectorProps) => {\n  const { currentCustomViewLocatorCode } = useCustomViewLocatorSelector(\n    props.customViewLocatorCodes\n  );\n\n  const locatorCode =\n    currentCustomViewLocatorCode ?? props.customViewLocatorCode;\n\n  if (!locatorCode) {\n    return null;\n  }\n\n  return <CustomViewSelector {...props} customViewLocatorCode={locatorCode} />;\n};\n\nexport default CustomViewSelectorOrNothing;\n"]} */"));
|
|
150
|
+
const hoverAndSelectedStateStyles = /*#__PURE__*/react.css("box-shadow:", designSystem.designTokens.shadow1, ";background-color:", designSystem.designTokens.colorSurface, ";color:", designSystem.designTokens.colorPrimary30, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:hoverAndSelectedStateStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["custom-views-selector.tsx"],"names":[],"mappings":"AAiDuC","file":"custom-views-selector.tsx","sourcesContent":["import {\n  useEffect,\n  useState,\n  Fragment,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CustomViewData } from '@commercetools-frontend/constants';\nimport { reportErrorToSentry } from '@commercetools-frontend/sentry';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { WindowEyeIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport useCustomViewLocatorSelector from '../../../hooks/use-custom-view-locator-selector';\nimport CustomViewLoader from '../custom-view-loader';\nimport messages from './messages';\nimport type { TCustomViewSelectorProps } from './types';\nimport { useCustomViewsConnector } from './use-custom-views-connector';\n\nconst COMPONENT_HEIGHT = '52px';\n\ntype TCustomViewSelectorWithRequiredProps = {\n  customViewLocatorCode: string;\n  margin?: string;\n  onCustomViewsResolved?: TCustomViewSelectorProps['onCustomViewsResolved'];\n};\n\ntype TWrapperProps = {\n  shouldRender: boolean;\n  margin?: string;\n};\nconst Wrapper = styled.div<TWrapperProps>`\n  height: ${(props) => (props.shouldRender ? COMPONENT_HEIGHT : '0')};\n  overflow: hidden;\n  transition: margin 0.3s ease-in-out, height 0.3s ease-in-out;\n  margin: ${(props) => (props.shouldRender ? props.margin : '0')};\n`;\n\nconst Container = styled.div`\n  background-color: ${designTokens.colorNeutral98};\n  padding: 10px ${designTokens.spacing30};\n  border: 1px solid ${designTokens.colorNeutral95};\n  border-radius: ${designTokens.borderRadius8};\n`;\n\nconst hoverAndSelectedStateStyles = css`\n  box-shadow: ${designTokens.shadow1};\n  background-color: ${designTokens.colorSurface};\n  color: ${designTokens.colorPrimary30};\n`;\n\ntype TCustomViewSelectorItemProps = {\n  selected?: boolean;\n  label: string;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n};\n\nconst CustomViewSelectorItem = (props: TCustomViewSelectorItemProps) => {\n  return (\n    <AccessibleButton\n      css={css`\n        display: flex;\n        align-items: center;\n        padding: ${designTokens.spacing20} ${designTokens.spacing25};\n        height: 30px;\n        border-radius: ${designTokens.borderRadius6};\n        color: ${designTokens.colorPrimary};\n        ${props.selected && hoverAndSelectedStateStyles}\n\n        :hover {\n          ${hoverAndSelectedStateStyles};\n        }\n      `}\n      onClick={props.onClick}\n      label={props.label}\n    >\n      <Text.Detail\n        tone=\"inherit\"\n        fontWeight={props.selected ? 'bold' : 'regular'}\n      >\n        {props.label}\n      </Text.Detail>\n    </AccessibleButton>\n  );\n};\n\nconst SelectorLabel = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  div {\n    font-weight: 300;\n  }\n`;\n\nconst Separator = styled.span`\n  width: 1px;\n  height: 18px;\n  background-color: #cccccc;\n`;\n\nfunction CustomViewSelector(props: TCustomViewSelectorWithRequiredProps) {\n  const [selectedCustomView, setSelectedCustomView] =\n    useState<CustomViewData | null>(null);\n  const { customViews, error, loading } = useCustomViewsConnector({\n    customViewLocatorCode: props.customViewLocatorCode,\n  });\n\n  const { onCustomViewsResolved } = props;\n  useEffect(() => {\n    if (!loading && !error && onCustomViewsResolved) {\n      onCustomViewsResolved(customViews);\n    }\n  }, [customViews, error, loading, onCustomViewsResolved]);\n  if (error) {\n    reportErrorToSentry(error, {\n      extra: {\n        customViewLocatorCode: props.customViewLocatorCode,\n      },\n    });\n    return null;\n  }\n\n  return (\n    <Wrapper shouldRender={customViews.length > 0} margin={props.margin || '0'}>\n      <Container>\n        <Constraints.Horizontal max=\"scale\">\n          <Spacings.Inline\n            scale=\"s\"\n            justifyContent=\"flex-start\"\n            alignItems=\"center\"\n          >\n            <SelectorLabel>\n              <WindowEyeIcon size=\"medium\" color=\"neutral60\" />\n              <Text.Detail tone=\"secondary\" intlMessage={messages.title} />\n            </SelectorLabel>\n            {customViews.map((customView, index) => {\n              const isNotLastItem = index !== customViews.length - 1;\n              return (\n                <Fragment key={customView.id}>\n                  <CustomViewSelectorItem\n                    selected={selectedCustomView?.id === customView.id}\n                    onClick={() => {\n                      setSelectedCustomView(customView);\n                    }}\n                    label={customView.defaultLabel}\n                  />\n                  {isNotLastItem && <Separator />}\n                </Fragment>\n              );\n            })}\n          </Spacings.Inline>\n\n          {selectedCustomView && (\n            <CustomViewLoader\n              customView={selectedCustomView}\n              onClose={() => {\n                setSelectedCustomView(null);\n              }}\n            />\n          )}\n        </Constraints.Horizontal>\n      </Container>\n    </Wrapper>\n  );\n}\nCustomViewSelector.displayName = 'CustomViewSelector';\n\nconst CustomViewSelectorOrNothing = (props: TCustomViewSelectorProps) => {\n  const { currentCustomViewLocatorCode } = useCustomViewLocatorSelector(\n    props.customViewLocatorCodes\n  );\n\n  const locatorCode =\n    currentCustomViewLocatorCode ?? props.customViewLocatorCode;\n\n  if (!locatorCode) {\n    return null;\n  }\n\n  return <CustomViewSelector {...props} customViewLocatorCode={locatorCode} />;\n};\n\nexport default CustomViewSelectorOrNothing;\n"]} */");
|
|
151
|
+
const CustomViewSelectorItem = props => {
|
|
152
|
+
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
153
|
+
css: /*#__PURE__*/react.css("display:flex;align-items:center;padding:", designSystem.designTokens.spacing20, " ", designSystem.designTokens.spacing25, ";height:30px;border-radius:", designSystem.designTokens.borderRadius6, ";color:", designSystem.designTokens.colorPrimary, ";", props.selected && hoverAndSelectedStateStyles, " :hover{", hoverAndSelectedStateStyles, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:CustomViewSelectorItem;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["custom-views-selector.tsx"],"names":[],"mappings":"AAkEc","file":"custom-views-selector.tsx","sourcesContent":["import {\n  useEffect,\n  useState,\n  Fragment,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CustomViewData } from '@commercetools-frontend/constants';\nimport { reportErrorToSentry } from '@commercetools-frontend/sentry';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { WindowEyeIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport useCustomViewLocatorSelector from '../../../hooks/use-custom-view-locator-selector';\nimport CustomViewLoader from '../custom-view-loader';\nimport messages from './messages';\nimport type { TCustomViewSelectorProps } from './types';\nimport { useCustomViewsConnector } from './use-custom-views-connector';\n\nconst COMPONENT_HEIGHT = '52px';\n\ntype TCustomViewSelectorWithRequiredProps = {\n  customViewLocatorCode: string;\n  margin?: string;\n  onCustomViewsResolved?: TCustomViewSelectorProps['onCustomViewsResolved'];\n};\n\ntype TWrapperProps = {\n  shouldRender: boolean;\n  margin?: string;\n};\nconst Wrapper = styled.div<TWrapperProps>`\n  height: ${(props) => (props.shouldRender ? COMPONENT_HEIGHT : '0')};\n  overflow: hidden;\n  transition: margin 0.3s ease-in-out, height 0.3s ease-in-out;\n  margin: ${(props) => (props.shouldRender ? props.margin : '0')};\n`;\n\nconst Container = styled.div`\n  background-color: ${designTokens.colorNeutral98};\n  padding: 10px ${designTokens.spacing30};\n  border: 1px solid ${designTokens.colorNeutral95};\n  border-radius: ${designTokens.borderRadius8};\n`;\n\nconst hoverAndSelectedStateStyles = css`\n  box-shadow: ${designTokens.shadow1};\n  background-color: ${designTokens.colorSurface};\n  color: ${designTokens.colorPrimary30};\n`;\n\ntype TCustomViewSelectorItemProps = {\n  selected?: boolean;\n  label: string;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n};\n\nconst CustomViewSelectorItem = (props: TCustomViewSelectorItemProps) => {\n  return (\n    <AccessibleButton\n      css={css`\n        display: flex;\n        align-items: center;\n        padding: ${designTokens.spacing20} ${designTokens.spacing25};\n        height: 30px;\n        border-radius: ${designTokens.borderRadius6};\n        color: ${designTokens.colorPrimary};\n        ${props.selected && hoverAndSelectedStateStyles}\n\n        :hover {\n          ${hoverAndSelectedStateStyles};\n        }\n      `}\n      onClick={props.onClick}\n      label={props.label}\n    >\n      <Text.Detail\n        tone=\"inherit\"\n        fontWeight={props.selected ? 'bold' : 'regular'}\n      >\n        {props.label}\n      </Text.Detail>\n    </AccessibleButton>\n  );\n};\n\nconst SelectorLabel = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  div {\n    font-weight: 300;\n  }\n`;\n\nconst Separator = styled.span`\n  width: 1px;\n  height: 18px;\n  background-color: #cccccc;\n`;\n\nfunction CustomViewSelector(props: TCustomViewSelectorWithRequiredProps) {\n  const [selectedCustomView, setSelectedCustomView] =\n    useState<CustomViewData | null>(null);\n  const { customViews, error, loading } = useCustomViewsConnector({\n    customViewLocatorCode: props.customViewLocatorCode,\n  });\n\n  const { onCustomViewsResolved } = props;\n  useEffect(() => {\n    if (!loading && !error && onCustomViewsResolved) {\n      onCustomViewsResolved(customViews);\n    }\n  }, [customViews, error, loading, onCustomViewsResolved]);\n  if (error) {\n    reportErrorToSentry(error, {\n      extra: {\n        customViewLocatorCode: props.customViewLocatorCode,\n      },\n    });\n    return null;\n  }\n\n  return (\n    <Wrapper shouldRender={customViews.length > 0} margin={props.margin || '0'}>\n      <Container>\n        <Constraints.Horizontal max=\"scale\">\n          <Spacings.Inline\n            scale=\"s\"\n            justifyContent=\"flex-start\"\n            alignItems=\"center\"\n          >\n            <SelectorLabel>\n              <WindowEyeIcon size=\"medium\" color=\"neutral60\" />\n              <Text.Detail tone=\"secondary\" intlMessage={messages.title} />\n            </SelectorLabel>\n            {customViews.map((customView, index) => {\n              const isNotLastItem = index !== customViews.length - 1;\n              return (\n                <Fragment key={customView.id}>\n                  <CustomViewSelectorItem\n                    selected={selectedCustomView?.id === customView.id}\n                    onClick={() => {\n                      setSelectedCustomView(customView);\n                    }}\n                    label={customView.defaultLabel}\n                  />\n                  {isNotLastItem && <Separator />}\n                </Fragment>\n              );\n            })}\n          </Spacings.Inline>\n\n          {selectedCustomView && (\n            <CustomViewLoader\n              customView={selectedCustomView}\n              onClose={() => {\n                setSelectedCustomView(null);\n              }}\n            />\n          )}\n        </Constraints.Horizontal>\n      </Container>\n    </Wrapper>\n  );\n}\nCustomViewSelector.displayName = 'CustomViewSelector';\n\nconst CustomViewSelectorOrNothing = (props: TCustomViewSelectorProps) => {\n  const { currentCustomViewLocatorCode } = useCustomViewLocatorSelector(\n    props.customViewLocatorCodes\n  );\n\n  const locatorCode =\n    currentCustomViewLocatorCode ?? props.customViewLocatorCode;\n\n  if (!locatorCode) {\n    return null;\n  }\n\n  return <CustomViewSelector {...props} customViewLocatorCode={locatorCode} />;\n};\n\nexport default CustomViewSelectorOrNothing;\n"]} */"),
|
|
154
|
+
onClick: props.onClick,
|
|
155
|
+
label: props.label,
|
|
156
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
157
|
+
tone: "inherit",
|
|
158
|
+
fontWeight: props.selected ? 'bold' : 'regular',
|
|
159
|
+
children: props.label
|
|
160
|
+
})
|
|
161
|
+
});
|
|
162
|
+
};
|
|
163
|
+
CustomViewSelectorItem.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
164
|
+
selected: _pt__default["default"].bool,
|
|
165
|
+
label: _pt__default["default"].string.isRequired,
|
|
166
|
+
onClick: _pt__default["default"].func
|
|
167
|
+
} : {};
|
|
168
|
+
const SelectorLabel = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
169
|
+
target: "e16cb3zv1"
|
|
170
|
+
} : {
|
|
171
|
+
target: "e16cb3zv1",
|
|
172
|
+
label: "SelectorLabel"
|
|
173
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
174
|
+
name: "1i68o0s",
|
|
175
|
+
styles: "display:flex;align-items:center;gap:6px;div{font-weight:300;}"
|
|
176
|
+
} : {
|
|
177
|
+
name: "1i68o0s",
|
|
178
|
+
styles: "display:flex;align-items:center;gap:6px;div{font-weight:300;}",
|
|
179
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["custom-views-selector.tsx"],"names":[],"mappings":"AA4FgC","file":"custom-views-selector.tsx","sourcesContent":["import {\n  useEffect,\n  useState,\n  Fragment,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CustomViewData } from '@commercetools-frontend/constants';\nimport { reportErrorToSentry } from '@commercetools-frontend/sentry';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { WindowEyeIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport useCustomViewLocatorSelector from '../../../hooks/use-custom-view-locator-selector';\nimport CustomViewLoader from '../custom-view-loader';\nimport messages from './messages';\nimport type { TCustomViewSelectorProps } from './types';\nimport { useCustomViewsConnector } from './use-custom-views-connector';\n\nconst COMPONENT_HEIGHT = '52px';\n\ntype TCustomViewSelectorWithRequiredProps = {\n  customViewLocatorCode: string;\n  margin?: string;\n  onCustomViewsResolved?: TCustomViewSelectorProps['onCustomViewsResolved'];\n};\n\ntype TWrapperProps = {\n  shouldRender: boolean;\n  margin?: string;\n};\nconst Wrapper = styled.div<TWrapperProps>`\n  height: ${(props) => (props.shouldRender ? COMPONENT_HEIGHT : '0')};\n  overflow: hidden;\n  transition: margin 0.3s ease-in-out, height 0.3s ease-in-out;\n  margin: ${(props) => (props.shouldRender ? props.margin : '0')};\n`;\n\nconst Container = styled.div`\n  background-color: ${designTokens.colorNeutral98};\n  padding: 10px ${designTokens.spacing30};\n  border: 1px solid ${designTokens.colorNeutral95};\n  border-radius: ${designTokens.borderRadius8};\n`;\n\nconst hoverAndSelectedStateStyles = css`\n  box-shadow: ${designTokens.shadow1};\n  background-color: ${designTokens.colorSurface};\n  color: ${designTokens.colorPrimary30};\n`;\n\ntype TCustomViewSelectorItemProps = {\n  selected?: boolean;\n  label: string;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n};\n\nconst CustomViewSelectorItem = (props: TCustomViewSelectorItemProps) => {\n  return (\n    <AccessibleButton\n      css={css`\n        display: flex;\n        align-items: center;\n        padding: ${designTokens.spacing20} ${designTokens.spacing25};\n        height: 30px;\n        border-radius: ${designTokens.borderRadius6};\n        color: ${designTokens.colorPrimary};\n        ${props.selected && hoverAndSelectedStateStyles}\n\n        :hover {\n          ${hoverAndSelectedStateStyles};\n        }\n      `}\n      onClick={props.onClick}\n      label={props.label}\n    >\n      <Text.Detail\n        tone=\"inherit\"\n        fontWeight={props.selected ? 'bold' : 'regular'}\n      >\n        {props.label}\n      </Text.Detail>\n    </AccessibleButton>\n  );\n};\n\nconst SelectorLabel = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  div {\n    font-weight: 300;\n  }\n`;\n\nconst Separator = styled.span`\n  width: 1px;\n  height: 18px;\n  background-color: #cccccc;\n`;\n\nfunction CustomViewSelector(props: TCustomViewSelectorWithRequiredProps) {\n  const [selectedCustomView, setSelectedCustomView] =\n    useState<CustomViewData | null>(null);\n  const { customViews, error, loading } = useCustomViewsConnector({\n    customViewLocatorCode: props.customViewLocatorCode,\n  });\n\n  const { onCustomViewsResolved } = props;\n  useEffect(() => {\n    if (!loading && !error && onCustomViewsResolved) {\n      onCustomViewsResolved(customViews);\n    }\n  }, [customViews, error, loading, onCustomViewsResolved]);\n  if (error) {\n    reportErrorToSentry(error, {\n      extra: {\n        customViewLocatorCode: props.customViewLocatorCode,\n      },\n    });\n    return null;\n  }\n\n  return (\n    <Wrapper shouldRender={customViews.length > 0} margin={props.margin || '0'}>\n      <Container>\n        <Constraints.Horizontal max=\"scale\">\n          <Spacings.Inline\n            scale=\"s\"\n            justifyContent=\"flex-start\"\n            alignItems=\"center\"\n          >\n            <SelectorLabel>\n              <WindowEyeIcon size=\"medium\" color=\"neutral60\" />\n              <Text.Detail tone=\"secondary\" intlMessage={messages.title} />\n            </SelectorLabel>\n            {customViews.map((customView, index) => {\n              const isNotLastItem = index !== customViews.length - 1;\n              return (\n                <Fragment key={customView.id}>\n                  <CustomViewSelectorItem\n                    selected={selectedCustomView?.id === customView.id}\n                    onClick={() => {\n                      setSelectedCustomView(customView);\n                    }}\n                    label={customView.defaultLabel}\n                  />\n                  {isNotLastItem && <Separator />}\n                </Fragment>\n              );\n            })}\n          </Spacings.Inline>\n\n          {selectedCustomView && (\n            <CustomViewLoader\n              customView={selectedCustomView}\n              onClose={() => {\n                setSelectedCustomView(null);\n              }}\n            />\n          )}\n        </Constraints.Horizontal>\n      </Container>\n    </Wrapper>\n  );\n}\nCustomViewSelector.displayName = 'CustomViewSelector';\n\nconst CustomViewSelectorOrNothing = (props: TCustomViewSelectorProps) => {\n  const { currentCustomViewLocatorCode } = useCustomViewLocatorSelector(\n    props.customViewLocatorCodes\n  );\n\n  const locatorCode =\n    currentCustomViewLocatorCode ?? props.customViewLocatorCode;\n\n  if (!locatorCode) {\n    return null;\n  }\n\n  return <CustomViewSelector {...props} customViewLocatorCode={locatorCode} />;\n};\n\nexport default CustomViewSelectorOrNothing;\n"]} */",
|
|
180
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
181
|
+
});
|
|
182
|
+
const Separator = /*#__PURE__*/_styled__default["default"]("span", process.env.NODE_ENV === "production" ? {
|
|
183
|
+
target: "e16cb3zv0"
|
|
184
|
+
} : {
|
|
185
|
+
target: "e16cb3zv0",
|
|
186
|
+
label: "Separator"
|
|
187
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
188
|
+
name: "1lsblg0",
|
|
189
|
+
styles: "width:1px;height:18px;background-color:#cccccc"
|
|
190
|
+
} : {
|
|
191
|
+
name: "1lsblg0",
|
|
192
|
+
styles: "width:1px;height:18px;background-color:#cccccc",
|
|
193
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["custom-views-selector.tsx"],"names":[],"mappings":"AAqG6B","file":"custom-views-selector.tsx","sourcesContent":["import {\n  useEffect,\n  useState,\n  Fragment,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CustomViewData } from '@commercetools-frontend/constants';\nimport { reportErrorToSentry } from '@commercetools-frontend/sentry';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { WindowEyeIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport useCustomViewLocatorSelector from '../../../hooks/use-custom-view-locator-selector';\nimport CustomViewLoader from '../custom-view-loader';\nimport messages from './messages';\nimport type { TCustomViewSelectorProps } from './types';\nimport { useCustomViewsConnector } from './use-custom-views-connector';\n\nconst COMPONENT_HEIGHT = '52px';\n\ntype TCustomViewSelectorWithRequiredProps = {\n  customViewLocatorCode: string;\n  margin?: string;\n  onCustomViewsResolved?: TCustomViewSelectorProps['onCustomViewsResolved'];\n};\n\ntype TWrapperProps = {\n  shouldRender: boolean;\n  margin?: string;\n};\nconst Wrapper = styled.div<TWrapperProps>`\n  height: ${(props) => (props.shouldRender ? COMPONENT_HEIGHT : '0')};\n  overflow: hidden;\n  transition: margin 0.3s ease-in-out, height 0.3s ease-in-out;\n  margin: ${(props) => (props.shouldRender ? props.margin : '0')};\n`;\n\nconst Container = styled.div`\n  background-color: ${designTokens.colorNeutral98};\n  padding: 10px ${designTokens.spacing30};\n  border: 1px solid ${designTokens.colorNeutral95};\n  border-radius: ${designTokens.borderRadius8};\n`;\n\nconst hoverAndSelectedStateStyles = css`\n  box-shadow: ${designTokens.shadow1};\n  background-color: ${designTokens.colorSurface};\n  color: ${designTokens.colorPrimary30};\n`;\n\ntype TCustomViewSelectorItemProps = {\n  selected?: boolean;\n  label: string;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n};\n\nconst CustomViewSelectorItem = (props: TCustomViewSelectorItemProps) => {\n  return (\n    <AccessibleButton\n      css={css`\n        display: flex;\n        align-items: center;\n        padding: ${designTokens.spacing20} ${designTokens.spacing25};\n        height: 30px;\n        border-radius: ${designTokens.borderRadius6};\n        color: ${designTokens.colorPrimary};\n        ${props.selected && hoverAndSelectedStateStyles}\n\n        :hover {\n          ${hoverAndSelectedStateStyles};\n        }\n      `}\n      onClick={props.onClick}\n      label={props.label}\n    >\n      <Text.Detail\n        tone=\"inherit\"\n        fontWeight={props.selected ? 'bold' : 'regular'}\n      >\n        {props.label}\n      </Text.Detail>\n    </AccessibleButton>\n  );\n};\n\nconst SelectorLabel = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  div {\n    font-weight: 300;\n  }\n`;\n\nconst Separator = styled.span`\n  width: 1px;\n  height: 18px;\n  background-color: #cccccc;\n`;\n\nfunction CustomViewSelector(props: TCustomViewSelectorWithRequiredProps) {\n  const [selectedCustomView, setSelectedCustomView] =\n    useState<CustomViewData | null>(null);\n  const { customViews, error, loading } = useCustomViewsConnector({\n    customViewLocatorCode: props.customViewLocatorCode,\n  });\n\n  const { onCustomViewsResolved } = props;\n  useEffect(() => {\n    if (!loading && !error && onCustomViewsResolved) {\n      onCustomViewsResolved(customViews);\n    }\n  }, [customViews, error, loading, onCustomViewsResolved]);\n  if (error) {\n    reportErrorToSentry(error, {\n      extra: {\n        customViewLocatorCode: props.customViewLocatorCode,\n      },\n    });\n    return null;\n  }\n\n  return (\n    <Wrapper shouldRender={customViews.length > 0} margin={props.margin || '0'}>\n      <Container>\n        <Constraints.Horizontal max=\"scale\">\n          <Spacings.Inline\n            scale=\"s\"\n            justifyContent=\"flex-start\"\n            alignItems=\"center\"\n          >\n            <SelectorLabel>\n              <WindowEyeIcon size=\"medium\" color=\"neutral60\" />\n              <Text.Detail tone=\"secondary\" intlMessage={messages.title} />\n            </SelectorLabel>\n            {customViews.map((customView, index) => {\n              const isNotLastItem = index !== customViews.length - 1;\n              return (\n                <Fragment key={customView.id}>\n                  <CustomViewSelectorItem\n                    selected={selectedCustomView?.id === customView.id}\n                    onClick={() => {\n                      setSelectedCustomView(customView);\n                    }}\n                    label={customView.defaultLabel}\n                  />\n                  {isNotLastItem && <Separator />}\n                </Fragment>\n              );\n            })}\n          </Spacings.Inline>\n\n          {selectedCustomView && (\n            <CustomViewLoader\n              customView={selectedCustomView}\n              onClose={() => {\n                setSelectedCustomView(null);\n              }}\n            />\n          )}\n        </Constraints.Horizontal>\n      </Container>\n    </Wrapper>\n  );\n}\nCustomViewSelector.displayName = 'CustomViewSelector';\n\nconst CustomViewSelectorOrNothing = (props: TCustomViewSelectorProps) => {\n  const { currentCustomViewLocatorCode } = useCustomViewLocatorSelector(\n    props.customViewLocatorCodes\n  );\n\n  const locatorCode =\n    currentCustomViewLocatorCode ?? props.customViewLocatorCode;\n\n  if (!locatorCode) {\n    return null;\n  }\n\n  return <CustomViewSelector {...props} customViewLocatorCode={locatorCode} />;\n};\n\nexport default CustomViewSelectorOrNothing;\n"]} */",
|
|
194
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
195
|
+
});
|
|
196
|
+
function CustomViewSelector(props) {
|
|
197
|
+
const _useState = react$1.useState(null),
|
|
198
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
199
|
+
selectedCustomView = _useState2[0],
|
|
200
|
+
setSelectedCustomView = _useState2[1];
|
|
201
|
+
const _useCustomViewsConnec = useCustomViewsConnector({
|
|
202
|
+
customViewLocatorCode: props.customViewLocatorCode
|
|
203
|
+
}),
|
|
204
|
+
customViews = _useCustomViewsConnec.customViews,
|
|
205
|
+
error = _useCustomViewsConnec.error,
|
|
206
|
+
loading = _useCustomViewsConnec.loading;
|
|
207
|
+
const onCustomViewsResolved = props.onCustomViewsResolved;
|
|
208
|
+
react$1.useEffect(() => {
|
|
209
|
+
if (!loading && !error && onCustomViewsResolved) {
|
|
210
|
+
onCustomViewsResolved(customViews);
|
|
211
|
+
}
|
|
212
|
+
}, [customViews, error, loading, onCustomViewsResolved]);
|
|
213
|
+
if (error) {
|
|
214
|
+
sentry.reportErrorToSentry(error, {
|
|
215
|
+
extra: {
|
|
216
|
+
customViewLocatorCode: props.customViewLocatorCode
|
|
217
|
+
}
|
|
218
|
+
});
|
|
219
|
+
return null;
|
|
220
|
+
}
|
|
221
|
+
return jsxRuntime.jsx(Wrapper, {
|
|
222
|
+
shouldRender: customViews.length > 0,
|
|
223
|
+
margin: props.margin || '0',
|
|
224
|
+
children: jsxRuntime.jsx(Container, {
|
|
225
|
+
children: jsxRuntime.jsxs(Constraints__default["default"].Horizontal, {
|
|
226
|
+
max: "scale",
|
|
227
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
228
|
+
scale: "s",
|
|
229
|
+
justifyContent: "flex-start",
|
|
230
|
+
alignItems: "center",
|
|
231
|
+
children: [jsxRuntime.jsxs(SelectorLabel, {
|
|
232
|
+
children: [jsxRuntime.jsx(icons.WindowEyeIcon, {
|
|
233
|
+
size: "medium",
|
|
234
|
+
color: "neutral60"
|
|
235
|
+
}), jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
236
|
+
tone: "secondary",
|
|
237
|
+
intlMessage: messages.title
|
|
238
|
+
})]
|
|
239
|
+
}), _mapInstanceProperty__default["default"](customViews).call(customViews, (customView, index) => {
|
|
240
|
+
const isNotLastItem = index !== customViews.length - 1;
|
|
241
|
+
return jsxRuntime.jsxs(react$1.Fragment, {
|
|
242
|
+
children: [jsxRuntime.jsx(CustomViewSelectorItem, {
|
|
243
|
+
selected: selectedCustomView?.id === customView.id,
|
|
244
|
+
onClick: () => {
|
|
245
|
+
setSelectedCustomView(customView);
|
|
246
|
+
},
|
|
247
|
+
label: customView.defaultLabel
|
|
248
|
+
}), isNotLastItem && jsxRuntime.jsx(Separator, {})]
|
|
249
|
+
}, customView.id);
|
|
250
|
+
})]
|
|
251
|
+
}), selectedCustomView && jsxRuntime.jsx(dist_commercetoolsFrontendApplicationComponents.CustomViewLoader, {
|
|
252
|
+
customView: selectedCustomView,
|
|
253
|
+
onClose: () => {
|
|
254
|
+
setSelectedCustomView(null);
|
|
255
|
+
}
|
|
256
|
+
})]
|
|
257
|
+
})
|
|
258
|
+
})
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
CustomViewSelector.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
262
|
+
customViewLocatorCode: _pt__default["default"].string.isRequired,
|
|
263
|
+
margin: _pt__default["default"].string
|
|
264
|
+
} : {};
|
|
265
|
+
CustomViewSelector.displayName = 'CustomViewSelector';
|
|
266
|
+
const CustomViewSelectorOrNothing = props => {
|
|
267
|
+
const _useCustomViewLocator = useCustomViewLocatorSelector(props.customViewLocatorCodes),
|
|
268
|
+
currentCustomViewLocatorCode = _useCustomViewLocator.currentCustomViewLocatorCode;
|
|
269
|
+
const locatorCode = currentCustomViewLocatorCode ?? props.customViewLocatorCode;
|
|
270
|
+
if (!locatorCode) {
|
|
271
|
+
return null;
|
|
272
|
+
}
|
|
273
|
+
return jsxRuntime.jsx(CustomViewSelector, _objectSpread(_objectSpread({}, props), {}, {
|
|
274
|
+
customViewLocatorCode: locatorCode
|
|
275
|
+
}));
|
|
276
|
+
};
|
|
277
|
+
|
|
278
|
+
exports["default"] = CustomViewSelectorOrNothing;
|