@teambit/compositions.ui.composition-compare 0.0.227 → 0.0.229

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.
@@ -0,0 +1,14 @@
1
+ import { CompositionContentProps } from '@teambit/compositions';
2
+ import { useContext, createContext } from 'react';
3
+
4
+ export type CompositionCompareContextModel = {
5
+ compositionProps?: CompositionContentProps;
6
+ isBase?: boolean;
7
+ isCompare?: boolean;
8
+ };
9
+
10
+ export const CompositionCompareContext: React.Context<CompositionCompareContextModel | undefined> = createContext<
11
+ CompositionCompareContextModel | undefined
12
+ >(undefined);
13
+
14
+ export const useCompositionCompare = () => useContext(CompositionCompareContext);
@@ -1,19 +1,22 @@
1
1
  .toolbar {
2
2
  display: flex;
3
- background-color: var(--bit-bg-heaviest, #ededed);
4
- padding: 8px;
3
+ padding: 4px;
5
4
  }
6
5
 
7
6
  .left,
8
7
  .right {
9
8
  display: flex;
10
9
  flex: 1;
11
- padding: 8px;
12
- background-color: #fff;
10
+ padding: 4px;
11
+ background-color: var(--background-color);
13
12
  align-items: center;
14
13
  justify-content: space-between;
15
14
  }
16
15
 
16
+ .right {
17
+ justify-content: flex-end;
18
+ }
19
+
17
20
  .mainContainer {
18
21
  display: flex;
19
22
  height: 100%;
@@ -30,8 +33,7 @@
30
33
 
31
34
  .subView {
32
35
  height: 100%;
33
- background-color: white;
34
- overflow-y: auto;
36
+ background-color: var(--background-color);
35
37
  }
36
38
 
37
39
  .loader {
@@ -42,6 +44,7 @@
42
44
 
43
45
  .widgets {
44
46
  display: flex;
47
+ padding: 4px;
45
48
  }
46
49
 
47
50
  .dropdown {
@@ -1,4 +1,4 @@
1
- /* eslint-disable react/prop-types */
1
+ import React, { useMemo, useState } from 'react';
2
2
  import { useComponentCompare } from '@teambit/component.ui.component-compare.context';
3
3
  import { CompositionContent, CompositionContentProps, EmptyStateSlot } from '@teambit/compositions';
4
4
  import { CompositionContextProvider } from '@teambit/compositions.ui.hooks.use-composition';
@@ -6,11 +6,12 @@ import {
6
6
  useCompareQueryParam,
7
7
  useUpdatedUrlFromQuery,
8
8
  } from '@teambit/component.ui.component-compare.hooks.use-component-compare-url';
9
+ import { uniqBy } from 'lodash';
9
10
  import { CompareSplitLayoutPreset } from '@teambit/component.ui.component-compare.layouts.compare-split-layout-preset';
10
11
  import { RoundLoader } from '@teambit/design.ui.round-loader';
11
12
  import queryString from 'query-string';
12
- import React, { useMemo, useState } from 'react';
13
13
  import { CompositionDropdown } from './composition-dropdown';
14
+ import { CompositionCompareContext } from './composition-compare.context';
14
15
 
15
16
  import styles from './composition-compare.module.scss';
16
17
 
@@ -20,11 +21,12 @@ export type CompositionCompareProps = {
20
21
  Right?: React.ReactNode;
21
22
  Left?: React.ReactNode;
22
23
  };
24
+ previewViewProps?: CompositionContentProps;
23
25
  PreviewView?: React.ComponentType<CompositionContentProps>;
24
26
  };
25
27
 
26
28
  export function CompositionCompare(props: CompositionCompareProps) {
27
- const { emptyState, PreviewView = CompositionContent, Widgets } = props;
29
+ const { emptyState, PreviewView = CompositionContent, Widgets, previewViewProps = {} } = props;
28
30
 
29
31
  const componentCompareContext = useComponentCompare();
30
32
 
@@ -62,31 +64,24 @@ export function CompositionCompare(props: CompositionCompareProps) {
62
64
  })) ||
63
65
  (compareCompositions && compareCompositions[0]);
64
66
 
65
- const baseCompositionDropdownSource =
66
- baseCompositions?.map((c) => {
67
- const href = !baseState?.controlled
68
- ? useUpdatedUrlFromQuery({
69
- compositionBaseFile: c.identifier,
70
- compositionCompareFile: selectedCompareComp?.identifier,
71
- })
72
- : useUpdatedUrlFromQuery({});
73
- const onClick = baseState?.controlled ? baseHooks?.onClick : undefined;
74
-
75
- return { id: c.identifier, label: c.displayName, href, onClick };
76
- }) || [];
77
-
78
- const compareCompositionDropdownSource =
79
- compareCompositions?.map((c) => {
67
+ const compositionsDropdownSource = uniqBy(baseCompositions?.concat(compareCompositions || []), 'identifier')?.map(
68
+ (c) => {
80
69
  const href = !compareState?.controlled
81
70
  ? useUpdatedUrlFromQuery({
82
71
  compositionBaseFile: selectedBaseComp?.identifier,
83
72
  compositionCompareFile: c.identifier,
84
73
  })
85
74
  : useUpdatedUrlFromQuery({});
86
- const onClick = compareState?.controlled ? compareHooks?.onClick : undefined;
87
75
 
76
+ const onClick = compareState?.controlled
77
+ ? (_, __) => {
78
+ compareHooks?.onClick?.(_, __);
79
+ baseHooks?.onClick?.(_, __);
80
+ }
81
+ : undefined;
88
82
  return { id: c.identifier, label: c.displayName, href, onClick };
89
- }) || [];
83
+ }
84
+ );
90
85
 
91
86
  const [baseCompositionParams, setBaseCompositionParams] = useState<Record<string, any>>({});
92
87
  const baseCompQueryParams = useMemo(() => queryString.stringify(baseCompositionParams), [baseCompositionParams]);
@@ -97,11 +92,6 @@ export function CompositionCompare(props: CompositionCompareProps) {
97
92
  [compareCompositionParams]
98
93
  );
99
94
 
100
- const selectedBaseDropdown = selectedBaseComp && {
101
- id: selectedBaseComp.identifier,
102
- label: selectedBaseComp.displayName,
103
- };
104
-
105
95
  const selectedCompareDropdown = selectedCompareComp && {
106
96
  id: selectedCompareComp.identifier,
107
97
  label: selectedCompareComp.displayName,
@@ -112,44 +102,69 @@ export function CompositionCompare(props: CompositionCompareProps) {
112
102
  return null;
113
103
  }
114
104
  const baseCompModel = base.model;
115
-
105
+ const compositionProps = {
106
+ forceHeight: undefined,
107
+ innerBottomPadding: 50,
108
+ ...previewViewProps,
109
+ emptyState,
110
+ component: baseCompModel,
111
+ queryParams: baseCompQueryParams,
112
+ selected: selectedCompareComp,
113
+ };
116
114
  return (
117
115
  <div className={styles.subView}>
118
- <CompositionContextProvider queryParams={baseCompositionParams} setQueryParams={setBaseCompositionParams}>
119
- <PreviewView
120
- emptyState={emptyState}
121
- component={baseCompModel}
122
- selected={selectedBaseComp}
123
- queryParams={baseCompQueryParams}
124
- forceHeight={undefined}
125
- innerBottomPadding={50}
126
- />
127
- </CompositionContextProvider>
116
+ <CompositionCompareContext.Provider value={{ compositionProps, isBase: true }}>
117
+ <CompositionContextProvider queryParams={baseCompositionParams} setQueryParams={setBaseCompositionParams}>
118
+ <PreviewView
119
+ forceHeight={undefined}
120
+ innerBottomPadding={50}
121
+ {...previewViewProps}
122
+ emptyState={emptyState}
123
+ component={baseCompModel}
124
+ selected={selectedCompareComp}
125
+ queryParams={baseCompQueryParams}
126
+ />
127
+ </CompositionContextProvider>
128
+ </CompositionCompareContext.Provider>
128
129
  </div>
129
130
  );
130
- }, [base, selectedBaseComp]);
131
+ }, [base, selectedCompareComp?.identifier]);
131
132
 
