## Description This change is a refactor of widget selection logic. It consolidates all the business logic to make it easy to maintain. It also improves the performance a bit. It touched a lot of features as we heavily rely on this ``` Select one Select multiple with drag Select multiple with shift Select multiple with cmd/ctrl Selections should be on the same level of hierarchy Unselect all by clicking on the canvas Unselect all by pressing esc Select all with cmd + a Paste in main container Paste in another container Undo Redo Modal Selection Modal child selection Context switching cmd click snipping mode new widget suggestion onboarding ``` > Refactor widget selection logic Fixes #19570 ## Type of change - Refactor ## How Has This Been Tested? All existing tests should pass ### Test Plan > Add Testsmith test cases links that relate to this PR ### Issues raised during DP testing https://github.com/appsmithorg/appsmith/pull/19643#issuecomment-1383570810 https://github.com/appsmithorg/appsmith/pull/19643#issuecomment-1383607820 https://github.com/appsmithorg/appsmith/pull/19643#issuecomment-1385095478 [Bug bash issues](https://www.notion.so/appsmith/610aa302f3e146a7b090b7dc6bc63ef9?v=0d277a9b07bf4aac9d717bcaf138c33a) ## Checklist: ### Dev activity - [ ] My code follows the style guidelines of this project - [ ] I have performed a self-review of my own code - [ ] I have commented my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [ ] My changes generate no new warnings - [ ] I have added tests that prove my fix is effective or that my feature works - [ ] New and existing unit tests pass locally with my changes - [ ] PR is being merged under a feature flag ### QA activity: - [ ] Test plan has been approved by relevant developers - [ ] Test plan has been peer reviewed by QA - [ ] Cypress test cases have been added and approved by either SDET or manual QA - [ ] Organized project review call with relevant stakeholders after Round 1/2 of QA - [ ] Added Test Plan Approved label after reveiwing all Cypress test
136 lines
4.1 KiB
JSON
136 lines
4.1 KiB
JSON
{
|
|
"dsl": {
|
|
"widgetName": "MainContainer",
|
|
"backgroundColor": "none",
|
|
"rightColumn": 1224,
|
|
"snapColumns": 16,
|
|
"detachFromLayout": true,
|
|
"widgetId": "0",
|
|
"topRow": 0,
|
|
"bottomRow": 1254,
|
|
"containerStyle": "none",
|
|
"snapRows": 33,
|
|
"parentRowSpace": 1,
|
|
"type": "CANVAS_WIDGET",
|
|
"canExtend": true,
|
|
"dynamicBindingPathList": [],
|
|
"version": 3,
|
|
"minHeight": 1292,
|
|
"parentColumnSpace": 1,
|
|
"leftColumn": 0,
|
|
"children": [
|
|
{
|
|
"backgroundColor": "#FFFFFF",
|
|
"widgetName": "Container3",
|
|
"type": "CONTAINER_WIDGET",
|
|
"containerStyle": "card",
|
|
"isVisible": true,
|
|
"isLoading": false,
|
|
"parentColumnSpace": 75.25,
|
|
"parentRowSpace": 38,
|
|
"dynamicBindingPathList": [],
|
|
"leftColumn": 0,
|
|
"rightColumn": 16,
|
|
"topRow": 1,
|
|
"bottomRow": 23,
|
|
"snapColumns": 16,
|
|
"orientation": "VERTICAL",
|
|
"children": [
|
|
{
|
|
"backgroundColor": "transparent",
|
|
"widgetName": "6gcpyqo8my",
|
|
"type": "CANVAS_WIDGET",
|
|
"containerStyle": "none",
|
|
"isVisible": true,
|
|
"isLoading": false,
|
|
"parentColumnSpace": 1,
|
|
"parentRowSpace": 1,
|
|
"leftColumn": 0,
|
|
"rightColumn": 1204,
|
|
"topRow": 0,
|
|
"bottomRow": 532,
|
|
"snapColumns": 16,
|
|
"orientation": "VERTICAL",
|
|
"children": [
|
|
{
|
|
"isVisible": true,
|
|
"isDisabled": false,
|
|
"datePickerType": "DATE_PICKER",
|
|
"dateFormat": "DD/MM/YYYY",
|
|
"label": "Date",
|
|
"widgetName": "DatePicker1",
|
|
"defaultDate": "2020-05-07T10:52:14.548+05:30",
|
|
"type": "DATE_PICKER_WIDGET",
|
|
"isLoading": false,
|
|
"parentColumnSpace": 71.75,
|
|
"parentRowSpace": 38,
|
|
"leftColumn": 1,
|
|
"rightColumn": 8,
|
|
"topRow": 13,
|
|
"bottomRow": 14,
|
|
"parentId": "7tkpo9s22m",
|
|
"widgetId": "4y9j8f6kg2"
|
|
},
|
|
{
|
|
"isVisible": true,
|
|
"text": "Submit",
|
|
"buttonStyle": "PRIMARY_BUTTON",
|
|
"widgetName": "Button1",
|
|
"isDisabled": false,
|
|
"isDefaultClickDisabled": true,
|
|
"type": "BUTTON_WIDGET",
|
|
"isLoading": false,
|
|
"parentColumnSpace": 71.75,
|
|
"parentRowSpace": 38,
|
|
"leftColumn": 12,
|
|
"rightColumn": 14,
|
|
"topRow": 9,
|
|
"bottomRow": 10,
|
|
"parentId": "7tkpo9s22m",
|
|
"widgetId": "nlzw81fc9u"
|
|
},
|
|
{
|
|
"isVisible": true,
|
|
"defaultText": "",
|
|
"isDisabled": false,
|
|
"widgetName": "RichTextEditor1",
|
|
"isDefaultClickDisabled": true,
|
|
"type": "RICH_TEXT_EDITOR_WIDGET",
|
|
"isLoading": false,
|
|
"parentColumnSpace": 71.75,
|
|
"parentRowSpace": 38,
|
|
"leftColumn": 3,
|
|
"rightColumn": 11,
|
|
"topRow": 2,
|
|
"bottomRow": 7,
|
|
"parentId": "7tkpo9s22m",
|
|
"widgetId": "6h8j08u7ea"
|
|
},
|
|
{
|
|
"isVisible": true,
|
|
"text": "Label",
|
|
"textAlign": "LEFT",
|
|
"widgetName": "Text1",
|
|
"type": "TEXT_WIDGET",
|
|
"isLoading": false,
|
|
"parentColumnSpace": 71.75,
|
|
"parentRowSpace": 38,
|
|
"leftColumn": 3,
|
|
"rightColumn": 5,
|
|
"topRow": 10,
|
|
"bottomRow": 12,
|
|
"parentId": "7tkpo9s22m",
|
|
"widgetId": "9xcfqahpw2"
|
|
}
|
|
],
|
|
"widgetId": "7tkpo9s22m",
|
|
"detachFromLayout": true,
|
|
"canExtend": false
|
|
}
|
|
],
|
|
"widgetId": "8xlprxx5pe"
|
|
}
|
|
]
|
|
}
|
|
}
|