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.
@@ -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.type?.name === exports.AccordionHeader.name);
38
- const Details = components.find(child => child.type?.name === exports.AccordionDetails.name);
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
@@ -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
@@ -16,6 +16,8 @@ const defaultState = {
16
16
  value: { allEntries: [] },
17
17
  confidence: 0.95,
18
18
  max_collinearity: 0.95,
19
+ liked_features: [],
20
+ disliked_features: [],
19
21
  };
20
22
  class FeatureLeaderboardWidgetModel extends base_1.DOMWidgetModel {
21
23
  defaults() {
@@ -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 FeatureLeaderboardEntryItem_1 = require("./entry-item/FeatureLeaderboardEntryItem");
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
- featureEntries.map(featureEntry => (react_1.default.createElement(FeatureLeaderboardEntryItem_1.FeatureLeaderboardEntryItem, { key: featureEntry.feature.id, featureEntry: featureEntry })))));
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 featureNameLabelStyle = {
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("span", { className: "label-bold", style: featureNameLabelStyle }, featureEntry.feature.id),
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
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dotdata_widgets",
3
- "version": "0.1.3",
3
+ "version": "0.1.4",
4
4
  "description": "A dotdata widget",
5
5
  "keywords": [
6
6
  "dotdata",