132
133
  const CompareLayout = useMemo(() => {
133
134
  if (compare === undefined) {
134
135
  return null;
135
136
  }
136
137
  const compareCompModel = compare.model;
137
-
138
+ const compositionProps = {
139
+ forceHeight: undefined,
140
+ innerBottomPadding: 50,
141
+ ...previewViewProps,
142
+ emptyState,
143
+ component: compareCompModel,
144
+ queryParams: compareCompQueryParams,
145
+ selected: selectedCompareComp,
146
+ };
138
147
  return (
139
148
  <div className={styles.subView}>
140
- <CompositionContextProvider queryParams={compareCompositionParams} setQueryParams={setCompareCompositionParams}>
141
- <PreviewView
142
- emptyState={emptyState}
143
- component={compareCompModel}
144
- selected={selectedCompareComp}
145
- queryParams={compareCompQueryParams}
146
- forceHeight={undefined}
147
- innerBottomPadding={50}
148
- />
149
- </CompositionContextProvider>
149
+ <CompositionCompareContext.Provider value={{ compositionProps, isCompare: true }}>
150
+ <CompositionContextProvider
151
+ queryParams={compareCompositionParams}
152
+ setQueryParams={setCompareCompositionParams}
153
+ >
154
+ <PreviewView
155
+ forceHeight={undefined}
156
+ innerBottomPadding={50}
157
+ {...previewViewProps}
158
+ emptyState={emptyState}
159
+ component={compareCompModel}
160
+ queryParams={compareCompQueryParams}
161
+ selected={selectedCompareComp}
162
+ />
163
+ </CompositionContextProvider>
164
+ </CompositionCompareContext.Provider>
150
165
  </div>
151
166
  );
152
- }, [compare, selectedCompareComp]);
167
+ }, [compare, selectedCompareComp?.identifier]);
153
168
 
