dotdata_widgets 0.1.3 → 0.1.4
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/css/widget.css +13 -0
- package/dist/index.js +2 -2
- package/lib/components/accordion/Accordion.js +2 -2
- package/lib/feature/feature-likes/feature-likes.js +38 -0
- package/lib/feature/feature-likes/index.js +18 -0
- package/lib/utils/model-transform-hook.js +21 -0
- package/lib/utils/set.js +14 -0
- package/lib/widgets/FeatureLeaderboardWidget.js +2 -0
- package/lib/widgets/feature-leaderboard/FeatureLeaderboardView.js +6 -2
- package/lib/widgets/feature-leaderboard/components/leaderboard-feature-likes.js +50 -0
- package/lib/widgets/feature-leaderboard/entry-item/FeatureLeaderboardEntryHeader.js +35 -0
- package/lib/widgets/feature-leaderboard/entry-item/FeatureLeaderboardEntryItem.js +2 -8
- package/lib/widgets/feature-leaderboard/leaderboard-entry/FeatureLeaderboardEntry.js +22 -0
- package/lib/widgets/feature-leaderboard/leaderboard-entry/FeatureLeaderboardEntryDetails.js +23 -0
- package/lib/widgets/feature-leaderboard/leaderboard-entry/FeatureLeaderboardEntryRow.js +29 -0
- package/package.json +1 -1
|
@@ -34,8 +34,8 @@ exports.AccordionDetails = AccordionDetails;
|
|
|
34
34
|
exports.Accordion = (0, react_1.forwardRef)(({ children, expandedDetailsStyle, collapsedDetailsStyle, expandedHeaderStyle, collapsedHeaderStyle, toggleStyle, initialState, }, ref) => {
|
|
35
35
|
const [isExpanded, setIsExpanded] = (0, react_1.useState)(() => initialState ?? false);
|
|
36
36
|
const components = react_1.default.Children.toArray(children).filter(react_1.default.isValidElement);
|
|
37
|
-
const Header = components.find(child => child
|
|
38
|
-
const Details = components.find(child => child
|
|
37
|
+
const Header = components.find(child => child?.type === exports.AccordionHeader);
|
|
38
|
+
const Details = components.find(child => child?.type === exports.AccordionDetails);
|
|
39
39
|
(0, react_1.useImperativeHandle)(ref, () => ({
|
|
40
40
|
collapse() {
|
|
41
41
|
setIsExpanded(false);
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.FeatureLikes = exports.FeatureLike = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const ThumbUpOffAlt_1 = __importDefault(require("@mui/icons-material/ThumbUpOffAlt"));
|
|
9
|
+
const ThumbDownOffAlt_1 = __importDefault(require("@mui/icons-material/ThumbDownOffAlt"));
|
|
10
|
+
var FeatureLike;
|
|
11
|
+
(function (FeatureLike) {
|
|
12
|
+
FeatureLike[FeatureLike["Neutral"] = 0] = "Neutral";
|
|
13
|
+
FeatureLike[FeatureLike["Liked"] = 1] = "Liked";
|
|
14
|
+
FeatureLike[FeatureLike["Disliked"] = 2] = "Disliked";
|
|
15
|
+
})(FeatureLike = exports.FeatureLike || (exports.FeatureLike = {}));
|
|
16
|
+
const FeatureLikes = ({ liked, toggleIsLiked, toggleIsDisliked }) => {
|
|
17
|
+
return (react_1.default.createElement("span", { style: {
|
|
18
|
+
display: 'flex',
|
|
19
|
+
alignItems: 'center',
|
|
20
|
+
justifyContent: 'center',
|
|
21
|
+
} },
|
|
22
|
+
react_1.default.createElement(ThumbUpOffAlt_1.default, { onClick: toggleIsLiked, sx: {
|
|
23
|
+
cursor: 'pointer',
|
|
24
|
+
fontSize: '18px',
|
|
25
|
+
color: liked === FeatureLike.Liked
|
|
26
|
+
? 'var( --c-green-600)'
|
|
27
|
+
: 'var( --c-grey-600)',
|
|
28
|
+
} }),
|
|
29
|
+
react_1.default.createElement(ThumbDownOffAlt_1.default, { onClick: toggleIsDisliked, sx: {
|
|
30
|
+
cursor: 'pointer',
|
|
31
|
+
fontSize: '18px',
|
|
32
|
+
color: liked === FeatureLike.Disliked
|
|
33
|
+
? 'var(--c-red-600)'
|
|
34
|
+
: 'var( --c-grey-600)',
|
|
35
|
+
} })));
|
|
36
|
+
};
|
|
37
|
+
exports.FeatureLikes = FeatureLikes;
|
|
38
|
+
//# sourceMappingURL=feature-likes.js.map
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./feature-likes"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.useModelTransform = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
function useModelTransform(model, setModel, transform, revTransform, defaultState) {
|
|
9
|
+
const [transformedModel, setTransformedModel] = react_1.default.useState(() => defaultState);
|
|
10
|
+
react_1.default.useEffect(() => {
|
|
11
|
+
setTransformedModel(transform(model));
|
|
12
|
+
}, [model]);
|
|
13
|
+
return [
|
|
14
|
+
transformedModel,
|
|
15
|
+
(s) => {
|
|
16
|
+
setModel(revTransform(s));
|
|
17
|
+
},
|
|
18
|
+
];
|
|
19
|
+
}
|
|
20
|
+
exports.useModelTransform = useModelTransform;
|
|
21
|
+
//# sourceMappingURL=model-transform-hook.js.map
|
package/lib/utils/set.js
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toggleSetItem = void 0;
|
|
4
|
+
function toggleSetItem(collection, item) {
|
|
5
|
+
if (collection.has(item)) {
|
|
6
|
+
collection.delete(item);
|
|
7
|
+
}
|
|
8
|
+
else {
|
|
9
|
+
collection.add(item);
|
|
10
|
+
}
|
|
11
|
+
return new Set(collection);
|
|
12
|
+
}
|
|
13
|
+
exports.toggleSetItem = toggleSetItem;
|
|
14
|
+
//# sourceMappingURL=set.js.map
|
|
@@ -7,7 +7,8 @@ exports.FeatureLeaderboardView = void 0;
|
|
|
7
7
|
const react_1 = __importDefault(require("react"));
|
|
8
8
|
const widget_model_1 = require("../../utils/widget-model");
|
|
9
9
|
const FeatureLeaderboardOverview_1 = require("./FeatureLeaderboardOverview");
|
|
10
|
-
const
|
|
10
|
+
const FeatureLeaderboardEntry_1 = require("./leaderboard-entry/FeatureLeaderboardEntry");
|
|
11
|
+
const FeatureLeaderboardEntryRow_1 = require("./leaderboard-entry/FeatureLeaderboardEntryRow");
|
|
11
12
|
const FeatureLeaderboardView = ({ model }) => {
|
|
12
13
|
const [featureLeaderboard] = (0, widget_model_1.useModelState)('value');
|
|
13
14
|
const [confidence, setConfidence] = (0, widget_model_1.useModelState)('confidence');
|
|
@@ -17,7 +18,10 @@ const FeatureLeaderboardView = ({ model }) => {
|
|
|
17
18
|
react_1.default.createElement("h2", { className: "grey-label" }, "Feature Pipeline Overview:"),
|
|
18
19
|
react_1.default.createElement(FeatureLeaderboardOverview_1.FeatureLeaderboardOverview, { confidence: confidence, setConfidence: setConfidence, maxCollinearity: maxCollinearity, setMaxCollinearity: setMaxCollinearity }),
|
|
19
20
|
react_1.default.createElement("br", null),
|
|
20
|
-
|
|
21
|
+
featureLeaderboard.isAssessed
|
|
22
|
+
? featureEntries.map(featureEntry => (react_1.default.createElement(FeatureLeaderboardEntry_1.FeatureLeaderboardEntry, { key: featureEntry.feature.id, featureEntry: featureEntry })))
|
|
23
|
+
: featureEntries.map(featureEntry => (react_1.default.createElement("div", { className: "feature-leaderboard-entry-row-wrapper", key: featureEntry.feature.id },
|
|
24
|
+
react_1.default.createElement(FeatureLeaderboardEntryRow_1.FeatureLeaderboardEntryRow, { feature: featureEntry.feature }))))));
|
|
21
25
|
};
|
|
22
26
|
exports.FeatureLeaderboardView = FeatureLeaderboardView;
|
|
23
27
|
function filterFeatures(featureLeaderboard, maxCollinearity, confidence) {
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.LeaderBoardFeatureLikes = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const lodash_1 = require("lodash");
|
|
9
|
+
const widget_model_1 = require("../../../utils/widget-model");
|
|
10
|
+
const feature_likes_1 = require("../../../feature/feature-likes");
|
|
11
|
+
const LeaderBoardFeatureLikes = ({ featureId, }) => {
|
|
12
|
+
const [likedFeatures, setLikedFeatures] = (0, widget_model_1.useModelState)('liked_features');
|
|
13
|
+
const [dislikedFeatures, setDislikedFeatures] = (0, widget_model_1.useModelState)('disliked_features');
|
|
14
|
+
const [liked, setLiked] = react_1.default.useState(() => feature_likes_1.FeatureLike.Neutral);
|
|
15
|
+
react_1.default.useEffect(() => {
|
|
16
|
+
const newState = likedFeatures.includes(featureId)
|
|
17
|
+
? feature_likes_1.FeatureLike.Liked
|
|
18
|
+
: dislikedFeatures.includes(featureId)
|
|
19
|
+
? feature_likes_1.FeatureLike.Disliked
|
|
20
|
+
: feature_likes_1.FeatureLike.Neutral;
|
|
21
|
+
setLiked(newState);
|
|
22
|
+
}, [likedFeatures, dislikedFeatures]);
|
|
23
|
+
function toggleIsLiked() {
|
|
24
|
+
if (liked === feature_likes_1.FeatureLike.Neutral) {
|
|
25
|
+
setLikedFeatures([...likedFeatures, featureId]);
|
|
26
|
+
}
|
|
27
|
+
if (liked === feature_likes_1.FeatureLike.Liked) {
|
|
28
|
+
setLikedFeatures((0, lodash_1.without)(likedFeatures, featureId));
|
|
29
|
+
}
|
|
30
|
+
if (liked === feature_likes_1.FeatureLike.Disliked) {
|
|
31
|
+
setDislikedFeatures((0, lodash_1.without)(likedFeatures, featureId));
|
|
32
|
+
setLikedFeatures([...likedFeatures, featureId]);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
function toggleIsDisliked() {
|
|
36
|
+
if (liked === feature_likes_1.FeatureLike.Neutral) {
|
|
37
|
+
setDislikedFeatures([...dislikedFeatures, featureId]);
|
|
38
|
+
}
|
|
39
|
+
if (liked === feature_likes_1.FeatureLike.Disliked) {
|
|
40
|
+
setDislikedFeatures((0, lodash_1.without)(likedFeatures, featureId));
|
|
41
|
+
}
|
|
42
|
+
if (liked === feature_likes_1.FeatureLike.Liked) {
|
|
43
|
+
setLikedFeatures((0, lodash_1.without)(likedFeatures, featureId));
|
|
44
|
+
setDislikedFeatures([...likedFeatures, featureId]);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return (react_1.default.createElement(feature_likes_1.FeatureLikes, { liked: liked, toggleIsLiked: toggleIsLiked, toggleIsDisliked: toggleIsDisliked }));
|
|
48
|
+
};
|
|
49
|
+
exports.LeaderBoardFeatureLikes = LeaderBoardFeatureLikes;
|
|
50
|
+
//# sourceMappingURL=leaderboard-feature-likes.js.map
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.FeatureLeaderboardEntryHeader = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const lodash_1 = require("lodash");
|
|
9
|
+
const widget_model_1 = require("../../../utils/widget-model");
|
|
10
|
+
const FeatureExplanation_1 = require("../../../feature/feature-explanation/FeatureExplanation");
|
|
11
|
+
const feature_likes_1 = require("../../../feature/feature-likes");
|
|
12
|
+
const featureNameLabelStyle = {
|
|
13
|
+
color: 'var(--c-grey-600)',
|
|
14
|
+
display: 'inline-block',
|
|
15
|
+
marginLeft: '10px',
|
|
16
|
+
minWidth: '5rem',
|
|
17
|
+
};
|
|
18
|
+
const FeatureLeaderboardEntryHeader = ({ feature }) => {
|
|
19
|
+
const [likedFeatures, setLikedFeatures] = (0, widget_model_1.useModelState)('liked_features');
|
|
20
|
+
const [isLiked, setIsLiked] = react_1.default.useState(() => false);
|
|
21
|
+
react_1.default.useEffect(() => {
|
|
22
|
+
setIsLiked(likedFeatures.includes(feature.id));
|
|
23
|
+
}, [likedFeatures]);
|
|
24
|
+
function toggleIsLiked() {
|
|
25
|
+
setLikedFeatures(isLiked
|
|
26
|
+
? (0, lodash_1.without)(likedFeatures, feature.id)
|
|
27
|
+
: [...likedFeatures, feature.id]);
|
|
28
|
+
}
|
|
29
|
+
return (react_1.default.createElement("div", { style: { display: 'flex', alignItems: 'center' } },
|
|
30
|
+
react_1.default.createElement(feature_likes_1.FeatureLikes, { isLiked: isLiked, toggleIsLiked: toggleIsLiked }),
|
|
31
|
+
react_1.default.createElement("span", { className: "label-bold", style: featureNameLabelStyle }, feature.id),
|
|
32
|
+
react_1.default.createElement(FeatureExplanation_1.FeatureExplanation, { key: feature.id, explanationBlocks: feature.explanation.tokens })));
|
|
33
|
+
};
|
|
34
|
+
exports.FeatureLeaderboardEntryHeader = FeatureLeaderboardEntryHeader;
|
|
35
|
+
//# sourceMappingURL=FeatureLeaderboardEntryHeader.js.map
|
|
@@ -6,21 +6,15 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.FeatureLeaderboardEntryItem = void 0;
|
|
7
7
|
const react_1 = __importDefault(require("react"));
|
|
8
8
|
const accordion_1 = require("../../../components/accordion");
|
|
9
|
-
const FeatureExplanation_1 = require("../../../feature/feature-explanation/FeatureExplanation");
|
|
10
9
|
const FeatureLeaderboardEntryDetails_1 = require("./FeatureLeaderboardEntryDetails");
|
|
11
|
-
const
|
|
12
|
-
color: 'var(--c-grey-600)',
|
|
13
|
-
display: 'inline-block',
|
|
14
|
-
minWidth: '5rem',
|
|
15
|
-
};
|
|
10
|
+
const FeatureLeaderboardEntryHeader_1 = require("./FeatureLeaderboardEntryHeader");
|
|
16
11
|
const FeatureLeaderboardEntryItem = ({ featureEntry }) => {
|
|
17
12
|
return (react_1.default.createElement(accordion_1.Accordion, { expandedDetailsStyle: {
|
|
18
13
|
borderBottom: '1px solid var(--c-grey-500)',
|
|
19
14
|
paddingBlockEnd: '30px',
|
|
20
15
|
} },
|
|
21
16
|
react_1.default.createElement(accordion_1.AccordionHeader, null,
|
|
22
|
-
react_1.default.createElement(
|
|
23
|
-
react_1.default.createElement(FeatureExplanation_1.FeatureExplanation, { key: featureEntry.feature.id, explanationBlocks: featureEntry.feature.explanation.tokens })),
|
|
17
|
+
react_1.default.createElement(FeatureLeaderboardEntryHeader_1.FeatureLeaderboardEntryHeader, { feature: featureEntry.feature })),
|
|
24
18
|
react_1.default.createElement(accordion_1.AccordionDetails, null,
|
|
25
19
|
react_1.default.createElement(FeatureLeaderboardEntryDetails_1.FeatureLeaderboardEntryDetails, { entry: featureEntry }))));
|
|
26
20
|
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.FeatureLeaderboardEntry = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const accordion_1 = require("../../../components/accordion");
|
|
9
|
+
const FeatureLeaderboardEntryDetails_1 = require("./FeatureLeaderboardEntryDetails");
|
|
10
|
+
const FeatureLeaderboardEntryRow_1 = require("./FeatureLeaderboardEntryRow");
|
|
11
|
+
const FeatureLeaderboardEntry = ({ featureEntry }) => {
|
|
12
|
+
return (react_1.default.createElement(accordion_1.Accordion, { expandedDetailsStyle: {
|
|
13
|
+
borderBottom: '1px solid var(--c-grey-500)',
|
|
14
|
+
paddingBlockEnd: '30px',
|
|
15
|
+
} },
|
|
16
|
+
react_1.default.createElement(accordion_1.AccordionHeader, null,
|
|
17
|
+
react_1.default.createElement(FeatureLeaderboardEntryRow_1.FeatureLeaderboardEntryRow, { feature: featureEntry.feature })),
|
|
18
|
+
react_1.default.createElement(accordion_1.AccordionDetails, null,
|
|
19
|
+
react_1.default.createElement(FeatureLeaderboardEntryDetails_1.FeatureLeaderboardEntryDetails, { entry: featureEntry }))));
|
|
20
|
+
};
|
|
21
|
+
exports.FeatureLeaderboardEntry = FeatureLeaderboardEntry;
|
|
22
|
+
//# sourceMappingURL=FeatureLeaderboardEntry.js.map
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.FeatureLeaderboardEntryDetails = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const feature_details_1 = require("../../../feature/feature-details");
|
|
9
|
+
const FeatureLeaderboardEntryDetails = ({ entry }) => {
|
|
10
|
+
return (react_1.default.createElement("div", null,
|
|
11
|
+
react_1.default.createElement("div", { style: { display: 'flex', gap: '50px' } },
|
|
12
|
+
react_1.default.createElement("div", { className: "feature-metrics", style: { flex: 3 } },
|
|
13
|
+
react_1.default.createElement("h3", { className: "grey-label" }, "Feature Statistics:"),
|
|
14
|
+
react_1.default.createElement(feature_details_1.FeatureStatisticsTable, { statistics: entry.stats })),
|
|
15
|
+
react_1.default.createElement("div", { className: "feature-histogram", style: { flex: 1 } },
|
|
16
|
+
react_1.default.createElement("h3", { className: "grey-label" }, "Feature Distribution:"),
|
|
17
|
+
react_1.default.createElement(feature_details_1.FeatureDistributionChart, { histogram: entry.histogram }))),
|
|
18
|
+
react_1.default.createElement("div", { className: "correlated-features" },
|
|
19
|
+
react_1.default.createElement("h3", { className: "grey-label" }, "Correlated Features:"),
|
|
20
|
+
react_1.default.createElement(feature_details_1.FeatureCorrelatedFeaturesTable, { correlatedFeatures: entry.topCorrelatedFeatures }))));
|
|
21
|
+
};
|
|
22
|
+
exports.FeatureLeaderboardEntryDetails = FeatureLeaderboardEntryDetails;
|
|
23
|
+
//# sourceMappingURL=FeatureLeaderboardEntryDetails.js.map
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.FeatureLeaderboardEntryRow = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const FeatureExplanation_1 = require("../../../feature/feature-explanation/FeatureExplanation");
|
|
9
|
+
const leaderboard_feature_likes_1 = require("../components/leaderboard-feature-likes");
|
|
10
|
+
const featureNameLabelStyle = {
|
|
11
|
+
color: 'var(--c-grey-600)',
|
|
12
|
+
display: 'inline-block',
|
|
13
|
+
marginLeft: '10px',
|
|
14
|
+
minWidth: '5rem',
|
|
15
|
+
};
|
|
16
|
+
const FeatureLeaderboardEntryRow = ({ feature }) => {
|
|
17
|
+
return (react_1.default.createElement("div", { style: {
|
|
18
|
+
display: 'flex',
|
|
19
|
+
alignItems: 'center',
|
|
20
|
+
position: 'relative',
|
|
21
|
+
width: '100%',
|
|
22
|
+
} },
|
|
23
|
+
react_1.default.createElement("span", { className: "label-bold", style: featureNameLabelStyle }, feature.id),
|
|
24
|
+
react_1.default.createElement(FeatureExplanation_1.FeatureExplanation, { key: feature.id, explanationBlocks: feature.explanation.tokens }),
|
|
25
|
+
react_1.default.createElement("div", { style: { marginLeft: 'auto' } },
|
|
26
|
+
react_1.default.createElement(leaderboard_feature_likes_1.LeaderBoardFeatureLikes, { featureId: feature.id }))));
|
|
27
|
+
};
|
|
28
|
+
exports.FeatureLeaderboardEntryRow = FeatureLeaderboardEntryRow;
|
|
29
|
+
//# sourceMappingURL=FeatureLeaderboardEntryRow.js.map
|