@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.
- package/composition-compare.context.tsx +14 -0
- package/composition-compare.module.scss +9 -6
- package/composition-compare.tsx +74 -67
- package/composition-dropdown.tsx +2 -9
- package/dist/composition-compare.context.d.ts +9 -0
- package/dist/composition-compare.context.js +8 -0
- package/dist/composition-compare.context.js.map +1 -0
- package/dist/composition-compare.d.ts +2 -1
- package/dist/composition-compare.js +29 -32
- package/dist/composition-compare.js.map +1 -1
- package/dist/composition-compare.module.scss +9 -6
- package/dist/composition-dropdown.js +2 -9
- package/dist/composition-dropdown.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +4 -1
- package/dist/index.js.map +1 -1
- package/index.ts +1 -0
- package/package.json +7 -5
- /package/dist/{preview-1693019835545.js → preview-1693474270980.js} +0 -0
|
@@ -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
|
-
|
|
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:
|
|
12
|
-
background-color:
|
|
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:
|
|
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 {
|
package/composition-compare.tsx
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
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
|
|
66
|
-
|
|
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
|
-
<
|
|
119
|
-
<
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
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,
|
|
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
|
-
<
|
|
141
|
-
<
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
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
|
-
{
|
|
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
|
-
{
|
|
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
|
}
|
package/composition-dropdown.tsx
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import React, {
|
|
1
|
+
import React, { useRef } from 'react';
|
|
2
2
|
import { MenuLinkItem } from '@teambit/design.ui.surfaces.menu.link-item';
|
|
3
|
-
import { Icon } from '@teambit/
|
|
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
|
-
|
|
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
|
|
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)
|
|
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(
|
|
109
|
-
react_1.default.createElement(
|
|
110
|
-
|
|
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(
|
|
118
|
-
react_1.default.createElement(
|
|
119
|
-
|
|
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
|
-
|
|
126
|
-
react_1.default.createElement("div", { className: composition_compare_module_scss_1.default.dropdown },
|
|
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
|
-
|
|
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA
|
|
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
|
-
|
|
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:
|
|
12
|
-
background-color:
|
|
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:
|
|
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
|
|
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(
|
|
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,+
|
|
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
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
package/package.json
CHANGED
|
@@ -1,28 +1,30 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@teambit/compositions.ui.composition-compare",
|
|
3
|
-
"version": "0.0.
|
|
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.
|
|
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.
|
|
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.
|
|
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",
|
|
File without changes
|