154
169
  const CompositionToolbar = () => {
155
170
  if (!base && !compare) {
@@ -158,33 +173,25 @@ export function CompositionCompare(props: CompositionCompareProps) {
158
173
 
159
174
  return (
160
175
  <div className={styles.toolbar}>
161
- {base && (
162
- <div className={styles.left}>
163
- <div className={styles.dropdown}>
164
- {baseCompositionDropdownSource.length > 0 && (
165
- <CompositionDropdown dropdownItems={baseCompositionDropdownSource} selected={selectedBaseDropdown} />
166
- )}
167
- </div>
168
- <div className={styles.widgets}>{Widgets?.Left}</div>
169
- </div>
170
- )}
171
- <div className={styles.right}>
176
+ <div className={styles.left}>
172
177
  <div className={styles.dropdown}>
173
- {compareCompositionDropdownSource.length > 0 && (
174
- <CompositionDropdown
175
- dropdownItems={compareCompositionDropdownSource}
176
- selected={selectedCompareDropdown}
177
- />
178
+ {compositionsDropdownSource.length > 0 && (
179
+ <CompositionDropdown dropdownItems={compositionsDropdownSource} selected={selectedCompareDropdown} />
178
180
  )}
179
181
  </div>
182
+ <div className={styles.widgets}>{Widgets?.Left}</div>
183
+ </div>
184
+ <div className={styles.right}>
180
185
  <div className={styles.widgets}>{Widgets?.Right}</div>
181
186
  </div>
182
187
  </div>
183
188
  );
184
189
  };
185
190
 
191
+ const key = `${componentCompareContext?.base?.model.id.toString()}-${componentCompareContext?.compare?.model.id.toString()}-composition-compare`;
192
+
186
193
  return (
187
- <>
194
+ <React.Fragment key={key}>
188
195
  {componentCompareContext?.loading && (
189
196
  <div className={styles.loader}>
190
197
  <RoundLoader />
@@ -192,6 +199,6 @@ export function CompositionCompare(props: CompositionCompareProps) {
192
199
  )}
193
200
  <CompositionToolbar />
194
201
  <CompareSplitLayoutPreset base={BaseLayout} compare={CompareLayout} />
195
- </>
202
+ </React.Fragment>
196
203
  );
197
204
  }
@@ -1,6 +1,6 @@
1
- import React, { useEffect, useRef } from 'react';
1
+ import React, { useRef } from 'react';
2
2
  import { MenuLinkItem } from '@teambit/design.ui.surfaces.menu.link-item';
3
- import { Icon } from '@teambit/evangelist.elements.icon';
3
+ import { Icon } from '@teambit/design.elements.icon';
4
4
  import { Dropdown } from '@teambit/evangelist.surfaces.dropdown';
5
5
 
6
6
  import styles from './composition-dropdown.module.scss';
@@ -41,15 +41,8 @@ type MenuItemProps = {
41
41
  function MenuItem(props: MenuItemProps) {
42
42
  const { selected, current } = props;
43
43
 
44
- const isCurrent = selected?.id === current.id;
45
44
  const currentVersionRef = useRef<HTMLDivElement>(null);
46
45
 
47
- useEffect(() => {
48
- if (isCurrent) {
49
- currentVersionRef.current?.scrollIntoView({ block: 'nearest', behavior: 'smooth' });
50
- }
51
- }, [isCurrent]);
52
-
53
46
  const onClick = (!!current.onClick && ((e) => current.onClick?.(current.id, e))) || undefined;
54
47
 
55
48
  return (
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { CompositionContentProps } from '@teambit/compositions';
3
+ export declare type CompositionCompareContextModel = {
4
+ compositionProps?: CompositionContentProps;
5
+ isBase?: boolean;
6
+ isCompare?: boolean;
7
+ };
8
+ export declare const CompositionCompareContext: React.Context<CompositionCompareContextModel | undefined>;
9
+ export declare const useCompositionCompare: () => CompositionCompareContextModel;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useCompositionCompare = exports.CompositionCompareContext = void 0;
4
+ const react_1 = require("react");
5
+ exports.CompositionCompareContext = (0, react_1.createContext)(undefined);
6
+ const useCompositionCompare = () => (0, react_1.useContext)(exports.CompositionCompareContext);
7
+ exports.useCompositionCompare = useCompositionCompare;
8
+ //# sourceMappingURL=composition-compare.context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"composition-compare.context.js","sourceRoot":"","sources":["../composition-compare.context.tsx"],"names":[],"mappings":";;;AACA,iCAAkD;AAQrC,QAAA,yBAAyB,GAA8D,IAAA,qBAAa,EAE/G,SAAS,CAAC,CAAC;AAEN,MAAM,qBAAqB,GAAG,GAAG,EAAE,CAAC,IAAA,kBAAU,EAAC,iCAAyB,CAAC,CAAC;AAApE,QAAA,qBAAqB,yBAA+C"}
@@ -1,11 +1,12 @@
1
- import { CompositionContentProps, EmptyStateSlot } from '@teambit/compositions';
2
1
  import React from 'react';
2
+ import { CompositionContentProps, EmptyStateSlot } from '@teambit/compositions';
3
3
  export declare type CompositionCompareProps = {
4
4
  emptyState?: EmptyStateSlot;
5
5
  Widgets?: {
6
6
  Right?: React.ReactNode;
7
7
  Left?: React.ReactNode;
8
8
  };
9
+ previewViewProps?: CompositionContentProps;
9
10
  PreviewView?: React.ComponentType<CompositionContentProps>;
10
11
  };
11
12
  export declare function CompositionCompare(props: CompositionCompareProps): JSX.Element;
@@ -27,20 +27,21 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
29
  exports.CompositionCompare = void 0;
30
- /* eslint-disable react/prop-types */
30
+ const react_1 = __importStar(require("react"));
31
31
  const component_ui_component_compare_context_1 = require("@teambit/component.ui.component-compare.context");
32
32
  const compositions_1 = require("@teambit/compositions");
33
33
  const compositions_ui_hooks_use_composition_1 = require("@teambit/compositions.ui.hooks.use-composition");
34
34
  const component_ui_component_compare_hooks_use_component_compare_url_1 = require("@teambit/component.ui.component-compare.hooks.use-component-compare-url");
35
+ const lodash_1 = require("lodash");
35
36
  const component_ui_component_compare_layouts_compare_split_layout_preset_1 = require("@teambit/component.ui.component-compare.layouts.compare-split-layout-preset");
36
37
  const design_ui_round_loader_1 = require("@teambit/design.ui.round-loader");
37
38
  const query_string_1 = __importDefault(require("query-string"));
38
- const react_1 = __importStar(require("react"));
39
39
  const composition_dropdown_1 = require("./composition-dropdown");
40
+ const composition_compare_context_1 = require("./composition-compare.context");
40
41
  const composition_compare_module_scss_1 = __importDefault(require("./composition-compare.module.scss"));
41
42
  function CompositionCompare(props) {
42
- var _a, _b, _c, _d;
43
- const { emptyState, PreviewView = compositions_1.CompositionContent, Widgets } = props;
43
+ var _a, _b, _c, _d, _e, _f, _g;
44
+ const { emptyState, PreviewView = compositions_1.CompositionContent, Widgets, previewViewProps = {} } = props;
44
45
  const componentCompareContext = (0, component_ui_component_compare_context_1.useComponentCompare)();
45
46
  const { base, compare, baseContext, compareContext } = componentCompareContext || {};
46
47
  const baseCompositions = base === null || base === void 0 ? void 0 : base.model.compositions;
@@ -67,34 +68,26 @@ function CompositionCompare(props) {
67
68
  return c.identifier === selectedCompositionCompareId;
68
69
  })) ||
69
70
  (compareCompositions && compareCompositions[0]);
70
- const baseCompositionDropdownSource = (baseCompositions === null || baseCompositions === void 0 ? void 0 : baseCompositions.map((c) => {
71
- const href = !(baseState === null || baseState === void 0 ? void 0 : baseState.controlled)
72
- ? (0, component_ui_component_compare_hooks_use_component_compare_url_1.useUpdatedUrlFromQuery)({
73
- compositionBaseFile: c.identifier,
74
- compositionCompareFile: selectedCompareComp === null || selectedCompareComp === void 0 ? void 0 : selectedCompareComp.identifier,
75
- })
76
- : (0, component_ui_component_compare_hooks_use_component_compare_url_1.useUpdatedUrlFromQuery)({});
77
- const onClick = (baseState === null || baseState === void 0 ? void 0 : baseState.controlled) ? baseHooks === null || baseHooks === void 0 ? void 0 : baseHooks.onClick : undefined;
78
- return { id: c.identifier, label: c.displayName, href, onClick };
79
- })) || [];
80
- const compareCompositionDropdownSource = (compareCompositions === null || compareCompositions === void 0 ? void 0 : compareCompositions.map((c) => {
71
+ const compositionsDropdownSource = (_e = (0, lodash_1.uniqBy)(baseCompositions === null || baseCompositions === void 0 ? void 0 : baseCompositions.concat(compareCompositions || []), 'identifier')) === null || _e === void 0 ? void 0 : _e.map((c) => {
81
72
  const href = !(compareState === null || compareState === void 0 ? void 0 : compareState.controlled)
82
73
  ? (0, component_ui_component_compare_hooks_use_component_compare_url_1.useUpdatedUrlFromQuery)({
83
74
  compositionBaseFile: selectedBaseComp === null || selectedBaseComp === void 0 ? void 0 : selectedBaseComp.identifier,
84
75
  compositionCompareFile: c.identifier,
85
76
  })
86
77
  : (0, component_ui_component_compare_hooks_use_component_compare_url_1.useUpdatedUrlFromQuery)({});
87
- const onClick = (compareState === null || compareState === void 0 ? void 0 : compareState.controlled) ? compareHooks === null || compareHooks === void 0 ? void 0 : compareHooks.onClick : undefined;
78
+ const onClick = (compareState === null || compareState === void 0 ? void 0 : compareState.controlled)
79
+ ? (_, __) => {
80
+ var _a, _b;
81
+ (_a = compareHooks === null || compareHooks === void 0 ? void 0 : compareHooks.onClick) === null || _a === void 0 ? void 0 : _a.call(compareHooks, _, __);
82
+ (_b = baseHooks === null || baseHooks === void 0 ? void 0 : baseHooks.onClick) === null || _b === void 0 ? void 0 : _b.call(baseHooks, _, __);
83
+ }
84
+ : undefined;
88
85
  return { id: c.identifier, label: c.displayName, href, onClick };
89
- })) || [];
86
+ });
90
87
  const [baseCompositionParams, setBaseCompositionParams] = (0, react_1.useState)({});
91
88
  const baseCompQueryParams = (0, react_1.useMemo)(() => query_string_1.default.stringify(baseCompositionParams), [baseCompositionParams]);
92
89
  const [compareCompositionParams, setCompareCompositionParams] = (0, react_1.useState)({});
93
90
  const compareCompQueryParams = (0, react_1.useMemo)(() => query_string_1.default.stringify(compareCompositionParams), [compareCompositionParams]);
94
- const selectedBaseDropdown = selectedBaseComp && {
95
- id: selectedBaseComp.identifier,
96
- label: selectedBaseComp.displayName,
97
- };
98
91
  const selectedCompareDropdown = selectedCompareComp && {
99
92
  id: selectedCompareComp.identifier,
100
93
  label: selectedCompareComp.displayName,
@@ -104,32 +97,36 @@ function CompositionCompare(props) {
104
97
  return null;
105
98
  }
106
99
  const baseCompModel = base.model;
100
+ const compositionProps = Object.assign(Object.assign({ forceHeight: undefined, innerBottomPadding: 50 }, previewViewProps), { emptyState, component: baseCompModel, queryParams: baseCompQueryParams, selected: selectedCompareComp });
107
101
  return (react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.subView },
108
- react_1.default.createElement(compositions_ui_hooks_use_composition_1.CompositionContextProvider, { queryParams: baseCompositionParams, setQueryParams: setBaseCompositionParams },
109
- react_1.default.createElement(PreviewView, { emptyState: emptyState, component: baseCompModel, selected: selectedBaseComp, queryParams: baseCompQueryParams, forceHeight: undefined, innerBottomPadding: 50 }))));
110
- }, [base, selectedBaseComp]);
102
+ react_1.default.createElement(composition_compare_context_1.CompositionCompareContext.Provider, { value: { compositionProps, isBase: true } },
103
+ react_1.default.createElement(compositions_ui_hooks_use_composition_1.CompositionContextProvider, { queryParams: baseCompositionParams, setQueryParams: setBaseCompositionParams },
104
+ react_1.default.createElement(PreviewView, Object.assign({ forceHeight: undefined, innerBottomPadding: 50 }, previewViewProps, { emptyState: emptyState, component: baseCompModel, selected: selectedCompareComp, queryParams: baseCompQueryParams }))))));
105
+ }, [base, selectedCompareComp === null || selectedCompareComp === void 0 ? void 0 : selectedCompareComp.identifier]);
111
106
  const CompareLayout = (0, react_1.useMemo)(() => {
112
107
  if (compare === undefined) {
113
108
  return null;
114
109
  }
115
110
  const compareCompModel = compare.model;
111
+ const compositionProps = Object.assign(Object.assign({ forceHeight: undefined, innerBottomPadding: 50 }, previewViewProps), { emptyState, component: compareCompModel, queryParams: compareCompQueryParams, selected: selectedCompareComp });
116
112
  return (react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.subView },
117
- react_1.default.createElement(compositions_ui_hooks_use_composition_1.CompositionContextProvider, { queryParams: compareCompositionParams, setQueryParams: setCompareCompositionParams },
118
- react_1.default.createElement(PreviewView, { emptyState: emptyState, component: compareCompModel, selected: selectedCompareComp, queryParams: compareCompQueryParams, forceHeight: undefined, innerBottomPadding: 50 }))));
119
- }, [compare, selectedCompareComp]);
113
+ react_1.default.createElement(composition_compare_context_1.CompositionCompareContext.Provider, { value: { compositionProps, isCompare: true } },
114
+ react_1.default.createElement(compositions_ui_hooks_use_composition_1.CompositionContextProvider, { queryParams: compareCompositionParams, setQueryParams: setCompareCompositionParams },
115
+ react_1.default.createElement(PreviewView, Object.assign({ forceHeight: undefined, innerBottomPadding: 50 }, previewViewProps, { emptyState: emptyState, component: compareCompModel, queryParams: compareCompQueryParams, selected: selectedCompareComp }))))));
116
+ }, [compare, selectedCompareComp === null || selectedCompareComp === void 0 ? void 0 : selectedCompareComp.identifier]);
120
117
  const CompositionToolbar = () => {
121
118
  if (!base && !compare) {
122
119
  return null;
123
120
  }
124
121
  return (react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.toolbar },
125
- base && (react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.left },
126
- react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.dropdown }, baseCompositionDropdownSource.length > 0 && (react_1.default.createElement(composition_dropdown_1.CompositionDropdown, { dropdownItems: baseCompositionDropdownSource, selected: selectedBaseDropdown }))),
127
- react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.widgets }, Widgets === null || Widgets === void 0 ? void 0 : Widgets.Left))),
122
+ react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.left },
123
+ react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.dropdown }, compositionsDropdownSource.length > 0 && (react_1.default.createElement(composition_dropdown_1.CompositionDropdown, { dropdownItems: compositionsDropdownSource, selected: selectedCompareDropdown }))),
124
+ react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.widgets }, Widgets === null || Widgets === void 0 ? void 0 : Widgets.Left)),
128
125
  react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.right },
