* Updated test * updated assertions * Resizing image to take full width of table cell * updated assertion * Stop updating dynamicBindingPathList directly from widget * Fix selectedRow and selectedRows computations * Fix primaryColumns computations * Updated test for derived column * Added tests for computed value * Added check clear data * Reordering of test * updated common method * Made image size as 100% of table cell size * add templating logic * Updated flow and dsl * Clear old primary columns * Updated testname * updated assertion * use evaluated values for children * Fix primary columns update on component mount and component update * add isArray check * remove property pane enhancement reducer * add property pane enhancement reducer * disable items other than template + fix running property enchancment on drop of list widget * disbled drag, resize, settingsControl, drag for items other than template * add grid options * uncomment the widget operation for add child for grid children * handle delete scenario for child widget in list widget * WIP: Use the new delete and update property features * add listdsl.json for testcases * add test cases for correct no. of items being rendered * add test cases currentItem binding in list widget * change dragEnabled to dragDisabled * change resizeEnabled to resizeDisabled * change settingsControlEnabled to settingsControlDisabled * change dropEnabled to dropDisabled * update settingsControlDisabled default value * Use deleteProperties in propertyControls * Fix unsetting of array indices when deleting widget properties * remove old TableWidget.tsx file * Fix derived column property update on primary column property update * Handle undefined primary columns * Fix filepicker immutable prop issue * Fix object.freeze issue when adding ids to the property pane configuration * fix widget issue in grid * Fix column actions dynamicBindingPathList inclusion issue * remove consoles + fix typo around batch update * Remove redundant tests * js binding test for date picker * hydate enhancement map on copy list widget * check for dynamicleaf * fixes * improve check * fix getNextWidgetName * update template in list widget when copying * updating template copy logic when copying widget * update dynamicBindingPathList in copied widget * Add path parameter to hidden functions in property pane configs * fix copy bug when copying list widget * add computed list property control * Remove time column type Fix editor prompt for currentRow Fix undefined derivedColumns scenario Remove validations for primaryColums and derivedColumns Fix section toggle for video, image and button column types * Fix table widget actions and custom column migrations * Add logs for cyclical dependency map ♻️ * Process array differences * add property control for list widget * Fix onClick migrations * Property pane config parity * binding and trigger paths from the property pane config (#2920) * try react virtualized library * Fix unit test * Fix unit test ✅ * Fix minor issues in table widget * Add default meta props to binding paths to ensure eval and validation * Dummy commit 🎉 * Remove unnecessary datepicker test Fix chart data as string issue * Achieve table column sorting and resizing parity with release * handle scenario where last column isn't available to access * Fix for panel config path not existing in the widget * Fix bindings in currentRow (default) Add dummy property pane config for canvas widget * Update canvas widgets with dynamicPathLists on delete of property paths * Add all diffs to change paths and trim later * Add back default properties 🚶🏻♂️ * Use object based paths instead of arrays for primaryColumns and derivedColumns * Fix issue in reordered columns * Fix inccorect update order * add virtualized list * Fix failing property pane tests * minor change * minor list widget change * Remove .vscode from git * Rename ads to alloy Fix isVisible in list widget * move grid component to widget folder * fix import in widget registry * add sticky row in virtualized list * add sticky container * Fix Height of grid widget items container * fix dragging of items in children other than template children * update list widget * update list widget * Fix padding in list widget * hide scrollbar in list widget list * fix copy bug in list widget * regenrate enhancement map on undo delete widget * Use enhancementmap for autocomplete in list widget Basic styles for list widget scrollbar * add custom control in widget config * minor commit * update scrollbar styles * remove unused variable * fix typo in custom control * comment out test cases * remove unused imports * remove unused imports * add JSON stringify in interweave * add noPad styling in dragLayer for noPad prop * implement grid gap * add list item background color prop * add white color in color picker control * fix gap in last list item * remove onBeforeParse in textcomponent * remove virtualization in grid widget * allow overflow-y * add onListItemClick action * add beta label * add pagination * fix actions in pagination in list widget * add list widget icon * add list background color default value * remove extra div * fix pagination issue * fix list widget crashing on perpage change * extract child operation function to widgetblueprint saga * refactor enhancements * add enhancement hook * refactor propertyUpdate hook enhancment * remove enhacement map * revert renaming ads to alloy * add autopagination * Cleanup unused vars Re-write loop using map Fix binding with external input widget * update default background color * remove unnessary scrol + fix pagination per page * remove console.log * use grid gap in pixel instead of snap * fix list widget tests for binding * add tests for on click action and pagination * remove unnecessary imports * remove overflow hidden in list component * Add feature to enable template actions * update property pane help text for list widget * disable pagination in editor view * update property pane options * add test case for action * uncomment tests * fix grid gap validation * update test cases * fix property pane opening issue for list tempalte * Disable form widgets in list widget * fix template issue for actions * add validation tests for list data * update starting template * add selectedRow + enable pagination in edit mode * remove extra padding in list widget + popper fix on settingDisabled * add stop propagation for button click * fix click event in edit mode * disallow filepicker widget for list widget * add test for list widget entity definition for selectItem * remove unused imports * fix test * remove evaluated value for list child widgets * add comment * remove log * fix copying bug in list widget * add check for not allowing template to copy * fix test * add test for property pane actions * remove unused import * add draglayercomponent test * add test for draggable component * add test for evaluatedvalue popup * add test for messages.ts * add test for widgeticons * add test for property pane selector * add test for widget config response * start testing widget configresponse * add test for enhancements in widget config * add test for codeeditor * add test for base widget + list widget * add test for executeWidgetBlueprintChildOperations * remove unused import * add test for widget operation utils * remove unused import * add test for handleSpecificCasesWhilePasting * remove unused function * remove unused import * add empty list styling * resolve all review comments * fix message test * add test for widget operation utils * fix merge conflicts * move validations in property config Co-authored-by: Abhinav Jha <abhinav@appsmith.com> Co-authored-by: nandan.anantharamu <nandan.anantharamu@thoughtspot.com> Co-authored-by: vicky-primathon.in <vicky.bansal@primathon.in> Co-authored-by: Pawan Kumar <pawankumar@Pawans-MacBook-Pro.local> Co-authored-by: Piyush <piyush@codeitout.com> Co-authored-by: hetunandu <hetu@appsmith.com> Co-authored-by: Hetu Nandu <hetunandu@gmail.com> Co-authored-by: root <root@DESKTOP-9GENCK0.localdomain>
139 lines
3.8 KiB
TypeScript
139 lines
3.8 KiB
TypeScript
import React, { useState } from "react";
|
|
import { useDrag, DragPreviewImage } from "react-dnd";
|
|
import blankImage from "assets/images/blank.png";
|
|
import { WidgetCardProps } from "widgets/BaseWidget";
|
|
import styled from "styled-components";
|
|
import { WidgetIcons } from "icons/WidgetIcons";
|
|
import {
|
|
useWidgetDragResize,
|
|
useShowPropertyPane,
|
|
useWidgetSelection,
|
|
} from "utils/hooks/dragResizeHooks";
|
|
import AnalyticsUtil from "utils/AnalyticsUtil";
|
|
import { generateReactKey } from "utils/generators";
|
|
import { Colors } from "constants/Colors";
|
|
import { AppState } from "reducers";
|
|
import { useSelector } from "react-redux";
|
|
|
|
type CardProps = {
|
|
details: WidgetCardProps;
|
|
};
|
|
|
|
export const Wrapper = styled.div`
|
|
padding: 10px 5px 10px 5px;
|
|
border-radius: 0px;
|
|
border: none;
|
|
position: relative;
|
|
color: ${Colors.ALTO};
|
|
height: 72px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
& > div {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
&:hover {
|
|
color: ${Colors.WHITE};
|
|
background: ${Colors.TUNDORA};
|
|
cursor: grab;
|
|
color: ${Colors.WHITE};
|
|
svg {
|
|
path {
|
|
fill: ${Colors.WHITE};
|
|
}
|
|
rect {
|
|
stroke: ${Colors.WHITE};
|
|
}
|
|
}
|
|
}
|
|
& i {
|
|
font-family: ${(props) => props.theme.fonts.text};
|
|
font-size: ${(props) => props.theme.fontSizes[7]}px;
|
|
}
|
|
`;
|
|
|
|
export const BetaLabel = styled.div`
|
|
font-size: 10px;
|
|
background: ${Colors.TUNDORA};
|
|
margin-top: 3px;
|
|
padding: 2px 4px;
|
|
border-radius: 3px;
|
|
position: absolute;
|
|
top: 0;
|
|
right: -2%;
|
|
`;
|
|
|
|
export const IconLabel = styled.h5`
|
|
text-align: center;
|
|
margin: 0;
|
|
text-transform: uppercase;
|
|
font-weight: ${(props) => props.theme.fontWeights[1]};
|
|
flex-shrink: 1;
|
|
font-size: ${(props) => props.theme.fontSizes[1]}px;
|
|
line-height: ${(props) => props.theme.lineHeights[2]}px;
|
|
&::selection {
|
|
background: none;
|
|
}
|
|
`;
|
|
|
|
const WidgetCard = (props: CardProps) => {
|
|
const { setIsDragging } = useWidgetDragResize();
|
|
const { selectWidget } = useWidgetSelection();
|
|
|
|
const selectedWidget = useSelector(
|
|
(state: AppState) => state.ui.widgetDragResize.selectedWidget,
|
|
);
|
|
|
|
// Generate a new widgetId which can be used in the future for this widget.
|
|
const [widgetId, setWidgetId] = useState(generateReactKey());
|
|
const showPropertyPane = useShowPropertyPane();
|
|
const [, drag, preview] = useDrag({
|
|
item: { ...props.details, widgetId },
|
|
begin: () => {
|
|
AnalyticsUtil.logEvent("WIDGET_CARD_DRAG", {
|
|
widgetType: props.details.type,
|
|
widgetName: props.details.widgetCardName,
|
|
});
|
|
showPropertyPane && showPropertyPane(undefined);
|
|
setIsDragging && setIsDragging(true);
|
|
|
|
// Make sure that this widget is selected
|
|
selectWidget && selectedWidget !== widgetId && selectWidget(widgetId);
|
|
},
|
|
end: (widget, monitor) => {
|
|
AnalyticsUtil.logEvent("WIDGET_CARD_DROP", {
|
|
widgetType: props.details.type,
|
|
widgetName: props.details.widgetCardName,
|
|
didDrop: monitor.didDrop(),
|
|
});
|
|
// We've finished dragging, generate a new widgetId to be used for next drag.
|
|
setWidgetId(generateReactKey());
|
|
setIsDragging && setIsDragging(false);
|
|
},
|
|
});
|
|
|
|
const iconType: string = props.details.type;
|
|
const Icon = WidgetIcons[iconType];
|
|
const className = `t--widget-card-draggable-${props.details.type
|
|
.split("_")
|
|
.join("")
|
|
.toLowerCase()}`;
|
|
return (
|
|
<React.Fragment>
|
|
<DragPreviewImage connect={preview} src={blankImage} />
|
|
<Wrapper ref={drag} className={className}>
|
|
<div>
|
|
<Icon />
|
|
<IconLabel>{props.details.widgetCardName}</IconLabel>
|
|
{props.details.isBeta && <BetaLabel>Beta</BetaLabel>}
|
|
</div>
|
|
</Wrapper>
|
|
</React.Fragment>
|
|
);
|
|
};
|
|
|
|
export default WidgetCard;
|