129
- react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.dropdown }, compareCompositionDropdownSource.length > 0 && (react_1.default.createElement(composition_dropdown_1.CompositionDropdown, { dropdownItems: compareCompositionDropdownSource, selected: selectedCompareDropdown }))),
130
126
  react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.widgets }, Widgets === null || Widgets === void 0 ? void 0 : Widgets.Right))));
131
127
  };
132
- return (react_1.default.createElement(react_1.default.Fragment, null,
128
+ const key = `${(_f = componentCompareContext === null || componentCompareContext === void 0 ? void 0 : componentCompareContext.base) === null || _f === void 0 ? void 0 : _f.model.id.toString()}-${(_g = componentCompareContext === null || componentCompareContext === void 0 ? void 0 : componentCompareContext.compare) === null || _g === void 0 ? void 0 : _g.model.id.toString()}-composition-compare`;
129
+ return (react_1.default.createElement(react_1.default.Fragment, { key: key },
133
130
  (componentCompareContext === null || componentCompareContext === void 0 ? void 0 : componentCompareContext.loading) && (react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.loader },
134
131
  react_1.default.createElement(design_ui_round_loader_1.RoundLoader, null))),
135
132
  react_1.default.createElement(CompositionToolbar, null),
@@ -1 +1 @@
1
- {"version":3,"file":"composition-compare.js","sourceRoot":"","sources":["../composition-compare.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"composition-compare.js","sourceRoot":"","sources":["../composition-compare.tsx"],"names":[],"mappings":"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"}
@@ -1,19 +1,22 @@
1
1
  .toolbar {
2
2
  display: flex;
3
- background-color: var(--bit-bg-heaviest, #ededed);
4
- padding: 8px;
3
+ padding: 4px;
5
4
  }
6
5
 
7
6
  .left,
8
7
  .right {
9
8
  display: flex;
10
9
  flex: 1;
11
- padding: 8px;
12
- background-color: #fff;
10
+ padding: 4px;
11
+ background-color: var(--background-color);
13
12
  align-items: center;
14
13
  justify-content: space-between;
15
14
  }
16
15
 
16
+ .right {
17
+ justify-content: flex-end;
18
+ }
19
+
17
20
  .mainContainer {
18
21
  display: flex;
19
22
  height: 100%;
@@ -30,8 +33,7 @@
30
33
 
31
34
  .subView {
32
35
  height: 100%;
33
- background-color: white;
34
- overflow-y: auto;
36
+ background-color: var(--background-color);
35
37
  }
36
38
 
37
39
  .loader {
@@ -42,6 +44,7 @@
42
44
 
43
45
  .widgets {
44
46
  display: flex;
47
+ padding: 4px;
45
48
  }
46
49
 
47
50
  .dropdown {
@@ -29,7 +29,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
29
29
  exports.CompositionDropdown = void 0;
30
30
  const react_1 = __importStar(require("react"));
31
31
  const design_ui_surfaces_menu_link_item_1 = require("@teambit/design.ui.surfaces.menu.link-item");
32
- const evangelist_elements_icon_1 = require("@teambit/evangelist.elements.icon");
32
+ const design_elements_icon_1 = require("@teambit/design.elements.icon");
33
33
  const evangelist_surfaces_dropdown_1 = require("@teambit/evangelist.surfaces.dropdown");
34
34
  const composition_dropdown_module_scss_1 = __importDefault(require("./composition-dropdown.module.scss"));
35
35
  function CompositionDropdown(props) {
@@ -37,21 +37,14 @@ function CompositionDropdown(props) {
37
37
  const key = (item) => `${item.id}-${item.href}`;
38
38
  return (react_1.default.createElement(evangelist_surfaces_dropdown_1.Dropdown, { dropClass: composition_dropdown_module_scss_1.default.menu, placeholder: react_1.default.createElement("div", { className: composition_dropdown_module_scss_1.default.placeholder },
39
39
  react_1.default.createElement("div", null, selected && selected.label),
40
- react_1.default.createElement(evangelist_elements_icon_1.Icon, { of: "fat-arrow-down" })) }, data.map((item) => {
40
+ react_1.default.createElement(design_elements_icon_1.Icon, { of: "fat-arrow-down" })) }, data.map((item) => {
41
41
  return react_1.default.createElement(MenuItem, { key: key(item), current: item, selected: selected });
42
42
  })));
43
43
  }
44
44
  exports.CompositionDropdown = CompositionDropdown;
45
45
  function MenuItem(props) {
46
46
  const { selected, current } = props;
47
- const isCurrent = (selected === null || selected === void 0 ? void 0 : selected.id) === current.id;
48
47
  const currentVersionRef = (0, react_1.useRef)(null);
49
- (0, react_1.useEffect)(() => {
50
- var _a;
51
- if (isCurrent) {
52
- (_a = currentVersionRef.current) === null || _a === void 0 ? void 0 : _a.scrollIntoView({ block: 'nearest', behavior: 'smooth' });
53
- }
54
- }, [isCurrent]);
55
48
  const onClick = (!!current.onClick && ((e) => { var _a; return (_a = current.onClick) === null || _a === void 0 ? void 0 : _a.call(current, current.id, e); })) || undefined;
56
49
  return (react_1.default.createElement("div", { ref: currentVersionRef, key: `${current.href}-container` },
57
50
  react_1.default.createElement(design_ui_surfaces_menu_link_item_1.MenuLinkItem, { key: current.href, active: current.id === (selected === null || selected === void 0 ? void 0 : selected.id), href: current.href, onClick: onClick },
@@ -1 +1 @@
1
- {"version":3,"file":"composition-dropdown.js","sourceRoot":"","sources":["../composition-dropdown.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAiD;AACjD,kGAA0E;AAC1E,gFAAyD;AACzD,wFAAiE;AAEjE,0GAAwD;AASxD,SAAgB,mBAAmB,CAAC,KAA+B;IACjE,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;IAChD,MAAM,GAAG,GAAG,CAAC,IAAkB,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;IAE9D,OAAO,CACL,8BAAC,uCAAQ,IACP,SAAS,EAAE,0CAAM,CAAC,IAAI,EACtB,WAAW,EACT,uCAAK,SAAS,EAAE,0CAAM,CAAC,WAAW;YAChC,2CAAM,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAO;YACvC,8BAAC,+BAAI,IAAC,EAAE,EAAC,gBAAgB,GAAG,CACxB,IAGP,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACjB,OAAO,8BAAC,QAAQ,IAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,GAAI,CAAC;IACzE,CAAC,CAAC,CACO,CACZ,CAAC;AACJ,CAAC;AAnBD,kDAmBC;AAOD,SAAS,QAAQ,CAAC,KAAoB;IACpC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IAEpC,MAAM,SAAS,GAAG,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,EAAE,MAAK,OAAO,CAAC,EAAE,CAAC;IAC9C,MAAM,iBAAiB,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IAEvD,IAAA,iBAAS,EAAC,GAAG,EAAE;;QACb,IAAI,SAAS,EAAE;YACb,MAAA,iBAAiB,CAAC,OAAO,0CAAE,cAAc,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;SACrF;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,OAAO,CAAC,OAAO,wDAAG,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA,EAAA,CAAC,CAAC,IAAI,SAAS,CAAC;IAE9F,OAAO,CACL,uCAAK,GAAG,EAAE,iBAAiB,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,YAAY;QAC3D,8BAAC,gDAAY,IAAC,GAAG,EAAE,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAK,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,EAAE,CAAA,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO;YACxG,2CAAM,OAAO,CAAC,KAAK,CAAO,CACb,CACX,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"composition-dropdown.js","sourceRoot":"","sources":["../composition-dropdown.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAsC;AACtC,kGAA0E;AAC1E,wEAAqD;AACrD,wFAAiE;AAEjE,0GAAwD;AASxD,SAAgB,mBAAmB,CAAC,KAA+B;IACjE,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;IAChD,MAAM,GAAG,GAAG,CAAC,IAAkB,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;IAE9D,OAAO,CACL,8BAAC,uCAAQ,IACP,SAAS,EAAE,0CAAM,CAAC,IAAI,EACtB,WAAW,EACT,uCAAK,SAAS,EAAE,0CAAM,CAAC,WAAW;YAChC,2CAAM,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAO;YACvC,8BAAC,2BAAI,IAAC,EAAE,EAAC,gBAAgB,GAAG,CACxB,IAGP,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACjB,OAAO,8BAAC,QAAQ,IAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,GAAI,CAAC;IACzE,CAAC,CAAC,CACO,CACZ,CAAC;AACJ,CAAC;AAnBD,kDAmBC;AAOD,SAAS,QAAQ,CAAC,KAAoB;IACpC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IAEpC,MAAM,iBAAiB,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IAEvD,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,OAAO,CAAC,OAAO,wDAAG,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA,EAAA,CAAC,CAAC,IAAI,SAAS,CAAC;IAE9F,OAAO,CACL,uCAAK,GAAG,EAAE,iBAAiB,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,YAAY;QAC3D,8BAAC,gDAAY,IAAC,GAAG,EAAE,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAK,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,EAAE,CAAA,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO;YACxG,2CAAM,OAAO,CAAC,KAAK,CAAO,CACb,CACX,CACP,CAAC;AACJ,CAAC"}
package/dist/index.d.ts CHANGED
@@ -1 +1,2 @@
1
1
  export { CompositionCompare } from './composition-compare';
2
+ export { useCompositionCompare, CompositionCompareContext } from './composition-compare.context';
package/dist/index.js CHANGED
@@ -1,6 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CompositionCompare = void 0;
3
+ exports.CompositionCompareContext = exports.useCompositionCompare = exports.CompositionCompare = void 0;
4
4
  var composition_compare_1 = require("./composition-compare");
5
5
  Object.defineProperty(exports, "CompositionCompare", { enumerable: true, get: function () { return composition_compare_1.CompositionCompare; } });
6
+ var composition_compare_context_1 = require("./composition-compare.context");
7
+ Object.defineProperty(exports, "useCompositionCompare", { enumerable: true, get: function () { return composition_compare_context_1.useCompositionCompare; } });
8
+ Object.defineProperty(exports, "CompositionCompareContext", { enumerable: true, get: function () { return composition_compare_context_1.CompositionCompareContext; } });
6
9
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";;;AAAA,6DAA2D;AAAlD,yHAAA,kBAAkB,OAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";;;AAAA,6DAA2D;AAAlD,yHAAA,kBAAkB,OAAA;AAC3B,6EAAiG;AAAxF,oIAAA,qBAAqB,OAAA;AAAE,wIAAA,yBAAyB,OAAA"}
package/index.ts CHANGED
@@ -1 +1,2 @@
1
1
  export { CompositionCompare } from './composition-compare';
2
+ export { useCompositionCompare, CompositionCompareContext } from './composition-compare.context';
package/package.json CHANGED
@@ -1,28 +1,30 @@
1
1
  {
2
2
  "name": "@teambit/compositions.ui.composition-compare",
3
- "version": "0.0.227",
3
+ "version": "0.0.229",
4
4
  "homepage": "https://bit.cloud/teambit/compositions/ui/composition-compare",
5
5
  "main": "dist/index.js",
6
6
  "componentId": {
7
7
  "scope": "teambit.compositions",
8
8
  "name": "ui/composition-compare",
9
- "version": "0.0.227"
9
+ "version": "0.0.229"
10
10
  },
11
11
  "dependencies": {
12
+ "lodash": "4.17.21",
12
13
  "query-string": "7.0.0",
13
14
  "core-js": "^3.0.0",
14
15
  "@teambit/design.ui.round-loader": "0.0.355",
16
+ "@teambit/design.elements.icon": "1.0.5",
15
17
  "@teambit/design.ui.surfaces.menu.link-item": "1.0.0",
16
- "@teambit/evangelist.elements.icon": "1.0.2",
17
18
  "@teambit/evangelist.surfaces.dropdown": "1.0.2",
18
- "@teambit/component.ui.component-compare.context": "0.0.88",
19
+ "@teambit/component.ui.component-compare.context": "0.0.90",
19
20
  "@teambit/component.ui.component-compare.hooks.use-component-compare-url": "0.0.3",
20
- "@teambit/component.ui.component-compare.layouts.compare-split-layout-preset": "0.0.4",
21
+ "@teambit/component.ui.component-compare.layouts.compare-split-layout-preset": "0.0.5",
21
22
  "@teambit/compositions.ui.hooks.use-composition": "0.0.172",
22
23
  "@teambit/ui-foundation.ui.constants.z-indexes": "0.0.499"
23
24
  },
24
25
  "devDependencies": {
25
26
  "@types/react": "^17.0.8",
27
+ "@types/lodash": "4.14.165",
26
28
  "@types/mocha": "9.1.0",
27
29
  "@types/node": "12.20.4",
28
30
  "@types/react-dom": "^17.0.5",