diff --git a/.github/config.json b/.github/config.json index d5e17dc2d4e..7117d4ab614 100644 --- a/.github/config.json +++ b/.github/config.json @@ -1 +1 @@ -{"runners":[{"versioning":{"source":"milestones","type":"SemVer"},"prereleaseName":"alpha","issue":{"labels":{"Widgets Product":{"conditions":[{"label":"Button Widget","type":"hasLabel","value":true},{"label":"Chart Widget","type":"hasLabel","value":true},{"label":"Container Widget","type":"hasLabel","value":true},{"label":"Date Picker Widget","type":"hasLabel","value":true},{"label":"Select Widget","type":"hasLabel","value":true},{"label":"File Picker Widget","type":"hasLabel","value":true},{"label":"Form Widget","type":"hasLabel","value":true},{"label":"Image Widget","type":"hasLabel","value":true},{"label":"Input Widget","type":"hasLabel","value":true},{"label":"List Widget","type":"hasLabel","value":true},{"label":"MultiSelect Widget","type":"hasLabel","value":true},{"label":"Map Widget","type":"hasLabel","value":true},{"label":"Modal Widget","type":"hasLabel","value":true},{"label":"Radio Widget","type":"hasLabel","value":true},{"label":"Rich Text Editor Widget","type":"hasLabel","value":true},{"label":"Tab Widget","type":"hasLabel","value":true},{"label":"Table Widget","type":"hasLabel","value":true},{"label":"Text Widget","type":"hasLabel","value":true},{"label":"Video Widget","type":"hasLabel","value":true},{"label":"iFrame","type":"hasLabel","value":true},{"label":"Menu Button","type":"hasLabel","value":true},{"label":"Rating","type":"hasLabel","value":true},{"label":"Widget Validation","type":"hasLabel","value":true},{"label":"New Widget","type":"hasLabel","value":true},{"label":"Switch widget","type":"hasLabel","value":true},{"label":"Audio Widget","type":"hasLabel","value":true},{"label":"Icon Button Widget","type":"hasLabel","value":true},{"label":"Stat Box Widget","type":"hasLabel","value":true},{"label":"Voice Recorder Widget","type":"hasLabel","value":true},{"label":"Calendar Widget","type":"hasLabel","value":true},{"label":"Menu Button Widget","type":"hasLabel","value":true},{"label":"Divider Widget","type":"hasLabel","value":true},{"label":"Rating Widget","type":"hasLabel","value":true},{"label":"View Mode","type":"hasLabel","value":true},{"label":"Widget Property","type":"hasLabel","value":true},{"label":"Document Viewer Widget","type":"hasLabel","value":true},{"label":"Radio Group Widget","type":"hasLabel","value":true},{"label":"Currency Input Widget","type":"hasLabel","value":true},{"label":"TreeSelect","type":"hasLabel","value":true},{"label":"MultiTree Select Widget","type":"hasLabel","value":true},{"label":"Phone Input Widget","type":"hasLabel","value":true},{"label":"JSON Form","type":"hasLabel","value":true},{"label":"All Widgets","type":"hasLabel","value":true},{"label":"Button Group widget","type":"hasLabel","value":true},{"label":"Progress bar widget","type":"hasLabel","value":true},{"label":"Audio Recorder Widget","type":"hasLabel","value":true},{"label":"Camera Widget","type":"hasLabel","value":true},{"label":"Table Widget V2","type":"hasLabel","value":true},{"label":"Map Chart Widget","type":"hasLabel","value":true},{"label":"Code Scanner Widget","type":"hasLabel","value":true},{"label":"Widget keyboard accessibility","type":"hasLabel","value":true},{"label":"List Widget V2","type":"hasLabel","value":true},{"label":"Slider Widget","type":"hasLabel","value":true},{"label":"One-click Binding","type":"hasLabel","value":true},{"label":"Old widget version","type":"hasLabel","value":true},{"label":"Widget Discoverability","type":"hasLabel","value":true},{"label":"Switch Group Widget","type":"hasLabel","value":true},{"label":"Checkbox Group widget","type":"hasLabel","value":true},{"label":"Checkbox Widget","type":"hasLabel","value":true},{"label":"Table Inline Edit","type":"hasLabel","value":true},{"label":"Custom Widgets","type":"hasLabel","value":true}],"requires":1},"Javascript Product":{"conditions":[{"label":"JS Linting & Errors","type":"hasLabel","value":true},{"label":"Autocomplete","type":"hasLabel","value":true},{"label":"Evaluated Value","type":"hasLabel","value":true},{"label":"Slash Command","type":"hasLabel","value":true},{"label":"New JS Function","type":"hasLabel","value":true},{"label":"JS Usability","type":"hasLabel","value":true},{"label":"Framework Functions","type":"hasLabel","value":true},{"label":"JS Objects","type":"hasLabel","value":true},{"label":"JS Evaluation","type":"hasLabel","value":true},{"label":"Custom JS Libraries","type":"hasLabel","value":true},{"label":"Action Selector","type":"hasLabel","value":true},{"label":"Widget setter method","type":"hasLabel","value":true},{"label":"Entity Refactor","type":"hasLabel","value":true},{"label":"AST-frontend","type":"hasLabel","value":true},{"label":"Sniping Mode","type":"hasLabel","value":true},{"label":"AST-backend","type":"hasLabel","value":true}],"requires":1},"IDE Product":{"conditions":[{"label":"IDE Product","type":"hasLabel","value":true},{"label":"IDE Infra","type":"hasLabel","value":true},{"label":"IDE Navigation","type":"hasLabel","value":true},{"label":"IDE tabs","type":"hasLabel","value":true},{"label":"Omnibar","type":"hasLabel","value":true},{"label":"Entity Explorer","type":"hasLabel","value":true},{"label":"Page Management","type":"hasLabel","value":true},{"label":"Preview mode","type":"hasLabel","value":true}],"requires":1},"Accelerators Product":{"conditions":[{"label":"Generate Page","type":"hasLabel","value":true},{"label":"Building blocks","type":"hasLabel","value":true}],"requires":1},"Templates Product":{"conditions":[{"label":"Partial-import-export","type":"hasLabel","value":true},{"label":"Templates Product","type":"hasLabel","value":true}],"requires":1},"Design System Product":{"conditions":[{"label":"Design System Product","type":"hasLabel","value":true},{"label":"ADS Component Issue","type":"hasLabel","value":true},{"label":"Keyboard accessibility ","type":"hasLabel","value":true},{"label":"Toggle button","type":"hasLabel","value":true},{"label":"ADS Category Token","type":"hasLabel","value":true},{"label":"ADS Component Documentation","type":"hasLabel","value":true},{"label":"ADS Migration","type":"hasLabel","value":true},{"label":"ADS Deduplication ","type":"hasLabel","value":true},{"label":"ADS Revamp","type":"hasLabel","value":true},{"label":"ADS Deduplication","type":"hasLabel","value":true},{"label":"ADS Unit Test","type":"hasLabel","value":true},{"label":"ADS Components","type":"hasLabel","value":true},{"label":"ADS Grayscale","type":"hasLabel","value":true},{"label":"Design System","type":"hasLabel","value":true},{"label":"ADS Typography","type":"hasLabel","value":true},{"label":"ADS Visual Styles","type":"hasLabel","value":true},{"label":"ADS Component Design","type":"hasLabel","value":true},{"label":"Modal Component","type":"hasLabel","value":true},{"label":"ADS Spacing","type":"hasLabel","value":true},{"label":"ads unit test","type":"hasLabel","value":true},{"label":"ads revamp","type":"hasLabel","value":true},{"label":"ads deduplication","type":"hasLabel","value":true}],"requires":1},"RBAC Product":{"conditions":[{"label":"Invite users","type":"hasLabel","value":true},{"label":"RBAC Product","type":"hasLabel","value":true}],"requires":1},"Workspace Product":{"conditions":[{"label":"Home Page","type":"hasLabel","value":true},{"label":"Workspace Product","type":"hasLabel","value":true}],"requires":1},"Billing & Licensing Product":{"conditions":[{"label":"Customer Portal","type":"hasLabel","value":true},{"label":"Cloud Services","type":"hasLabel","value":true},{"label":"Billing","type":"hasLabel","value":true},{"label":"Self Serve","type":"hasLabel","value":true},{"label":"Enterprise Billing","type":"hasLabel","value":true},{"label":"Analytics Improvements","type":"hasLabel","value":true},{"label":"Self Serve 1.0","type":"hasLabel","value":true},{"label":"License","type":"hasLabel","value":true},{"label":"BE instance","type":"hasLabel","value":true},{"label":"Invite flow","type":"hasLabel","value":true},{"label":"CE Instance Usage","type":"hasLabel","value":true},{"label":"Feature Flagging","type":"hasLabel","value":true}],"requires":1},"Packages Product":{"conditions":[{"label":"Packages Product","type":"hasLabel","value":true}],"requires":1},"Environments Product":{"conditions":[{"label":"Environments Product","type":"hasLabel","value":true}],"requires":1},"UI Building Product":{"conditions":[{"label":"Property Pane","type":"hasLabel","value":true},{"label":"Copy Paste","type":"hasLabel","value":true},{"label":"Drag & Drop","type":"hasLabel","value":true},{"label":"Undo/Redo","type":"hasLabel","value":true},{"label":"Widgets Pane","type":"hasLabel","value":true},{"label":"UI Performance","type":"hasLabel","value":true},{"label":"Widget Grouping","type":"hasLabel","value":true},{"label":"Reflow & Resize","type":"hasLabel","value":true},{"label":"Canvas / Grid","type":"hasLabel","value":true},{"label":"Auto Height","type":"hasLabel","value":true},{"label":"Browser specific","type":"hasLabel","value":true},{"label":"Auto Layout","type":"hasLabel","value":true},{"label":"Fixed layout","type":"hasLabel","value":true},{"label":"App Navigation","type":"hasLabel","value":true}],"requires":1},"Onboarding Product":{"conditions":[{"label":"Welcome Screen","type":"hasLabel","value":true}],"requires":1},"Git Product":{"conditions":[{"label":"Git Product","type":"hasLabel","value":true},{"label":"Git Auto-commit","type":"hasLabel","value":true},{"label":"Auto-commit","type":"hasLabel","value":true},{"label":"Continuous Deployment","type":"hasLabel","value":true},{"label":"Default branch","type":"hasLabel","value":true},{"label":"Git status","type":"hasLabel","value":true},{"label":"Git performance","type":"hasLabel","value":true},{"label":"SDLC","type":"hasLabel","value":true},{"label":"Git IA","type":"hasLabel","value":true},{"label":"Branch management","type":"hasLabel","value":true}],"requires":1},"Embedding Apps Product":{"conditions":[{"label":"Embedding Apps Product","type":"hasLabel","value":true}],"requires":1},"Integrations Product":{"conditions":[{"label":"New Datasource","type":"hasLabel","value":true},{"label":"Firestore","type":"hasLabel","value":true},{"label":"Google Sheets","type":"hasLabel","value":true},{"label":"Mongo","type":"hasLabel","value":true},{"label":"Redshift","type":"hasLabel","value":true},{"label":"snowflake","type":"hasLabel","value":true},{"label":"S3","type":"hasLabel","value":true},{"label":"Redis","type":"hasLabel","value":true},{"label":"Postgres","type":"hasLabel","value":true},{"label":"GraphQL Plugin","type":"hasLabel","value":true},{"label":"ArangoDB","type":"hasLabel","value":true},{"label":"MsSQL","type":"hasLabel","value":true},{"label":"Elastic Search","type":"hasLabel","value":true},{"label":"OAuth","type":"hasLabel","value":true},{"label":"Airtable","type":"hasLabel","value":true},{"label":"CURL","type":"hasLabel","value":true},{"label":"DynamoDB","type":"hasLabel","value":true},{"label":"Zendesk","type":"hasLabel","value":true},{"label":"Hubspot","type":"hasLabel","value":true},{"label":"Query Forms","type":"hasLabel","value":true},{"label":"Twilio","type":"hasLabel","value":true},{"label":"MySQL","type":"hasLabel","value":true},{"label":"Connection pool","type":"hasLabel","value":true},{"label":"MariaDB","type":"hasLabel","value":true},{"label":"Integrations Pod General","type":"hasLabel","value":true},{"label":"SMTP plugin","type":"hasLabel","value":true},{"label":"Oracle SQL DB","type":"hasLabel","value":true},{"label":"Query filter","type":"hasLabel","value":true},{"label":"Activation - datasources","type":"hasLabel","value":true},{"label":"REST API","type":"hasLabel","value":true},{"label":"REST API","type":"hasLabel","value":true},{"label":"Datasources","type":"hasLabel","value":true},{"label":"REST API plugin","type":"hasLabel","value":true},{"label":"Prepared statements","type":"hasLabel","value":true},{"label":"Query Generation","type":"hasLabel","value":true},{"label":"Core Query Execution","type":"hasLabel","value":true},{"label":"Query Management","type":"hasLabel","value":true},{"label":"Query Settings","type":"hasLabel","value":true},{"label":"Query performance","type":"hasLabel","value":true},{"label":"Datatype issue","type":"hasLabel","value":true},{"label":"SmartSubstitution","type":"hasLabel","value":true},{"label":"Suggested Widgets","type":"hasLabel","value":true},{"label":"SAAS Plugins","type":"hasLabel","value":true},{"label":"Reconnect DS modal","type":"hasLabel","value":true},{"label":"OnPageLoad","type":"hasLabel","value":true},{"label":"File upload issues","type":"hasLabel","value":true},{"label":"AI","type":"hasLabel","value":true},{"label":"Appsmith AI","type":"hasLabel","value":true},{"label":"Database Schema","type":"hasLabel","value":true}],"requires":1},"Identity & Authentication Product":{"conditions":[{"label":"Login / Signup","type":"hasLabel","value":true},{"label":"SSO","type":"hasLabel","value":true},{"label":"SCIM","type":"hasLabel","value":true},{"label":"Email verification","type":"hasLabel","value":true}],"requires":1},"Artifact Platform Product":{"conditions":[{"label":"Fork App","type":"hasLabel","value":true},{"label":"Publish App","type":"hasLabel","value":true},{"label":"Secret Management","type":"hasLabel","value":true},{"label":"Import-Export-App","type":"hasLabel","value":true}],"requires":1},"DevOps Pod":{"conditions":[{"label":"Docker","type":"hasLabel","value":true},{"label":"Super Admin","type":"hasLabel","value":true},{"label":"Deployment","type":"hasLabel","value":true},{"label":"K8s","type":"hasLabel","value":true},{"label":"Email Config","type":"hasLabel","value":true},{"label":"Backup & Restore","type":"hasLabel","value":true},{"label":"AWS AMI","type":"hasLabel","value":true},{"label":"Observability","type":"hasLabel","value":true},{"label":"Heroku","type":"hasLabel","value":true},{"label":"New Deployment Mode","type":"hasLabel","value":true},{"label":"Supervisor","type":"hasLabel","value":true},{"label":"Deployment Certificates","type":"hasLabel","value":true},{"label":"Mock Data","type":"hasLabel","value":true},{"label":"AWS ECS","type":"hasLabel","value":true},{"label":"Ingress","type":"hasLabel","value":true},{"label":"Nginx","type":"hasLabel","value":true}],"requires":1},"Performance Pod":{"conditions":[{"label":"Performance","type":"hasLabel","value":true},{"label":"Performance infra","type":"hasLabel","value":true}],"requires":1},"Git Platform Pod":{"conditions":[{"label":"Environments Product","type":"hasLabel","value":true},{"label":"Git Product","type":"hasLabel","value":true},{"label":"Artifact Platform Product","type":"hasLabel","value":true}],"requires":1},"IDE Pod":{"conditions":[{"label":"Telemetry","type":"hasLabel","value":true},{"label":"i18n","type":"hasLabel","value":true},{"label":"IDE Product","type":"hasLabel","value":true},{"label":"App setting","type":"hasLabel","value":true},{"label":"Debugger Product","type":"hasLabel","value":true},{"label":"Embedding Apps Product","type":"hasLabel","value":true}],"requires":1},"Platform Administration Pod":{"conditions":[{"label":"Airgap","type":"hasLabel","value":true},{"label":"Enterprise Edition","type":"hasLabel","value":true},{"label":"Invite flow","type":"hasLabel","value":true},{"label":"User Profile","type":"hasLabel","value":true},{"label":"User Session ","type":"hasLabel","value":true},{"label":"User Session","type":"hasLabel","value":true},{"label":"Admin Settings Product","type":"hasLabel","value":true},{"label":"RBAC Product","type":"hasLabel","value":true},{"label":"Workspace Product","type":"hasLabel","value":true},{"label":"Branding Product","type":"hasLabel","value":true},{"label":"Audit Logs Product","type":"hasLabel","value":true},{"label":"Identity & Authentication Product","type":"hasLabel","value":true}],"requires":1},"DB Infrastructure Pod":{"conditions":[{"label":"Move to Postgres","type":"hasLabel","value":true}],"requires":1},"Widgets & Accelerators Pod":{"conditions":[{"label":"Accelerators Product","type":"hasLabel","value":true},{"label":"Templates Product","type":"hasLabel","value":true},{"label":"Widgets Product","type":"hasLabel","value":true},{"label":"App Theming Product","type":"hasLabel","value":true}],"requires":1},"Packages Pod":{"conditions":[{"label":"Module creator","type":"hasLabel","value":true},{"label":"Module consumer","type":"hasLabel","value":true},{"label":"Package versioning","type":"hasLabel","value":true},{"label":"Convert to module","type":"hasLabel","value":true},{"label":"Query module","type":"hasLabel","value":true},{"label":"JS module","type":"hasLabel","value":true},{"label":"UI module","type":"hasLabel","value":true},{"label":"Packages Pod","type":"hasLabel","value":true},{"label":"Packages Product","type":"hasLabel","value":true}],"requires":1},"Workflows Pod":{"conditions":[{"label":"Workflows Product","type":"hasLabel","value":true}],"requires":1},"Query & JS Pod":{"conditions":[{"label":"Javascript Product","type":"hasLabel","value":true},{"label":"Onboarding Product","type":"hasLabel","value":true},{"label":"Integrations Product","type":"hasLabel","value":true}],"requires":1},"QA Pod":{"conditions":[{"label":"QA","type":"hasLabel","value":true},{"label":"Automation Test","type":"hasLabel","value":true},{"label":"TestGap","type":"hasLabel","value":true},{"label":"Automation failures","type":"hasLabel","value":true},{"label":"Needs automation","type":"hasLabel","value":true}],"requires":1},"Anvil POD":{"conditions":[{"label":"Checkbox Component","type":"hasLabel","value":true},{"label":"WDS team","type":"hasLabel","value":true},{"label":"Anvil POD","type":"hasLabel","value":true},{"label":"WDS - all widgets","type":"hasLabel","value":true},{"label":"WDS - input widget","type":"hasLabel","value":true},{"label":"WDS - paragraph widget","type":"hasLabel","value":true},{"label":"WDS - statbox widget","type":"hasLabel","value":true},{"label":"WDS - modal widget","type":"hasLabel","value":true},{"label":"WDS - icon widget","type":"hasLabel","value":true},{"label":"WDS - checkbox widget","type":"hasLabel","value":true},{"label":"WDS - table widget","type":"hasLabel","value":true},{"label":"WDS - keyValue widget","type":"hasLabel","value":true},{"label":"WDS - switch group widget","type":"hasLabel","value":true},{"label":"WDS - theming","type":"hasLabel","value":true},{"label":"Anvil layout","type":"hasLabel","value":true},{"label":"Anvil - theming","type":"hasLabel","value":true},{"label":"Anvil - vertical alignment","type":"hasLabel","value":true},{"label":"Anvil - layout component","type":"hasLabel","value":true},{"label":"Anvil - drag & drop","type":"hasLabel","value":true},{"label":"Anvil - zones & sections","type":"hasLabel","value":true},{"label":"Anvil - copy paste experience","type":"hasLabel","value":true},{"label":"WDS - phone widget","type":"hasLabel","value":true},{"label":"WDS - responsive widget","type":"hasLabel","value":true},{"label":"Anvil - responsive viewport","type":"hasLabel","value":true},{"label":"WDS - widget styling","type":"hasLabel","value":true},{"label":"Anvil - spacing","type":"hasLabel","value":true},{"label":"Anvil - responsive canvas","type":"hasLabel","value":true},{"label":"WDS - inline button widget","type":"hasLabel","value":true},{"label":"Anvil team","type":"hasLabel","value":true}],"requires":1},"Activation Pod":{"conditions":[{"label":"Activation","type":"hasLabel","value":true}],"requires":1},"Stability Pod":{"conditions":[{"label":"Stability Issue","type":"hasLabel","value":true},{"label":"cypress-flaky-fix","type":"hasLabel","value":true},{"label":"Cypress flaky tests","type":"hasLabel","value":true}],"requires":1},"Documentation Pod":{"conditions":[{"label":"Documentation","type":"hasLabel","value":true}],"requires":1}}},"root":"."}],"labels":{"Tab Widget":{"color":"e2c76c","name":"Tab Widget","description":""},"Dont merge":{"color":"ADB39C","name":"Dont merge","description":""},"Epic":{"color":"3E4B9E","name":"Epic","description":"A zenhub epic that describes a project"},"Menu Button Widget":{"color":"235708","name":"Menu Button Widget","description":"Issues related to Menu Button widget"},"Checkbox Group widget":{"color":"bbeecd","name":"Checkbox Group widget","description":"Issues related to Checkbox Group Widget"},"Input Widget":{"color":"ae65d8","name":"Input Widget","description":""},"Security":{"color":"99139C","name":"Security","description":""},"QA":{"color":"","name":"QA","description":"Needs QA attention"},"Verified":{"color":"9bf416","name":"Verified","description":""},"Wont Fix":{"color":"ffffff","name":"Wont Fix","description":"This will not be worked on"},"MySQL":{"color":"c9ddc6","name":"MySQL","description":"Issues related to MySQL plugin"},"Development":{"color":"9F8A02","name":"Development","description":""},"Help Wanted":{"color":"008672","name":"Help Wanted","description":"Extra attention is needed"},"Home Page":{"color":"","name":"Home Page","description":"Issues related to the application home page"},"Rating Widget":{"color":"235708","name":"Rating Widget","description":"Issues related to the rating widget"},"Stat Box Widget":{"color":"f1c9ce","name":"Stat Box Widget","description":"Issues related to stat box"},"Enhancement":{"color":"a2eeef","name":"Enhancement","description":"New feature or request"},"Fork App":{"color":"af87c7","name":"Fork App","description":"Issues related to forking apps"},"Container Widget":{"color":"19AD0D","name":"Container Widget","description":"Container widget"},"Papercut":{"color":"B562F6","name":"Papercut","description":""},"Needs Design":{"color":"bfd4f2","name":"Needs Design","description":"needs design or changes to design"},"i18n":{"color":"1799b0","name":"i18n","description":"Represents issues that need to be tackled to handle internationalization"},"Rich Text Editor Widget":{"color":"f72cac","name":"Rich Text Editor Widget","description":""},"skip-changelog":{"color":"06086F","name":"skip-changelog","description":"Adding this label to a PR prevents it from being listed in the changelog"},"Low":{"color":"79e53b","name":"Low","description":"An issue that is neither critical nor breaks a user flow"},"potential-duplicate":{"color":"d3cb2e","name":"potential-duplicate","description":"This label marks issues that are potential duplicates of already open issues"},"Audio Widget":{"color":"447B9A","name":"Audio Widget","description":"Issues related to Audio Widget"},"Firestore":{"color":"8078b0","name":"Firestore","description":"Issues related to the firestore Integration"},"New Widget":{"color":"be4cf2","name":"New Widget","description":"A request for a new widget"},"Modal Widget":{"color":"03846f","name":"Modal Widget","description":""},"UX Improvement":{"color":"f4a089","name":"UX Improvement","description":""},"S3":{"color":"8078b0","name":"S3","description":"Issues related to the S3 plugin"},"Release Blocker":{"color":"5756bf","name":"Release Blocker","description":"This issue must be resolved before the release"},"safari":{"color":"51C6AA","name":"safari","description":"Bugs seen on safari browser"},"Example Apps":{"color":"1799b0","name":"Example Apps","description":"Example apps created for new signups"},"MultiSelect Widget":{"color":"AB62D4","name":"MultiSelect Widget","description":"Issues related to MultiSelect Widget"},"Calendar Widget":{"color":"8c6644","name":"Calendar Widget","description":""},"Website":{"color":"151720","name":"Website","description":"Related to www.appsmith.com website"},"Low effort":{"color":"8B59F0","name":"Low effort","description":"Something that'll take a few days to build"},"Checkbox Widget":{"color":"bbeecd","name":"Checkbox Widget","description":""},"Spam":{"color":"620faf","name":"Spam","description":""},"Voice Recorder Widget":{"color":"85bc87","name":"Voice Recorder Widget","description":""},"Select Widget":{"color":"0c669e","name":"Select Widget","description":"Select or dropdown widget"},"Bug":{"color":"8ba6fd","name":"Bug","description":"Something isn't right"},"Widget Validation":{"color":"6990BC","name":"Widget Validation","description":"Issues related to widget property validation"},"Generate Page":{"color":"2b4664","name":"Generate Page","description":"Issures related to page generation"},"File Picker Widget":{"color":"6ae4f2","name":"File Picker Widget","description":""},"snowflake":{"color":"8078b0","name":"snowflake","description":"Issues related to the snowflake Integration"},"Automation":{"color":"CCAF60","name":"Automation","description":""},"hotfix":{"color":"BA3F1D","name":"hotfix","description":""},"Import-Export-App":{"color":"48883f","name":"Import-Export-App","description":"Issues related to importing and exporting apps"},"High effort":{"color":"A7E87B","name":"High effort","description":"Something that'll take more than a month to build"},"Telemetry":{"color":"bc70f9","name":"Telemetry","description":"Issues related to instrumenting appsmith"},"Radio Widget":{"color":"91ef15","name":"Radio Widget","description":""},"Omnibar":{"color":"1bb96a","name":"Omnibar","description":"Issues related to the omnibar for navigation"},"Button Widget":{"color":"34efae","name":"Button Widget","description":""},"Switch widget":{"color":"33A8CE","name":"Switch widget","description":"The switch widget"},"Map Widget":{"color":"7eef7a","name":"Map Widget","description":""},"Task":{"color":"085630","name":"Task","description":"A simple Todo"},"Design System":{"color":"2958a4","name":"Design System","description":"Design system"},"opera":{"color":"C63F5B","name":"opera","description":"Any issues identified on the opera browser"},"Login / Signup":{"color":"","name":"Login / Signup","description":"Authentication flows"},"Image Widget":{"color":"8de8ad","name":"Image Widget","description":""},"firefox":{"color":"6d56e2","name":"firefox","description":""},"Property Pane":{"color":"b356ff","name":"Property Pane","description":"Issues related to the behaviour of the property pane"},"Deployment":{"color":"93491f","name":"Deployment","description":"Installation process of appsmith"},"Production":{"color":"b60205","name":"Production","description":""},"Dependencies":{"color":"0366d6","name":"Dependencies","description":"Pull requests that update a dependency file"},"Google Sheets":{"color":"8078b0","name":"Google Sheets","description":"Issues related to Google Sheets"},"Icon Button Widget":{"color":"D319CE","name":"Icon Button Widget","description":"Issues related to the icon button widget"},"Mongo":{"color":"8078b0","name":"Mongo","description":"Issues related to Mongo DB plugin"},"Documentation":{"color":"a8dff7","name":"Documentation","description":"Improvements or additions to documentation"},"TestGap":{"color":"","name":"TestGap","description":"Issues identified for test plan improvement"},"keyboard shortcut":{"color":"0688B6","name":"keyboard shortcut","description":""},"Reopen":{"color":"897548","name":"Reopen","description":""},"Redshift":{"color":"8078b0","name":"Redshift","description":"Issues related to the redshift integration"},"Date Picker Widget":{"color":"ef1ce1","name":"Date Picker Widget","description":""},"Entity Explorer":{"color":"1bb96a","name":"Entity Explorer","description":"Issues related to navigation using the entity explorer"},"JS Linting & Errors":{"color":"E56AA5","name":"JS Linting & Errors","description":"Issues related to JS Linting and errors"},"iFrame":{"color":"3CD1DB","name":"iFrame","description":"Issues related to iFrame"},"Stale":{"color":"ededed","name":"Stale","description":null},"Text Widget":{"color":"d130d1","name":"Text Widget","description":""},"Video Widget":{"color":"23dd4b","name":"Video Widget","description":""},"Datasources":{"color":"3d590f","name":"Datasources","description":"Issues related to configuring datasource on appsmith"},"error":{"color":"B66773","name":"error","description":"All issues connected to error messages"},"Form Widget":{"color":"09ed77","name":"Form Widget","description":""},"Needs Triaging":{"color":"e8b851","name":"Needs Triaging","description":"Needs attention from maintainers to triage"},"Autocomplete":{"color":"235708","name":"Autocomplete","description":"Issues related to the autocomplete"},"hacktoberfest":{"color":"0052cc","name":"hacktoberfest","description":"All issues that can be solved by the community during Hacktoberfest"},"Medium effort":{"color":"D31156","name":"Medium effort","description":"Something that'll take more than a week but less than a month to build"},"Release":{"color":"57e5e0","name":"Release","description":""},"High":{"color":"c94d14","name":"High","description":"This issue blocks a user from building or impacts a lot of users"},"UI Performance":{"color":"1799b0","name":"UI Performance","description":"Issues related to UI performance"},"Deploy Preview":{"color":"bfdadc","name":"Deploy Preview","description":"Issues found in Deploy Preview"},"Needs Tests":{"color":"8ee263","name":"Needs Tests","description":"Needs automated tests to assert a feature/bug fix"},"Refactor":{"color":"B96662","name":"Refactor","description":"needs refactoring of code"},"Divider Widget":{"color":"235708","name":"Divider Widget","description":"Issues related to the divider widget"},"Table Widget":{"color":"2eead1","name":"Table Widget","description":""},"Needs More Info":{"color":"e54c10","name":"Needs More Info","description":"Needs additional information"},"Good First Issue":{"color":"7057ff","name":"Good First Issue","description":"Good for newcomers"},"UI Improvement":{"color":"9aeef4","name":"UI Improvement","description":""},"Backend":{"color":"d4c5f9","name":"Backend","description":"This marks the issue or pull request to reference server code"},"Frontend":{"color":"87c7f2","name":"Frontend","description":"This label marks the issue or pull request to reference client code"},"Chart Widget":{"color":"616ecc","name":"Chart Widget","description":""},"List Widget":{"color":"8508A0","name":"List Widget","description":"Issues related to the list widget"},"Duplicate":{"color":"cfd3d7","name":"Duplicate","description":"This issue or pull request already exists"},"JS Snippets":{"color":"8d62d2","name":"JS Snippets","description":"issues related to JS Snippets"},"Copy Paste":{"name":"Copy Paste","description":"Issues related to copy paste","color":"b4f0a9"},"Drag & Drop":{"name":"Drag & Drop","description":"Issues related to the drag & drop experience","color":"92115a"},"Sniping Mode":{"name":"Sniping Mode","description":"Issues related to sniping mode","color":"48883f"},"Redis":{"name":"Redis","description":"Issues related to Redis","color":"8078b0"},"New Datasource":{"color":"60b14c","name":"New Datasource","description":"Requests for new datasources"},"Evaluated Value":{"name":"Evaluated Value","description":"Issues related to evaluated values","color":"39f6e7"},"Undo/Redo":{"name":"Undo/Redo","description":"Issues related to undo/redo","color":"f25880"},"App Navigation":{"name":"App Navigation","description":"Issues related to the topbar navigation and configuring it","color":"4773ab"},"Widgets Pane":{"name":"Widgets Pane","description":"Issues related to the discovery and organisation of widgets","color":"ad5d78"},"View Mode":{"color":"1799b0","name":"View Mode","description":"Issues related to the view mode"},"Content":{"name":"Content","description":"For content related topics i.e blogs, templates, videos","color":"a8dff7"},"Slash Command":{"name":"Slash Command","description":"Issues related to the slash command","color":"a0608e"},"Widget Property":{"name":"Widget Property","description":"Issues related to adding / modifying widget properties across widgets","color":"5e92cb"},"Windows":{"name":"Windows","description":"Issues related exclusively to Windows systems","color":"b4cb8a"},"Old App Issues":{"name":"Old App Issues","description":"Issues related to apps old apps a few weeks old and app issues in stale browser session","color":"87ab18"},"Document Viewer Widget":{"name":"Document Viewer Widget","description":"Issues related to Document Viewer Widget","color":"899d4b"},"Radio Group Widget":{"name":"Radio Group Widget","description":"Issues related to radio group widget","color":"b68495"},"Super Admin":{"name":"Super Admin","description":"Issues related to the super admin page","color":"aa95cf"},"Postgres":{"name":"Postgres","description":"Postgres related issues","color":"8078b0"},"New JS Function":{"name":"New JS Function","description":"Issues related to adding a JS Function","color":"8e8aa4"},"Cannot Reproduce Issue":{"color":"93c9cc","name":"Cannot Reproduce Issue","description":"Issues that cannot be reproduced"},"Widget Grouping":{"name":"Widget Grouping","description":"Issues related to Widget Grouping","color":"a49951"},"K8s":{"name":"K8s","description":"Kubernetes related issues","color":"5f318a"},"Docker":{"name":"Docker","description":"Issues related to docker","color":"89b808"},"Camera Widget":{"name":"Camera Widget","description":"Issues and enhancements related to camera widget","color":"e6038e"},"SAAS Plugins":{"name":"SAAS Plugins","description":"Issues related to SAAS Plugins","color":"80e18f"},"JS Promises":{"name":"JS Promises","description":"Issues related to promises","color":"d7771f"},"OnPageLoad":{"name":"OnPageLoad","description":"OnPageLoad issues on functions and queries","color":"2b4664"},"JS Usability":{"name":"JS Usability","description":"usability issues with JS editor and JS elsewhere","color":"a302b0"},"Currency Input Widget":{"name":"Currency Input Widget","description":"Issues related to currency input widget","color":"b2164f"},"TreeSelect":{"name":"TreeSelect","description":"Issues related to TreeSelect Widget","color":"a1633e"},"MultiTree Select Widget":{"name":"MultiTree Select Widget","description":"Issues related to MultiTree Select Widget","color":"a1633e"},"Welcome Screen":{"name":"Welcome Screen","description":"Issues related to the welcome screen","color":"48883f"},"Realtime Commenting":{"color":"a70b86","name":"Realtime Commenting","description":"In-app communication between teams"},"Phone Input Widget":{"name":"Phone Input Widget","description":"Issues related to the Phone Input widget","color":"a70b86"},"JSON Form":{"name":"JSON Form","description":"Issue / features related to the JSON form wiget","color":"46b209"},"All Widgets":{"name":"All Widgets","description":"Issues related to all widgets","color":"972b36"},"V1":{"name":"V1","description":"V1","color":"67ab2e"},"Reflow & Resize":{"name":"Reflow & Resize","description":"All issues related to reflow and resize experience","color":"748a13"},"SSO":{"name":"SSO","description":"Issues, requests and enhancements around Single sign-on.","color":""},"Multi User Realtime":{"name":"Multi User Realtime","description":"Issues related to multiple users using or editing an application","color":"e7b6ce"},"Ready for design":{"name":"Ready for design","description":"this issue is ready for design: it contains clear problem statements and other required information","color":"ebf442"},"Support":{"name":"Support","description":"Issues created by the A-force team to address user queries","color":"1740f3"},"Button Group widget":{"name":"Button Group widget","description":"Issue and enhancements related to the button group widget","color":"f17025"},"GraphQL Plugin":{"name":"GraphQL Plugin","description":"Issues related to GraphQL plugin","color":"8078b0"},"DevOps Pod":{"name":"DevOps Pod","description":"Issues related to devops","color":"d956c7"},"medium":{"name":"medium","description":"Issues that frustrate users due to poor UX","color":"23dfd9"},"ArangoDB":{"name":"ArangoDB","description":"Issues related to arangoDB","color":"8078b0"},"Code Refactoring":{"name":"Code Refactoring","description":"Issues related to code refactoring","color":"76310e"},"Progress bar widget":{"name":"Progress bar widget","description":"To track issues related to progress bar","color":"2d7abf"},"Audio Recorder Widget":{"name":"Audio Recorder Widget","description":"Issues related to Audio Recorder Widget","color":"9accef"},"Airtable":{"name":"Airtable","description":"Issues for Airtable","color":"60885f"},"Canvas / Grid":{"name":"Canvas / Grid","description":"Issues related to the canvas","color":"16b092"},"Email Config":{"name":"Email Config","description":"Issues related to configuring the email service","color":"2a21d1"},"CURL":{"name":"CURL","description":"Issues related to CURL impor","color":"60885f"},"Canvas Zooms":{"name":"Canvas Zooms","description":"Issues related to zooming the canvas","color":"e6038e"},"business":{"name":"business","description":"Features that will be a part of our business edition","color":"cd59eb"},"Action Pod":{"name":"Action Pod","description":"","color":"ee2e36"},"AutomationGap1":{"color":"a5e07c","name":"AutomationGap1","description":"Issues that needs automated tests"},"A-Force11":{"name":"A-Force11","description":"Issues raised by A-Force team","color":"d667b6"},"Business Edition":{"name":"Business Edition","description":"Features that will be a part of our business edition","color":"89bb6c"},"storeValue":{"name":"storeValue","description":"Issues related to the store value function","color":"5d3e66"},"DynamoDB":{"name":"DynamoDB","description":"Issues that are related to DynamoDB should have this label","color":"60885f"},"Backup & Restore":{"name":"Backup & Restore","description":"Issues related to backup and restore","color":"86874d"},"Billing":{"name":"Billing","description":"Billing infrastructure and flows for Business Edition and Trial users","color":"d2bc40"},"Datatype issue":{"name":"Datatype issue","description":"Issues that have risen because data types weren't handled","color":"cef66b"},"OAuth":{"name":"OAuth","description":"OAuth related bugs or features","color":"60885f"},"Table Widget V2":{"name":"Table Widget V2","description":"Issues related to Table Widget V2","color":"3a7192"},"IDE Navigation":{"name":"IDE Navigation","description":"Issues/feature requests related to IDE navigation, and context switching","color":"1bb96a"},"Query performance":{"name":"Query performance","description":"Issues that have to do with lack in performance of query execution","color":"cef66b"},"SAAS Manager App":{"name":"SAAS Manager App","description":"Issues with the SAAS manager app","color":"d427db"},"Twilio":{"name":"Twilio","description":"Issues related to Twilio integration","color":"23ba8d"},"Hubspot":{"name":"Hubspot","description":"Issues related to Hubspot integration","color":"60885f"},"Zendesk":{"name":"Zendesk","description":"Issues related to Zendesk integration","color":"60885f"},"Entity Refactor":{"name":"Entity Refactor","description":"Issues related to refactor logic","color":"705a2c"},"Map Chart Widget":{"name":"Map Chart Widget","description":"Issues related to Map Chart Widgets","color":"c8397f"},"Product Catchup":{"name":"Product Catchup","description":"Issues created in the product catchup","color":"29cd2c"},"Framework Functions":{"name":"Framework Functions","description":"Issues related to internal functions like showAlert(), navigateTo() etc...","color":"c25a09"},"Frontend Libraries Upgrade":{"name":"Frontend Libraries Upgrade","description":"Issues related to frontend libraries upgrade","color":"ede1fc"},"MsSQL":{"name":"MsSQL","description":"Issues related to MsSQL plugin","color":"8078b0"},"Elastic Search":{"name":"Elastic Search","description":"Issues related to the elastic search datasource","color":"8078b0"},"Core Query Execution":{"color":"cef66b","name":"Core Query Execution","description":"Issues related to the execution of all queries"},"Query Management":{"name":"Query Management","description":"Issues related to the CRUD of actions or queries","color":"cef66b"},"Query Settings":{"name":"Query Settings","description":"Issues related to the settings of all queries","color":"cef66b"},"Code Editor":{"name":"Code Editor","description":"Issues related to the code editor","color":"4ca16e"},"Query Forms":{"color":"12b253","name":"Query Forms","description":"Isuses related to the query forms"},"JS Objects":{"color":"22962c","name":"JS Objects","description":"Issues related to JS Objects"},"JS Evaluation":{"color":"22962c","name":"JS Evaluation","description":"Issues related to JS evaluation on the platform"},"SmartSubstitution":{"name":"SmartSubstitution","description":"Issues related to Smart substitution of mustache bindings in queries","color":"bae511"},"Query Generation":{"name":"Query Generation","description":"Issues related to query generation","color":"cef66b"},"Suggested Widgets":{"name":"Suggested Widgets","description":"Issues related to suggesting widgets based on query response","color":"6ac063"},"Code Scanner Widget":{"name":"Code Scanner Widget","description":"Issues related to code scanner widget","color":"9bc1a0"},"Clean URLs":{"name":"Clean URLs","description":"Issues related to clean URLs epic","color":"112623"},"Widget keyboard accessibility":{"name":"Widget keyboard accessibility","description":"All issues related to keyboard accessibility in widgets","color":"b626fd"},"Connection pool":{"name":"Connection pool","description":"issues to do with connection pooling of various plugins","color":"94fe36"},"List Widget V2":{"name":"List Widget V2","description":"Issues related to the list widget v2","color":"adaaf7"},"Auto Height":{"name":"Auto Height","description":"Issues related to dynamic height of widgets","color":"5149cf"},"cypress_failed_test":{"name":"cypress_failed_test","description":"Cypress failed tests","color":"4745d5"},"Needs validation":{"name":"Needs validation","description":"Needs problem validation before being picked up","color":"66673d"},"Slider Widget":{"name":"Slider Widget","description":"Issues raised for slider widgets.","color":"2eef5f"},"Multitenancy":{"name":"Multitenancy","description":"Support multitenancy within single appsmith instance","color":"8c49a9"},"Conversion Algorithm":{"name":"Conversion Algorithm","description":"All issue related to converting app from fixed to flex mode & vice versa","color":"d12d2e"},"Browser specific":{"name":"Browser specific","description":"All issue related to browser","color":"d12d2e"},"Performance infra":{"name":"Performance infra","description":"all issue related to the performance infra","color":"8a60f6"},"DSL Update":{"name":"DSL Update","description":"Issues related to storing and updating the DSL","color":"e16cf3"},"AST-frontend":{"name":"AST-frontend","description":"Issues related to maintaining AST logic","color":"2b4664"},"AST-backend":{"name":"AST-backend","description":"Backend issues related to AST parsing","color":"48883f"},"MariaDB":{"name":"MariaDB","description":"MariaDB datasource","color":"8428c3"},"ADS Component Issue":{"name":"ADS Component Issue","description":"Issues which are caused due to ADS components","color":"d89119"},"Regressed":{"color":"723fd0","name":"Regressed","description":"Scenarios that were working before but have now regressed"},"Needs RCA":{"name":"Needs RCA","description":"a critical or high priority issue that needs an RCA","color":"2cc68f"},"Custom JS Libraries":{"name":"Custom JS Libraries","description":"Issues related to adding custom JS library","color":"bacb6d"},"Integrations Pod General":{"name":"Integrations Pod General","description":"Issues related to the Integrations Pod that don't fit into other tags.","color":"287823"},"Performance Pod":{"name":"Performance Pod","description":"All things related to Appsmith performance","color":"b5a25d"},"Performance":{"name":"Performance","description":"Issues related to performance","color":"9a18d7"},"File upload issues":{"name":"File upload issues","description":"Issues related to uploading any type of files from within Appsmith","color":"2b4664"},"Action Selector":{"name":"Action Selector","description":"Issues related to action selector on the property pane","color":"2f9e20"},"Community Reported":{"name":"Community Reported","description":"issues reported by community members","color":"1402e5"},"JS Function execution":{"name":"JS Function execution","description":"JS function execution","color":"7c2de1"},"Self Serve":{"name":"Self Serve","description":"For all issues related to self-serve flow for business edition","color":"4dacfc"},"Self Serve 1.0":{"name":"Self Serve 1.0","description":"For all issues related to v1 of the self serve project","color":"ae839e"},"Customer Portal":{"name":"Customer Portal","description":"For all tasks/issues pertaining to customer.appsmith.com","color":"d2bc40"},"Cloud Services":{"name":"Cloud Services","description":"For all tasks/issues on Appsmith cloud-services relating to licensing, usage and billing","color":"d2bc40"},"One-click Binding":{"name":"One-click Binding","description":"Issues related to the One click binding epic","color":"f1661c"},"Airgap":{"name":"Airgap","description":"Tickets related to supporting air-gapped Appsmith instances","color":"1cb294"},"SMTP plugin":{"name":"SMTP plugin","description":"Issues related to SMTP plugin","color":"541457"},"AWS AMI":{"name":"AWS AMI","description":"Issues Related to AWS AMI","color":"b44680"},"Old widget version":{"name":"Old widget version","description":"Use this label to raise issue specific only to an older version of a widget","color":"ff3814"},"Enterprise Billing":{"name":"Enterprise Billing","description":"To track all tasks/issues related to licensing & billing for enterprise customers","color":"14c156"},"Oracle SQL DB":{"name":"Oracle SQL DB","description":"Issues related to the Oracle plugin","color":"cbabcb"},"Community Contributor":{"name":"Community Contributor","description":"Meant to track issues that are assigned to external contributors","color":"149ab6"},"widget vertical alignment":{"name":"widget vertical alignment","description":"All issue related widget vertical alignment on the auto layout canvas","color":"d12d2e"},"Observability":{"name":"Observability","description":"Issues related to observability on the Appsmith instance","color":"dff913"},"Checkbox Component":{"name":"Checkbox Component","description":"This labels deals with checkbox component in wds package","color":"75a401"},"Analytics Improvements":{"name":"Analytics Improvements","description":"For all tasks focused on improving our overall analytics and fixing any issues ","color":"29b8ed"},"WDS team":{"name":"WDS team","description":"","color":"8d675a"},"Enterprise Edition":{"name":"Enterprise Edition","description":"Features that will be supported in Enterprise Edition only","color":"984f5e"},"Query filter":{"name":"Query filter","description":"Issues related to query filtering, e.g., WHERE clause","color":"a15134"},"Keyboard accessibility ":{"name":"Keyboard accessibility ","description":"All issue related to ADS component keyboard accessibility","color":"2ba696"},"Toggle button":{"name":"Toggle button","description":"All issue related to ADS toggle button","color":"edc47f"},"SCIM":{"name":"SCIM","description":"Label to collate our SCIM issues","color":"48883f"},"ADS Category Token":{"name":"ADS Category Token","description":"All issues related appsmith design system category tokens","color":"920961"},"ADS Component Documentation":{"name":"ADS Component Documentation","description":"All issues Appsmith design system component documentation","color":"64c46a"},"ADS Migration":{"name":"ADS Migration","description":"All issues related to Appsmith design system migration","color":"b082d6"},"ADS Deduplication ":{"name":"ADS Deduplication ","description":"Replacing component with ADS components","color":"b082d6"},"ADS Revamp":{"name":"ADS Revamp","description":"All issues related to ads revamp. ","color":"b082d6"},"ADS Deduplication":{"name":"ADS Deduplication","description":"Replacing component with ADS components","color":"b082d6"},"ADS Grayscale":{"name":"ADS Grayscale","description":"Support grayscale color changes","color":"b03577"},"ADS Unit Test":{"name":"ADS Unit Test","description":"All issue related ads unit cases ","color":"b082d6"},"ADS Components":{"name":"ADS Components","description":"All issues related ADS components","color":"b082d6"},"Widget Discoverability":{"name":"Widget Discoverability","description":"Issues related to Widget Discoverability","color":"7b55ce"},"Widget setter method":{"name":"Widget setter method","description":"Issues with widget property setters","color":"8dce87"},"License":{"name":"License","description":"For all issues/tasks related to licensing of appsmith-ee edition","color":"90ee98"},"Platformization":{"name":"Platformization","description":"Issues or tasks related to platformization of Appsmith codebase","color":"4e972b"},"Activation - datasources":{"name":"Activation - datasources","description":"issues related to activation projects","color":"7c7ace"},"Partial-import-export":{"name":"Partial-import-export","description":"Label for granular reusability.","color":"717732"},"AI":{"name":"AI","description":"All tasks related to AI","color":"2b4664"},"ADS Typography":{"name":"ADS Typography","description":"All issue related typographical changes","color":"2dbe8d"},"Auto Layout":{"name":"Auto Layout","description":"Issues relates to auto layout","color":"92cf8c"},"Heroku":{"name":"Heroku","description":"Issues related to Heroku","color":"a81b69"},"ADS Visual Styles":{"name":"ADS Visual Styles","description":"All issues related to ADS visual styles","color":"d3da89"},"ADS Component Design":{"name":"ADS Component Design","description":"All issue related to component design","color":"5cc91e"},"Modal Component":{"name":"Modal Component","description":"All issue related to ads modal component","color":"ee63f3"},"App setting":{"name":"App setting","description":"Related to app settings panel within the app","color":"174f98"},"BE instance":{"name":"BE instance","description":"For all issues related to license, billing on BE instance","color":"ae8f98"},"Fixed layout":{"name":"Fixed layout","description":"issues related to fixed layout","color":"b66681"},"Anvil layout":{"name":"Anvil layout","description":"issues related to the new layout system anvil","color":"5e0904"},"New Deployment Mode":{"name":"New Deployment Mode","description":"Support a new mode of deployment","color":"108033"},"Custom widgets":{"name":"Custom widgets","description":"For all issues related to the custom widget project","color":"c9db9c"},"Homepage Experience V2":{"name":"Homepage Experience V2","description":"Label for reporting new tasks and bug fixes related to revamped homepage experience","color":"c55d54"},"Customer Success":{"name":"Customer Success","description":"Issues that the success team cares about","color":"6ccabd"},"Invite flow":{"name":"Invite flow","description":"Invite users flow and any associated actions","color":"881b35"},"Invite users":{"name":"Invite users","description":"Invite users flow and any associated actions","color":""},"Workflows Pod":{"name":"Workflows Pod","description":"Issues that the workflows team owns","color":"446925"},"DailyPromotionBlocker":{"name":"DailyPromotionBlocker","description":"DailyPromotion Blocker","color":"9b2280"},"JS Binding":{"name":"JS Binding","description":"All issues related to the JS Binding experience","color":"422fed"},"REST API":{"name":"REST API","description":"REST API plugin related issues","color":"e3ede5"},"Critical":{"color":"a1e3db","name":"Critical","description":"This issue breaks existing apps. Drop everything else to resolve"},"Module creator":{"name":"Module creator","description":"Issues related to the module creator side","color":"bb2c05"},"Module consumer":{"name":"Module consumer","description":"Issues related to the module consumer side","color":"83d3c5"},"Package versioning":{"name":"Package versioning","description":"ISsues related to how we manage versions for packages","color":"4c5218"},"Convert to module":{"name":"Convert to module","description":"Issues related to the module creation flow using conversion","color":"4c5218"},"Query module":{"name":"Query module","description":"Issues affecting query modules or its instances","color":"b11a7e"},"JS module":{"name":"JS module","description":"Issues affecting JS modules or its instances","color":"bf76f6"},"Secret Management":{"name":"Secret Management","description":"Issues related to secret management","color":"2b4664"},"REST API plugin":{"name":"REST API plugin","description":"REST API plugin related issues","color":"b5948a"},"UI module":{"name":"UI module","description":"Issues affecting UI modules or its instances","color":"d2acee"},"Preview mode":{"name":"Preview mode","description":"Issues related to app previews","color":"48883f"},"Git Auto-commit":{"name":"Git Auto-commit","description":"Issues related to autocommit","color":"717732"},"QA Pod":{"name":"QA Pod","description":"Issues under the QA Pod","color":"717732"},"Automation Test":{"name":"Automation Test","description":"","color":""},"Automation failures":{"name":"Automation failures","description":"","color":""},"Needs automation":{"name":"Needs automation","description":"Issues that needs automated tests","color":""},"Prepared statements":{"name":"Prepared statements","description":"Issues related to prepared statement flow","color":""},"Switch Group Widget":{"name":"Switch Group Widget","description":"Issues related to Switch group Widget","color":""},"Supervisor":{"name":"Supervisor","description":"Issues related to supervisor","color":"2c5813"},"Deployment Certificates":{"name":"Deployment Certificates","description":"Issues related to lets encrypt","color":"e148aa"},"Mock Data":{"name":"Mock Data","description":"Issues related to mock databases","color":"ebf251"},"AWS ECS":{"name":"AWS ECS","description":"Issues related to ECS Fargate","color":"e506ff"},"Publish App":{"name":"Publish App","description":"Issues related to app deployment","color":"2b4664"},"IDE Infra":{"name":"IDE Infra","description":"Issues related to the IDE infrastructure like saving changes","color":"1bb96a"},"User Profile":{"name":"User Profile","description":"Issues related to a user profile","color":"a60d34"},"Page Management":{"color":"1bb96a","name":"Page Management","description":"Issues related to configuring pages"},"Ingress":{"name":"Ingress","description":"Ingress Controller","color":"a86802"},"Nginx":{"name":"Nginx","description":"Issues related to Nginx","color":"e54195"},"Building blocks":{"name":"Building blocks","description":"Building blocks on cavas, on templates listing or drag and drop of building blocks.","color":"48883f"},"Table Inline Edit":{"name":"Table Inline Edit","description":"Issues related to inline editing","color":"60895a"},"User Session ":{"name":"User Session ","description":"For all issues/tasks related to user sessions","color":"65a3f5"},"WDS - all widgets":{"name":"WDS - all widgets","description":"all widget present in WDS","color":"2670ae"},"WDS - input widget":{"name":"WDS - input widget","description":"Issues related to input widget on WDS","color":"2670ae"},"WDS - paragraph widget":{"name":"WDS - paragraph widget","description":"issues related to paragraph widget on WDS","color":"2670ae"},"WDS - statbox widget":{"name":"WDS - statbox widget","description":"issues related to statbox widget on WDS","color":"2670ae"},"WDS - modal widget":{"name":"WDS - modal widget","description":"Issues related to modal widget on WDS","color":"2670ae"},"WDS - icon widget":{"name":"WDS - icon widget","description":"Issues related to icon widget on WDS","color":"2670ae"},"WDS - checkbox widget":{"name":"WDS - checkbox widget","description":"Issues related to checkbox widget on WDS","color":"2670ae"},"WDS - table widget":{"name":"WDS - table widget","description":"Issues related to table widget on WDS","color":"2670ae"},"WDS - keyValue widget":{"name":"WDS - keyValue widget","description":"Issues related to key-value widget on WDS","color":"2670ae"},"WDS - switch group widget":{"name":"WDS - switch group widget","description":"Issues related to switch group widget on WDS","color":"2670ae"},"WDS - theming":{"name":"WDS - theming","description":"Issues related to theming on the Anvil instance","color":"2670ae"},"Anvil POD":{"name":"Anvil POD","description":"Issue related to Anvil project","color":"5e0904"},"Anvil - theming":{"name":"Anvil - theming","description":"Issues related to theming on the Anvil instance","color":"c28de5"},"Anvil - vertical alignment":{"name":"Anvil - vertical alignment","description":"Issues related to vertical alignment on the Anvil layout","color":"c28de5"},"Anvil - layout component":{"name":"Anvil - layout component","description":"Issues related to layout component on the Anvil layout","color":"c28de5"},"Anvil - drag & drop":{"name":"Anvil - drag & drop","description":"Issues related to drag & drop experience on Anvil","color":"c28de5"},"Anvil - zones & sections":{"name":"Anvil - zones & sections","description":"Issues related to zones and sections on the Anvil layout","color":"c28de5"},"Anvil - copy paste experience":{"name":"Anvil - copy paste experience","description":"Issues related to copy paste experience on the Anvil layout","color":"c28de5"},"WDS - phone widget":{"name":"WDS - phone widget","description":"Issues related to phone widget on WDS","color":"c28de5"},"WDS - responsive widget":{"name":"WDS - responsive widget","description":"All issues related to widget responsiveness","color":"11ee05"},"Anvil - responsive viewport":{"color":"11ee05","name":"Anvil - responsive viewport","description":"Issues seen on different viewports like mobile"},"WDS - widget styling":{"color":"11ee05","name":"WDS - widget styling","description":"all about widget styling"},"Anvil - spacing":{"name":"Anvil - spacing","description":"Related to spacing between widgets in auto layout","color":"11ee05"},"Anvil - responsive canvas":{"name":"Anvil - responsive canvas","description":"All issues related to canvas responsiveness","color":"11ee05"},"WDS - inline button widget":{"name":"WDS - inline button widget","description":"Issues related to inline button widget on WDS","color":"7cef83"},"Activation Pod":{"name":"Activation Pod","description":"for Activation group","color":"d67d00"},"Activation":{"name":"Activation","description":"for Activation group","color":"d67d00"},"Tests":{"name":"Tests","description":"Test issues","color":"4fc7b6"},"Ballpark: XXS":{"name":"Ballpark: XXS","description":"~1xDev in 1/2xSprint","color":""},"Ballpark: XS":{"name":"Ballpark: XS","description":"~1xDev in 1xSprint","color":"53bf71"},"Ballpark: S":{"name":"Ballpark: S","description":"~2xDev in 1xSprint","color":"6e9e65"},"Ballpark: M":{"name":"Ballpark: M","description":"~1xPOD in 1xSprint","color":"2229e6"},"Ballpark: L":{"name":"Ballpark: L","description":"~1xPOD in 3xSprint or 2xPODs in 1xSprint","color":"49962f"},"Ballpark: XL":{"name":"Ballpark: XL","description":"~1xPOD in 1xQuarter or 2xPODs in 2xSprint","color":"b524c9"},"Ballpark: XXL":{"name":"Ballpark: XXL","description":"~2xPODs in 1xQuarter","color":"22092c"},"Auto-commit":{"name":"Auto-commit","description":"Issues related to auto-generated commits showing up on git ","color":"e25b89"},"Continuous Deployment":{"name":"Continuous Deployment","description":"Issues related to CD pipeline on git","color":"aea47c"},"Default branch":{"name":"Default branch","description":"Issues related to using a default branch on git","color":"195737"},"Git status":{"name":"Git status","description":"Issues related to information shown on git status modal or number of changes appearing in a branch","color":"c851b8"},"Git performance":{"name":"Git performance","description":"Issues related to perceived performance on any git operation","color":"189af6"},"Anvil team":{"name":"Anvil team","description":"issues related to the new layout system anvil","color":"798200"},"SDLC":{"name":"SDLC","description":"Issues related to software development lifecycle experiences","color":"bae511"},"Reconnect DS modal":{"name":"Reconnect DS modal","description":"Issues related to reconnect datasource modal post app import","color":"2e398b"},"Stability Pod":{"name":"Stability Pod","description":"For all issues/tasks to be prioritized under Stability pod","color":"86ddf6"},"Stability Issue":{"name":"Stability Issue","description":"Every issue handle by Stability Pod","color":"4d024a"},"Move to Postgres":{"name":"Move to Postgres","description":"Issues required to be solved for the move to Postgres as repository layer","color":"4e13ac"},"User Session":{"name":"User Session","description":"Issues related to user sessions","color":"8255e5"},"IDE tabs":{"name":"IDE tabs","description":"query and js tabs","color":"1bb96a"},"Inviting Contribution":{"name":"Inviting Contribution","description":"Issues that we would like contributions to","color":""},"cypress-flaky-fix":{"name":"cypress-flaky-fix","description":"This label is auto-added when a PR which only has Cypress fixes are merged to release","color":"722cbc"},"Cypress flaky tests":{"name":"Cypress flaky tests","description":"Test scripts that need to be fixed on Cypress by dev or SDET","color":"722cbc"},"Help enterprise":{"name":"Help enterprise","description":"Requested by Appsmith customers or prospects","color":"FF8C00"},"Learnability":{"name":"Learnability","description":"Issues affecting the product learnability, making the product harder for new users.","color":"800c2f"},"ADS Spacing":{"name":"ADS Spacing","description":"","color":"686ebb"},"ads unit test":{"name":"ads unit test","description":"All issue related ads unit cases","color":"686ebb"},"ads revamp":{"name":"ads revamp","description":"All issues related to ads revamp.","color":"686ebb"},"Javascript Product":{"color":"709a21","name":"Javascript Product","description":"Issues related to users writing javascript in appsmith"},"IDE Product":{"color":"1bb96a","name":"IDE Product","description":"Issues related to the IDE Product"},"IDE Pod":{"color":"1bb96a","name":"IDE Pod","description":"Issues that new developers face while exploring the IDE"},"Accelerators Product":{"name":"Accelerators Product","description":"Issues related to app building accelerators","color":"f3fce6"},"Templates Product":{"name":"Templates Product","description":"Issues related to Templates","color":"f3fce6"},"Design System Product":{"name":"Design System Product","description":"Appsmith design system related issues","color":"2b4664"},"ads deduplication":{"name":"ads deduplication","description":"Replacing component with ADS components","color":"708943"},"Admin Settings Product":{"color":"708943","name":"Admin Settings Product","description":"Issues in admin settings pages"},"Appsmith AI":{"name":"Appsmith AI","description":"All issues related to the Appsmith AI datasource","color":"708943"},"Query & JS Pod":{"color":"709a21","name":"Query & JS Pod","description":"Issues related to the query & JS Pod"},"RBAC Product":{"name":"RBAC Product","description":"Issues, requests and enhancements around RBAC.","color":""},"Workspace Product":{"name":"Workspace Product","description":"Issues related to workspaces","color":""},"CE Instance Usage":{"name":"CE Instance Usage","description":"For all issues relating to usage, licensing or billing on the CE instance","color":""},"Billing & Licensing Product":{"name":"Billing & Licensing Product","description":"Issues pertaining to licensing, billing and usage across self serve and enterprise customers","color":"446925"},"Platform Administration Pod":{"color":"446925","name":"Platform Administration Pod","description":"Issues related to platform administration & management"},"DB Infrastructure Pod":{"name":"DB Infrastructure Pod","description":"Pod to handle database infrastructure","color":"446925"},"Packages Product":{"name":"Packages Product","description":"Issues related to packages","color":"446925"},"Workflows Product":{"name":"Workflows Product","description":"Issues related to the workflows product","color":"446925"},"Debugger Product":{"color":"857f58","name":"Debugger Product","description":"Issues related to the debugger"},"Packages Pod":{"name":"Packages Pod","description":"issues that belong to the packages pod","color":"857f58"},"Environments Product":{"name":"Environments Product","description":"Issues related to datasource environments","color":"857f58"},"Custom Widgets":{"name":"Custom Widgets","description":"For all issues related to the custom widget project","color":"857f58"},"Branding Product":{"name":"Branding Product","description":"All issues under branding and whitelabelling appsmith ecosystem","color":"857f58"},"Widgets & Accelerators Pod":{"name":"Widgets & Accelerators Pod","description":"Issues related to widgets & Accelerators","color":"27496a"},"Widgets Product":{"name":"Widgets Product","description":"This label groups issues related to widgets","color":"f3fce6"},"App Theming Product":{"name":"App Theming Product","description":"Items that are related to the App level theming controls epic","color":"48883f"},"UI Building Product":{"color":"48883f","name":"UI Building Product","description":"Issues related to the UI Building experience"},"Onboarding Product":{"color":"48883f","name":"Onboarding Product","description":"Issues related to onboarding new developers"},"Database Schema":{"name":"Database Schema","description":"Issues related to database schema","color":"48883f"},"Git Product":{"color":"48883f","name":"Git Product","description":"Issues related to version control product"},"Git Platform Pod":{"name":"Git Platform Pod","description":"Issues related to the git & the app platform ","color":"48883f"},"Embedding Apps Product":{"name":"Embedding Apps Product","description":"Issues related to embedding","color":"48883f"},"Integrations Product":{"name":"Integrations Product","description":"Issues related to a specific integration","color":"b9f21c"},"Feature Flagging":{"name":"Feature Flagging","description":"Anything related feature flagging","color":"4574ae"},"Audit Logs Product":{"name":"Audit Logs Product","description":"Audit trails to ensure data security","color":"4574ae"},"Identity & Authentication Product":{"name":"Identity & Authentication Product","description":"Issues related to user identity & authentication","color":"4574ae"},"Email verification":{"name":"Email verification","description":"Email verification issues","color":"4574ae"},"Artifact Platform Product":{"name":"Artifact Platform Product","description":"Issues related to the application platform","color":"4574ae"},"Git IA":{"name":"Git IA","description":"Issues related to Git IA changes","color":"df8bd6"},"Documentation Pod":{"name":"Documentation Pod","description":"Issues related to user education","color":"8c8c02"},"Branch management":{"name":"Branch management","description":"Issues related to using a branch management on git","color":"ebe6af"}},"success":true} \ No newline at end of file +{"runners":[{"versioning":{"source":"milestones","type":"SemVer"},"prereleaseName":"alpha","issue":{"labels":{"Widgets Product":{"conditions":[{"label":"Button Widget","type":"hasLabel","value":true},{"label":"Chart Widget","type":"hasLabel","value":true},{"label":"Container Widget","type":"hasLabel","value":true},{"label":"Date Picker Widget","type":"hasLabel","value":true},{"label":"Select Widget","type":"hasLabel","value":true},{"label":"File Picker Widget","type":"hasLabel","value":true},{"label":"Form Widget","type":"hasLabel","value":true},{"label":"Image Widget","type":"hasLabel","value":true},{"label":"Input Widget","type":"hasLabel","value":true},{"label":"List Widget","type":"hasLabel","value":true},{"label":"MultiSelect Widget","type":"hasLabel","value":true},{"label":"Map Widget","type":"hasLabel","value":true},{"label":"Modal Widget","type":"hasLabel","value":true},{"label":"Radio Widget","type":"hasLabel","value":true},{"label":"Rich Text Editor Widget","type":"hasLabel","value":true},{"label":"Tab Widget","type":"hasLabel","value":true},{"label":"Table Widget","type":"hasLabel","value":true},{"label":"Text Widget","type":"hasLabel","value":true},{"label":"Video Widget","type":"hasLabel","value":true},{"label":"iFrame","type":"hasLabel","value":true},{"label":"Menu Button","type":"hasLabel","value":true},{"label":"Rating","type":"hasLabel","value":true},{"label":"Widget Validation","type":"hasLabel","value":true},{"label":"New Widget","type":"hasLabel","value":true},{"label":"Switch widget","type":"hasLabel","value":true},{"label":"Audio Widget","type":"hasLabel","value":true},{"label":"Icon Button Widget","type":"hasLabel","value":true},{"label":"Stat Box Widget","type":"hasLabel","value":true},{"label":"Voice Recorder Widget","type":"hasLabel","value":true},{"label":"Calendar Widget","type":"hasLabel","value":true},{"label":"Menu Button Widget","type":"hasLabel","value":true},{"label":"Divider Widget","type":"hasLabel","value":true},{"label":"Rating Widget","type":"hasLabel","value":true},{"label":"View Mode","type":"hasLabel","value":true},{"label":"Widget Property","type":"hasLabel","value":true},{"label":"Document Viewer Widget","type":"hasLabel","value":true},{"label":"Radio Group Widget","type":"hasLabel","value":true},{"label":"Currency Input Widget","type":"hasLabel","value":true},{"label":"TreeSelect","type":"hasLabel","value":true},{"label":"MultiTree Select Widget","type":"hasLabel","value":true},{"label":"Phone Input Widget","type":"hasLabel","value":true},{"label":"JSON Form","type":"hasLabel","value":true},{"label":"All Widgets","type":"hasLabel","value":true},{"label":"Button Group widget","type":"hasLabel","value":true},{"label":"Progress bar widget","type":"hasLabel","value":true},{"label":"Audio Recorder Widget","type":"hasLabel","value":true},{"label":"Camera Widget","type":"hasLabel","value":true},{"label":"Table Widget V2","type":"hasLabel","value":true},{"label":"Map Chart Widget","type":"hasLabel","value":true},{"label":"Code Scanner Widget","type":"hasLabel","value":true},{"label":"Widget keyboard accessibility","type":"hasLabel","value":true},{"label":"List Widget V2","type":"hasLabel","value":true},{"label":"Slider Widget","type":"hasLabel","value":true},{"label":"One-click Binding","type":"hasLabel","value":true},{"label":"Old widget version","type":"hasLabel","value":true},{"label":"Widget Discoverability","type":"hasLabel","value":true},{"label":"Switch Group Widget","type":"hasLabel","value":true},{"label":"Checkbox Group widget","type":"hasLabel","value":true},{"label":"Checkbox Widget","type":"hasLabel","value":true},{"label":"Table Inline Edit","type":"hasLabel","value":true},{"label":"Custom Widgets","type":"hasLabel","value":true}],"requires":1},"Javascript Product":{"conditions":[{"label":"JS Linting & Errors","type":"hasLabel","value":true},{"label":"Autocomplete","type":"hasLabel","value":true},{"label":"Evaluated Value","type":"hasLabel","value":true},{"label":"Slash Command","type":"hasLabel","value":true},{"label":"New JS Function","type":"hasLabel","value":true},{"label":"JS Usability","type":"hasLabel","value":true},{"label":"Framework Functions","type":"hasLabel","value":true},{"label":"JS Objects","type":"hasLabel","value":true},{"label":"JS Evaluation","type":"hasLabel","value":true},{"label":"Custom JS Libraries","type":"hasLabel","value":true},{"label":"Action Selector","type":"hasLabel","value":true},{"label":"Widget setter method","type":"hasLabel","value":true},{"label":"Entity Refactor","type":"hasLabel","value":true},{"label":"AST-frontend","type":"hasLabel","value":true},{"label":"Sniping Mode","type":"hasLabel","value":true},{"label":"AST-backend","type":"hasLabel","value":true}],"requires":1},"IDE Product":{"conditions":[{"label":"IDE Product","type":"hasLabel","value":true},{"label":"IDE Infra","type":"hasLabel","value":true},{"label":"IDE Navigation","type":"hasLabel","value":true},{"label":"IDE tabs","type":"hasLabel","value":true},{"label":"Omnibar","type":"hasLabel","value":true},{"label":"Entity Explorer","type":"hasLabel","value":true},{"label":"Page Management","type":"hasLabel","value":true},{"label":"Preview mode","type":"hasLabel","value":true}],"requires":1},"Accelerators Product":{"conditions":[{"label":"Generate Page","type":"hasLabel","value":true},{"label":"Building blocks","type":"hasLabel","value":true}],"requires":1},"Templates Product":{"conditions":[{"label":"Partial-import-export","type":"hasLabel","value":true},{"label":"Templates Product","type":"hasLabel","value":true}],"requires":1},"Design System Product":{"conditions":[{"label":"Design System Product","type":"hasLabel","value":true},{"label":"ADS Component Issue","type":"hasLabel","value":true},{"label":"Keyboard accessibility ","type":"hasLabel","value":true},{"label":"Toggle button","type":"hasLabel","value":true},{"label":"ADS Category Token","type":"hasLabel","value":true},{"label":"ADS Component Documentation","type":"hasLabel","value":true},{"label":"ADS Migration","type":"hasLabel","value":true},{"label":"ADS Deduplication ","type":"hasLabel","value":true},{"label":"ADS Revamp","type":"hasLabel","value":true},{"label":"ADS Deduplication","type":"hasLabel","value":true},{"label":"ADS Unit Test","type":"hasLabel","value":true},{"label":"ADS Components","type":"hasLabel","value":true},{"label":"ADS Grayscale","type":"hasLabel","value":true},{"label":"Design System","type":"hasLabel","value":true},{"label":"ADS Typography","type":"hasLabel","value":true},{"label":"ADS Visual Styles","type":"hasLabel","value":true},{"label":"ADS Component Design","type":"hasLabel","value":true},{"label":"Modal Component","type":"hasLabel","value":true},{"label":"ADS Spacing","type":"hasLabel","value":true},{"label":"ads unit test","type":"hasLabel","value":true},{"label":"ads revamp","type":"hasLabel","value":true},{"label":"ads deduplication","type":"hasLabel","value":true}],"requires":1},"RBAC Product":{"conditions":[{"label":"Invite users","type":"hasLabel","value":true},{"label":"RBAC Product","type":"hasLabel","value":true}],"requires":1},"Workspace Product":{"conditions":[{"label":"Home Page","type":"hasLabel","value":true},{"label":"Workspace Product","type":"hasLabel","value":true}],"requires":1},"Billing & Licensing Product":{"conditions":[{"label":"Customer Portal","type":"hasLabel","value":true},{"label":"Cloud Services","type":"hasLabel","value":true},{"label":"Billing","type":"hasLabel","value":true},{"label":"Self Serve","type":"hasLabel","value":true},{"label":"Enterprise Billing","type":"hasLabel","value":true},{"label":"Analytics Improvements","type":"hasLabel","value":true},{"label":"Self Serve 1.0","type":"hasLabel","value":true},{"label":"License","type":"hasLabel","value":true},{"label":"BE instance","type":"hasLabel","value":true},{"label":"Invite flow","type":"hasLabel","value":true},{"label":"CE Instance Usage","type":"hasLabel","value":true},{"label":"Feature Flagging","type":"hasLabel","value":true}],"requires":1},"Packages Product":{"conditions":[{"label":"Packages Product","type":"hasLabel","value":true}],"requires":1},"Environments Product":{"conditions":[{"label":"Environments Product","type":"hasLabel","value":true}],"requires":1},"UI Building Product":{"conditions":[{"label":"Property Pane","type":"hasLabel","value":true},{"label":"Copy Paste","type":"hasLabel","value":true},{"label":"Drag & Drop","type":"hasLabel","value":true},{"label":"Undo/Redo","type":"hasLabel","value":true},{"label":"Widgets Pane","type":"hasLabel","value":true},{"label":"UI Performance","type":"hasLabel","value":true},{"label":"Widget Grouping","type":"hasLabel","value":true},{"label":"Reflow & Resize","type":"hasLabel","value":true},{"label":"Canvas / Grid","type":"hasLabel","value":true},{"label":"Auto Height","type":"hasLabel","value":true},{"label":"Browser specific","type":"hasLabel","value":true},{"label":"Auto Layout","type":"hasLabel","value":true},{"label":"Fixed layout","type":"hasLabel","value":true},{"label":"App Navigation","type":"hasLabel","value":true}],"requires":1},"Onboarding Product":{"conditions":[{"label":"Welcome Screen","type":"hasLabel","value":true}],"requires":1},"Git Product":{"conditions":[{"label":"Git Product","type":"hasLabel","value":true},{"label":"Git Auto-commit","type":"hasLabel","value":true},{"label":"Auto-commit","type":"hasLabel","value":true},{"label":"Continuous Deployment","type":"hasLabel","value":true},{"label":"Default branch","type":"hasLabel","value":true},{"label":"Git status","type":"hasLabel","value":true},{"label":"Git performance","type":"hasLabel","value":true},{"label":"SDLC","type":"hasLabel","value":true},{"label":"Git IA","type":"hasLabel","value":true},{"label":"Branch management","type":"hasLabel","value":true}],"requires":1},"Embedding Apps Product":{"conditions":[{"label":"Embedding Apps Product","type":"hasLabel","value":true}],"requires":1},"Integrations Product":{"conditions":[{"label":"New Datasource","type":"hasLabel","value":true},{"label":"Firestore","type":"hasLabel","value":true},{"label":"Google Sheets","type":"hasLabel","value":true},{"label":"Mongo","type":"hasLabel","value":true},{"label":"Redshift","type":"hasLabel","value":true},{"label":"snowflake","type":"hasLabel","value":true},{"label":"S3","type":"hasLabel","value":true},{"label":"Redis","type":"hasLabel","value":true},{"label":"Postgres","type":"hasLabel","value":true},{"label":"GraphQL Plugin","type":"hasLabel","value":true},{"label":"ArangoDB","type":"hasLabel","value":true},{"label":"MsSQL","type":"hasLabel","value":true},{"label":"Elastic Search","type":"hasLabel","value":true},{"label":"OAuth","type":"hasLabel","value":true},{"label":"Airtable","type":"hasLabel","value":true},{"label":"CURL","type":"hasLabel","value":true},{"label":"DynamoDB","type":"hasLabel","value":true},{"label":"Zendesk","type":"hasLabel","value":true},{"label":"Hubspot","type":"hasLabel","value":true},{"label":"Query Forms","type":"hasLabel","value":true},{"label":"Twilio","type":"hasLabel","value":true},{"label":"MySQL","type":"hasLabel","value":true},{"label":"Connection pool","type":"hasLabel","value":true},{"label":"MariaDB","type":"hasLabel","value":true},{"label":"Integrations Pod General","type":"hasLabel","value":true},{"label":"SMTP plugin","type":"hasLabel","value":true},{"label":"Oracle SQL DB","type":"hasLabel","value":true},{"label":"Query filter","type":"hasLabel","value":true},{"label":"Activation - datasources","type":"hasLabel","value":true},{"label":"REST API","type":"hasLabel","value":true},{"label":"REST API","type":"hasLabel","value":true},{"label":"Datasources","type":"hasLabel","value":true},{"label":"REST API plugin","type":"hasLabel","value":true},{"label":"Prepared statements","type":"hasLabel","value":true},{"label":"Query Generation","type":"hasLabel","value":true},{"label":"Core Query Execution","type":"hasLabel","value":true},{"label":"Query Management","type":"hasLabel","value":true},{"label":"Query Settings","type":"hasLabel","value":true},{"label":"Query performance","type":"hasLabel","value":true},{"label":"Datatype issue","type":"hasLabel","value":true},{"label":"SmartSubstitution","type":"hasLabel","value":true},{"label":"Suggested Widgets","type":"hasLabel","value":true},{"label":"SAAS Plugins","type":"hasLabel","value":true},{"label":"Reconnect DS modal","type":"hasLabel","value":true},{"label":"OnPageLoad","type":"hasLabel","value":true},{"label":"File upload issues","type":"hasLabel","value":true},{"label":"AI","type":"hasLabel","value":true},{"label":"Appsmith AI","type":"hasLabel","value":true},{"label":"Database Schema","type":"hasLabel","value":true}],"requires":1},"Identity & Authentication Product":{"conditions":[{"label":"Login / Signup","type":"hasLabel","value":true},{"label":"SSO","type":"hasLabel","value":true},{"label":"SCIM","type":"hasLabel","value":true},{"label":"Email verification","type":"hasLabel","value":true}],"requires":1},"Artifact Platform Product":{"conditions":[{"label":"Fork App","type":"hasLabel","value":true},{"label":"Publish App","type":"hasLabel","value":true},{"label":"Secret Management","type":"hasLabel","value":true},{"label":"Import-Export-App","type":"hasLabel","value":true}],"requires":1},"DevOps Pod":{"conditions":[{"label":"Docker","type":"hasLabel","value":true},{"label":"Super Admin","type":"hasLabel","value":true},{"label":"Deployment","type":"hasLabel","value":true},{"label":"K8s","type":"hasLabel","value":true},{"label":"Email Config","type":"hasLabel","value":true},{"label":"Backup & Restore","type":"hasLabel","value":true},{"label":"AWS AMI","type":"hasLabel","value":true},{"label":"Observability","type":"hasLabel","value":true},{"label":"Heroku","type":"hasLabel","value":true},{"label":"New Deployment Mode","type":"hasLabel","value":true},{"label":"Supervisor","type":"hasLabel","value":true},{"label":"Deployment Certificates","type":"hasLabel","value":true},{"label":"Mock Data","type":"hasLabel","value":true},{"label":"AWS ECS","type":"hasLabel","value":true},{"label":"Ingress","type":"hasLabel","value":true},{"label":"Nginx","type":"hasLabel","value":true}],"requires":1},"Performance Pod":{"conditions":[{"label":"Performance","type":"hasLabel","value":true},{"label":"Performance infra","type":"hasLabel","value":true}],"requires":1},"Git Platform Pod":{"conditions":[{"label":"Environments Product","type":"hasLabel","value":true},{"label":"Git Product","type":"hasLabel","value":true},{"label":"Artifact Platform Product","type":"hasLabel","value":true}],"requires":1},"IDE Pod":{"conditions":[{"label":"Telemetry","type":"hasLabel","value":true},{"label":"i18n","type":"hasLabel","value":true},{"label":"IDE Product","type":"hasLabel","value":true},{"label":"App setting","type":"hasLabel","value":true},{"label":"Debugger Product","type":"hasLabel","value":true},{"label":"Embedding Apps Product","type":"hasLabel","value":true}],"requires":1},"Platform Administration Pod":{"conditions":[{"label":"Airgap","type":"hasLabel","value":true},{"label":"Enterprise Edition","type":"hasLabel","value":true},{"label":"Invite flow","type":"hasLabel","value":true},{"label":"User Profile","type":"hasLabel","value":true},{"label":"User Session ","type":"hasLabel","value":true},{"label":"User Session","type":"hasLabel","value":true},{"label":"Admin Settings Product","type":"hasLabel","value":true},{"label":"RBAC Product","type":"hasLabel","value":true},{"label":"Workspace Product","type":"hasLabel","value":true},{"label":"Branding Product","type":"hasLabel","value":true},{"label":"Audit Logs Product","type":"hasLabel","value":true},{"label":"Identity & Authentication Product","type":"hasLabel","value":true}],"requires":1},"DB Infrastructure Pod":{"conditions":[{"label":"Move to Postgres","type":"hasLabel","value":true}],"requires":1},"Widgets & Accelerators Pod":{"conditions":[{"label":"Accelerators Product","type":"hasLabel","value":true},{"label":"Templates Product","type":"hasLabel","value":true},{"label":"Widgets Product","type":"hasLabel","value":true},{"label":"App Theming Product","type":"hasLabel","value":true}],"requires":1},"Packages Pod":{"conditions":[{"label":"Module creator","type":"hasLabel","value":true},{"label":"Module consumer","type":"hasLabel","value":true},{"label":"Package versioning","type":"hasLabel","value":true},{"label":"Convert to module","type":"hasLabel","value":true},{"label":"Query module","type":"hasLabel","value":true},{"label":"JS module","type":"hasLabel","value":true},{"label":"UI module","type":"hasLabel","value":true},{"label":"Packages Pod","type":"hasLabel","value":true},{"label":"Packages Product","type":"hasLabel","value":true}],"requires":1},"Workflows Pod":{"conditions":[{"label":"Workflows Product","type":"hasLabel","value":true}],"requires":1},"Query & JS Pod":{"conditions":[{"label":"Javascript Product","type":"hasLabel","value":true},{"label":"Onboarding Product","type":"hasLabel","value":true},{"label":"Integrations Product","type":"hasLabel","value":true},{"label":"Reconfigure Datasource Modal","type":"hasLabel","value":true}],"requires":1},"QA Pod":{"conditions":[{"label":"QA","type":"hasLabel","value":true},{"label":"Automation Test","type":"hasLabel","value":true},{"label":"TestGap","type":"hasLabel","value":true},{"label":"Automation failures","type":"hasLabel","value":true},{"label":"Needs automation","type":"hasLabel","value":true}],"requires":1},"Anvil POD":{"conditions":[{"label":"Checkbox Component","type":"hasLabel","value":true},{"label":"WDS team","type":"hasLabel","value":true},{"label":"Anvil POD","type":"hasLabel","value":true},{"label":"WDS - all widgets","type":"hasLabel","value":true},{"label":"WDS - input widget","type":"hasLabel","value":true},{"label":"WDS - paragraph widget","type":"hasLabel","value":true},{"label":"WDS - statbox widget","type":"hasLabel","value":true},{"label":"WDS - modal widget","type":"hasLabel","value":true},{"label":"WDS - icon widget","type":"hasLabel","value":true},{"label":"WDS - checkbox widget","type":"hasLabel","value":true},{"label":"WDS - table widget","type":"hasLabel","value":true},{"label":"WDS - keyValue widget","type":"hasLabel","value":true},{"label":"WDS - switch group widget","type":"hasLabel","value":true},{"label":"WDS - theming","type":"hasLabel","value":true},{"label":"Anvil layout","type":"hasLabel","value":true},{"label":"Anvil - theming","type":"hasLabel","value":true},{"label":"Anvil - vertical alignment","type":"hasLabel","value":true},{"label":"Anvil - layout component","type":"hasLabel","value":true},{"label":"Anvil - drag & drop","type":"hasLabel","value":true},{"label":"Anvil - zones & sections","type":"hasLabel","value":true},{"label":"Anvil - copy paste experience","type":"hasLabel","value":true},{"label":"WDS - phone widget","type":"hasLabel","value":true},{"label":"WDS - responsive widget","type":"hasLabel","value":true},{"label":"Anvil - responsive viewport","type":"hasLabel","value":true},{"label":"WDS - widget styling","type":"hasLabel","value":true},{"label":"Anvil - spacing","type":"hasLabel","value":true},{"label":"Anvil - responsive canvas","type":"hasLabel","value":true},{"label":"WDS - inline button widget","type":"hasLabel","value":true},{"label":"Anvil team","type":"hasLabel","value":true}],"requires":1},"Activation Pod":{"conditions":[{"label":"Activation","type":"hasLabel","value":true}],"requires":1},"Stability Pod":{"conditions":[{"label":"Stability Issue","type":"hasLabel","value":true},{"label":"cypress-flaky-fix","type":"hasLabel","value":true},{"label":"Cypress flaky tests","type":"hasLabel","value":true}],"requires":1},"Documentation Pod":{"conditions":[{"label":"Documentation","type":"hasLabel","value":true}],"requires":1}}},"root":"."}],"labels":{"Tab Widget":{"color":"e2c76c","name":"Tab Widget","description":""},"Dont merge":{"color":"ADB39C","name":"Dont merge","description":""},"Epic":{"color":"3E4B9E","name":"Epic","description":"A zenhub epic that describes a project"},"Menu Button Widget":{"color":"235708","name":"Menu Button Widget","description":"Issues related to Menu Button widget"},"Checkbox Group widget":{"color":"bbeecd","name":"Checkbox Group widget","description":"Issues related to Checkbox Group Widget"},"Input Widget":{"color":"ae65d8","name":"Input Widget","description":""},"Security":{"color":"99139C","name":"Security","description":""},"QA":{"color":"","name":"QA","description":"Needs QA attention"},"Verified":{"color":"9bf416","name":"Verified","description":""},"Wont Fix":{"color":"ffffff","name":"Wont Fix","description":"This will not be worked on"},"MySQL":{"color":"c9ddc6","name":"MySQL","description":"Issues related to MySQL plugin"},"Development":{"color":"9F8A02","name":"Development","description":""},"Help Wanted":{"color":"008672","name":"Help Wanted","description":"Extra attention is needed"},"Home Page":{"color":"","name":"Home Page","description":"Issues related to the application home page"},"Rating Widget":{"color":"235708","name":"Rating Widget","description":"Issues related to the rating widget"},"Stat Box Widget":{"color":"f1c9ce","name":"Stat Box Widget","description":"Issues related to stat box"},"Enhancement":{"color":"a2eeef","name":"Enhancement","description":"New feature or request"},"Fork App":{"color":"af87c7","name":"Fork App","description":"Issues related to forking apps"},"Container Widget":{"color":"19AD0D","name":"Container Widget","description":"Container widget"},"Papercut":{"color":"B562F6","name":"Papercut","description":""},"Needs Design":{"color":"bfd4f2","name":"Needs Design","description":"needs design or changes to design"},"i18n":{"color":"1799b0","name":"i18n","description":"Represents issues that need to be tackled to handle internationalization"},"Rich Text Editor Widget":{"color":"f72cac","name":"Rich Text Editor Widget","description":""},"skip-changelog":{"color":"06086F","name":"skip-changelog","description":"Adding this label to a PR prevents it from being listed in the changelog"},"Low":{"color":"79e53b","name":"Low","description":"An issue that is neither critical nor breaks a user flow"},"potential-duplicate":{"color":"d3cb2e","name":"potential-duplicate","description":"This label marks issues that are potential duplicates of already open issues"},"Audio Widget":{"color":"447B9A","name":"Audio Widget","description":"Issues related to Audio Widget"},"Firestore":{"color":"8078b0","name":"Firestore","description":"Issues related to the firestore Integration"},"New Widget":{"color":"be4cf2","name":"New Widget","description":"A request for a new widget"},"Modal Widget":{"color":"03846f","name":"Modal Widget","description":""},"UX Improvement":{"color":"f4a089","name":"UX Improvement","description":""},"S3":{"color":"8078b0","name":"S3","description":"Issues related to the S3 plugin"},"Release Blocker":{"color":"5756bf","name":"Release Blocker","description":"This issue must be resolved before the release"},"safari":{"color":"51C6AA","name":"safari","description":"Bugs seen on safari browser"},"Example Apps":{"color":"1799b0","name":"Example Apps","description":"Example apps created for new signups"},"MultiSelect Widget":{"color":"AB62D4","name":"MultiSelect Widget","description":"Issues related to MultiSelect Widget"},"Calendar Widget":{"color":"8c6644","name":"Calendar Widget","description":""},"Website":{"color":"151720","name":"Website","description":"Related to www.appsmith.com website"},"Low effort":{"color":"8B59F0","name":"Low effort","description":"Something that'll take a few days to build"},"Checkbox Widget":{"color":"bbeecd","name":"Checkbox Widget","description":""},"Spam":{"color":"620faf","name":"Spam","description":""},"Voice Recorder Widget":{"color":"85bc87","name":"Voice Recorder Widget","description":""},"Select Widget":{"color":"0c669e","name":"Select Widget","description":"Select or dropdown widget"},"Bug":{"color":"8ba6fd","name":"Bug","description":"Something isn't right"},"Widget Validation":{"color":"6990BC","name":"Widget Validation","description":"Issues related to widget property validation"},"Generate Page":{"color":"2b4664","name":"Generate Page","description":"Issures related to page generation"},"File Picker Widget":{"color":"6ae4f2","name":"File Picker Widget","description":""},"snowflake":{"color":"8078b0","name":"snowflake","description":"Issues related to the snowflake Integration"},"Automation":{"color":"CCAF60","name":"Automation","description":""},"hotfix":{"color":"BA3F1D","name":"hotfix","description":""},"Import-Export-App":{"color":"48883f","name":"Import-Export-App","description":"Issues related to importing and exporting apps"},"High effort":{"color":"A7E87B","name":"High effort","description":"Something that'll take more than a month to build"},"Telemetry":{"color":"bc70f9","name":"Telemetry","description":"Issues related to instrumenting appsmith"},"Radio Widget":{"color":"91ef15","name":"Radio Widget","description":""},"Omnibar":{"color":"1bb96a","name":"Omnibar","description":"Issues related to the omnibar for navigation"},"Button Widget":{"color":"34efae","name":"Button Widget","description":""},"Switch widget":{"color":"33A8CE","name":"Switch widget","description":"The switch widget"},"Map Widget":{"color":"7eef7a","name":"Map Widget","description":""},"Task":{"color":"085630","name":"Task","description":"A simple Todo"},"Design System":{"color":"2958a4","name":"Design System","description":"Design system"},"opera":{"color":"C63F5B","name":"opera","description":"Any issues identified on the opera browser"},"Login / Signup":{"color":"","name":"Login / Signup","description":"Authentication flows"},"Image Widget":{"color":"8de8ad","name":"Image Widget","description":""},"firefox":{"color":"6d56e2","name":"firefox","description":""},"Property Pane":{"color":"b356ff","name":"Property Pane","description":"Issues related to the behaviour of the property pane"},"Deployment":{"color":"93491f","name":"Deployment","description":"Installation process of appsmith"},"Production":{"color":"b60205","name":"Production","description":""},"Dependencies":{"color":"0366d6","name":"Dependencies","description":"Pull requests that update a dependency file"},"Google Sheets":{"color":"8078b0","name":"Google Sheets","description":"Issues related to Google Sheets"},"Icon Button Widget":{"color":"D319CE","name":"Icon Button Widget","description":"Issues related to the icon button widget"},"Mongo":{"color":"8078b0","name":"Mongo","description":"Issues related to Mongo DB plugin"},"Documentation":{"color":"a8dff7","name":"Documentation","description":"Improvements or additions to documentation"},"TestGap":{"color":"","name":"TestGap","description":"Issues identified for test plan improvement"},"keyboard shortcut":{"color":"0688B6","name":"keyboard shortcut","description":""},"Reopen":{"color":"897548","name":"Reopen","description":""},"Redshift":{"color":"8078b0","name":"Redshift","description":"Issues related to the redshift integration"},"Date Picker Widget":{"color":"ef1ce1","name":"Date Picker Widget","description":""},"Entity Explorer":{"color":"1bb96a","name":"Entity Explorer","description":"Issues related to navigation using the entity explorer"},"JS Linting & Errors":{"color":"E56AA5","name":"JS Linting & Errors","description":"Issues related to JS Linting and errors"},"iFrame":{"color":"3CD1DB","name":"iFrame","description":"Issues related to iFrame"},"Stale":{"color":"ededed","name":"Stale","description":null},"Text Widget":{"color":"d130d1","name":"Text Widget","description":""},"Video Widget":{"color":"23dd4b","name":"Video Widget","description":""},"Datasources":{"color":"3d590f","name":"Datasources","description":"Issues related to configuring datasource on appsmith"},"error":{"color":"B66773","name":"error","description":"All issues connected to error messages"},"Form Widget":{"color":"09ed77","name":"Form Widget","description":""},"Needs Triaging":{"color":"e8b851","name":"Needs Triaging","description":"Needs attention from maintainers to triage"},"Autocomplete":{"color":"235708","name":"Autocomplete","description":"Issues related to the autocomplete"},"hacktoberfest":{"color":"0052cc","name":"hacktoberfest","description":"All issues that can be solved by the community during Hacktoberfest"},"Medium effort":{"color":"D31156","name":"Medium effort","description":"Something that'll take more than a week but less than a month to build"},"Release":{"color":"57e5e0","name":"Release","description":""},"High":{"color":"c94d14","name":"High","description":"This issue blocks a user from building or impacts a lot of users"},"UI Performance":{"color":"1799b0","name":"UI Performance","description":"Issues related to UI performance"},"Deploy Preview":{"color":"bfdadc","name":"Deploy Preview","description":"Issues found in Deploy Preview"},"Needs Tests":{"color":"8ee263","name":"Needs Tests","description":"Needs automated tests to assert a feature/bug fix"},"Refactor":{"color":"B96662","name":"Refactor","description":"needs refactoring of code"},"Divider Widget":{"color":"235708","name":"Divider Widget","description":"Issues related to the divider widget"},"Table Widget":{"color":"2eead1","name":"Table Widget","description":""},"Needs More Info":{"color":"e54c10","name":"Needs More Info","description":"Needs additional information"},"Good First Issue":{"color":"7057ff","name":"Good First Issue","description":"Good for newcomers"},"UI Improvement":{"color":"9aeef4","name":"UI Improvement","description":""},"Backend":{"color":"d4c5f9","name":"Backend","description":"This marks the issue or pull request to reference server code"},"Frontend":{"color":"87c7f2","name":"Frontend","description":"This label marks the issue or pull request to reference client code"},"Chart Widget":{"color":"616ecc","name":"Chart Widget","description":""},"List Widget":{"color":"8508A0","name":"List Widget","description":"Issues related to the list widget"},"Duplicate":{"color":"cfd3d7","name":"Duplicate","description":"This issue or pull request already exists"},"JS Snippets":{"color":"8d62d2","name":"JS Snippets","description":"issues related to JS Snippets"},"Copy Paste":{"name":"Copy Paste","description":"Issues related to copy paste","color":"b4f0a9"},"Drag & Drop":{"name":"Drag & Drop","description":"Issues related to the drag & drop experience","color":"92115a"},"Sniping Mode":{"name":"Sniping Mode","description":"Issues related to sniping mode","color":"48883f"},"Redis":{"name":"Redis","description":"Issues related to Redis","color":"8078b0"},"New Datasource":{"color":"60b14c","name":"New Datasource","description":"Requests for new datasources"},"Evaluated Value":{"name":"Evaluated Value","description":"Issues related to evaluated values","color":"39f6e7"},"Undo/Redo":{"name":"Undo/Redo","description":"Issues related to undo/redo","color":"f25880"},"App Navigation":{"name":"App Navigation","description":"Issues related to the topbar navigation and configuring it","color":"4773ab"},"Widgets Pane":{"name":"Widgets Pane","description":"Issues related to the discovery and organisation of widgets","color":"ad5d78"},"View Mode":{"color":"1799b0","name":"View Mode","description":"Issues related to the view mode"},"Content":{"name":"Content","description":"For content related topics i.e blogs, templates, videos","color":"a8dff7"},"Slash Command":{"name":"Slash Command","description":"Issues related to the slash command","color":"a0608e"},"Widget Property":{"name":"Widget Property","description":"Issues related to adding / modifying widget properties across widgets","color":"5e92cb"},"Windows":{"name":"Windows","description":"Issues related exclusively to Windows systems","color":"b4cb8a"},"Old App Issues":{"name":"Old App Issues","description":"Issues related to apps old apps a few weeks old and app issues in stale browser session","color":"87ab18"},"Document Viewer Widget":{"name":"Document Viewer Widget","description":"Issues related to Document Viewer Widget","color":"899d4b"},"Radio Group Widget":{"name":"Radio Group Widget","description":"Issues related to radio group widget","color":"b68495"},"Super Admin":{"name":"Super Admin","description":"Issues related to the super admin page","color":"aa95cf"},"Postgres":{"name":"Postgres","description":"Postgres related issues","color":"8078b0"},"New JS Function":{"name":"New JS Function","description":"Issues related to adding a JS Function","color":"8e8aa4"},"Cannot Reproduce Issue":{"color":"93c9cc","name":"Cannot Reproduce Issue","description":"Issues that cannot be reproduced"},"Widget Grouping":{"name":"Widget Grouping","description":"Issues related to Widget Grouping","color":"a49951"},"K8s":{"name":"K8s","description":"Kubernetes related issues","color":"5f318a"},"Docker":{"name":"Docker","description":"Issues related to docker","color":"89b808"},"Camera Widget":{"name":"Camera Widget","description":"Issues and enhancements related to camera widget","color":"e6038e"},"SAAS Plugins":{"name":"SAAS Plugins","description":"Issues related to SAAS Plugins","color":"80e18f"},"JS Promises":{"name":"JS Promises","description":"Issues related to promises","color":"d7771f"},"OnPageLoad":{"name":"OnPageLoad","description":"OnPageLoad issues on functions and queries","color":"2b4664"},"JS Usability":{"name":"JS Usability","description":"usability issues with JS editor and JS elsewhere","color":"a302b0"},"Currency Input Widget":{"name":"Currency Input Widget","description":"Issues related to currency input widget","color":"b2164f"},"TreeSelect":{"name":"TreeSelect","description":"Issues related to TreeSelect Widget","color":"a1633e"},"MultiTree Select Widget":{"name":"MultiTree Select Widget","description":"Issues related to MultiTree Select Widget","color":"a1633e"},"Welcome Screen":{"name":"Welcome Screen","description":"Issues related to the welcome screen","color":"48883f"},"Realtime Commenting":{"color":"a70b86","name":"Realtime Commenting","description":"In-app communication between teams"},"Phone Input Widget":{"name":"Phone Input Widget","description":"Issues related to the Phone Input widget","color":"a70b86"},"JSON Form":{"name":"JSON Form","description":"Issue / features related to the JSON form wiget","color":"46b209"},"All Widgets":{"name":"All Widgets","description":"Issues related to all widgets","color":"972b36"},"V1":{"name":"V1","description":"V1","color":"67ab2e"},"Reflow & Resize":{"name":"Reflow & Resize","description":"All issues related to reflow and resize experience","color":"748a13"},"SSO":{"name":"SSO","description":"Issues, requests and enhancements around Single sign-on.","color":""},"Multi User Realtime":{"name":"Multi User Realtime","description":"Issues related to multiple users using or editing an application","color":"e7b6ce"},"Ready for design":{"name":"Ready for design","description":"this issue is ready for design: it contains clear problem statements and other required information","color":"ebf442"},"Support":{"name":"Support","description":"Issues created by the A-force team to address user queries","color":"1740f3"},"Button Group widget":{"name":"Button Group widget","description":"Issue and enhancements related to the button group widget","color":"f17025"},"GraphQL Plugin":{"name":"GraphQL Plugin","description":"Issues related to GraphQL plugin","color":"8078b0"},"DevOps Pod":{"name":"DevOps Pod","description":"Issues related to devops","color":"d956c7"},"medium":{"name":"medium","description":"Issues that frustrate users due to poor UX","color":"23dfd9"},"ArangoDB":{"name":"ArangoDB","description":"Issues related to arangoDB","color":"8078b0"},"Code Refactoring":{"name":"Code Refactoring","description":"Issues related to code refactoring","color":"76310e"},"Progress bar widget":{"name":"Progress bar widget","description":"To track issues related to progress bar","color":"2d7abf"},"Audio Recorder Widget":{"name":"Audio Recorder Widget","description":"Issues related to Audio Recorder Widget","color":"9accef"},"Airtable":{"name":"Airtable","description":"Issues for Airtable","color":"60885f"},"Canvas / Grid":{"name":"Canvas / Grid","description":"Issues related to the canvas","color":"16b092"},"Email Config":{"name":"Email Config","description":"Issues related to configuring the email service","color":"2a21d1"},"CURL":{"name":"CURL","description":"Issues related to CURL impor","color":"60885f"},"Canvas Zooms":{"name":"Canvas Zooms","description":"Issues related to zooming the canvas","color":"e6038e"},"business":{"name":"business","description":"Features that will be a part of our business edition","color":"cd59eb"},"Action Pod":{"name":"Action Pod","description":"","color":"ee2e36"},"AutomationGap1":{"color":"a5e07c","name":"AutomationGap1","description":"Issues that needs automated tests"},"A-Force11":{"name":"A-Force11","description":"Issues raised by A-Force team","color":"d667b6"},"Business Edition":{"name":"Business Edition","description":"Features that will be a part of our business edition","color":"89bb6c"},"storeValue":{"name":"storeValue","description":"Issues related to the store value function","color":"5d3e66"},"DynamoDB":{"name":"DynamoDB","description":"Issues that are related to DynamoDB should have this label","color":"60885f"},"Backup & Restore":{"name":"Backup & Restore","description":"Issues related to backup and restore","color":"86874d"},"Billing":{"name":"Billing","description":"Billing infrastructure and flows for Business Edition and Trial users","color":"d2bc40"},"Datatype issue":{"name":"Datatype issue","description":"Issues that have risen because data types weren't handled","color":"cef66b"},"OAuth":{"name":"OAuth","description":"OAuth related bugs or features","color":"60885f"},"Table Widget V2":{"name":"Table Widget V2","description":"Issues related to Table Widget V2","color":"3a7192"},"IDE Navigation":{"name":"IDE Navigation","description":"Issues/feature requests related to IDE navigation, and context switching","color":"1bb96a"},"Query performance":{"name":"Query performance","description":"Issues that have to do with lack in performance of query execution","color":"cef66b"},"SAAS Manager App":{"name":"SAAS Manager App","description":"Issues with the SAAS manager app","color":"d427db"},"Twilio":{"name":"Twilio","description":"Issues related to Twilio integration","color":"23ba8d"},"Hubspot":{"name":"Hubspot","description":"Issues related to Hubspot integration","color":"60885f"},"Zendesk":{"name":"Zendesk","description":"Issues related to Zendesk integration","color":"60885f"},"Entity Refactor":{"name":"Entity Refactor","description":"Issues related to refactor logic","color":"705a2c"},"Map Chart Widget":{"name":"Map Chart Widget","description":"Issues related to Map Chart Widgets","color":"c8397f"},"Product Catchup":{"name":"Product Catchup","description":"Issues created in the product catchup","color":"29cd2c"},"Framework Functions":{"name":"Framework Functions","description":"Issues related to internal functions like showAlert(), navigateTo() etc...","color":"c25a09"},"Frontend Libraries Upgrade":{"name":"Frontend Libraries Upgrade","description":"Issues related to frontend libraries upgrade","color":"ede1fc"},"MsSQL":{"name":"MsSQL","description":"Issues related to MsSQL plugin","color":"8078b0"},"Elastic Search":{"name":"Elastic Search","description":"Issues related to the elastic search datasource","color":"8078b0"},"Core Query Execution":{"color":"cef66b","name":"Core Query Execution","description":"Issues related to the execution of all queries"},"Query Management":{"name":"Query Management","description":"Issues related to the CRUD of actions or queries","color":"cef66b"},"Query Settings":{"name":"Query Settings","description":"Issues related to the settings of all queries","color":"cef66b"},"Code Editor":{"name":"Code Editor","description":"Issues related to the code editor","color":"4ca16e"},"Query Forms":{"color":"12b253","name":"Query Forms","description":"Isuses related to the query forms"},"JS Objects":{"color":"22962c","name":"JS Objects","description":"Issues related to JS Objects"},"JS Evaluation":{"color":"22962c","name":"JS Evaluation","description":"Issues related to JS evaluation on the platform"},"SmartSubstitution":{"name":"SmartSubstitution","description":"Issues related to Smart substitution of mustache bindings in queries","color":"bae511"},"Query Generation":{"name":"Query Generation","description":"Issues related to query generation","color":"cef66b"},"Suggested Widgets":{"name":"Suggested Widgets","description":"Issues related to suggesting widgets based on query response","color":"6ac063"},"Code Scanner Widget":{"name":"Code Scanner Widget","description":"Issues related to code scanner widget","color":"9bc1a0"},"Clean URLs":{"name":"Clean URLs","description":"Issues related to clean URLs epic","color":"112623"},"Widget keyboard accessibility":{"name":"Widget keyboard accessibility","description":"All issues related to keyboard accessibility in widgets","color":"b626fd"},"Connection pool":{"name":"Connection pool","description":"issues to do with connection pooling of various plugins","color":"94fe36"},"List Widget V2":{"name":"List Widget V2","description":"Issues related to the list widget v2","color":"adaaf7"},"Auto Height":{"name":"Auto Height","description":"Issues related to dynamic height of widgets","color":"5149cf"},"cypress_failed_test":{"name":"cypress_failed_test","description":"Cypress failed tests","color":"4745d5"},"Needs validation":{"name":"Needs validation","description":"Needs problem validation before being picked up","color":"66673d"},"Slider Widget":{"name":"Slider Widget","description":"Issues raised for slider widgets.","color":"2eef5f"},"Multitenancy":{"name":"Multitenancy","description":"Support multitenancy within single appsmith instance","color":"8c49a9"},"Conversion Algorithm":{"name":"Conversion Algorithm","description":"All issue related to converting app from fixed to flex mode & vice versa","color":"d12d2e"},"Browser specific":{"name":"Browser specific","description":"All issue related to browser","color":"d12d2e"},"Performance infra":{"name":"Performance infra","description":"all issue related to the performance infra","color":"8a60f6"},"DSL Update":{"name":"DSL Update","description":"Issues related to storing and updating the DSL","color":"e16cf3"},"AST-frontend":{"name":"AST-frontend","description":"Issues related to maintaining AST logic","color":"2b4664"},"AST-backend":{"name":"AST-backend","description":"Backend issues related to AST parsing","color":"48883f"},"MariaDB":{"name":"MariaDB","description":"MariaDB datasource","color":"8428c3"},"ADS Component Issue":{"name":"ADS Component Issue","description":"Issues which are caused due to ADS components","color":"d89119"},"Regressed":{"color":"723fd0","name":"Regressed","description":"Scenarios that were working before but have now regressed"},"Needs RCA":{"name":"Needs RCA","description":"a critical or high priority issue that needs an RCA","color":"2cc68f"},"Custom JS Libraries":{"name":"Custom JS Libraries","description":"Issues related to adding custom JS library","color":"bacb6d"},"Integrations Pod General":{"name":"Integrations Pod General","description":"Issues related to the Integrations Pod that don't fit into other tags.","color":"287823"},"Performance Pod":{"name":"Performance Pod","description":"All things related to Appsmith performance","color":"b5a25d"},"Performance":{"name":"Performance","description":"Issues related to performance","color":"9a18d7"},"File upload issues":{"name":"File upload issues","description":"Issues related to uploading any type of files from within Appsmith","color":"2b4664"},"Action Selector":{"name":"Action Selector","description":"Issues related to action selector on the property pane","color":"2f9e20"},"Community Reported":{"name":"Community Reported","description":"issues reported by community members","color":"1402e5"},"JS Function execution":{"name":"JS Function execution","description":"JS function execution","color":"7c2de1"},"Self Serve":{"name":"Self Serve","description":"For all issues related to self-serve flow for business edition","color":"4dacfc"},"Self Serve 1.0":{"name":"Self Serve 1.0","description":"For all issues related to v1 of the self serve project","color":"ae839e"},"Customer Portal":{"name":"Customer Portal","description":"For all tasks/issues pertaining to customer.appsmith.com","color":"d2bc40"},"Cloud Services":{"name":"Cloud Services","description":"For all tasks/issues on Appsmith cloud-services relating to licensing, usage and billing","color":"d2bc40"},"One-click Binding":{"name":"One-click Binding","description":"Issues related to the One click binding epic","color":"f1661c"},"Airgap":{"name":"Airgap","description":"Tickets related to supporting air-gapped Appsmith instances","color":"1cb294"},"SMTP plugin":{"name":"SMTP plugin","description":"Issues related to SMTP plugin","color":"541457"},"AWS AMI":{"name":"AWS AMI","description":"Issues Related to AWS AMI","color":"b44680"},"Old widget version":{"name":"Old widget version","description":"Use this label to raise issue specific only to an older version of a widget","color":"ff3814"},"Enterprise Billing":{"name":"Enterprise Billing","description":"To track all tasks/issues related to licensing & billing for enterprise customers","color":"14c156"},"Oracle SQL DB":{"name":"Oracle SQL DB","description":"Issues related to the Oracle plugin","color":"cbabcb"},"Community Contributor":{"name":"Community Contributor","description":"Meant to track issues that are assigned to external contributors","color":"149ab6"},"widget vertical alignment":{"name":"widget vertical alignment","description":"All issue related widget vertical alignment on the auto layout canvas","color":"d12d2e"},"Observability":{"name":"Observability","description":"Issues related to observability on the Appsmith instance","color":"dff913"},"Checkbox Component":{"name":"Checkbox Component","description":"This labels deals with checkbox component in wds package","color":"75a401"},"Analytics Improvements":{"name":"Analytics Improvements","description":"For all tasks focused on improving our overall analytics and fixing any issues ","color":"29b8ed"},"WDS team":{"name":"WDS team","description":"","color":"8d675a"},"Enterprise Edition":{"name":"Enterprise Edition","description":"Features that will be supported in Enterprise Edition only","color":"984f5e"},"Query filter":{"name":"Query filter","description":"Issues related to query filtering, e.g., WHERE clause","color":"a15134"},"Keyboard accessibility ":{"name":"Keyboard accessibility ","description":"All issue related to ADS component keyboard accessibility","color":"2ba696"},"Toggle button":{"name":"Toggle button","description":"All issue related to ADS toggle button","color":"edc47f"},"SCIM":{"name":"SCIM","description":"Label to collate our SCIM issues","color":"48883f"},"ADS Category Token":{"name":"ADS Category Token","description":"All issues related appsmith design system category tokens","color":"920961"},"ADS Component Documentation":{"name":"ADS Component Documentation","description":"All issues Appsmith design system component documentation","color":"64c46a"},"ADS Migration":{"name":"ADS Migration","description":"All issues related to Appsmith design system migration","color":"b082d6"},"ADS Deduplication ":{"name":"ADS Deduplication ","description":"Replacing component with ADS components","color":"b082d6"},"ADS Revamp":{"name":"ADS Revamp","description":"All issues related to ads revamp. ","color":"b082d6"},"ADS Deduplication":{"name":"ADS Deduplication","description":"Replacing component with ADS components","color":"b082d6"},"ADS Grayscale":{"name":"ADS Grayscale","description":"Support grayscale color changes","color":"b03577"},"ADS Unit Test":{"name":"ADS Unit Test","description":"All issue related ads unit cases ","color":"b082d6"},"ADS Components":{"name":"ADS Components","description":"All issues related ADS components","color":"b082d6"},"Widget Discoverability":{"name":"Widget Discoverability","description":"Issues related to Widget Discoverability","color":"7b55ce"},"Widget setter method":{"name":"Widget setter method","description":"Issues with widget property setters","color":"8dce87"},"License":{"name":"License","description":"For all issues/tasks related to licensing of appsmith-ee edition","color":"90ee98"},"Platformization":{"name":"Platformization","description":"Issues or tasks related to platformization of Appsmith codebase","color":"4e972b"},"Activation - datasources":{"name":"Activation - datasources","description":"issues related to activation projects","color":"7c7ace"},"Partial-import-export":{"name":"Partial-import-export","description":"Label for granular reusability.","color":"717732"},"AI":{"name":"AI","description":"All tasks related to AI","color":"2b4664"},"ADS Typography":{"name":"ADS Typography","description":"All issue related typographical changes","color":"2dbe8d"},"Auto Layout":{"name":"Auto Layout","description":"Issues relates to auto layout","color":"92cf8c"},"Heroku":{"name":"Heroku","description":"Issues related to Heroku","color":"a81b69"},"ADS Visual Styles":{"name":"ADS Visual Styles","description":"All issues related to ADS visual styles","color":"d3da89"},"ADS Component Design":{"name":"ADS Component Design","description":"All issue related to component design","color":"5cc91e"},"Modal Component":{"name":"Modal Component","description":"All issue related to ads modal component","color":"ee63f3"},"App setting":{"name":"App setting","description":"Related to app settings panel within the app","color":"174f98"},"BE instance":{"name":"BE instance","description":"For all issues related to license, billing on BE instance","color":"ae8f98"},"Fixed layout":{"name":"Fixed layout","description":"issues related to fixed layout","color":"b66681"},"Anvil layout":{"name":"Anvil layout","description":"issues related to the new layout system anvil","color":"5e0904"},"New Deployment Mode":{"name":"New Deployment Mode","description":"Support a new mode of deployment","color":"108033"},"Custom widgets":{"name":"Custom widgets","description":"For all issues related to the custom widget project","color":"c9db9c"},"Homepage Experience V2":{"name":"Homepage Experience V2","description":"Label for reporting new tasks and bug fixes related to revamped homepage experience","color":"c55d54"},"Customer Success":{"name":"Customer Success","description":"Issues that the success team cares about","color":"6ccabd"},"Invite flow":{"name":"Invite flow","description":"Invite users flow and any associated actions","color":"881b35"},"Invite users":{"name":"Invite users","description":"Invite users flow and any associated actions","color":""},"Workflows Pod":{"name":"Workflows Pod","description":"Issues that the workflows team owns","color":"446925"},"DailyPromotionBlocker":{"name":"DailyPromotionBlocker","description":"DailyPromotion Blocker","color":"9b2280"},"JS Binding":{"name":"JS Binding","description":"All issues related to the JS Binding experience","color":"422fed"},"REST API":{"name":"REST API","description":"REST API plugin related issues","color":"e3ede5"},"Critical":{"color":"a1e3db","name":"Critical","description":"This issue breaks existing apps. Drop everything else to resolve"},"Module creator":{"name":"Module creator","description":"Issues related to the module creator side","color":"bb2c05"},"Module consumer":{"name":"Module consumer","description":"Issues related to the module consumer side","color":"83d3c5"},"Package versioning":{"name":"Package versioning","description":"ISsues related to how we manage versions for packages","color":"4c5218"},"Convert to module":{"name":"Convert to module","description":"Issues related to the module creation flow using conversion","color":"4c5218"},"Query module":{"name":"Query module","description":"Issues affecting query modules or its instances","color":"b11a7e"},"JS module":{"name":"JS module","description":"Issues affecting JS modules or its instances","color":"bf76f6"},"Secret Management":{"name":"Secret Management","description":"Issues related to secret management","color":"2b4664"},"REST API plugin":{"name":"REST API plugin","description":"REST API plugin related issues","color":"b5948a"},"UI module":{"name":"UI module","description":"Issues affecting UI modules or its instances","color":"d2acee"},"Preview mode":{"name":"Preview mode","description":"Issues related to app previews","color":"48883f"},"Git Auto-commit":{"name":"Git Auto-commit","description":"Issues related to autocommit","color":"717732"},"QA Pod":{"name":"QA Pod","description":"Issues under the QA Pod","color":"717732"},"Automation Test":{"name":"Automation Test","description":"","color":""},"Automation failures":{"name":"Automation failures","description":"","color":""},"Needs automation":{"name":"Needs automation","description":"Issues that needs automated tests","color":""},"Prepared statements":{"name":"Prepared statements","description":"Issues related to prepared statement flow","color":""},"Switch Group Widget":{"name":"Switch Group Widget","description":"Issues related to Switch group Widget","color":""},"Supervisor":{"name":"Supervisor","description":"Issues related to supervisor","color":"2c5813"},"Deployment Certificates":{"name":"Deployment Certificates","description":"Issues related to lets encrypt","color":"e148aa"},"Mock Data":{"name":"Mock Data","description":"Issues related to mock databases","color":"ebf251"},"AWS ECS":{"name":"AWS ECS","description":"Issues related to ECS Fargate","color":"e506ff"},"Publish App":{"name":"Publish App","description":"Issues related to app deployment","color":"2b4664"},"IDE Infra":{"name":"IDE Infra","description":"Issues related to the IDE infrastructure like saving changes","color":"1bb96a"},"User Profile":{"name":"User Profile","description":"Issues related to a user profile","color":"a60d34"},"Page Management":{"color":"1bb96a","name":"Page Management","description":"Issues related to configuring pages"},"Ingress":{"name":"Ingress","description":"Ingress Controller","color":"a86802"},"Nginx":{"name":"Nginx","description":"Issues related to Nginx","color":"e54195"},"Building blocks":{"name":"Building blocks","description":"Building blocks on cavas, on templates listing or drag and drop of building blocks.","color":"48883f"},"Table Inline Edit":{"name":"Table Inline Edit","description":"Issues related to inline editing","color":"60895a"},"User Session ":{"name":"User Session ","description":"For all issues/tasks related to user sessions","color":"65a3f5"},"WDS - all widgets":{"name":"WDS - all widgets","description":"all widget present in WDS","color":"2670ae"},"WDS - input widget":{"name":"WDS - input widget","description":"Issues related to input widget on WDS","color":"2670ae"},"WDS - paragraph widget":{"name":"WDS - paragraph widget","description":"issues related to paragraph widget on WDS","color":"2670ae"},"WDS - statbox widget":{"name":"WDS - statbox widget","description":"issues related to statbox widget on WDS","color":"2670ae"},"WDS - modal widget":{"name":"WDS - modal widget","description":"Issues related to modal widget on WDS","color":"2670ae"},"WDS - icon widget":{"name":"WDS - icon widget","description":"Issues related to icon widget on WDS","color":"2670ae"},"WDS - checkbox widget":{"name":"WDS - checkbox widget","description":"Issues related to checkbox widget on WDS","color":"2670ae"},"WDS - table widget":{"name":"WDS - table widget","description":"Issues related to table widget on WDS","color":"2670ae"},"WDS - keyValue widget":{"name":"WDS - keyValue widget","description":"Issues related to key-value widget on WDS","color":"2670ae"},"WDS - switch group widget":{"name":"WDS - switch group widget","description":"Issues related to switch group widget on WDS","color":"2670ae"},"WDS - theming":{"name":"WDS - theming","description":"Issues related to theming on the Anvil instance","color":"2670ae"},"Anvil POD":{"name":"Anvil POD","description":"Issue related to Anvil project","color":"5e0904"},"Anvil - theming":{"name":"Anvil - theming","description":"Issues related to theming on the Anvil instance","color":"c28de5"},"Anvil - vertical alignment":{"name":"Anvil - vertical alignment","description":"Issues related to vertical alignment on the Anvil layout","color":"c28de5"},"Anvil - layout component":{"name":"Anvil - layout component","description":"Issues related to layout component on the Anvil layout","color":"c28de5"},"Anvil - drag & drop":{"name":"Anvil - drag & drop","description":"Issues related to drag & drop experience on Anvil","color":"c28de5"},"Anvil - zones & sections":{"name":"Anvil - zones & sections","description":"Issues related to zones and sections on the Anvil layout","color":"c28de5"},"Anvil - copy paste experience":{"name":"Anvil - copy paste experience","description":"Issues related to copy paste experience on the Anvil layout","color":"c28de5"},"WDS - phone widget":{"name":"WDS - phone widget","description":"Issues related to phone widget on WDS","color":"c28de5"},"WDS - responsive widget":{"name":"WDS - responsive widget","description":"All issues related to widget responsiveness","color":"11ee05"},"Anvil - responsive viewport":{"color":"11ee05","name":"Anvil - responsive viewport","description":"Issues seen on different viewports like mobile"},"WDS - widget styling":{"color":"11ee05","name":"WDS - widget styling","description":"all about widget styling"},"Anvil - spacing":{"name":"Anvil - spacing","description":"Related to spacing between widgets in auto layout","color":"11ee05"},"Anvil - responsive canvas":{"name":"Anvil - responsive canvas","description":"All issues related to canvas responsiveness","color":"11ee05"},"WDS - inline button widget":{"name":"WDS - inline button widget","description":"Issues related to inline button widget on WDS","color":"7cef83"},"Activation Pod":{"name":"Activation Pod","description":"for Activation group","color":"d67d00"},"Activation":{"name":"Activation","description":"for Activation group","color":"d67d00"},"Tests":{"name":"Tests","description":"Test issues","color":"4fc7b6"},"Ballpark: XXS":{"name":"Ballpark: XXS","description":"~1xDev in 1/2xSprint","color":""},"Ballpark: XS":{"name":"Ballpark: XS","description":"~1xDev in 1xSprint","color":"53bf71"},"Ballpark: S":{"name":"Ballpark: S","description":"~2xDev in 1xSprint","color":"6e9e65"},"Ballpark: M":{"name":"Ballpark: M","description":"~1xPOD in 1xSprint","color":"2229e6"},"Ballpark: L":{"name":"Ballpark: L","description":"~1xPOD in 3xSprint or 2xPODs in 1xSprint","color":"49962f"},"Ballpark: XL":{"name":"Ballpark: XL","description":"~1xPOD in 1xQuarter or 2xPODs in 2xSprint","color":"b524c9"},"Ballpark: XXL":{"name":"Ballpark: XXL","description":"~2xPODs in 1xQuarter","color":"22092c"},"Auto-commit":{"name":"Auto-commit","description":"Issues related to auto-generated commits showing up on git ","color":"e25b89"},"Continuous Deployment":{"name":"Continuous Deployment","description":"Issues related to CD pipeline on git","color":"aea47c"},"Default branch":{"name":"Default branch","description":"Issues related to using a default branch on git","color":"195737"},"Git status":{"name":"Git status","description":"Issues related to information shown on git status modal or number of changes appearing in a branch","color":"c851b8"},"Git performance":{"name":"Git performance","description":"Issues related to perceived performance on any git operation","color":"189af6"},"Anvil team":{"name":"Anvil team","description":"issues related to the new layout system anvil","color":"798200"},"SDLC":{"name":"SDLC","description":"Issues related to software development lifecycle experiences","color":"bae511"},"Reconnect DS modal":{"name":"Reconnect DS modal","description":"Issues related to reconnect datasource modal post app import","color":"2e398b"},"Stability Pod":{"name":"Stability Pod","description":"For all issues/tasks to be prioritized under Stability pod","color":"86ddf6"},"Stability Issue":{"name":"Stability Issue","description":"Every issue handle by Stability Pod","color":"4d024a"},"Move to Postgres":{"name":"Move to Postgres","description":"Issues required to be solved for the move to Postgres as repository layer","color":"4e13ac"},"User Session":{"name":"User Session","description":"Issues related to user sessions","color":"8255e5"},"IDE tabs":{"name":"IDE tabs","description":"query and js tabs","color":"1bb96a"},"Inviting Contribution":{"name":"Inviting Contribution","description":"Issues that we would like contributions to","color":""},"cypress-flaky-fix":{"name":"cypress-flaky-fix","description":"This label is auto-added when a PR which only has Cypress fixes are merged to release","color":"722cbc"},"Cypress flaky tests":{"name":"Cypress flaky tests","description":"Test scripts that need to be fixed on Cypress by dev or SDET","color":"722cbc"},"Help enterprise":{"name":"Help enterprise","description":"Requested by Appsmith customers or prospects","color":"FF8C00"},"Learnability":{"name":"Learnability","description":"Issues affecting the product learnability, making the product harder for new users.","color":"800c2f"},"ADS Spacing":{"name":"ADS Spacing","description":"","color":"686ebb"},"ads unit test":{"name":"ads unit test","description":"All issue related ads unit cases","color":"686ebb"},"ads revamp":{"name":"ads revamp","description":"All issues related to ads revamp.","color":"686ebb"},"Javascript Product":{"color":"709a21","name":"Javascript Product","description":"Issues related to users writing javascript in appsmith"},"IDE Product":{"color":"1bb96a","name":"IDE Product","description":"Issues related to the IDE Product"},"IDE Pod":{"color":"1bb96a","name":"IDE Pod","description":"Issues that new developers face while exploring the IDE"},"Accelerators Product":{"name":"Accelerators Product","description":"Issues related to app building accelerators","color":"f3fce6"},"Templates Product":{"name":"Templates Product","description":"Issues related to Templates","color":"f3fce6"},"Design System Product":{"name":"Design System Product","description":"Appsmith design system related issues","color":"2b4664"},"ads deduplication":{"name":"ads deduplication","description":"Replacing component with ADS components","color":"708943"},"Admin Settings Product":{"color":"708943","name":"Admin Settings Product","description":"Issues in admin settings pages"},"Appsmith AI":{"name":"Appsmith AI","description":"All issues related to the Appsmith AI datasource","color":"708943"},"Query & JS Pod":{"color":"709a21","name":"Query & JS Pod","description":"Issues related to the query & JS Pod"},"RBAC Product":{"name":"RBAC Product","description":"Issues, requests and enhancements around RBAC.","color":""},"Workspace Product":{"name":"Workspace Product","description":"Issues related to workspaces","color":""},"CE Instance Usage":{"name":"CE Instance Usage","description":"For all issues relating to usage, licensing or billing on the CE instance","color":""},"Billing & Licensing Product":{"name":"Billing & Licensing Product","description":"Issues pertaining to licensing, billing and usage across self serve and enterprise customers","color":"446925"},"Platform Administration Pod":{"color":"446925","name":"Platform Administration Pod","description":"Issues related to platform administration & management"},"DB Infrastructure Pod":{"name":"DB Infrastructure Pod","description":"Pod to handle database infrastructure","color":"446925"},"Packages Product":{"name":"Packages Product","description":"Issues related to packages","color":"446925"},"Workflows Product":{"name":"Workflows Product","description":"Issues related to the workflows product","color":"446925"},"Debugger Product":{"color":"857f58","name":"Debugger Product","description":"Issues related to the debugger"},"Packages Pod":{"name":"Packages Pod","description":"issues that belong to the packages pod","color":"857f58"},"Environments Product":{"name":"Environments Product","description":"Issues related to datasource environments","color":"857f58"},"Custom Widgets":{"name":"Custom Widgets","description":"For all issues related to the custom widget project","color":"857f58"},"Branding Product":{"name":"Branding Product","description":"All issues under branding and whitelabelling appsmith ecosystem","color":"857f58"},"Widgets & Accelerators Pod":{"name":"Widgets & Accelerators Pod","description":"Issues related to widgets & Accelerators","color":"27496a"},"Widgets Product":{"name":"Widgets Product","description":"This label groups issues related to widgets","color":"f3fce6"},"App Theming Product":{"name":"App Theming Product","description":"Items that are related to the App level theming controls epic","color":"48883f"},"UI Building Product":{"color":"48883f","name":"UI Building Product","description":"Issues related to the UI Building experience"},"Onboarding Product":{"color":"48883f","name":"Onboarding Product","description":"Issues related to onboarding new developers"},"Database Schema":{"name":"Database Schema","description":"Issues related to database schema","color":"48883f"},"Git Product":{"color":"48883f","name":"Git Product","description":"Issues related to version control product"},"Git Platform Pod":{"name":"Git Platform Pod","description":"Issues related to the git & the app platform ","color":"48883f"},"Embedding Apps Product":{"name":"Embedding Apps Product","description":"Issues related to embedding","color":"48883f"},"Integrations Product":{"name":"Integrations Product","description":"Issues related to a specific integration","color":"b9f21c"},"Feature Flagging":{"name":"Feature Flagging","description":"Anything related feature flagging","color":"4574ae"},"Audit Logs Product":{"name":"Audit Logs Product","description":"Audit trails to ensure data security","color":"4574ae"},"Identity & Authentication Product":{"name":"Identity & Authentication Product","description":"Issues related to user identity & authentication","color":"4574ae"},"Email verification":{"name":"Email verification","description":"Email verification issues","color":"4574ae"},"Artifact Platform Product":{"name":"Artifact Platform Product","description":"Issues related to the application platform","color":"4574ae"},"Git IA":{"name":"Git IA","description":"Issues related to Git IA changes","color":"df8bd6"},"Documentation Pod":{"name":"Documentation Pod","description":"Issues related to user education","color":"8c8c02"},"Branch management":{"name":"Branch management","description":"Issues related to using a branch management on git","color":"ebe6af"},"Reconfigure Datasource Modal":{"name":"Reconfigure Datasource Modal","description":"Issues related to reconfigure DS modal that comes after importing applications","color":"5ac17b"}},"success":true} \ No newline at end of file diff --git a/.github/workflows/github-release.yml b/.github/workflows/github-release.yml index bf230d050ec..c4dd4001beb 100644 --- a/.github/workflows/github-release.yml +++ b/.github/workflows/github-release.yml @@ -247,6 +247,12 @@ jobs: run: | scripts/generate_info_json.sh + - name: Place server artifacts-es + run: | + if [[ -f scripts/prepare_server_artifacts.sh ]]; then + scripts/prepare_server_artifacts.sh + fi + - name: Login to DockerHub uses: docker/login-action@v1 with: diff --git a/.github/workflows/sync-release-to-pg.yml b/.github/workflows/sync-release-to-pg.yml index 2e50073a07b..f5ad35e0669 100644 --- a/.github/workflows/sync-release-to-pg.yml +++ b/.github/workflows/sync-release-to-pg.yml @@ -71,7 +71,7 @@ jobs: # This is the ChannelId of the proj postgres channel. body="$(jq -nc \ - --arg channel C06Q3A97USE \ + --arg channel C07JMLWEXDJ \ --arg text "$slack_message" \ '$ARGS.named' )" diff --git a/.github/workflows/test-build-docker-image.yml b/.github/workflows/test-build-docker-image.yml index 71fe51a5cb8..f14c565e210 100644 --- a/.github/workflows/test-build-docker-image.yml +++ b/.github/workflows/test-build-docker-image.yml @@ -435,6 +435,12 @@ jobs: scripts/generate_info_json.sh fi + - name: Place server artifacts-es + run: | + if [[ -f scripts/prepare_server_artifacts.sh ]]; then + scripts/prepare_server_artifacts.sh + fi + - name: Set up Depot CLI uses: depot/setup-action@v1 diff --git a/app/client/cypress/e2e/Regression/ClientSide/ActionExecution/uiToCode_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/ActionExecution/uiToCode_spec.ts index 05aaff090f0..375553cbb9a 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/ActionExecution/uiToCode_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/ActionExecution/uiToCode_spec.ts @@ -49,12 +49,12 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { agHelper.GetNClick(propPane._navigateToType("URL")); agHelper.TypeText( propPane._actionSelectorFieldByLabel("Enter URL"), - "https://google.com", + "https://www.appsmith.com", ); agHelper.GetNClick(propPane._actionSelectorPopupClose); propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');}}`, ); // Add third action @@ -80,7 +80,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { // Validate the code propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, ); // Delete the third action @@ -97,7 +97,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { // Assert the code for the remaining actions propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');copyToClipboard('text to copy');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');copyToClipboard('text to copy');}}`, ); // Delete the first action @@ -113,7 +113,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { // Assert the code for the remaining actions propPane.ValidateJSFieldValue( "onClick", - `{{navigateTo('https://google.com', {}, 'SAME_WINDOW');copyToClipboard('text to copy');}}`, + `{{navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');copyToClipboard('text to copy');}}`, ); }); @@ -132,13 +132,13 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { agHelper.GetNClick(propPane._navigateToType("URL")); agHelper.TypeText( propPane._actionSelectorFieldByLabel("Enter URL"), - "https://google.com", + "https://www.appsmith.com", ); agHelper.GetNClick(propPane._actionSelectorPopupClose); propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');}}`, ); // Add third action @@ -165,7 +165,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, ); // Delete the third action @@ -197,7 +197,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, ); }); @@ -216,13 +216,13 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { agHelper.GetNClick(propPane._navigateToType("URL")); agHelper.TypeText( propPane._actionSelectorFieldByLabel("Enter URL"), - "https://google.com", + "https://www.appsmith.com", ); agHelper.GetNClick(propPane._actionSelectorPopupClose); propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');}}`, ); // Add third action @@ -249,7 +249,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { propPane.ValidateJSFieldValue( "onClick", - `{{showAlert('Hello!', '');navigateTo('https://google.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, + `{{showAlert('Hello!', '');navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');storeValue('secret-key', 'secret-value');copyToClipboard('text to copy');}}`, ); // Delete the third action @@ -286,7 +286,7 @@ describe("UI to Code", { tags: ["@tag.JS"] }, () => { propPane.ValidateJSFieldValue( "onClick", - `{{navigateTo('https://google.com', {}, 'SAME_WINDOW');copyToClipboard('text to copy');}}`, + `{{navigateTo('https://www.appsmith.com', {}, 'SAME_WINDOW');copyToClipboard('text to copy');}}`, ); }); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Binding/Promises_1_Spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Binding/Promises_1_Spec.ts index fd6dfbe37b8..7e97e10dc94 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Binding/Promises_1_Spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Binding/Promises_1_Spec.ts @@ -64,7 +64,7 @@ describe("Validate basic Promises", { tags: ["@tag.Binding"] }, () => { deployMode.NavigateBacktoEditor(); agHelper.AddDsl("promisesBtnImgDsl", locators._buttonByText("Submit")); apiPage.CreateAndFillApi( - "https://picsum.photos/200/300", + "http://host.docker.internal:4200/453-200x300.jpg", "RandomImy", 30000, ); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Git/GitAutocommit_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Git/GitAutocommit_spec.ts index 56caa3725d9..9d38aa357dc 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Git/GitAutocommit_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Git/GitAutocommit_spec.ts @@ -21,9 +21,6 @@ describe( }, function () { it("Check if autocommit progress bar is visible and network requests are properly called", function () { - featureFlagIntercept({ - release_git_autocommit_feature_enabled: true, - }); agHelper.GenerateUUID(); cy.get("@guid").then((uid) => { wsName = "GitAC-" + uid; diff --git a/app/client/cypress/e2e/Regression/ClientSide/IDE/Canvas_Context_Property_Pane_1_spec.js b/app/client/cypress/e2e/Regression/ClientSide/IDE/Canvas_Context_Property_Pane_1_spec.js index 0913adcfa78..0940b777580 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/IDE/Canvas_Context_Property_Pane_1_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/IDE/Canvas_Context_Property_Pane_1_spec.js @@ -117,10 +117,16 @@ describe("Canvas context Property Pane", { tags: ["@tag.IDE"] }, function () { propertySectionState = { basic: false, general: true, - validation: false, - formsettings: true, }; + if (!Cypress.env("AIRGAPPED")) { + propertySectionState = { + ...propertySectionState, + validation: false, + formsettings: true, + }; + } + verifyPropertyPaneContext( () => { setPropertyPaneSectionState(propertySectionState); diff --git a/app/client/cypress/e2e/Regression/ClientSide/IDE/Command_Click_Navigation_spec.js b/app/client/cypress/e2e/Regression/ClientSide/IDE/Command_Click_Navigation_spec.js index fb16242360b..1ae8d3082b1 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/IDE/Command_Click_Navigation_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/IDE/Command_Click_Navigation_spec.js @@ -79,7 +79,7 @@ describe("1. CommandClickNavigation", { tags: ["@tag.IDE"] }, function () { //Assert working on url field cy.updateCodeInput( ".t--dataSourceField", - "https://www.test.com/{{ SQL_Query.data }}", + "http://host.docker.internal:5001/{{ SQL_Query.data }}", ); agHelper.Sleep(); diff --git a/app/client/cypress/e2e/Regression/ClientSide/OneClickBinding/PropertyControl_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/OneClickBinding/PropertyControl_spec.ts index 2ecdeb7a2ac..94d2acc069d 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/OneClickBinding/PropertyControl_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/OneClickBinding/PropertyControl_spec.ts @@ -149,7 +149,7 @@ describe( propPane.MoveToTab("Content"); [1, 2, 3, 4, 5].forEach(() => { - apiPage.CreateAndFillApi("http://www.example.com"); + apiPage.CreateAndFillApi("https://www.appsmith.com/"); }); EditorNavigation.SelectEntityByName("Table1", EntityType.Widget); diff --git a/app/client/cypress/e2e/Regression/ClientSide/SetProperty/WidgetPropertySetters1_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/SetProperty/WidgetPropertySetters1_spec.ts index 105616188d1..cacf76c350a 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/SetProperty/WidgetPropertySetters1_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/SetProperty/WidgetPropertySetters1_spec.ts @@ -46,9 +46,9 @@ const setterMethodsToTest = [ property: "url", widget: WIDGET.AUDIO, actionBinding: - "{{Audio1.setURL('https://www.youtube.com/watch?v=JGwWNGJdvx8')}}", + "{{Audio1.setURL('http://host.docker.internal:4200/bird.mp4')}}", valueBinding: "{{Audio1.url}}", - expectedValue: "https://www.youtube.com/watch?v=JGwWNGJdvx8", + expectedValue: "http://host.docker.internal:4200/bird.mp4", }, { name: "setPlaying", diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/DocumentViewer/DocumentViewer_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Widgets/DocumentViewer/DocumentViewer_spec.ts index 4f66939deef..490bc3c766c 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/DocumentViewer/DocumentViewer_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/DocumentViewer/DocumentViewer_spec.ts @@ -19,7 +19,7 @@ const ppt = const pngImage = "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRb8umIiCU_K6ac-xS-ni4y6SP7XAd8C7Ms3Q&usqp=CAU"; const jpgImage = - "https://img.frentityExplorerpik.com/frentityExplorer-photo/beautiful-scenery-summit-mount-everest-covered-with-snow-white-clouds_181624-21317.jpg?w=1380&t=st=1691154236~exp=1691154836~hmac=35ce7f92dd16711c69509a0edbb23cedb34e49f960f560c77174994b6d5705a0"; + "https://community.appsmith.com/sites/default/files/styles/small_thumbnail/public/2024-03/aws-logo.jpg?itok=yG4bpfFs"; const pdf = "https://www.learningcontainer.com/wp-content/uploads/2019/09/sample-pdf-file.pdf"; diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image2_Spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image2_Spec.ts index 2919e3ca527..bf7d32d3852 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image2_Spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image2_Spec.ts @@ -16,12 +16,15 @@ describe( { tags: ["@tag.Widget", "@tag.Image"] }, function () { const image = (src: string) => 'img[src="' + src + '"]'; - const jpgImg = "https://jpeg.org/images/jpegsystems-home.jpg"; + const jpgImg = + "https://community.appsmith.com/sites/default/files/styles/small_thumbnail/public/2024-03/aws-logo.jpg?itok=yG4bpfFs"; const gifImg = - "https://mir-s3-cdn-cf.behance.net/project_modules/max_1200/5eeea355389655.59822ff824b72.gif"; - const svgImg = "https://assets.codepen.io/3/kiwi.svg"; - const webpImg = "https://www.gstatic.com/webp/gallery/4.sm.webp"; - const pngImg = "https://assets.appsmith.com/widgets/default.png"; + "https://www.appsmith.com/_next/image?url=https%3A%2F%2Fimages.ctfassets.net%2Flpvian6u6i39%2F5dIHs6B4O8JrcziD01Tzpr%2F080ac2887506afab72a160b897364607%2Fimage-11.gif&w=1080&q=75"; + const svgImg = "https://community.appsmith.com/appsmith-community-logo.svg"; + const webpImg = + "https://www.appsmith.com/assets/images/animations/widgets/img_0.webp"; + const pngImg = + "https://community.appsmith.com/sites/default/files/styles/16_9_card/public/septembercoding-min%20%281%29.png?itok=unYUZ0zm"; before(() => { entityExplorer.DragDropWidgetNVerify(draggableWidgets.IMAGE); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image3_Spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image3_Spec.ts index 0a758e49140..1b0fb86b0fc 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image3_Spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image3_Spec.ts @@ -15,7 +15,8 @@ describe( "Image widget - Rotation & Download", { tags: ["@tag.Widget", "@tag.Image"] }, function () { - const jpgImg = "https://jpeg.org/images/jpegsystems-home.jpg"; + const jpgImg = + "https://community.appsmith.com/sites/default/files/styles/small_thumbnail/public/2024-03/aws-logo.jpg?itok=yG4bpfFs"; before(() => { entityExplorer.DragDropWidgetNVerify(draggableWidgets.IMAGE); propPane.UpdatePropertyFieldValue("Image", jpgImg); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image_validation_spec.js b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image_validation_spec.js index 0a6b85398f0..682c2031eb0 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image_validation_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Image/Image_validation_spec.js @@ -15,7 +15,7 @@ describe( .invoke("attr", "src") .should( "contain", - "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png", + "http://host.docker.internal:4200/clouddefaultImage.png", ); }); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/DataIdentifier_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/DataIdentifier_spec.ts index 1d64e70592b..0b1f970d36c 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/DataIdentifier_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/DataIdentifier_spec.ts @@ -15,19 +15,19 @@ const data = [ { id: "001", name: "Blue", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", same: "1", }, { id: "002", name: "Green", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", same: "01", }, { id: "003", name: "Red", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", same: 1, }, ]; diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_BasicClientSideData_spec.js b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_BasicClientSideData_spec.js index 59ebf8744cd..c762a36fc84 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_BasicClientSideData_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_BasicClientSideData_spec.js @@ -10,17 +10,17 @@ const simpleListData1 = [ { id: "001", name: "Blue", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "002", name: "Green", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "003", name: "Red", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, ]; diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_EvaluatedPopup_spec.js b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_EvaluatedPopup_spec.js index 8e5ed01d002..25f27987ab7 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_EvaluatedPopup_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_EvaluatedPopup_spec.js @@ -18,17 +18,17 @@ describe( `{{[{ id: "001", name: "Blue", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "002", name: "Green", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "003", name: "Red", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }]}}`, ); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_TriggerRow_SelectedRow.js b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_TriggerRow_SelectedRow.js index 3cabf71a3ad..cd42ab2444b 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_TriggerRow_SelectedRow.js +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/ListV2/Listv2_TriggerRow_SelectedRow.js @@ -8,32 +8,32 @@ const data = [ { id: "001", name: "Blue", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "002", name: "Green", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "003", name: "Red", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "004", name: "Yellow", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "005", name: "Orange", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, { id: "006", name: "Indigo", - img: "https://assets.appsmith.com/widgets/default.png", + img: "http://host.docker.internal:4200/clouddefaultImage.png", }, ]; @@ -105,7 +105,7 @@ describe( const data = JSON.parse(val.text()); const triggeredItemView = { Image1: { - image: "https://assets.appsmith.com/widgets/default.png", + image: "http://host.docker.internal:4200/clouddefaultImage.png", isVisible: true, }, Text1: { @@ -137,7 +137,7 @@ describe( const data = JSON.parse(val.text()); const SelectedRow = { Image1: { - image: "https://assets.appsmith.com/widgets/default.png", + image: "http://host.docker.internal:4200/clouddefaultImage.png", isVisible: true, }, Text1: { @@ -198,7 +198,7 @@ describe( const data = JSON.parse(val.text()); const triggeredItemView = { Image1: { - image: "https://assets.appsmith.com/widgets/default.png", + image: "http://host.docker.internal:4200/clouddefaultImage.png", isVisible: true, }, Text1: { @@ -230,7 +230,7 @@ describe( const data = JSON.parse(val.text()); const selectedItemView = { Image1: { - image: "https://assets.appsmith.com/widgets/default.png", + image: "http://host.docker.internal:4200/clouddefaultImage.png", isVisible: true, }, Text1: { @@ -313,7 +313,7 @@ describe( const data = JSON.parse(val.text()); const triggeredItemView = { Image1: { - image: "https://assets.appsmith.com/widgets/default.png", + image: "http://host.docker.internal:4200/clouddefaultImage.png", isVisible: true, }, Text1: { diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV1/Table_PropertyPane_1_spec.js b/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV1/Table_PropertyPane_1_spec.js index 65e50a77355..b0bf0d75d33 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV1/Table_PropertyPane_1_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV1/Table_PropertyPane_1_spec.js @@ -105,8 +105,7 @@ describe( it("3. Column Detail - Edit column name and validate test for computed value based on column type selected (image, button , url)", function () { // Changing Column data type from "Date" to "Image" - const imageVal = - "https://images.pexels.com/photos/736230/pexels-photo-736230.jpeg?auto=compress&cs=tinysrgb&dpr=1&w=500"; + const imageVal = "http://host.docker.internal:4200/453-200x300.jpg"; cy.changeColumnType("Image", false); // "Moement "date" to "Image" diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV2/TableV2_PropertyPane_1_spec.js b/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV2/TableV2_PropertyPane_1_spec.js index 62ebf0ce61e..8711ea6bf07 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV2/TableV2_PropertyPane_1_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/TableV2/TableV2_PropertyPane_1_spec.js @@ -195,8 +195,7 @@ describe( }); // Changing Column data type from "Date" to "Image" - const imageVal = - "https://images.pexels.com/photos/736230/pexels-photo-736230.jpeg?auto=compress&cs=tinysrgb&dpr=1&w=500"; + const imageVal = "http://host.docker.internal:4200/453-200x300.jpg"; cy.changeColumnType("Image"); // "Moement "date" to "Image" diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/TreeSelect/Tree_Select_2_spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Widgets/TreeSelect/Tree_Select_2_spec.ts index 5d7ef2800f6..2814f31c2ac 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/TreeSelect/Tree_Select_2_spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/TreeSelect/Tree_Select_2_spec.ts @@ -308,7 +308,7 @@ describe( propPane.ToggleJSMode("onOptionChange", true); propPane.UpdatePropertyFieldValue( "onOptionChange", - `{{download('https://assets.codepen.io/3/kiwi.svg', 'kiwi.svg', 'image/svg+xml').then(() => { + `{{download('http://host.docker.internal:4200/kiwi.svg', 'kiwi.svg', 'image/svg+xml').then(() => { showAlert('Download Success', ''); });}}`, ); diff --git a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Video/Video2_Spec.ts b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Video/Video2_Spec.ts index 55ab1a650cd..ad7e177f8ec 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/Widgets/Video/Video2_Spec.ts +++ b/app/client/cypress/e2e/Regression/ClientSide/Widgets/Video/Video2_Spec.ts @@ -66,7 +66,7 @@ describe( //Check for Non-video url propPane.TypeTextIntoField( "URL", - "https://www.pexels.com/photo/closeup-photo-of-brown-brick-wall-1227511/", + "http://host.docker.internal:4200/453-200x300.jpg/", ); deployMode.DeployApp(locators._widgetInDeployed(draggableWidgets.VIDEO)); agHelper.GetElement(widgetLocators.video).then(($video) => { diff --git a/app/client/cypress/e2e/Regression/ServerSide/ActionExecution/Block_Execution.ts b/app/client/cypress/e2e/Regression/ServerSide/ActionExecution/Block_Execution.ts index e02a590d80c..a77b917e526 100644 --- a/app/client/cypress/e2e/Regression/ServerSide/ActionExecution/Block_Execution.ts +++ b/app/client/cypress/e2e/Regression/ServerSide/ActionExecution/Block_Execution.ts @@ -9,7 +9,7 @@ describe( "Block Action Execution when no field is present", { tags: ["@tag.Datasource"] }, () => { - const url = "https://www.google.com"; + const url = "https://www.appsmith.com/"; it("1. Ensure API Run button is disabled when no url is present", () => { apiPage.CreateApi("FirstAPI", "GET"); apiPage.AssertRunButtonDisability(true); diff --git a/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_Bugs_Spec.js b/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_Bugs_Spec.js index 58584e081e6..7feda064b36 100644 --- a/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_Bugs_Spec.js +++ b/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_Bugs_Spec.js @@ -69,7 +69,9 @@ describe("Rest Bugs tests", { tags: ["@tag.Datasource"] }, function () { .find("img") .invoke("attr", "src") .then(($src) => { - expect($src).not.eq("https://assets.appsmith.com/widgets/default.png"); + expect($src).not.eq( + "http://host.docker.internal:4200/clouddefaultImage.png", + ); //expect($src).contains("cat"); }); @@ -89,7 +91,9 @@ describe("Rest Bugs tests", { tags: ["@tag.Datasource"] }, function () { .find("img") .invoke("attr", "src") .then(($src) => { - expect($src).not.eq("https://assets.appsmith.com/widgets/default.png"); + expect($src).not.eq( + "http://host.docker.internal:4200/clouddefaultImage.png", + ); //expect($src).contains("dog"); }); @@ -117,7 +121,9 @@ describe("Rest Bugs tests", { tags: ["@tag.Datasource"] }, function () { .find("img") .invoke("attr", "src") .then(($src) => { - expect($src).not.eq("https://assets.appsmith.com/widgets/default.png"); + expect($src).not.eq( + "http://host.docker.internal:4200/clouddefaultImage.png", + ); //expect($src).contains("cocktail"); }); diff --git a/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_MultiPart_Spec.ts b/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_MultiPart_Spec.ts index e2007f6b0c9..7d05cf8f040 100644 --- a/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_MultiPart_Spec.ts +++ b/app/client/cypress/e2e/Regression/ServerSide/ApiTests/API_MultiPart_Spec.ts @@ -179,7 +179,7 @@ describe( .invoke("attr", "src") .then(($src) => { expect($src).not.eq( - "https://assets.appsmith.com/widgets/default.png", + "http://host.docker.internal:4200/clouddefaultImage.png", ); }); agHelper.AssertElementVisibility(locators._buttonByText("Select Files")); //verifying if reset! diff --git a/app/client/cypress/e2e/Regression/ServerSide/OnLoadTests/APIOnLoad_Spec.ts b/app/client/cypress/e2e/Regression/ServerSide/OnLoadTests/APIOnLoad_Spec.ts index b89bc975b8b..440487f3521 100644 --- a/app/client/cypress/e2e/Regression/ServerSide/OnLoadTests/APIOnLoad_Spec.ts +++ b/app/client/cypress/e2e/Regression/ServerSide/OnLoadTests/APIOnLoad_Spec.ts @@ -46,7 +46,7 @@ describe( it("2. Shows when API failed to load on page load.", function () { cy.fixture("testdata").then(function (dataSet: any) { apiPage.CreateAndFillApi( - "https://abc.com/" + dataSet.methods, + "https://www.appsmith.com/" + dataSet.methods, "PageLoadApi2", ); }); diff --git a/app/client/cypress/e2e/Sanity/Datasources/MsSQL_Basic_Spec.ts b/app/client/cypress/e2e/Sanity/Datasources/MsSQL_Basic_Spec.ts index 6b6dbe59cb0..9f97d88433a 100644 --- a/app/client/cypress/e2e/Sanity/Datasources/MsSQL_Basic_Spec.ts +++ b/app/client/cypress/e2e/Sanity/Datasources/MsSQL_Basic_Spec.ts @@ -57,16 +57,16 @@ describe( ,amazon_category_and_sub_category VARCHAR(120) ,customers_who_bought_this_item_also_bought VARCHAR(932) ); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('eac7efa5dbd3d667f26eb3d3ab504464','Hornby 2014 Catalogue','Hornby','£3.42','5 new','15',1,'4.9 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Hornby-R8150-Catalogue-2015/dp/B00S9SUUBE | http://www.amazon.co.uk/Hornby-Book-Model-Railways-Edition/dp/1844860957 | http://www.amazon.co.uk/Hornby-Book-Scenic-Railway-Modelling/dp/1844861120 | http://www.amazon.co.uk/Peco-60-Plans-Book/dp/B002QVL16I | http://www.amazon.co.uk/Hornby-Gloucester | http://www.amazon.co.uk/Airfix-5014429781902'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('b17540ef7e86e461d37f3ae58b7b72ac','FunkyBuys® Large Christmas Holiday Express Festive Train Set (SI-TY1017) Toy Light / Sounds / Battery Operated & Smoke','FunkyBuys','£16.99',NULL,'2',1,'4.5 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Christmas-Holiday-Express-Festive-Train-Set-Toy/dp/B009R8S8AA | http://www.amazon.co.uk/Goldlok-Holiday-Express-Operated-Multi-Colour/dp/B009R8PAO2 | http://www.amazon.co.uk/FunkyBuys%C2%AE-Christmas-SI-TY1017-Ornaments-Operated/dp/B01437QMHA | http://www.amazon.co.uk/Holiday-Express-Christmas-Ornament-Decoration | http://www.amazon.co.uk/Seasonal-Vision-Christmas-Tree-Train/dp/B0044ZC1W2 | http://www.amazon.co.uk/Coca-Cola-Santa-Express-Train-Set/dp/B004BYSNU0'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('348f344247b0c1a935b1223072ef9d8a','CLASSIC TOY TRAIN SET TRACK CARRIAGES LIGHT ENGINE BOXED BOYS KIDS BATTERY','ccf','£9.99','2 new','17',2,'3.9 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Classic-Train-Lights-Battery-Operated/dp/B0041L9OHE | http://www.amazon.co.uk/Train-With-Tracks-Battery-Operated-x/dp/B009P540O8 | http://www.amazon.co.uk/13-Piece-Train-Set-Ideal/dp/B0173N6E4W | http://www.amazon.co.uk/Train-Flash-Electric-Sound-Europe/dp/B008D7CEH4 | http://www.amazon.co.uk/Train-Ultimate-Sticker-Book-Stickers/dp/1405314516 | http://www.amazon.co.uk/Train-Stickers-Dover-Little-Activity/dp/0486403106'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('eac7efa5dbd3d667f26eb3d3ab504464','Hornby 2014 Catalogue','Hornby','£3.42','5 new','15',1,'4.9 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Hornby-R8150-Catalogue-2015/dp/B00S9SUUBE | https://www.appsmith.com/Hornby-Book-Model-Railways-Edition/dp/1844860957 | https://www.appsmith.com/Hornby-Book-Scenic-Railway-Modelling/dp/1844861120 | https://www.appsmith.com/Peco-60-Plans-Book/dp/B002QVL16I | https://www.appsmith.com/Hornby-Gloucester | https://www.appsmith.com/Airfix-5014429781902'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('b17540ef7e86e461d37f3ae58b7b72ac','FunkyBuys® Large Christmas Holiday Express Festive Train Set (SI-TY1017) Toy Light / Sounds / Battery Operated & Smoke','FunkyBuys','£16.99',NULL,'2',1,'4.5 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Christmas-Holiday-Express-Festive-Train-Set-Toy/dp/B009R8S8AA | https://www.appsmith.com/Goldlok-Holiday-Express-Operated-Multi-Colour/dp/B009R8PAO2 | https://www.appsmith.com/FunkyBuys%C2%AE-Christmas-SI-TY1017-Ornaments-Operated/dp/B01437QMHA | https://www.appsmith.com/Holiday-Express-Christmas-Ornament-Decoration | https://www.appsmith.com/Seasonal-Vision-Christmas-Tree-Train/dp/B0044ZC1W2 | https://www.appsmith.com/Coca-Cola-Santa-Express-Train-Set/dp/B004BYSNU0'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('348f344247b0c1a935b1223072ef9d8a','CLASSIC TOY TRAIN SET TRACK CARRIAGES LIGHT ENGINE BOXED BOYS KIDS BATTERY','ccf','£9.99','2 new','17',2,'3.9 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Classic-Train-Lights-Battery-Operated/dp/B0041L9OHE | https://www.appsmith.com/Train-With-Tracks-Battery-Operated-x/dp/B009P540O8 | https://www.appsmith.com/13-Piece-Train-Set-Ideal/dp/B0173N6E4W | https://www.appsmith.com/Train-Flash-Electric-Sound-Europe/dp/B008D7CEH4 | https://www.appsmith.com/Train-Ultimate-Sticker-Book-Stickers/dp/1405314516 | https://www.appsmith.com/Train-Stickers-Dover-Little-Activity/dp/0486403106'); INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('e12b92dbb8eaee78b22965d2a9bbbd9f','HORNBY Coach R4410A BR Hawksworth Corridor 3rd','Hornby','£39.99',NULL,'1',2,'5.0 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains',NULL); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('e33a9adeed5f36840ccc227db4682a36','Hornby 00 Gauge 0-4-0 Gildenlow Salt Co. Steam Locomotive Model','Hornby','£32.19',NULL,'3',2,'4.7 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Hornby-R6367-RailRoad-Gauge-Rolling/dp/B000WDWSD2 | http://www.amazon.co.uk/Hornby-R3064-RailRoad-Smokey-Locomotive | http://www.amazon.co.uk/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | http://www.amazon.co.uk/Hornby-R6371-RailRoad-Petrol-Tanker/dp/B000WDS002 | http://www.amazon.co.uk/Hornby-R076-00-Gauge-Footbridge | http://www.amazon.co.uk/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('cb34f0a84102c1ebc3ef6892d7444d36','20pcs Model Garden Light Double Heads Lamppost Scale 1:100','Generic','£6.99',NULL,'2',1,'5.0 out of 5 stars','Hobbies > Model Trains & Railway Sets > Lighting & Signal Engineering > Lamps & Lighting','http://www.amazon.co.uk/Single-Head-Garden-Lights-Lamppost-Layout/dp/B008XCSHCA | http://www.amazon.co.uk/douself-100Pcs-OO-Scale-Passenger/dp/B00GRUD8W4 | http://www.amazon.co.uk/Hornby-Digital-Electric-Point-Track/dp/B00105UJ14 | http://www.amazon.co.uk/20Pcs-Scenery-Landscape-Train-Flowers/dp/B00C1843MA | http://www.amazon.co.uk/Scenery-Landscape-100-Made-Plastic-Cement/dp/B007UYIJ48'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('f74b562470571dfb689324adf236f82c','Hornby 00 Gauge 230mm BR Bogie Passenger Brake Coach Model (Red)','Hornby','£24.99',NULL,'2',1,'4.5 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Hornby-R4388-RailRoad-Composite-Gauge/dp/B00260GEXO | http://www.amazon.co.uk/Hornby-R1138-Passenger-Freight-Electric/dp/B006ZL6976'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('87bbb472ef9d90dcef140a551665c929','Hornby Santa''s Express Train Set','Hornby','£69.93','3 new','36',7,'4.3 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Hornby-R8221-Gauge-Track-Extension/dp/B000PVFYZ0 | http://www.amazon.co.uk/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | http://www.amazon.co.uk/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22 | http://www.amazon.co.uk/Hornby-R6370-RailRoad-Tredegar-Gauge/dp/B000WDZH58 | http://www.amazon.co.uk/Hornby-R044-Passing-Contact-Switch/dp/B000H5V0RK | http://www.amazon.co.uk/Hornby-Gauge-Logan-Plank-Wagon/dp/B00SWV6RAG'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('7e2aa2b4596a39ba852449718413d7cc','Hornby Gauge Western Express Digital Train Set with eLink and TTS Loco Train Set','Hornby','£235.58','4 new','1',1,'5.0 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Hornby-Western-Master-E-Link-Electric/dp/B00BUKPXS8 | http://www.amazon.co.uk/Hornby-Gloucester | http://www.amazon.co.uk/Hornby-Majestic-E-Link-Gauge-Electric/dp/B00BUKPXU6 | http://www.amazon.co.uk/Hornby-Gauge-Master-Glens/dp/B00TQNJIIW | http://www.amazon.co.uk/Hornby-Gauge-Eurostar-2014-Train/dp/B00TQNJIIC | http://www.amazon.co.uk/HORNBY-Digital-Train-Layout-Track/dp/B006BRH55Y'); - INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('5afbaf65680c9f378af5b3a3ae22427e','Learning Curve Chuggington Interactive Chatsworth','Chuggington',NULL,'1 new','8',1,'4.8 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','http://www.amazon.co.uk/Learning-Curve-Chuggington | http://www.amazon.co.uk/Chuggington | http://www.amazon.co.uk/Learning-Curve-Chuggington | http://www.amazon.co.uk/Learning-Chuggington');`; + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('e33a9adeed5f36840ccc227db4682a36','Hornby 00 Gauge 0-4-0 Gildenlow Salt Co. Steam Locomotive Model','Hornby','£32.19',NULL,'3',2,'4.7 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Hornby-R6367-RailRoad-Gauge-Rolling/dp/B000WDWSD2 | https://www.appsmith.com/Hornby-R3064-RailRoad-Smokey-Locomotive | https://www.appsmith.com/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | https://www.appsmith.com/Hornby-R6371-RailRoad-Petrol-Tanker/dp/B000WDS002 | https://www.appsmith.com/Hornby-R076-00-Gauge-Footbridge | https://www.appsmith.com/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('cb34f0a84102c1ebc3ef6892d7444d36','20pcs Model Garden Light Double Heads Lamppost Scale 1:100','Generic','£6.99',NULL,'2',1,'5.0 out of 5 stars','Hobbies > Model Trains & Railway Sets > Lighting & Signal Engineering > Lamps & Lighting','https://www.appsmith.com/Single-Head-Garden-Lights-Lamppost-Layout/dp/B008XCSHCA | https://www.appsmith.com/douself-100Pcs-OO-Scale-Passenger/dp/B00GRUD8W4 | https://www.appsmith.com/Hornby-Digital-Electric-Point-Track/dp/B00105UJ14 | https://www.appsmith.com/20Pcs-Scenery-Landscape-Train-Flowers/dp/B00C1843MA | https://www.appsmith.com/Scenery-Landscape-100-Made-Plastic-Cement/dp/B007UYIJ48'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('f74b562470571dfb689324adf236f82c','Hornby 00 Gauge 230mm BR Bogie Passenger Brake Coach Model (Red)','Hornby','£24.99',NULL,'2',1,'4.5 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Hornby-R4388-RailRoad-Composite-Gauge/dp/B00260GEXO | https://www.appsmith.com/Hornby-R1138-Passenger-Freight-Electric/dp/B006ZL6976'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('87bbb472ef9d90dcef140a551665c929','Hornby Santa''s Express Train Set','Hornby','£69.93','3 new','36',7,'4.3 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Hornby-R8221-Gauge-Track-Extension/dp/B000PVFYZ0 | https://www.appsmith.com/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | https://www.appsmith.com/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22 | https://www.appsmith.com/Hornby-R6370-RailRoad-Tredegar-Gauge/dp/B000WDZH58 | https://www.appsmith.com/Hornby-R044-Passing-Contact-Switch/dp/B000H5V0RK | https://www.appsmith.com/Hornby-Gauge-Logan-Plank-Wagon/dp/B00SWV6RAG'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('7e2aa2b4596a39ba852449718413d7cc','Hornby Gauge Western Express Digital Train Set with eLink and TTS Loco Train Set','Hornby','£235.58','4 new','1',1,'5.0 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Hornby-Western-Master-E-Link-Electric/dp/B00BUKPXS8 | https://www.appsmith.com/Hornby-Gloucester | https://www.appsmith.com/Hornby-Majestic-E-Link-Gauge-Electric/dp/B00BUKPXU6 | https://www.appsmith.com/Hornby-Gauge-Master-Glens/dp/B00TQNJIIW | https://www.appsmith.com/Hornby-Gauge-Eurostar-2014-Train/dp/B00TQNJIIC | https://www.appsmith.com/HORNBY-Digital-Train-Layout-Track/dp/B006BRH55Y'); + INSERT INTO amazon_sales(uniq_id,product_name,manufacturer,price,number_available_in_stock,number_of_reviews,number_of_answered_questions,average_review_rating,amazon_category_and_sub_category,customers_who_bought_this_item_also_bought) VALUES ('5afbaf65680c9f378af5b3a3ae22427e','Learning Curve Chuggington Interactive Chatsworth','Chuggington',NULL,'1 new','8',1,'4.8 out of 5 stars','Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains','https://www.appsmith.com/Learning-Curve-Chuggington | https://www.appsmith.com/Chuggington | https://www.appsmith.com/Learning-Curve-Chuggington | https://www.appsmith.com/Learning-Chuggington');`; dataSources.EnterQuery(query); dataSources.RunQuery(); diff --git a/app/client/cypress/fixtures/AllWidgetsDsl.json b/app/client/cypress/fixtures/AllWidgetsDsl.json index ecef2eab4f1..43801ddd683 100644 --- a/app/client/cypress/fixtures/AllWidgetsDsl.json +++ b/app/client/cypress/fixtures/AllWidgetsDsl.json @@ -583,7 +583,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "1d8czar35l", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -799,17 +799,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", diff --git a/app/client/cypress/fixtures/Bugs/CheckboxGroupInListWidgetDsl.json b/app/client/cypress/fixtures/Bugs/CheckboxGroupInListWidgetDsl.json index 7f8906186b2..19233e17ca9 100644 --- a/app/client/cypress/fixtures/Bugs/CheckboxGroupInListWidgetDsl.json +++ b/app/client/cypress/fixtures/Bugs/CheckboxGroupInListWidgetDsl.json @@ -24,7 +24,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1.0, "enableRotation": false, @@ -279,17 +279,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -428,7 +428,7 @@ } ], "leftColumn": 0.0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "n1szm8g77z", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/ContainerWithOtherWidgetsDsl.json b/app/client/cypress/fixtures/ContainerWithOtherWidgetsDsl.json index 52cf3c13be4..18c6d2b0e7b 100644 --- a/app/client/cypress/fixtures/ContainerWithOtherWidgetsDsl.json +++ b/app/client/cypress/fixtures/ContainerWithOtherWidgetsDsl.json @@ -217,7 +217,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "5o3alick0b", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -476,17 +476,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", diff --git a/app/client/cypress/fixtures/ContextSwitching.json b/app/client/cypress/fixtures/ContextSwitching.json index 2a78e803b5e..c721e34c2b4 100644 --- a/app/client/cypress/fixtures/ContextSwitching.json +++ b/app/client/cypress/fixtures/ContextSwitching.json @@ -214,7 +214,7 @@ "key": "borderRadius" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "r8ob443ol9", "image": "", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Datatypes/BinaryDTdsl.json b/app/client/cypress/fixtures/Datatypes/BinaryDTdsl.json index 5d70884c16f..5a52c47b8f4 100644 --- a/app/client/cypress/fixtures/Datatypes/BinaryDTdsl.json +++ b/app/client/cypress/fixtures/Datatypes/BinaryDTdsl.json @@ -460,7 +460,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "pf0s33wwbz", "image": "{{Updateimage.files[0].data}}", "isDeprecated": false, @@ -1267,7 +1267,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "pf0s33wwbz", "image": "{{Insertimage.files[0].data}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/DynamicHeightListTextDsl.json b/app/client/cypress/fixtures/DynamicHeightListTextDsl.json index d87b901a309..941ae61fca4 100644 --- a/app/client/cypress/fixtures/DynamicHeightListTextDsl.json +++ b/app/client/cypress/fixtures/DynamicHeightListTextDsl.json @@ -29,7 +29,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -182,17 +182,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "widgetName": "List1", @@ -238,7 +238,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/EmptyListWidget.json b/app/client/cypress/fixtures/EmptyListWidget.json index b60cf3fd24f..24899de8313 100644 --- a/app/client/cypress/fixtures/EmptyListWidget.json +++ b/app/client/cypress/fixtures/EmptyListWidget.json @@ -36,17 +36,17 @@ { "id":"001", "name":"Blue", - "img":"https://assets.appsmith.com/widgets/default.png" + "img":"http://host.docker.internal:4200/clouddefaultImage.png" }, { "id":"002", "name":"Green", - "img":"https://assets.appsmith.com/widgets/default.png" + "img":"http://host.docker.internal:4200/clouddefaultImage.png" }, { "id":"003", "name":"Red", - "img":"https://assets.appsmith.com/widgets/default.png" + "img":"http://host.docker.internal:4200/clouddefaultImage.png" } ], "widgetName":"List1", diff --git a/app/client/cypress/fixtures/ImageHugWidgetDsl.json b/app/client/cypress/fixtures/ImageHugWidgetDsl.json index 84d58e0c5bf..c97594b135d 100644 --- a/app/client/cypress/fixtures/ImageHugWidgetDsl.json +++ b/app/client/cypress/fixtures/ImageHugWidgetDsl.json @@ -22,7 +22,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/InputWidgetV2InsideListDSL.json b/app/client/cypress/fixtures/InputWidgetV2InsideListDSL.json index 2fe537602bf..3e1298022ba 100644 --- a/app/client/cypress/fixtures/InputWidgetV2InsideListDSL.json +++ b/app/client/cypress/fixtures/InputWidgetV2InsideListDSL.json @@ -91,17 +91,17 @@ { "id":"001", "name":"Blue", - "img":"https://assets.appsmith.com/widgets/default.png" + "img":"http://host.docker.internal:4200/clouddefaultImage.png" }, { "id":"002", "name":"Green", - "img":"https://assets.appsmith.com/widgets/default.png" + "img":"http://host.docker.internal:4200/clouddefaultImage.png" }, { "id":"003", "name":"Red", - "img":"https://assets.appsmith.com/widgets/default.png" + "img":"http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas":true, diff --git a/app/client/cypress/fixtures/JSApiOnLoadDsl.json b/app/client/cypress/fixtures/JSApiOnLoadDsl.json index c8f3e897cd8..7de5341d237 100644 --- a/app/client/cypress/fixtures/JSApiOnLoadDsl.json +++ b/app/client/cypress/fixtures/JSApiOnLoadDsl.json @@ -134,7 +134,7 @@ "key": "borderRadius" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "n08zeysxti", "image": "", "rightColumn": 36, diff --git a/app/client/cypress/fixtures/JSObjOnLoadApp.json b/app/client/cypress/fixtures/JSObjOnLoadApp.json index 3266ee78d1a..b4c7de01bbe 100644 --- a/app/client/cypress/fixtures/JSObjOnLoadApp.json +++ b/app/client/cypress/fixtures/JSObjOnLoadApp.json @@ -2791,7 +2791,7 @@ "key": "borderRadius" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "lp46gw08hk", "image": "", "rightColumn": 25, @@ -5586,7 +5586,7 @@ "key": "borderRadius" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "lp46gw08hk", "image": "", "rightColumn": 25, diff --git a/app/client/cypress/fixtures/ListWidgetWithDataAndButtonDSL.json b/app/client/cypress/fixtures/ListWidgetWithDataAndButtonDSL.json index 95c1afc7dc1..b6f1027cf80 100644 --- a/app/client/cypress/fixtures/ListWidgetWithDataAndButtonDSL.json +++ b/app/client/cypress/fixtures/ListWidgetWithDataAndButtonDSL.json @@ -169,7 +169,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "y8iriyc5nu", "image": "{{List1.listData.map((currentItem) => currentItem.img)}}", "isDeprecated": false, @@ -407,7 +407,7 @@ }, "boxShadow": "{{appsmith.theme.boxShadow.appBoxShadow}}", "widgetName": "List1", - "listData": "[\n {\n \"step\": \"#1\",\n \"task\": \"https://www.appsmith.com\",\n \"status\": \"✅\",\n \"action\": \"'\"\n },\n {\n \"step\": \"#2\",\n \"task\": \"https://www.google.com\",\n \"status\": \"--\",\n \"action\": \"\"\n },\n {\n \"step\": \"#3\",\n \"task\": \"https://www.mozilla.org/\",\n \"status\": \"--\",\n \"action\": \"\"\n }\n]", + "listData": "[\n {\n \"step\": \"#1\",\n \"task\": \"https://www.appsmith.com\",\n \"status\": \"✅\",\n \"action\": \"'\"\n },\n {\n \"step\": \"#2\",\n \"task\": \"https://www.appsmith.com\",\n \"status\": \"--\",\n \"action\": \"\"\n },\n {\n \"step\": \"#3\",\n \"task\": \"https://www.mozilla.org/\",\n \"status\": \"--\",\n \"action\": \"\"\n }\n]", "isCanvas": true, "displayName": "List", "iconSVG": "/static/media/icon.9925ee17dee37bf1ba7374412563a8a7.svg", @@ -552,7 +552,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "y8iriyc5nu", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/ListV2WithNullPrimaryKey.json b/app/client/cypress/fixtures/Listv2/ListV2WithNullPrimaryKey.json index 93f2da2c7f4..40c270391e8 100644 --- a/app/client/cypress/fixtures/Listv2/ListV2WithNullPrimaryKey.json +++ b/app/client/cypress/fixtures/Listv2/ListV2WithNullPrimaryKey.json @@ -169,7 +169,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "yw653gsmbv", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -367,17 +367,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -519,7 +519,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "w95o2stmmq", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/ListV2_Reset_dsl.json b/app/client/cypress/fixtures/Listv2/ListV2_Reset_dsl.json index d3239445745..d4f957d2582 100644 --- a/app/client/cypress/fixtures/Listv2/ListV2_Reset_dsl.json +++ b/app/client/cypress/fixtures/Listv2/ListV2_Reset_dsl.json @@ -257,32 +257,32 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "004", "name": "Yellow", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "005", "name": "Orange", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "006", "name": "Indigo", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -414,7 +414,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "4c4lsxnbxl", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/ListV2_nested_sibling_listwidget_dsl.json b/app/client/cypress/fixtures/Listv2/ListV2_nested_sibling_listwidget_dsl.json index 0685cc53e99..a8fe8e92307 100644 --- a/app/client/cypress/fixtures/Listv2/ListV2_nested_sibling_listwidget_dsl.json +++ b/app/client/cypress/fixtures/Listv2/ListV2_nested_sibling_listwidget_dsl.json @@ -30,17 +30,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -165,7 +165,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "819owyun3i", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -298,17 +298,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -432,7 +432,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "819owyun3i", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -653,17 +653,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -787,7 +787,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "9lswt6ei9p", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/ListWithInputForSelectedAndTriggerRow.json b/app/client/cypress/fixtures/Listv2/ListWithInputForSelectedAndTriggerRow.json index 71d690fb408..dcd2eeaef26 100644 --- a/app/client/cypress/fixtures/Listv2/ListWithInputForSelectedAndTriggerRow.json +++ b/app/client/cypress/fixtures/Listv2/ListWithInputForSelectedAndTriggerRow.json @@ -76,32 +76,32 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "004", "name": "Yellow", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "005", "name": "Orange", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "006", "name": "Indigo", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -250,7 +250,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "h2b802pelw", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/ListWithModalStatCheckboxAndRadio.json b/app/client/cypress/fixtures/Listv2/ListWithModalStatCheckboxAndRadio.json index d65aa35bc7f..177dc8395eb 100644 --- a/app/client/cypress/fixtures/Listv2/ListWithModalStatCheckboxAndRadio.json +++ b/app/client/cypress/fixtures/Listv2/ListWithModalStatCheckboxAndRadio.json @@ -29,17 +29,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, diff --git a/app/client/cypress/fixtures/Listv2/Listv2JSObjects.json b/app/client/cypress/fixtures/Listv2/Listv2JSObjects.json index bb01cb8df1a..f962cb47ebc 100644 --- a/app/client/cypress/fixtures/Listv2/Listv2JSObjects.json +++ b/app/client/cypress/fixtures/Listv2/Listv2JSObjects.json @@ -207,7 +207,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "nw33u3efde", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/emptyList.json b/app/client/cypress/fixtures/Listv2/emptyList.json index 6d3bc884f13..d9ecdaa4fc4 100644 --- a/app/client/cypress/fixtures/Listv2/emptyList.json +++ b/app/client/cypress/fixtures/Listv2/emptyList.json @@ -30,17 +30,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, diff --git a/app/client/cypress/fixtures/Listv2/level3NestedList.json b/app/client/cypress/fixtures/Listv2/level3NestedList.json index e6fe7e3c3be..2a4fef2589f 100644 --- a/app/client/cypress/fixtures/Listv2/level3NestedList.json +++ b/app/client/cypress/fixtures/Listv2/level3NestedList.json @@ -260,17 +260,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -507,17 +507,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, diff --git a/app/client/cypress/fixtures/Listv2/listWithServerSideData.json b/app/client/cypress/fixtures/Listv2/listWithServerSideData.json index 3a70889f8ef..7a7396fae63 100644 --- a/app/client/cypress/fixtures/Listv2/listWithServerSideData.json +++ b/app/client/cypress/fixtures/Listv2/listWithServerSideData.json @@ -104,7 +104,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/Listv2/nestedList.json b/app/client/cypress/fixtures/Listv2/nestedList.json index 16661f19f37..a40d1c0e991 100644 --- a/app/client/cypress/fixtures/Listv2/nestedList.json +++ b/app/client/cypress/fixtures/Listv2/nestedList.json @@ -27,17 +27,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -173,7 +173,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "bvt9um0p1b", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -516,17 +516,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -657,7 +657,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "t5kmrwsh0s", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/simpleList.json b/app/client/cypress/fixtures/Listv2/simpleList.json index 7fabb0d5f27..e4b10252a52 100644 --- a/app/client/cypress/fixtures/Listv2/simpleList.json +++ b/app/client/cypress/fixtures/Listv2/simpleList.json @@ -27,17 +27,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -166,7 +166,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "bvt9um0p1b", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/simpleListWithCurrencyWidget.json b/app/client/cypress/fixtures/Listv2/simpleListWithCurrencyWidget.json index cd4c1c7ec0b..8afffe4b31d 100644 --- a/app/client/cypress/fixtures/Listv2/simpleListWithCurrencyWidget.json +++ b/app/client/cypress/fixtures/Listv2/simpleListWithCurrencyWidget.json @@ -24,7 +24,7 @@ "triggeredItemView": "{{{}}}", "widgetName": "List1", "requiresFlatWidgetChildren": true, - "listData": "[\n {\n \"id\": \"000\",\n \"name\": \"Yellow\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"004\",\n \"name\": \"Black\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"005\",\n \"name\": \"Yellow\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"006\",\n \"name\": \"Indigo\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n }\n ]", + "listData": "[\n {\n \"id\": \"000\",\n \"name\": \"Yellow\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"004\",\n \"name\": \"Black\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"005\",\n \"name\": \"Yellow\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"006\",\n \"name\": \"Indigo\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n }\n ]", "isCanvas": true, "displayName": "List V2", "iconSVG": "/static/media/icon.9925ee17dee37bf1ba7374412563a8a7.svg", @@ -149,7 +149,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "haq56bwf64", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/simpleListWithInputAndButton.json b/app/client/cypress/fixtures/Listv2/simpleListWithInputAndButton.json index 9baa2c7f5fc..b709118c77d 100644 --- a/app/client/cypress/fixtures/Listv2/simpleListWithInputAndButton.json +++ b/app/client/cypress/fixtures/Listv2/simpleListWithInputAndButton.json @@ -28,37 +28,37 @@ { "id": "000", "name": "Yellow", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "004", "name": "Black", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "005", "name": "Yellow", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "006", "name": "Indigo", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -189,7 +189,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "htltz07tuq", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/simpleListWithLargeData.json b/app/client/cypress/fixtures/Listv2/simpleListWithLargeData.json index 8d625e83e84..3a24ec2e491 100644 --- a/app/client/cypress/fixtures/Listv2/simpleListWithLargeData.json +++ b/app/client/cypress/fixtures/Listv2/simpleListWithLargeData.json @@ -165,7 +165,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "e4nnev99kg", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Listv2/simpleListWithTabsWidget.json b/app/client/cypress/fixtures/Listv2/simpleListWithTabsWidget.json index d5c2fc12456..2e8f89f70dc 100644 --- a/app/client/cypress/fixtures/Listv2/simpleListWithTabsWidget.json +++ b/app/client/cypress/fixtures/Listv2/simpleListWithTabsWidget.json @@ -29,17 +29,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "isCanvas": true, @@ -177,7 +177,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "a9xde6ouir", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/ResizeListDsl.json b/app/client/cypress/fixtures/ResizeListDsl.json index 482727f227c..9d000c309be 100644 --- a/app/client/cypress/fixtures/ResizeListDsl.json +++ b/app/client/cypress/fixtures/ResizeListDsl.json @@ -70,7 +70,7 @@ "triggeredItemView": "{{{}}}", "widgetName": "List1", "requiresFlatWidgetChildren": true, - "listData": "[\n {\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n\t{\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n\t{\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"https://assets.appsmith.com/widgets/default.png\"\n }\n]", + "listData": "[\n {\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n\t{\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n\t{\n \"id\": \"001\",\n \"name\": \"Blue\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"002\",\n \"name\": \"Green\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n },\n {\n \"id\": \"003\",\n \"name\": \"Red\",\n \"img\": \"http://host.docker.internal:4200/clouddefaultImage.png\"\n }\n]", "isCanvas": true, "displayName": "List", "iconSVG": "/static/media/icon.9925ee17dee37bf1ba7374412563a8a7.svg", @@ -193,7 +193,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "8pdxjzto4a", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/SampleAppIDETest.json b/app/client/cypress/fixtures/SampleAppIDETest.json index 512677c5371..caa3b9320a6 100644 --- a/app/client/cypress/fixtures/SampleAppIDETest.json +++ b/app/client/cypress/fixtures/SampleAppIDETest.json @@ -1392,7 +1392,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "0pndua8j2k", "image": "{{tbl_userInfo.selectedRow.image}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/Table/ImageResizeDSL.json b/app/client/cypress/fixtures/Table/ImageResizeDSL.json index 1b59ef3d76b..b047c10d9c6 100644 --- a/app/client/cypress/fixtures/Table/ImageResizeDSL.json +++ b/app/client/cypress/fixtures/Table/ImageResizeDSL.json @@ -306,7 +306,7 @@ "rightColumn": 64, "textSize": "0.875rem", "widgetId": "gu00tyfnjm", - "tableData": "[\n{\n \"albumId\": 1,\n \"id\": 1,\n \"title\": \"accusamus beatae ad facilis cum similique qui sunt\",\n \"url\": \"https://via.placeholder.com/600/92c952\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/92c952\",\n \"image\": \"https://picsum.photos/200/300\"\n },\n {\n \"albumId\": 1,\n \"id\": 2,\n \"title\": \"reprehenderit est deserunt velit ipsam\",\n \"url\": \"https://via.placeholder.com/600/771796\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/771796\",\n \"image\": \"https://picsum.photos/300/300\"\n },\n {\n \"albumId\": 1,\n \"id\": 3,\n \"title\": \"officia porro iure quia iusto qui ipsa ut modi\",\n \"url\": \"https://via.placeholder.com/600/24f355\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/24f355\",\n \"image\": \"https://picsum.photos/400/300\"\n },\n {\n \"albumId\": 1,\n \"id\": 4,\n \"title\": \"culpa odio esse rerum omnis laboriosam voluptate repudiandae\",\n \"url\": \"https://via.placeholder.com/600/d32776\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/d32776\",\n \"image\": \"https://picsum.photos/500/300\"\n },\n {\n \"albumId\": 1,\n \"id\": 5,\n \"title\": \"natus nisi omnis corporis facere molestiae rerum in\",\n \"url\": \"https://via.placeholder.com/600/f66b97\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/f66b97\",\n \"image\": \"https://picsum.photos/100/300\"\n }\n]", + "tableData": "[\n{\n \"albumId\": 1,\n \"id\": 1,\n \"title\": \"accusamus beatae ad facilis cum similique qui sunt\",\n \"url\": \"https://via.placeholder.com/600/92c952\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/92c952\",\n \"image\": \"http://host.docker.internal:4200/453-200x300.jpg\"\n },\n {\n \"albumId\": 1,\n \"id\": 2,\n \"title\": \"reprehenderit est deserunt velit ipsam\",\n \"url\": \"https://via.placeholder.com/600/771796\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/771796\",\n \"image\": \"http://host.docker.internal:4200/453-200x300.jpg\"\n },\n {\n \"albumId\": 1,\n \"id\": 3,\n \"title\": \"officia porro iure quia iusto qui ipsa ut modi\",\n \"url\": \"https://via.placeholder.com/600/24f355\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/24f355\",\n \"image\": \"http://host.docker.internal:4200/453-200x300.jpg\"\n },\n {\n \"albumId\": 1,\n \"id\": 4,\n \"title\": \"culpa odio esse rerum omnis laboriosam voluptate repudiandae\",\n \"url\": \"https://via.placeholder.com/600/d32776\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/d32776\",\n \"image\": \"http://host.docker.internal:4200/453-200x300.jpg\"\n },\n {\n \"albumId\": 1,\n \"id\": 5,\n \"title\": \"natus nisi omnis corporis facere molestiae rerum in\",\n \"url\": \"https://via.placeholder.com/600/f66b97\",\n \"thumbnailUrl\": \"https://via.placeholder.com/150/f66b97\",\n \"image\": \"http://host.docker.internal:4200/453-200x300.jpg\"\n }\n]", "label": "Data", "searchKey": "", "parentId": "0", diff --git a/app/client/cypress/fixtures/ThemeAppdsl.json b/app/client/cypress/fixtures/ThemeAppdsl.json index 7131871a00c..3e665a60c71 100644 --- a/app/client/cypress/fixtures/ThemeAppdsl.json +++ b/app/client/cypress/fixtures/ThemeAppdsl.json @@ -519,7 +519,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -643,17 +643,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "widgetName": "List1", @@ -697,7 +697,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/apiParallelDsl.json b/app/client/cypress/fixtures/apiParallelDsl.json index e9c4a4bb338..c943e736f1e 100644 --- a/app/client/cypress/fixtures/apiParallelDsl.json +++ b/app/client/cypress/fixtures/apiParallelDsl.json @@ -40,7 +40,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "k7gqsx8va7", "image": "{{List1.listData.map((currentItem) => currentItem.image)}}", "rightColumn": 13, @@ -413,7 +413,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "k7gqsx8va7", "image": "{{currentItem.image}}", "rightColumn": 13, @@ -695,7 +695,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "k7gqsx8va7", "image": "{{FlowerImage1.data}}", "rightColumn": 24, @@ -729,7 +729,7 @@ "key": "image" } ], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "k7gqsx8va7", "image": "{{FlowerImage2.data}}", "rightColumn": 37, diff --git a/app/client/cypress/fixtures/base64imagedsl.json b/app/client/cypress/fixtures/base64imagedsl.json index 498a7a8feba..0b01706b27a 100644 --- a/app/client/cypress/fixtures/base64imagedsl.json +++ b/app/client/cypress/fixtures/base64imagedsl.json @@ -22,7 +22,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "image": "", diff --git a/app/client/cypress/fixtures/displayWidgetDsl.json b/app/client/cypress/fixtures/displayWidgetDsl.json index 30d601c14d2..9d1360e720e 100644 --- a/app/client/cypress/fixtures/displayWidgetDsl.json +++ b/app/client/cypress/fixtures/displayWidgetDsl.json @@ -53,7 +53,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "image": "", "widgetName": "Image1", diff --git a/app/client/cypress/fixtures/dynamicHeightListDsl.json b/app/client/cypress/fixtures/dynamicHeightListDsl.json index b5803190eca..76eb5511579 100644 --- a/app/client/cypress/fixtures/dynamicHeightListDsl.json +++ b/app/client/cypress/fixtures/dynamicHeightListDsl.json @@ -29,7 +29,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -182,17 +182,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "widgetName": "List1", @@ -238,7 +238,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/exported-app.json b/app/client/cypress/fixtures/exported-app.json index f1fd770f949..d86c14559b7 100644 --- a/app/client/cypress/fixtures/exported-app.json +++ b/app/client/cypress/fixtures/exported-app.json @@ -98,7 +98,7 @@ "parentColumnSpace": 34.6875, "imageShape": "RECTANGLE", "leftColumn": 6, - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png" + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png" } ] } diff --git a/app/client/cypress/fixtures/listRegression2Dsl.json b/app/client/cypress/fixtures/listRegression2Dsl.json index 9b43ded25d0..b4fe6d7fae1 100644 --- a/app/client/cypress/fixtures/listRegression2Dsl.json +++ b/app/client/cypress/fixtures/listRegression2Dsl.json @@ -28,7 +28,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -267,7 +267,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/listRegression3Dsl.json b/app/client/cypress/fixtures/listRegression3Dsl.json index 1a9993812b2..ce39097b674 100644 --- a/app/client/cypress/fixtures/listRegression3Dsl.json +++ b/app/client/cypress/fixtures/listRegression3Dsl.json @@ -29,7 +29,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -268,7 +268,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/listRegressionDsl.json b/app/client/cypress/fixtures/listRegressionDsl.json index eaa50d68c9f..93a2bc696de 100644 --- a/app/client/cypress/fixtures/listRegressionDsl.json +++ b/app/client/cypress/fixtures/listRegressionDsl.json @@ -28,7 +28,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -267,7 +267,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/listV2AudioVideoDsl.json b/app/client/cypress/fixtures/listV2AudioVideoDsl.json index 76b5182b98c..b1b2885424e 100644 --- a/app/client/cypress/fixtures/listV2AudioVideoDsl.json +++ b/app/client/cypress/fixtures/listV2AudioVideoDsl.json @@ -145,7 +145,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "25ukodbr6c", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -533,17 +533,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", diff --git a/app/client/cypress/fixtures/listV2ButtonsDsl.json b/app/client/cypress/fixtures/listV2ButtonsDsl.json index 08fde581096..ea2ff345cb1 100644 --- a/app/client/cypress/fixtures/listV2ButtonsDsl.json +++ b/app/client/cypress/fixtures/listV2ButtonsDsl.json @@ -145,7 +145,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "25ukodbr6c", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -637,17 +637,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", diff --git a/app/client/cypress/fixtures/listV2NestedDsl.json b/app/client/cypress/fixtures/listV2NestedDsl.json index d2f772e7c95..a5c63e6c741 100644 --- a/app/client/cypress/fixtures/listV2NestedDsl.json +++ b/app/client/cypress/fixtures/listV2NestedDsl.json @@ -145,7 +145,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "crx5qmd37r", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -428,7 +428,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "crx5qmd37r", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -711,7 +711,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "crx5qmd37r", "image": "{{currentItem.img}}", "isDeprecated": false, @@ -963,17 +963,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", @@ -1094,17 +1094,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", @@ -1224,17 +1224,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", diff --git a/app/client/cypress/fixtures/listWidgetLintDsl.json b/app/client/cypress/fixtures/listWidgetLintDsl.json index 20005ec4a1d..5562310edc5 100644 --- a/app/client/cypress/fixtures/listWidgetLintDsl.json +++ b/app/client/cypress/fixtures/listWidgetLintDsl.json @@ -27,7 +27,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -161,7 +161,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/listv2PaginationDsl.json b/app/client/cypress/fixtures/listv2PaginationDsl.json index 2facbd179e2..d98e97bb5e9 100644 --- a/app/client/cypress/fixtures/listv2PaginationDsl.json +++ b/app/client/cypress/fixtures/listv2PaginationDsl.json @@ -201,7 +201,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "5khw0s488h", "image": "{{currentItem.img}}", "isDeprecated": false, diff --git a/app/client/cypress/fixtures/listwidgetdsl.json b/app/client/cypress/fixtures/listwidgetdsl.json index f34952103fc..642b0eaa376 100644 --- a/app/client/cypress/fixtures/listwidgetdsl.json +++ b/app/client/cypress/fixtures/listwidgetdsl.json @@ -56,7 +56,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "image": "{{currentItem.img}}", @@ -193,7 +193,7 @@ "template": { "Image1": { "isVisible": true, - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "image": "{{List1.listData.map((currentItem) => currentItem.img)}}", diff --git a/app/client/cypress/fixtures/mobileViewScrollDsl.json b/app/client/cypress/fixtures/mobileViewScrollDsl.json index 57d420fa320..a422600b79d 100644 --- a/app/client/cypress/fixtures/mobileViewScrollDsl.json +++ b/app/client/cypress/fixtures/mobileViewScrollDsl.json @@ -65,17 +65,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "pageSize": 2, @@ -158,7 +158,7 @@ "children": [ { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, diff --git a/app/client/cypress/fixtures/onPageLoadActionsDsl.json b/app/client/cypress/fixtures/onPageLoadActionsDsl.json index 8d3c4b68ddd..fce6d97f48a 100644 --- a/app/client/cypress/fixtures/onPageLoadActionsDsl.json +++ b/app/client/cypress/fixtures/onPageLoadActionsDsl.json @@ -34,7 +34,7 @@ "imageShape": "RECTANGLE", "leftColumn": 8, "dynamicBindingPathList": [], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "nyx7m0wdr7", "image": "", "rightColumn": 54, @@ -122,7 +122,7 @@ "imageShape": "RECTANGLE", "leftColumn": 8, "dynamicBindingPathList": [], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "agtoehwrk0", "image": "", "rightColumn": 27, diff --git a/app/client/cypress/fixtures/promisesBtnImgDsl.json b/app/client/cypress/fixtures/promisesBtnImgDsl.json index aadddae4d0e..9e53667b60b 100644 --- a/app/client/cypress/fixtures/promisesBtnImgDsl.json +++ b/app/client/cypress/fixtures/promisesBtnImgDsl.json @@ -45,7 +45,7 @@ "imageShape": "RECTANGLE", "leftColumn": 12, "dynamicBindingPathList": [], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "rmhpjhzzn1", "image": "", "rightColumn": 29, diff --git a/app/client/cypress/fixtures/promisesBtnListDsl.json b/app/client/cypress/fixtures/promisesBtnListDsl.json index e06f6d49778..f7657b9e6d6 100644 --- a/app/client/cypress/fixtures/promisesBtnListDsl.json +++ b/app/client/cypress/fixtures/promisesBtnListDsl.json @@ -60,7 +60,7 @@ "template": { "Image2": { "isVisible": true, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "imageShape": "RECTANGLE", "maxZoomLevel": 1, "enableRotation": false, @@ -259,7 +259,7 @@ } ], "leftColumn": 0, - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "egbqwm9hx0", "image": "{{currentItem.img}}", "rightColumn": 16, diff --git a/app/client/cypress/fixtures/resetWidgetDSL.json b/app/client/cypress/fixtures/resetWidgetDSL.json index af06a179c7e..8620ebbd6fd 100644 --- a/app/client/cypress/fixtures/resetWidgetDSL.json +++ b/app/client/cypress/fixtures/resetWidgetDSL.json @@ -480,17 +480,17 @@ { "id": "001", "name": "Blue", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "002", "name": "Green", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "id": "003", "name": "Red", - "img": "https://assets.appsmith.com/widgets/default.png" + "img": "http://host.docker.internal:4200/clouddefaultImage.png" } ], "displayName": "List", diff --git a/app/client/cypress/fixtures/tableResizedColumnsDsl.json b/app/client/cypress/fixtures/tableResizedColumnsDsl.json index 2ac1da30aee..282909f8e46 100644 --- a/app/client/cypress/fixtures/tableResizedColumnsDsl.json +++ b/app/client/cypress/fixtures/tableResizedColumnsDsl.json @@ -80,7 +80,7 @@ "imageShape": "RECTANGLE", "leftColumn": 0, "dynamicBindingPathList": [], - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png" + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "backgroundColor": "#FFFFFF", diff --git a/app/client/cypress/fixtures/tableV2ResizedColumnsDsl.json b/app/client/cypress/fixtures/tableV2ResizedColumnsDsl.json index 1be715bfabb..47028f88bb3 100644 --- a/app/client/cypress/fixtures/tableV2ResizedColumnsDsl.json +++ b/app/client/cypress/fixtures/tableV2ResizedColumnsDsl.json @@ -80,7 +80,7 @@ "imageShape": "RECTANGLE", "leftColumn": 0, "dynamicBindingPathList": [], - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png" + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "backgroundColor": "#FFFFFF", diff --git a/app/client/cypress/fixtures/templatePageWithNullbindings.json b/app/client/cypress/fixtures/templatePageWithNullbindings.json index 632e48de665..2ffe721a361 100644 --- a/app/client/cypress/fixtures/templatePageWithNullbindings.json +++ b/app/client/cypress/fixtures/templatePageWithNullbindings.json @@ -262,7 +262,7 @@ "imageShape": "RECTANGLE", "leftColumn": 42.0, "dynamicBindingPathList": [], - "defaultImage": "https://assets.appsmith.com/widgets/default.png", + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png", "key": "21idekou80", "labelTextSize": "0.875rem", "image": "https://i.ibb.co/bvSrMX7/Group-84601.png", diff --git a/app/client/cypress/fixtures/test-data-gsheet.ts b/app/client/cypress/fixtures/test-data-gsheet.ts index 05d45543c04..3a5c47d63cb 100644 --- a/app/client/cypress/fixtures/test-data-gsheet.ts +++ b/app/client/cypress/fixtures/test-data-gsheet.ts @@ -15,7 +15,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Hornby-R8150-Catalogue-2015/dp/B00S9SUUBE | http://www.amazon.co.uk/Hornby-Book-Model-Railways-Edition/dp/1844860957 | http://www.amazon.co.uk/Hornby-Book-Scenic-Railway-Modelling/dp/1844861120 | http://www.amazon.co.uk/Peco-60-Plans-Book/dp/B002QVL16I | http://www.amazon.co.uk/Hornby-Gloucester | http://www.amazon.co.uk/Airfix-5014429781902", + "https://www.appsmith.com/Hornby-R8150-Catalogue-2015/dp/B00S9SUUBE | https://www.appsmith.com/Hornby-Book-Model-Railways-Edition/dp/1844860957 | https://www.appsmith.com/Hornby-Book-Scenic-Railway-Modelling/dp/1844861120 | https://www.appsmith.com/Peco-60-Plans-Book/dp/B002QVL16I | https://www.appsmith.com/Hornby-Gloucester | https://www.appsmith.com/Airfix-5014429781902", }, { rowIndex: "1", @@ -35,7 +35,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Christmas-Holiday-Express-Festive-Train-Set-Toy/dp/B009R8S8AA | http://www.amazon.co.uk/Goldlok-Holiday-Express-Operated-Multi-Colour/dp/B009R8PAO2 | http://www.amazon.co.uk/FunkyBuys%C2%AE-Christmas-SI-TY1017-Ornaments-Operated/dp/B01437QMHA | http://www.amazon.co.uk/Holiday-Express-Christmas-Ornament-Decoration | http://www.amazon.co.uk/Seasonal-Vision-Christmas-Tree-Train/dp/B0044ZC1W2 | http://www.amazon.co.uk/Coca-Cola-Santa-Express-Train-Set/dp/B004BYSNU0", + "https://www.appsmith.com/Christmas-Holiday-Express-Festive-Train-Set-Toy/dp/B009R8S8AA | https://www.appsmith.com/Goldlok-Holiday-Express-Operated-Multi-Colour/dp/B009R8PAO2 | https://www.appsmith.com/FunkyBuys%C2%AE-Christmas-SI-TY1017-Ornaments-Operated/dp/B01437QMHA | https://www.appsmith.com/Holiday-Express-Christmas-Ornament-Decoration | https://www.appsmith.com/Seasonal-Vision-Christmas-Tree-Train/dp/B0044ZC1W2 | https://www.appsmith.com/Coca-Cola-Santa-Express-Train-Set/dp/B004BYSNU0", }, { rowIndex: "2", @@ -55,7 +55,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Classic-Train-Lights-Battery-Operated/dp/B0041L9OHE | http://www.amazon.co.uk/Train-With-Tracks-Battery-Operated-x/dp/B009P540O8 | http://www.amazon.co.uk/13-Piece-Train-Set-Ideal/dp/B0173N6E4W | http://www.amazon.co.uk/Train-Flash-Electric-Sound-Europe/dp/B008D7CEH4 | http://www.amazon.co.uk/Train-Ultimate-Sticker-Book-Stickers/dp/1405314516 | http://www.amazon.co.uk/Train-Stickers-Dover-Little-Activity/dp/0486403106", + "https://www.appsmith.com/Classic-Train-Lights-Battery-Operated/dp/B0041L9OHE | https://www.appsmith.com/Train-With-Tracks-Battery-Operated-x/dp/B009P540O8 | https://www.appsmith.com/13-Piece-Train-Set-Ideal/dp/B0173N6E4W | https://www.appsmith.com/Train-Flash-Electric-Sound-Europe/dp/B008D7CEH4 | https://www.appsmith.com/Train-Ultimate-Sticker-Book-Stickers/dp/1405314516 | https://www.appsmith.com/Train-Stickers-Dover-Little-Activity/dp/0486403106", }, { rowIndex: "3", @@ -92,7 +92,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Hornby-R6367-RailRoad-Gauge-Rolling/dp/B000WDWSD2 | http://www.amazon.co.uk/Hornby-R3064-RailRoad-Smokey-Locomotive | http://www.amazon.co.uk/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | http://www.amazon.co.uk/Hornby-R6371-RailRoad-Petrol-Tanker/dp/B000WDS002 | http://www.amazon.co.uk/Hornby-R076-00-Gauge-Footbridge | http://www.amazon.co.uk/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22", + "https://www.appsmith.com/Hornby-R6367-RailRoad-Gauge-Rolling/dp/B000WDWSD2 | https://www.appsmith.com/Hornby-R3064-RailRoad-Smokey-Locomotive | https://www.appsmith.com/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | https://www.appsmith.com/Hornby-R6371-RailRoad-Petrol-Tanker/dp/B000WDS002 | https://www.appsmith.com/Hornby-R076-00-Gauge-Footbridge | https://www.appsmith.com/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22", }, { rowIndex: "5", @@ -110,7 +110,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Lighting & Signal Engineering > Lamps & Lighting", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Single-Head-Garden-Lights-Lamppost-Layout/dp/B008XCSHCA | http://www.amazon.co.uk/douself-100Pcs-OO-Scale-Passenger/dp/B00GRUD8W4 | http://www.amazon.co.uk/Hornby-Digital-Electric-Point-Track/dp/B00105UJ14 | http://www.amazon.co.uk/20Pcs-Scenery-Landscape-Train-Flowers/dp/B00C1843MA | http://www.amazon.co.uk/Scenery-Landscape-100-Made-Plastic-Cement/dp/B007UYIJ48", + "https://www.appsmith.com/Single-Head-Garden-Lights-Lamppost-Layout/dp/B008XCSHCA | https://www.appsmith.com/douself-100Pcs-OO-Scale-Passenger/dp/B00GRUD8W4 | https://www.appsmith.com/Hornby-Digital-Electric-Point-Track/dp/B00105UJ14 | https://www.appsmith.com/20Pcs-Scenery-Landscape-Train-Flowers/dp/B00C1843MA | https://www.appsmith.com/Scenery-Landscape-100-Made-Plastic-Cement/dp/B007UYIJ48", }, { rowIndex: "6", @@ -130,7 +130,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Hornby-R4388-RailRoad-Composite-Gauge/dp/B00260GEXO | http://www.amazon.co.uk/Hornby-R1138-Passenger-Freight-Electric/dp/B006ZL6976", + "https://www.appsmith.com/Hornby-R4388-RailRoad-Composite-Gauge/dp/B00260GEXO | https://www.appsmith.com/Hornby-R1138-Passenger-Freight-Electric/dp/B006ZL6976", }, { rowIndex: "7", @@ -148,7 +148,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Hornby-R8221-Gauge-Track-Extension/dp/B000PVFYZ0 | http://www.amazon.co.uk/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | http://www.amazon.co.uk/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22 | http://www.amazon.co.uk/Hornby-R6370-RailRoad-Tredegar-Gauge/dp/B000WDZH58 | http://www.amazon.co.uk/Hornby-R044-Passing-Contact-Switch/dp/B000H5V0RK | http://www.amazon.co.uk/Hornby-Gauge-Logan-Plank-Wagon/dp/B00SWV6RAG", + "https://www.appsmith.com/Hornby-R8221-Gauge-Track-Extension/dp/B000PVFYZ0 | https://www.appsmith.com/Hornby-R8222-Gauge-Track-Extension/dp/B000RK3FZK | https://www.appsmith.com/Hornby-R6368-RailRoad-Gauge-Brake/dp/B000WDWT22 | https://www.appsmith.com/Hornby-R6370-RailRoad-Tredegar-Gauge/dp/B000WDZH58 | https://www.appsmith.com/Hornby-R044-Passing-Contact-Switch/dp/B000H5V0RK | https://www.appsmith.com/Hornby-Gauge-Logan-Plank-Wagon/dp/B00SWV6RAG", }, { rowIndex: "8", @@ -168,7 +168,7 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Hornby-Western-Master-E-Link-Electric/dp/B00BUKPXS8 | http://www.amazon.co.uk/Hornby-Gloucester | http://www.amazon.co.uk/Hornby-Majestic-E-Link-Gauge-Electric/dp/B00BUKPXU6 | http://www.amazon.co.uk/Hornby-Gauge-Master-Glens/dp/B00TQNJIIW | http://www.amazon.co.uk/Hornby-Gauge-Eurostar-2014-Train/dp/B00TQNJIIC | http://www.amazon.co.uk/HORNBY-Digital-Train-Layout-Track/dp/B006BRH55Y", + "https://www.appsmith.com/Hornby-Western-Master-E-Link-Electric/dp/B00BUKPXS8 | https://www.appsmith.com/Hornby-Gloucester | https://www.appsmith.com/Hornby-Majestic-E-Link-Gauge-Electric/dp/B00BUKPXU6 | https://www.appsmith.com/Hornby-Gauge-Master-Glens/dp/B00TQNJIIW | https://www.appsmith.com/Hornby-Gauge-Eurostar-2014-Train/dp/B00TQNJIIC | https://www.appsmith.com/HORNBY-Digital-Train-Layout-Track/dp/B006BRH55Y", }, { rowIndex: "9", @@ -187,6 +187,6 @@ export const GSHEET_DATA = [ amazon_category_and_sub_category: "Hobbies > Model Trains & Railway Sets > Rail Vehicles > Trains", customers_who_bought_this_item_also_bought: - "http://www.amazon.co.uk/Learning-Curve-Chuggington | http://www.amazon.co.uk/Chuggington | http://www.amazon.co.uk/Learning-Curve-Chuggington | http://www.amazon.co.uk/Learning-Chuggington", + "https://www.appsmith.com/Learning-Curve-Chuggington | https://www.appsmith.com/Chuggington | https://www.appsmith.com/Learning-Curve-Chuggington | https://www.appsmith.com/Learning-Chuggington", }, ]; diff --git a/app/client/cypress/fixtures/testdata.json b/app/client/cypress/fixtures/testdata.json index ec1d74fc67c..313ad425fe2 100644 --- a/app/client/cypress/fixtures/testdata.json +++ b/app/client/cypress/fixtures/testdata.json @@ -166,5 +166,5 @@ "APPURL": "http://localhost:8081/app/app1/page1-63d38854252ca15b7ec9fabb", "iframeUrl": "https://elfsight.com/social-feed-widget/iframe/", "iframeUrlSubstring": "https://elfsight.com/", - "iframeRandomUrl": "https://www.google.com" + "iframeRandomUrl": "https://www.appsmith.com/" } diff --git a/app/client/cypress/fixtures/viewdsl.json b/app/client/cypress/fixtures/viewdsl.json index 0d1428446d6..281881c9918 100644 --- a/app/client/cypress/fixtures/viewdsl.json +++ b/app/client/cypress/fixtures/viewdsl.json @@ -72,7 +72,7 @@ "isVisible": true, "defaultImage": "https://www.cowgirlcontractcleaning.com/wp-content/uploads/sites/360/2018/05/placeholder-img-5.jpg", "imageShape": "RECTANGLE", - "image": "https://images.pexels.com/photos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940hotos/60597/dahlia-red-blossom-bloom-60597.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940", + "image": "http://host.docker.internal:4200/453-200x300.jpg", "widgetName": "Image1", "type": "IMAGE_WIDGET", "isLoading": false, diff --git a/app/client/cypress/fixtures/widgetSelection.json b/app/client/cypress/fixtures/widgetSelection.json index a584ad7ad6b..d44cd99b999 100644 --- a/app/client/cypress/fixtures/widgetSelection.json +++ b/app/client/cypress/fixtures/widgetSelection.json @@ -194,7 +194,7 @@ "imageShape": "RECTANGLE", "leftColumn": 6, "borderRadius": "0px", - "defaultImage": "https://res.cloudinary.com/drako999/image/upload/v1589196259/default.png" + "defaultImage": "http://host.docker.internal:4200/clouddefaultImage.png" }, { "labelTextSize": "0.875rem", diff --git a/app/client/cypress/support/Pages/Anvil/Locators/index.ts b/app/client/cypress/support/Pages/Anvil/Locators/index.ts index 21bf736b713..76f837e73c7 100644 --- a/app/client/cypress/support/Pages/Anvil/Locators/index.ts +++ b/app/client/cypress/support/Pages/Anvil/Locators/index.ts @@ -1,6 +1,6 @@ import { MAIN_CONTAINER_WIDGET_ID } from "../../../../../src/constants/WidgetConstants"; import { getAnvilCanvasId } from "../../../../../src/layoutSystems/anvil/viewer/canvas/utils"; -import { AnvilDataAttributes } from "../../../../../src/widgets/wds/constants"; +import { AnvilDataAttributes } from "../../../../../src/modules/ui-builder/ui/wds/constants"; // anvil widget based selectors const anvilWidgetSelector = "[data-testid=t--anvil-widget-wrapper]"; diff --git a/app/client/cypress/support/Pages/GitSync.ts b/app/client/cypress/support/Pages/GitSync.ts index 2fbf3b139a6..1aa7589ba7c 100644 --- a/app/client/cypress/support/Pages/GitSync.ts +++ b/app/client/cypress/support/Pages/GitSync.ts @@ -1,5 +1,5 @@ import { ObjectsRegistry } from "../Objects/Registry"; -const GITHUB_API_BASE = "https://api.github.com"; + //const GITEA_API_BASE = "http://35.154.225.218"; export class GitSync { public agHelper = ObjectsRegistry.AggregateHelper; diff --git a/app/client/packages/utils/src/compose/compose.ts b/app/client/packages/utils/src/compose/compose.ts new file mode 100644 index 00000000000..3fd17574c16 --- /dev/null +++ b/app/client/packages/utils/src/compose/compose.ts @@ -0,0 +1,4 @@ +export const compose = + (...fns: Array<(arg: T) => T>) => + (x: T) => + fns.reduce((acc, fn) => fn(acc), x); diff --git a/app/client/packages/utils/src/compose/index.ts b/app/client/packages/utils/src/compose/index.ts new file mode 100644 index 00000000000..cbcc7441207 --- /dev/null +++ b/app/client/packages/utils/src/compose/index.ts @@ -0,0 +1 @@ +export { compose } from "./compose"; diff --git a/app/client/packages/utils/src/index.ts b/app/client/packages/utils/src/index.ts index 7ea2e7134f2..442a65511ef 100644 --- a/app/client/packages/utils/src/index.ts +++ b/app/client/packages/utils/src/index.ts @@ -1 +1,2 @@ export * from "./object"; +export * from "./compose"; diff --git a/app/client/src/PluginActionEditor/PluginActionContext.tsx b/app/client/src/PluginActionEditor/PluginActionContext.tsx index 670efc34811..42c0d4e6745 100644 --- a/app/client/src/PluginActionEditor/PluginActionContext.tsx +++ b/app/client/src/PluginActionEditor/PluginActionContext.tsx @@ -6,14 +6,16 @@ import React, { } from "react"; import type { Action } from "entities/Action"; import type { Plugin } from "api/PluginApi"; -import type { Datasource } from "entities/Datasource"; +import type { Datasource, EmbeddedRestDatasource } from "entities/Datasource"; +import type { ActionResponse } from "api/ActionAPI"; interface PluginActionContextType { action: Action; + actionResponse?: ActionResponse; editorConfig: unknown[]; settingsConfig: unknown[]; plugin: Plugin; - datasource?: Datasource; + datasource?: EmbeddedRestDatasource | Datasource; } // No need to export this context to use it. Use the hook defined below instead diff --git a/app/client/src/PluginActionEditor/PluginActionEditor.tsx b/app/client/src/PluginActionEditor/PluginActionEditor.tsx index 5ffa8a4d777..8eaa3bc51ba 100644 --- a/app/client/src/PluginActionEditor/PluginActionEditor.tsx +++ b/app/client/src/PluginActionEditor/PluginActionEditor.tsx @@ -4,6 +4,7 @@ import { identifyEntityFromPath } from "../navigation/FocusEntity"; import { useSelector } from "react-redux"; import { getActionByBaseId, + getActionResponses, getDatasource, getEditorConfig, getPlugin, @@ -39,6 +40,8 @@ const PluginActionEditor = (props: ChildrenProps) => { const editorConfig = useSelector((state) => getEditorConfig(state, pluginId)); + const actionResponses = useSelector(getActionResponses); + if (!isEditorInitialized) { return ( @@ -71,9 +74,12 @@ const PluginActionEditor = (props: ChildrenProps) => { ); } + const actionResponse = actionResponses[action.id]; + return ( { /> } formName={FORM_NAME} - headersCount={0} httpMethodOptions={HTTP_METHOD_OPTIONS} isChangePermitted={isChangePermitted} paginationUiComponent={ @@ -45,7 +44,6 @@ const APIEditorForm = () => { theme={theme} /> } - paramsCount={0} /> ); }; diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/CommonEditorForm.tsx b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/CommonEditorForm.tsx index 881fdc56147..a9ae550c0ec 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/CommonEditorForm.tsx +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/CommonEditorForm.tsx @@ -1,11 +1,11 @@ import React from "react"; import { type Action } from "entities/Action"; import { EditorTheme } from "components/editorComponents/CodeEditor/EditorConfig"; -import type { AutoGeneratedHeader } from "pages/Editor/APIEditor/helpers"; import { InfoFields } from "./InfoFields"; import { RequestTabs } from "./RequestTabs"; import { HintMessages } from "./HintMessages"; import { Flex } from "@appsmith/ads"; +import useGetFormActionValues from "./hooks/useGetFormActionValues"; interface Props { httpMethodOptions: { value: string }[]; @@ -14,27 +14,19 @@ interface Props { isChangePermitted: boolean; bodyUIComponent: React.ReactNode; paginationUiComponent: React.ReactNode; - headersCount: number; - paramsCount: number; - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - datasourceHeaders?: any; - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - datasourceParams?: any; - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - actionConfigurationHeaders?: any; - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - actionConfigurationParams?: any; - autoGeneratedActionConfigHeaders?: AutoGeneratedHeader[]; } const CommonEditorForm = (props: Props) => { const { action } = props; const hintMessages = action.messages || []; const theme = EditorTheme.LIGHT; + const { + actionHeaders, + actionParams, + autoGeneratedHeaders, + datasourceHeaders, + datasourceParams, + } = useGetFormActionValues(); return ( @@ -48,17 +40,15 @@ const CommonEditorForm = (props: Props) => { /> - {Object.values(API_EDITOR_TABS).map((tab) => ( - - {createMessage(API_EDITOR_TAB_TITLES[tab])} - - ))} + {Object.values(API_EDITOR_TABS) + .filter((tab) => { + return !(!props.showSettings && tab === API_EDITOR_TABS.SETTINGS); + }) + .map((tab) => ( + + {createMessage(API_EDITOR_TAB_TITLES[tab])} + + ))} diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/components/DatasourceConfig.tsx b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/components/DatasourceConfig.tsx index a6b89e29191..549112e7f4d 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/components/DatasourceConfig.tsx +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/components/DatasourceConfig.tsx @@ -1,6 +1,6 @@ import styled from "styled-components"; -import FormRow from "../../../../../../components/editorComponents/FormRow"; -import FormLabel from "../../../../../../components/editorComponents/FormLabel"; +import FormRow from "components/editorComponents/FormRow"; +import FormLabel from "components/editorComponents/FormLabel"; import { Button, Icon, Text, Tooltip } from "@appsmith/ads"; import { API_PANE_AUTO_GENERATED_HEADER, diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useGetFormActionValues.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useGetFormActionValues.ts new file mode 100644 index 00000000000..1078d18282d --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useGetFormActionValues.ts @@ -0,0 +1,78 @@ +import { getFormValues } from "redux-form"; +import { API_EDITOR_FORM_NAME } from "ee/constants/forms"; +import { getCurrentEnvironmentId } from "ee/selectors/environmentSelectors"; +import get from "lodash/get"; +import { useSelector } from "react-redux"; +import { + type Action, + type ApiAction, + isAPIAction, + type Property, +} from "entities/Action"; +import { getDatasources } from "ee/selectors/entitiesSelector"; + +function useGetFormActionValues() { + const formValues = useSelector(getFormValues(API_EDITOR_FORM_NAME)) as Action; + const datasources = useSelector(getDatasources); + const currentEnvironment = useSelector(getCurrentEnvironmentId); + + // In an unlikely scenario where form is not initialised, + // return empty values to avoid form ui issues + if (!isAPIAction(formValues)) { + return { + actionHeaders: [], + actionParams: [], + autoGeneratedHeaders: [], + datasourceParams: [], + datasourceHeaders: [], + }; + } + + const actionHeaders = get( + formValues, + "actionConfiguration.headers", + [], + ) as Property[]; + + const autoGeneratedHeaders: ApiAction["actionConfiguration"]["autoGeneratedHeaders"] = + get(formValues, "actionConfiguration.autoGeneratedHeaders", []); + + const actionParams = get( + formValues, + "actionConfiguration.queryParameters", + [], + ) as Property[]; + + let datasourceFromAction: Action["datasource"] | undefined = get( + formValues, + "datasource", + ); + + if (datasourceFromAction && Object.hasOwn(datasourceFromAction, "id")) { + datasourceFromAction = datasources.find( + (d) => d.id === datasourceFromAction?.id, + ); + } + + const datasourceHeaders = get( + datasourceFromAction, + `datasourceStorages.${currentEnvironment}.datasourceConfiguration.headers`, + [], + ) as Property[]; + + const datasourceParams = get( + datasourceFromAction, + `datasourceStorages.${currentEnvironment}.datasourceConfiguration.queryParameters`, + [], + ) as Property[]; + + return { + actionHeaders, + autoGeneratedHeaders, + actionParams, + datasourceHeaders, + datasourceParams, + }; +} + +export default useGetFormActionValues; diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getHeadersCount.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getHeadersCount.ts new file mode 100644 index 00000000000..a0b124525b4 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getHeadersCount.ts @@ -0,0 +1,22 @@ +import getValidProperties from "./getValidProperties"; +import type { Property } from "entities/Action"; + +function getHeadersCount( + actionHeaders?: Property[], + datasourceHeaders?: Property[], + autoGeneratedActionHeaders?: Property[], +): number { + const validActionHeaders = getValidProperties(actionHeaders); + const validDatasourceHeaders = getValidProperties(datasourceHeaders); + const validAutoGeneratedHeaders = getValidProperties( + autoGeneratedActionHeaders, + ); + + return ( + validActionHeaders.length + + validDatasourceHeaders.length + + validAutoGeneratedHeaders.length + ); +} + +export default getHeadersCount; diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getParamsCount.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getParamsCount.ts new file mode 100644 index 00000000000..3d91bf946cf --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getParamsCount.ts @@ -0,0 +1,14 @@ +import type { Property } from "entities/Action"; +import getValidProperties from "./getValidProperties"; + +function getParamsCount( + actionParams?: Property[], + datasourceParams?: Property[], +) { + const validActionParams = getValidProperties(actionParams); + const validDatasourceParams = getValidProperties(datasourceParams); + + return validActionParams.length + validDatasourceParams.length; +} + +export default getParamsCount; diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getValidProperties.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getValidProperties.ts new file mode 100644 index 00000000000..a2822433bd9 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/getValidProperties.ts @@ -0,0 +1,11 @@ +import type { Property } from "entities/Action"; + +function getValidProperties(value?: Property[]) { + if (!Array.isArray(value)) { + return []; + } + + return value.filter((v) => v.key && v.key !== ""); +} + +export default getValidProperties; diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/index.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/index.ts new file mode 100644 index 00000000000..76d68357ccc --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/utils/index.ts @@ -0,0 +1,2 @@ +export { default as getHeadersCount } from "./getHeadersCount"; +export { default as getParamsCount } from "./getParamsCount"; diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx index c7af1a52bbb..98c144af91a 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx @@ -4,6 +4,7 @@ import { PluginType } from "entities/Action"; import { usePluginActionContext } from "PluginActionEditor"; import { changeApi } from "actions/apiPaneActions"; import { changeQuery } from "actions/queryPaneActions"; +import usePrevious from "utils/hooks/usePrevious"; import { useChangeActionCall } from "./useChangeActionCall"; jest.mock("react-redux", () => ({ @@ -22,6 +23,8 @@ jest.mock("PluginActionEditor", () => ({ usePluginActionContext: jest.fn(), })); +jest.mock("utils/hooks/usePrevious", () => jest.fn()); + describe("useChangeActionCall hook", () => { const dispatchMock = jest.fn(); @@ -105,4 +108,36 @@ describe("useChangeActionCall hook", () => { // Expect no action to be dispatched expect(dispatchMock).not.toHaveBeenCalled(); }); + + it("should not dispatch any action if the action Id has not changed", () => { + const actionMock = { id: "actionId" }; + const pluginMock = { id: "pluginId", type: PluginType.API }; + + // First we mount, so it should be called as previous action id was undefined + (usePluginActionContext as jest.Mock).mockReturnValueOnce({ + action: actionMock, + plugin: pluginMock, + }); + (usePrevious as jest.Mock).mockReturnValueOnce(undefined); + renderHook(() => useChangeActionCall()); + expect(changeApi).toHaveBeenCalledTimes(1); + + // Now we mock the action object to change but not the id. It should not be called again + (usePluginActionContext as jest.Mock).mockReturnValueOnce({ + action: { ...actionMock, testId: "test" }, + plugin: pluginMock, + }); + (usePrevious as jest.Mock).mockReturnValueOnce("actionId"); + renderHook(() => useChangeActionCall()); + expect(changeApi).toHaveBeenCalledTimes(1); + + // Now we change the action id, so it will be called the second time + (usePluginActionContext as jest.Mock).mockReturnValueOnce({ + action: { id: "actionId2", testId: "test" }, + plugin: pluginMock, + }); + (usePrevious as jest.Mock).mockReturnValueOnce("actionId"); + renderHook(() => useChangeActionCall()); + expect(changeApi).toHaveBeenCalledTimes(2); + }); }); diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts index 562bbad8679..88a56e14d90 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts @@ -4,14 +4,18 @@ import { changeApi } from "actions/apiPaneActions"; import { changeQuery } from "actions/queryPaneActions"; import { PluginType } from "entities/Action"; import { usePluginActionContext } from "PluginActionEditor"; +import usePrevious from "utils/hooks/usePrevious"; export const useChangeActionCall = () => { const { action, plugin } = usePluginActionContext(); + const prevActionId = usePrevious(action.id); const dispatch = useDispatch(); useEffect(() => { if (!plugin?.id || !action) return; + if (prevActionId === action.id) return; + switch (plugin?.type) { case PluginType.API: dispatch(changeApi(action?.id, false)); @@ -29,5 +33,5 @@ export const useChangeActionCall = () => { ); break; } - }, [action, plugin, dispatch]); + }, [action, plugin, dispatch, prevActionId]); }; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx new file mode 100644 index 00000000000..f20a395d4cb --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx @@ -0,0 +1,67 @@ +import React, { useCallback } from "react"; +import { IDEBottomView, ViewHideBehaviour } from "IDE"; +import { ActionExecutionResizerHeight } from "pages/Editor/APIEditor/constants"; +import EntityBottomTabs from "components/editorComponents/EntityBottomTabs"; +import { useDispatch, useSelector } from "react-redux"; +import { getApiPaneDebuggerState } from "selectors/apiPaneSelectors"; +import { setApiPaneDebuggerState } from "actions/apiPaneActions"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import AnalyticsUtil from "ee/utils/AnalyticsUtil"; +import { usePluginActionResponseTabs } from "./hooks"; + +function PluginActionResponse() { + const dispatch = useDispatch(); + + const tabs = usePluginActionResponseTabs(); + + // TODO combine API and Query Debugger state + const { open, responseTabHeight, selectedTab } = useSelector( + getApiPaneDebuggerState, + ); + + const toggleHide = useCallback( + () => dispatch(setApiPaneDebuggerState({ open: !open })), + [dispatch, open], + ); + + const updateSelectedResponseTab = useCallback( + (tabKey: string) => { + if (tabKey === DEBUGGER_TAB_KEYS.ERROR_TAB) { + AnalyticsUtil.logEvent("OPEN_DEBUGGER", { + source: "API_PANE", + }); + } + + dispatch(setApiPaneDebuggerState({ open: true, selectedTab: tabKey })); + }, + [dispatch], + ); + + const updateResponsePaneHeight = useCallback( + (height: number) => { + dispatch(setApiPaneDebuggerState({ responseTabHeight: height })); + }, + [dispatch], + ); + + return ( + + ); +} + +export default PluginActionResponse; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiFormatSegmentedResponse.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiFormatSegmentedResponse.tsx new file mode 100644 index 00000000000..4fe9f53b905 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiFormatSegmentedResponse.tsx @@ -0,0 +1,126 @@ +import React, { useCallback, useMemo, useState } from "react"; +import { isArray, isString } from "lodash"; +import { isHtml } from "../utils"; +import ReadOnlyEditor from "components/editorComponents/ReadOnlyEditor"; +import { SegmentedControlContainer } from "pages/Editor/QueryEditor/EditorJSONtoForm"; +import { Flex, SegmentedControl } from "@appsmith/ads"; +import type { ActionResponse } from "api/ActionAPI"; +import { setActionResponseDisplayFormat } from "actions/pluginActionActions"; +import { actionResponseDisplayDataFormats } from "pages/Editor/utils"; +import { ResponseDisplayFormats } from "constants/ApiEditorConstants/CommonApiConstants"; +import { useDispatch } from "react-redux"; +import styled from "styled-components"; +import { ResponseFormatTabs } from "./ResponseFormatTabs"; + +const ResponseBodyContainer = styled.div` + overflow-y: clip; + height: 100%; + display: grid; +`; + +function ApiFormatSegmentedResponse(props: { + actionResponse: ActionResponse; + actionId: string; + responseTabHeight: number; +}) { + const dispatch = useDispatch(); + const onResponseTabSelect = useCallback( + (tab: string) => { + dispatch( + setActionResponseDisplayFormat({ + id: props.actionId, + field: "responseDisplayFormat", + value: tab, + }), + ); + }, + [dispatch, props.actionId], + ); + + const { responseDataTypes, responseDisplayFormat } = + actionResponseDisplayDataFormats(props.actionResponse); + + let filteredResponseDataTypes: { key: string; title: string }[] = [ + ...responseDataTypes, + ]; + + if (!!props.actionResponse.body && !isArray(props.actionResponse.body)) { + filteredResponseDataTypes = responseDataTypes.filter( + (item) => item.key !== ResponseDisplayFormats.TABLE, + ); + + if (responseDisplayFormat.title === ResponseDisplayFormats.TABLE) { + onResponseTabSelect(filteredResponseDataTypes[0]?.title); + } + } + + const responseTabs = filteredResponseDataTypes?.map((dataType, index) => ({ + index: index, + key: dataType.key, + title: dataType.title, + panelComponent: ( + []} + responseType={dataType.key} + tableBodyHeight={props.responseTabHeight} + /> + ), + })); + + const segmentedControlOptions = responseTabs?.map((item) => ({ + value: item.key, + label: item.title, + })); + + const onChange = useCallback( + (value: string) => { + setSelectedControl(value); + onResponseTabSelect(value); + }, + [onResponseTabSelect], + ); + + const [selectedControl, setSelectedControl] = useState( + segmentedControlOptions[0]?.value, + ); + + const selectedTabIndex = filteredResponseDataTypes?.findIndex( + (dataType) => dataType.title === responseDisplayFormat?.title, + ); + + const value = useMemo( + () => ({ value: props.actionResponse.body as string }), + [props.actionResponse.body], + ); + + return ( + + {isString(props.actionResponse?.body) && + isHtml(props.actionResponse?.body) ? ( + + ) : responseTabs && responseTabs.length > 0 && selectedTabIndex !== -1 ? ( + + + + + [] + } + responseType={selectedControl || segmentedControlOptions[0]?.value} + tableBodyHeight={props.responseTabHeight} + /> + + ) : null} + + ); +} + +export default ApiFormatSegmentedResponse; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiResponse.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiResponse.tsx new file mode 100644 index 00000000000..bb32f43ad19 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiResponse.tsx @@ -0,0 +1,170 @@ +import React, { useMemo } from "react"; +import ReactJson from "react-json-view"; +import { isEmpty, noop } from "lodash"; +import styled from "styled-components"; +import { Callout, Flex } from "@appsmith/ads"; +import { + JsonWrapper, + reactJsonProps, +} from "components/editorComponents/Debugger/ErrorLogs/components/LogCollapseData"; +import type { ActionResponse } from "api/ActionAPI"; +import type { EditorTheme } from "components/editorComponents/CodeEditor/EditorConfig"; +import type { SourceEntity } from "entities/AppsmithConsole"; +import ApiResponseMeta from "components/editorComponents/ApiResponseMeta"; +import ActionExecutionInProgressView from "components/editorComponents/ActionExecutionInProgressView"; +import LogAdditionalInfo from "components/editorComponents/Debugger/ErrorLogs/components/LogAdditionalInfo"; +import LogHelper from "components/editorComponents/Debugger/ErrorLogs/components/LogHelper"; +import LOG_TYPE from "entities/AppsmithConsole/logtype"; +import { type Action } from "entities/Action"; +import { hasFailed } from "../utils"; +import { getUpdateTimestamp } from "components/editorComponents/Debugger/ErrorLogs/ErrorLogItem"; +import { ENTITY_TYPE } from "ee/entities/AppsmithConsole/utils"; +import ApiFormatSegmentedResponse from "./ApiFormatSegmentedResponse"; +import { NoResponse } from "./NoResponse"; + +const HelpSection = styled.div` + padding-bottom: 5px; + padding-top: 10px; +`; + +const ResponseDataContainer = styled.div` + flex: 1; + overflow: auto; + display: flex; + flex-direction: column; + + & .CodeEditorTarget { + overflow: hidden; + } +`; + +export const ResponseTabErrorContainer = styled.div` + display: flex; + flex-direction: column; + padding: 8px 16px; + gap: 8px; + height: fit-content; + background: var(--ads-v2-color-bg-error); + border-bottom: 1px solid var(--ads-v2-color-border); +`; + +export const ResponseTabErrorContent = styled.div` + display: flex; + align-items: flex-start; + gap: 4px; + font-size: 12px; + line-height: 16px; +`; + +export const ResponseTabErrorDefaultMessage = styled.div` + flex-shrink: 0; +`; + +export const apiReactJsonProps = { ...reactJsonProps, collapsed: 0 }; + +export function ApiResponse(props: { + action: Action; + actionResponse?: ActionResponse; + isRunning: boolean; + isRunDisabled: boolean; + theme: EditorTheme; + onRunClick: () => void; + responseTabHeight: number; +}) { + const { id, name } = props.action; + const actionSource: SourceEntity = useMemo( + () => ({ + type: ENTITY_TYPE.ACTION, + name, + id, + }), + [name, id], + ); + + if (!props.actionResponse) { + return ( + + + + ); + } + + const { messages, pluginErrorDetails, request } = props.actionResponse; + + const runHasFailed = hasFailed(props.actionResponse); + const requestWithTimestamp = getUpdateTimestamp(request); + + return ( + + + {Array.isArray(messages) && messages.length > 0 && ( + + {messages.map((message, i) => ( + + {message} + + ))} + + )} + {props.isRunning && ( + + )} + {runHasFailed && !props.isRunning ? ( + + + + Your API failed to execute + {pluginErrorDetails && ":"} + + {pluginErrorDetails && ( + <> +
+ {pluginErrorDetails.downstreamErrorMessage} +
+ {pluginErrorDetails.downstreamErrorCode && ( + + )} + + )} + +
+ {requestWithTimestamp && ( + + + + )} +
+ ) : ( + + {isEmpty(props.actionResponse.statusCode) ? ( + + ) : ( + + )} + + )} +
+ ); +} diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiResponseHeaders.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiResponseHeaders.tsx new file mode 100644 index 00000000000..7f055d5bc4f --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ApiResponseHeaders.tsx @@ -0,0 +1,111 @@ +import React, { useMemo } from "react"; +import type { ActionResponse } from "api/ActionAPI"; +import { Callout, Flex } from "@appsmith/ads"; +import { CHECK_REQUEST_BODY, createMessage } from "ee/constants/messages"; +import { isArray, isEmpty } from "lodash"; +import ReadOnlyEditor from "components/editorComponents/ReadOnlyEditor"; +import { hasFailed } from "../utils"; +import styled from "styled-components"; +import { NoResponse } from "./NoResponse"; + +const ResponseDataContainer = styled.div` + flex: 1; + overflow: auto; + display: flex; + flex-direction: column; + + & .CodeEditorTarget { + overflow: hidden; + } +`; + +const headersTransformer = (headers: Record = {}) => { + let responseHeaders = {}; + + // if no headers are present in the response, use the default body text. + if (headers) { + Object.entries(headers).forEach(([key, value]) => { + if (isArray(value) && value.length < 2) { + responseHeaders = { + ...responseHeaders, + [key]: value[0], + }; + + return; + } + + responseHeaders = { + ...responseHeaders, + [key]: value, + }; + }); + } + + return responseHeaders; +}; + +export function ApiResponseHeaders(props: { + isRunning: boolean; + onDebugClick: () => void; + actionResponse?: ActionResponse; + isRunDisabled: boolean; + onRunClick: () => void; +}) { + const responseHeaders = useMemo(() => { + return headersTransformer(props.actionResponse?.headers); + }, [props.actionResponse?.headers]); + + const errorCalloutLinks = useMemo(() => { + return [ + { + children: "Debug", + endIcon: "bug", + onClick: props.onDebugClick, + to: "", + }, + ]; + }, [props.onDebugClick]); + + const headersInput = useMemo(() => { + return { + value: !isEmpty(responseHeaders) + ? JSON.stringify(responseHeaders, null, 2) + : "", + }; + }, [responseHeaders]); + + if (!props.actionResponse) { + return ( + + + + ); + } + + const runHasFailed = hasFailed(props.actionResponse); + + return ( + + {runHasFailed && !props.isRunning && ( + + {createMessage(CHECK_REQUEST_BODY)} + + )} + + {isEmpty(props.actionResponse.statusCode) ? ( + + ) : ( + + )} + + + ); +} diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/components/NoResponse.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/NoResponse.tsx new file mode 100644 index 00000000000..a133ec66556 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/NoResponse.tsx @@ -0,0 +1,65 @@ +import NoResponseSVG from "assets/images/no-response.svg"; +import { Classes, Text, TextType } from "@appsmith/ads-old"; +import { + EMPTY_RESPONSE_FIRST_HALF, + EMPTY_RESPONSE_LAST_HALF, +} from "ee/constants/messages"; +import { Button } from "@appsmith/ads"; +import React from "react"; +import styled from "styled-components"; + +const StyledText = styled(Text)` + &&&& { + margin-top: 0; + } +`; + +const NoResponseContainer = styled.div` + flex: 1; + width: 100%; + display: flex; + align-items: center; + justify-content: center; + flex-direction: column; + + .${Classes.ICON} { + margin-right: 0; + + svg { + width: 150px; + height: 150px; + } + } + + .${Classes.TEXT} { + margin-top: ${(props) => props.theme.spaces[9]}px; + } +`; + +interface NoResponseProps { + isRunDisabled: boolean; + isRunning: boolean; + onRunClick: () => void; +} + +export const NoResponse = ({ + isRunDisabled, + isRunning, + onRunClick, +}: NoResponseProps) => ( + + no-response-yet +
+ {EMPTY_RESPONSE_FIRST_HALF()} + + {EMPTY_RESPONSE_LAST_HALF()} +
+
+); diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ResponseFormatTabs.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ResponseFormatTabs.tsx new file mode 100644 index 00000000000..eb8dec8a7bf --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/components/ResponseFormatTabs.tsx @@ -0,0 +1,63 @@ +import React from "react"; +import { ResponseDisplayFormats } from "constants/ApiEditorConstants/CommonApiConstants"; +import ReadOnlyEditor from "components/editorComponents/ReadOnlyEditor"; +import { isString } from "lodash"; +import Table from "pages/Editor/QueryEditor/Table"; + +type ResponseData = string | Record[]; + +const inputValue = (data: ResponseData) => { + return { + value: isString(data) ? data : JSON.stringify(data, null, 2), + }; +}; + +const tableValue = (data: ResponseData): Record[] => { + if (isString(data)) { + return [{}]; + } + + return data; +}; + +export const ResponseFormatTabs = (props: { + responseType: string; + data: ResponseData; + tableBodyHeight?: number; +}) => { + switch (props.responseType) { + case ResponseDisplayFormats.JSON: + return ( + + ); + case ResponseDisplayFormats.TABLE: + return ( + + ); + case ResponseDisplayFormats.RAW: + return ( + + ); + default: + return ( + + ); + } +}; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/hooks/index.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/hooks/index.ts new file mode 100644 index 00000000000..2ae6129b3bc --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/hooks/index.ts @@ -0,0 +1 @@ +export { default as usePluginActionResponseTabs } from "ee/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs"; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/index.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/index.ts new file mode 100644 index 00000000000..34d4978ec70 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/index.ts @@ -0,0 +1 @@ +export { default } from "./PluginActionResponse"; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/actionHasFailed.test.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/actionHasFailed.test.ts new file mode 100644 index 00000000000..d28645ec5bc --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/actionHasFailed.test.ts @@ -0,0 +1,30 @@ +import actionHasFailed from "./actionHasFailed"; +import type { ActionResponse } from "api/ActionAPI"; + +describe("actionHasFailed", () => { + it("Should only check the status code", () => { + const input: ActionResponse = { + body: "Success", + dataTypes: [], + duration: "200", + headers: {}, + size: "200", + statusCode: "404", + }; + + expect(actionHasFailed(input)).toBe(true); + }); + + it("Checks the 200 series of status code", () => { + const input: ActionResponse = { + body: "Success", + dataTypes: [], + duration: "200", + headers: {}, + size: "200", + statusCode: "201", + }; + + expect(actionHasFailed(input)).toBe(false); + }); +}); diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/actionHasFailed.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/actionHasFailed.ts new file mode 100644 index 00000000000..6352a8a0961 --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/actionHasFailed.ts @@ -0,0 +1,9 @@ +import type { ActionResponse } from "api/ActionAPI"; + +function hasFailed(actionResponse: ActionResponse) { + return actionResponse.statusCode + ? actionResponse.statusCode[0] !== "2" + : false; +} + +export default hasFailed; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/index.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/index.ts new file mode 100644 index 00000000000..62ec8938b3e --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/index.ts @@ -0,0 +1,2 @@ +export { default as hasFailed } from "./actionHasFailed"; +export { default as isHtml } from "./isHtml"; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/isHtml.test.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/isHtml.test.ts new file mode 100644 index 00000000000..6e014afafee --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/isHtml.test.ts @@ -0,0 +1,39 @@ +import { isHtml } from "./index"; + +describe("isHtml", () => { + it("returns false for empty string", () => { + const input = ""; + + expect(isHtml(input)).toBe(false); + }); + + it("returns false for JSON", () => { + const input = `{"name": "test"}`; + + expect(isHtml(input)).toBe(false); + }); + + it("returns false for string", () => { + const input = "An error string returned"; + + expect(isHtml(input)).toBe(false); + }); + + it("returns false for invalid html", () => { + const input = " { + const input = "

This is incomplete"; + + expect(isHtml(input)).toBe(true); + }); + + it("returns true for HTML", () => { + const input = "

This is a html response

"; + + expect(isHtml(input)).toBe(true); + }); +}); diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/isHtml.ts b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/isHtml.ts new file mode 100644 index 00000000000..551f1d66bfd --- /dev/null +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/utils/isHtml.ts @@ -0,0 +1,25 @@ +import log from "loglevel"; + +const isHtml = (str: string): boolean => { + try { + const doc = new DOMParser().parseFromString(str, "text/html"); + + // Check for parsing errors + const parseError = doc.querySelector("parsererror"); + + if (parseError) { + return false; + } + + // Check for at least one element node in the body + return Array.from(doc.body.childNodes).some( + (node: ChildNode) => node.nodeType === 1, + ); + } catch (error) { + log.error("Error parsing HTML:", error); + + return false; + } +}; + +export default isHtml; diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponsePane.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponsePane.tsx deleted file mode 100644 index 5a0be861970..00000000000 --- a/app/client/src/PluginActionEditor/components/PluginActionResponsePane.tsx +++ /dev/null @@ -1,7 +0,0 @@ -import React from "react"; - -const PluginActionResponsePane = () => { - return
; -}; - -export default PluginActionResponsePane; diff --git a/app/client/src/PluginActionEditor/index.ts b/app/client/src/PluginActionEditor/index.ts index 0a58d00bdaa..20265c8bc5a 100644 --- a/app/client/src/PluginActionEditor/index.ts +++ b/app/client/src/PluginActionEditor/index.ts @@ -5,4 +5,4 @@ export { } from "./PluginActionContext"; export { default as PluginActionToolbar } from "./components/PluginActionToolbar"; export { default as PluginActionForm } from "./components/PluginActionForm"; -export { default as PluginActionResponsePane } from "./components/PluginActionResponsePane"; +export { default as PluginActionResponse } from "./components/PluginActionResponse"; diff --git a/app/client/src/WidgetProvider/factory/helpers.ts b/app/client/src/WidgetProvider/factory/helpers.ts index 50cc4166a25..28731d7bc97 100644 --- a/app/client/src/WidgetProvider/factory/helpers.ts +++ b/app/client/src/WidgetProvider/factory/helpers.ts @@ -17,7 +17,7 @@ import { WidgetFeaturePropertyPaneEnhancements, } from "../../utils/WidgetFeatures"; import { generateReactKey } from "utils/generators"; -import { DEFAULT_WIDGET_ON_CANVAS_UI } from "widgets/wds/constants"; +import { DEFAULT_WIDGET_ON_CANVAS_UI } from "modules/ui-builder/ui/wds/constants"; import type { WidgetDefaultProps } from "WidgetProvider/constants"; export enum PropertyPaneConfigTypes { diff --git a/app/client/src/api/Api.ts b/app/client/src/api/Api.ts index 206f38a1f55..1eff364c4d0 100644 --- a/app/client/src/api/Api.ts +++ b/app/client/src/api/Api.ts @@ -1,15 +1,13 @@ -import type { AxiosInstance, AxiosRequestConfig } from "axios"; import axios from "axios"; -import { REQUEST_TIMEOUT_MS } from "ee/constants/ApiConstants"; -import { convertObjectToQueryParams } from "utils/URLUtils"; +import type { AxiosInstance, AxiosRequestConfig } from "axios"; import { - apiFailureResponseInterceptor, apiRequestInterceptor, + apiFailureResponseInterceptor, apiSuccessResponseInterceptor, - blockedApiRoutesForAirgapInterceptor, -} from "ee/api/ApiUtils"; +} from "./interceptors"; +import { REQUEST_TIMEOUT_MS } from "ee/constants/ApiConstants"; +import { convertObjectToQueryParams } from "utils/URLUtils"; -//TODO(abhinav): Refactor this to make more composable. export const apiRequestConfig = { baseURL: "/api/", timeout: REQUEST_TIMEOUT_MS, @@ -21,16 +19,7 @@ export const apiRequestConfig = { const axiosInstance: AxiosInstance = axios.create(); -const requestInterceptors = [ - blockedApiRoutesForAirgapInterceptor, - apiRequestInterceptor, -]; - -requestInterceptors.forEach((interceptor) => { - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - axiosInstance.interceptors.request.use(interceptor as any); -}); +axiosInstance.interceptors.request.use(apiRequestInterceptor); axiosInstance.interceptors.response.use( apiSuccessResponseInterceptor, diff --git a/app/client/src/api/ConsolidatedPageLoadApi.tsx b/app/client/src/api/ConsolidatedPageLoadApi.tsx deleted file mode 100644 index 473b9a09301..00000000000 --- a/app/client/src/api/ConsolidatedPageLoadApi.tsx +++ /dev/null @@ -1,26 +0,0 @@ -import Api from "./Api"; -import type { AxiosPromise } from "axios"; -import type { ApiResponse } from "api/ApiResponses"; - -import type { InitConsolidatedApi } from "sagas/InitSagas"; - -class ConsolidatedPageLoadApi extends Api { - static url = "v1/consolidated-api"; - static consolidatedApiViewUrl = `${ConsolidatedPageLoadApi.url}/view`; - static consolidatedApiEditUrl = `${ConsolidatedPageLoadApi.url}/edit`; - - static async getConsolidatedPageLoadDataView(params: { - applicationId?: string; - defaultPageId?: string; - }): Promise>> { - return Api.get(ConsolidatedPageLoadApi.consolidatedApiViewUrl, params); - } - static async getConsolidatedPageLoadDataEdit(params: { - applicationId?: string; - defaultPageId?: string; - }): Promise>> { - return Api.get(ConsolidatedPageLoadApi.consolidatedApiEditUrl, params); - } -} - -export default ConsolidatedPageLoadApi; diff --git a/app/client/src/api/__tests__/apiFailureResponseInterceptors.ts b/app/client/src/api/__tests__/apiFailureResponseInterceptors.ts new file mode 100644 index 00000000000..7802d608b81 --- /dev/null +++ b/app/client/src/api/__tests__/apiFailureResponseInterceptors.ts @@ -0,0 +1,225 @@ +import axios from "axios"; +import type { AxiosError } from "axios"; + +import { + apiFailureResponseInterceptor, + apiSuccessResponseInterceptor, +} from "api/interceptors"; +import type { ApiResponse } from "api/types"; +import { + createMessage, + ERROR_0, + ERROR_413, + ERROR_500, + SERVER_API_TIMEOUT_ERROR, +} from "ee/constants/messages"; +import { ERROR_CODES } from "ee/constants/ApiConstants"; +import { UserCancelledActionExecutionError } from "sagas/ActionExecution/errorUtils"; + +describe("Api success response interceptors", () => { + beforeAll(() => { + axios.interceptors.response.use( + apiSuccessResponseInterceptor, + apiFailureResponseInterceptor, + ); + }); + + it("checks 413 error", async () => { + axios.defaults.adapter = async () => { + return Promise.reject({ + response: { + status: 413, + }, + } as AxiosError); + }; + + try { + await axios.get("https://example.com"); + } catch (error) { + expect((error as AxiosError).response?.status).toBe(413); + expect((error as AxiosError).message).toBe( + createMessage(ERROR_413, 100), + ); + expect( + (error as AxiosError & { statusCode?: string }).statusCode, + ).toBe("AE-APP-4013"); + } + + axios.defaults.adapter = undefined; + }); + + it("checks the response message when request is made when user is offline", async () => { + const onlineGetter: jest.SpyInstance = jest.spyOn( + window.navigator, + "onLine", + "get", + ); + + onlineGetter.mockReturnValue(false); + axios.defaults.adapter = async () => { + return new Promise((resolve, reject) => { + reject({ + message: "Network Error", + } as AxiosError); + }); + }; + + try { + await axios.get("https://example.com"); + } catch (error) { + expect((error as AxiosError).message).toBe( + createMessage(ERROR_0), + ); + } + + onlineGetter.mockRestore(); + axios.defaults.adapter = undefined; + }); + + it("checks if it throws UserCancelledActionExecutionError user cancels the request ", async () => { + const cancelToken = axios.CancelToken.source(); + + axios.defaults.adapter = async () => { + return new Promise((resolve, reject) => { + cancelToken.cancel("User cancelled the request"); + + reject({ + message: "User cancelled the request", + } as AxiosError); + }); + }; + + try { + await axios.get("https://example.com", { + cancelToken: cancelToken.token, + }); + } catch (error) { + expect(error).toBeInstanceOf(UserCancelledActionExecutionError); + } + + axios.defaults.adapter = undefined; + }); + + it("checks the response message when request fails for exeuction action urls", async () => { + axios.defaults.adapter = async () => { + return Promise.reject({ + response: { + status: 500, + statusText: "Internal Server Error", + headers: { + "content-length": 1, + }, + config: { + headers: { + timer: "1000", + }, + }, + }, + config: { + url: "/v1/actions/execute", + }, + }); + }; + + const url = "/v1/actions/execute"; + const response = await axios.get(url); + + expect(response).toHaveProperty("clientMeta"); + + axios.defaults.adapter = undefined; + }); + + it("checks the error response in case of timeout", async () => { + axios.defaults.adapter = async () => { + return Promise.reject({ + code: "ECONNABORTED", + message: "timeout of 1000ms exceeded", + }); + }; + + try { + await axios.get("https://example.com"); + } catch (error) { + expect((error as AxiosError).message).toBe( + createMessage(SERVER_API_TIMEOUT_ERROR), + ); + expect((error as AxiosError).code).toBe( + ERROR_CODES.REQUEST_TIMEOUT, + ); + } + + axios.defaults.adapter = undefined; + }); + + it("checks the error response in case of server error", async () => { + axios.defaults.adapter = async () => { + return Promise.reject({ + response: { + status: 502, + }, + }); + }; + + try { + await axios.get("https://example.com"); + } catch (error) { + expect((error as AxiosError).message).toBe( + createMessage(ERROR_500), + ); + expect((error as AxiosError).code).toBe( + ERROR_CODES.SERVER_ERROR, + ); + } + + axios.defaults.adapter = undefined; + }); + + it("checks error response in case of unauthorized error", async () => { + axios.defaults.adapter = async () => { + return Promise.reject({ + response: { + status: 401, + }, + }); + }; + + try { + await axios.get("https://example.com"); + } catch (error) { + expect((error as AxiosError).message).toBe( + "Unauthorized. Redirecting to login page...", + ); + expect((error as AxiosError).code).toBe( + ERROR_CODES.REQUEST_NOT_AUTHORISED, + ); + } + }); + + it("checks error response in case of not found error", async () => { + axios.defaults.adapter = async () => { + return Promise.reject({ + response: { + data: { + responseMeta: { + status: 404, + error: { + code: "AE-ACL-4004", + }, + }, + }, + }, + }); + }; + + try { + await axios.get("https://example.com"); + } catch (error) { + expect((error as AxiosError).message).toBe( + "Resource Not Found", + ); + expect((error as AxiosError).code).toBe( + ERROR_CODES.PAGE_NOT_FOUND, + ); + } + }); +}); diff --git a/app/client/src/api/__tests__/apiRequestInterceptors.ts b/app/client/src/api/__tests__/apiRequestInterceptors.ts new file mode 100644 index 00000000000..8a90efc3d4b --- /dev/null +++ b/app/client/src/api/__tests__/apiRequestInterceptors.ts @@ -0,0 +1,121 @@ +import axios from "axios"; +import { + addGitBranchHeader, + blockAirgappedRoutes, + addRequestedByHeader, + addEnvironmentHeader, + increaseGitApiTimeout, + addAnonymousUserIdHeader, + addPerformanceMonitoringHeaders, +} from "api/interceptors/request"; + +describe("Api request interceptors", () => { + beforeAll(() => { + axios.defaults.adapter = async (config) => { + return new Promise((resolve) => { + resolve({ + data: "Test data", + status: 200, + statusText: "OK", + headers: { + "content-length": 123, + "content-type": "application/json", + }, + config, + }); + }); + }; + }); + + it("checks if the request config has timer in the headers", async () => { + const url = "v1/actions/execute"; + const identifier = axios.interceptors.request.use( + addPerformanceMonitoringHeaders, + ); + const response = await axios.get(url); + + expect(response.config.headers).toHaveProperty("timer"); + + axios.interceptors.request.eject(identifier); + }); + + it("checks if the request config has anonymousUserId in the headers", async () => { + const url = "v1/actions/execute"; + const identifier = axios.interceptors.request.use((config) => + addAnonymousUserIdHeader(config, { + segmentEnabled: true, + anonymousId: "anonymousUserId", + }), + ); + const response = await axios.get(url); + + expect(response.config.headers).toHaveProperty("x-anonymous-user-id"); + expect(response.config.headers["x-anonymous-user-id"]).toBe( + "anonymousUserId", + ); + + axios.interceptors.request.eject(identifier); + }); + + it("checks if the request config has csrfToken in the headers", async () => { + const url = "v1/actions/execute"; + const identifier = axios.interceptors.request.use(addRequestedByHeader); + const response = await axios.post(url); + + expect(response.config.headers).toHaveProperty("X-Requested-By"); + expect(response.config.headers["X-Requested-By"]).toBe("Appsmith"); + + axios.interceptors.request.eject(identifier); + }); + + it("checks if the request config has gitBranch in the headers", async () => { + const url = "v1/"; + const identifier = axios.interceptors.request.use((config) => { + return addGitBranchHeader(config, { branch: "master" }); + }); + const response = await axios.get(url); + + expect(response.config.headers).toHaveProperty("branchName"); + expect(response.config.headers["branchName"]).toBe("master"); + + axios.interceptors.request.eject(identifier); + }); + + it("checks if the request config has environmentId in the headers", async () => { + const url = "v1/saas"; + const identifier = axios.interceptors.request.use((config) => { + return addEnvironmentHeader(config, { env: "default" }); + }); + + const response = await axios.get(url); + + expect(response.config.headers).toHaveProperty("X-Appsmith-EnvironmentId"); + expect(response.config.headers["X-Appsmith-EnvironmentId"]).toBe("default"); + + axios.interceptors.request.eject(identifier); + }); + + it("checks if request is 200 ok when isAirgapped is true", async () => { + const url = "v1/saas"; + const identifier = axios.interceptors.request.use((config) => { + return blockAirgappedRoutes(config, { isAirgapped: true }); + }); + const response = await axios.get(url); + + expect(response.data).toBeNull(); + expect(response.status).toBe(200); + expect(response.statusText).toBe("OK"); + + axios.interceptors.request.eject(identifier); + }); + + it("checks if the request config has a timeout of 120s", async () => { + const url = "v1/git/"; + const identifier = axios.interceptors.request.use(increaseGitApiTimeout); + const response = await axios.get(url); + + expect(response.config.timeout).toBe(120000); + + axios.interceptors.request.eject(identifier); + }); +}); diff --git a/app/client/src/api/__tests__/apiSucessResponseInterceptors.ts b/app/client/src/api/__tests__/apiSucessResponseInterceptors.ts new file mode 100644 index 00000000000..1b8963577d4 --- /dev/null +++ b/app/client/src/api/__tests__/apiSucessResponseInterceptors.ts @@ -0,0 +1,40 @@ +import axios from "axios"; +import { apiSuccessResponseInterceptor } from "api/interceptors"; + +describe("Api success response interceptors", () => { + beforeAll(() => { + axios.interceptors.response.use(apiSuccessResponseInterceptor); + axios.defaults.adapter = async (config) => { + return new Promise((resolve) => { + resolve({ + data: { + data: "Test data", + }, + status: 200, + statusText: "OK", + headers: { + "content-length": 123, + "content-type": "application/json", + }, + config, + }); + }); + }; + }); + + it("checks response for non-action-execution url", async () => { + const url = "/v1/sass"; + const response = await axios.get(url); + + expect(response.data).toBe("Test data"); + }); + + it("checks response for action-execution url", async () => { + const url = "/v1/actions/execute"; + const response = await axios.get(url); + + expect(response).toHaveProperty("data"); + expect(response.data).toBe("Test data"); + expect(response).toHaveProperty("clientMeta"); + }); +}); diff --git a/app/client/src/api/core/api.ts b/app/client/src/api/core/api.ts new file mode 100644 index 00000000000..ecfb9e74f09 --- /dev/null +++ b/app/client/src/api/core/api.ts @@ -0,0 +1,31 @@ +import type { AxiosResponseData } from "api/types"; + +import { apiFactory } from "./factory"; + +const apiInstance = apiFactory(); + +export async function get(...args: Parameters) { + // Note: we are passing AxiosResponseData as the second type argument to set the default type of the response data.The reason + // is we modify the response data in the responseSuccessInterceptor to return `.data` property from the axios response so that we can + // just `response.data` instead of `response.data.data`. So we have to make sure that the response data's type matches what we do in the interceptor. + return apiInstance.get>(...args); +} + +export async function post(...args: Parameters) { + return apiInstance.post>(...args); +} + +export async function put(...args: Parameters) { + return apiInstance.put>(...args); +} + +// Note: _delete is used instead of delete because delete is a reserved keyword in JavaScript +async function _delete(...args: Parameters) { + return apiInstance.delete>(...args); +} + +export { _delete as delete }; + +export async function patch(...args: Parameters) { + return apiInstance.patch>(...args); +} diff --git a/app/client/src/api/core/factory.ts b/app/client/src/api/core/factory.ts new file mode 100644 index 00000000000..b0b75ada388 --- /dev/null +++ b/app/client/src/api/core/factory.ts @@ -0,0 +1,17 @@ +import axios from "axios"; +import { DEFAULT_AXIOS_CONFIG } from "ee/constants/ApiConstants"; +import { apiRequestInterceptor } from "api/interceptors/request/apiRequestInterceptor"; +import { apiSuccessResponseInterceptor } from "api/interceptors/response/apiSuccessResponseInterceptor"; +import { apiFailureResponseInterceptor } from "api/interceptors/response/apiFailureResponseInterceptor"; + +export function apiFactory() { + const axiosInstance = axios.create(DEFAULT_AXIOS_CONFIG); + + axiosInstance.interceptors.request.use(apiRequestInterceptor); + axiosInstance.interceptors.response.use( + apiSuccessResponseInterceptor, + apiFailureResponseInterceptor, + ); + + return axiosInstance; +} diff --git a/app/client/src/api/core/index.ts b/app/client/src/api/core/index.ts new file mode 100644 index 00000000000..ed3655362f5 --- /dev/null +++ b/app/client/src/api/core/index.ts @@ -0,0 +1,2 @@ +export * as api from "./api"; +export { apiFactory } from "./factory"; diff --git a/app/client/src/api/helpers/addExecutionMetaProperties.ts b/app/client/src/api/helpers/addExecutionMetaProperties.ts new file mode 100644 index 00000000000..e4fba5c6152 --- /dev/null +++ b/app/client/src/api/helpers/addExecutionMetaProperties.ts @@ -0,0 +1,12 @@ +import type { AxiosResponse } from "axios"; + +export const addExecutionMetaProperties = (response: AxiosResponse) => { + const clientMeta = { + size: response.headers["content-length"], + duration: Number( + performance.now() - response.config.headers.timer, + ).toFixed(), + }; + + return { ...response.data, clientMeta }; +}; diff --git a/app/client/src/api/helpers/index.ts b/app/client/src/api/helpers/index.ts new file mode 100644 index 00000000000..1cd96da7b8c --- /dev/null +++ b/app/client/src/api/helpers/index.ts @@ -0,0 +1,3 @@ +export { is404orAuthPath } from "./is404orAuthPath"; +export { validateJsonResponseMeta } from "./validateJsonResponseMeta"; +export { addExecutionMetaProperties } from "./addExecutionMetaProperties"; diff --git a/app/client/src/api/helpers/is404orAuthPath.ts b/app/client/src/api/helpers/is404orAuthPath.ts new file mode 100644 index 00000000000..10d4193ebbc --- /dev/null +++ b/app/client/src/api/helpers/is404orAuthPath.ts @@ -0,0 +1,5 @@ +export const is404orAuthPath = () => { + const pathName = window.location.pathname; + + return /^\/404/.test(pathName) || /^\/user\/\w+/.test(pathName); +}; diff --git a/app/client/src/api/helpers/validateJsonResponseMeta.ts b/app/client/src/api/helpers/validateJsonResponseMeta.ts new file mode 100644 index 00000000000..de295660abd --- /dev/null +++ b/app/client/src/api/helpers/validateJsonResponseMeta.ts @@ -0,0 +1,14 @@ +import * as Sentry from "@sentry/react"; +import type { AxiosResponse } from "axios"; +import { CONTENT_TYPE_HEADER_KEY } from "constants/ApiEditorConstants/CommonApiConstants"; + +export const validateJsonResponseMeta = (response: AxiosResponse) => { + if ( + response.headers[CONTENT_TYPE_HEADER_KEY] === "application/json" && + !response.data.responseMeta + ) { + Sentry.captureException(new Error("Api responded without response meta"), { + contexts: { response: response.data }, + }); + } +}; diff --git a/app/client/src/api/index.ts b/app/client/src/api/index.ts new file mode 100644 index 00000000000..b2221a94a89 --- /dev/null +++ b/app/client/src/api/index.ts @@ -0,0 +1 @@ +export * from "./services"; diff --git a/app/client/src/api/interceptors/index.ts b/app/client/src/api/interceptors/index.ts new file mode 100644 index 00000000000..346dac3b386 --- /dev/null +++ b/app/client/src/api/interceptors/index.ts @@ -0,0 +1,2 @@ +export * from "./request"; +export * from "./response"; diff --git a/app/client/src/api/interceptors/request/addAnonymousUserIdHeader.ts b/app/client/src/api/interceptors/request/addAnonymousUserIdHeader.ts new file mode 100644 index 00000000000..d87e95c6307 --- /dev/null +++ b/app/client/src/api/interceptors/request/addAnonymousUserIdHeader.ts @@ -0,0 +1,16 @@ +import type { InternalAxiosRequestConfig } from "axios"; + +export const addAnonymousUserIdHeader = ( + config: InternalAxiosRequestConfig, + options: { anonymousId?: string; segmentEnabled?: boolean }, +) => { + const { anonymousId, segmentEnabled } = options; + + config.headers = config.headers || {}; + + if (segmentEnabled && anonymousId) { + config.headers["x-anonymous-user-id"] = anonymousId; + } + + return config; +}; diff --git a/app/client/src/api/interceptors/request/addEnvironmentHeader.ts b/app/client/src/api/interceptors/request/addEnvironmentHeader.ts new file mode 100644 index 00000000000..82c9d89fc41 --- /dev/null +++ b/app/client/src/api/interceptors/request/addEnvironmentHeader.ts @@ -0,0 +1,19 @@ +import type { InternalAxiosRequestConfig } from "axios"; +import { ENV_ENABLED_ROUTES_REGEX } from "ee/constants/ApiConstants"; + +export const addEnvironmentHeader = ( + config: InternalAxiosRequestConfig, + options: { env: string }, +) => { + const { env } = options; + + config.headers = config.headers || {}; + + if (ENV_ENABLED_ROUTES_REGEX.test(config.url?.split("?")[0] || "")) { + if (env) { + config.headers["X-Appsmith-EnvironmentId"] = env; + } + } + + return config; +}; diff --git a/app/client/src/api/interceptors/request/addGitBranchHeader.ts b/app/client/src/api/interceptors/request/addGitBranchHeader.ts new file mode 100644 index 00000000000..b15105bcb83 --- /dev/null +++ b/app/client/src/api/interceptors/request/addGitBranchHeader.ts @@ -0,0 +1,16 @@ +import type { InternalAxiosRequestConfig } from "axios"; + +export const addGitBranchHeader = ( + config: InternalAxiosRequestConfig, + options: { branch?: string }, +) => { + const { branch } = options; + + config.headers = config.headers || {}; + + if (branch) { + config.headers.branchName = branch; + } + + return config; +}; diff --git a/app/client/src/api/interceptors/request/addPerformanceMonitoringHeaders.ts b/app/client/src/api/interceptors/request/addPerformanceMonitoringHeaders.ts new file mode 100644 index 00000000000..53ec7ad1bde --- /dev/null +++ b/app/client/src/api/interceptors/request/addPerformanceMonitoringHeaders.ts @@ -0,0 +1,10 @@ +import type { InternalAxiosRequestConfig } from "axios"; + +export const addPerformanceMonitoringHeaders = ( + config: InternalAxiosRequestConfig, +) => { + config.headers = config.headers || {}; + config.headers["timer"] = performance.now(); + + return config; +}; diff --git a/app/client/src/api/interceptors/request/addRequestedByHeader.ts b/app/client/src/api/interceptors/request/addRequestedByHeader.ts new file mode 100644 index 00000000000..c64a363dc87 --- /dev/null +++ b/app/client/src/api/interceptors/request/addRequestedByHeader.ts @@ -0,0 +1,13 @@ +import type { InternalAxiosRequestConfig } from "axios"; + +export const addRequestedByHeader = (config: InternalAxiosRequestConfig) => { + config.headers = config.headers || {}; + + const methodUpper = config.method?.toUpperCase(); + + if (methodUpper && methodUpper !== "GET" && methodUpper !== "HEAD") { + config.headers["X-Requested-By"] = "Appsmith"; + } + + return config; +}; diff --git a/app/client/src/api/interceptors/request/apiRequestInterceptor.ts b/app/client/src/api/interceptors/request/apiRequestInterceptor.ts new file mode 100644 index 00000000000..8f7919c067d --- /dev/null +++ b/app/client/src/api/interceptors/request/apiRequestInterceptor.ts @@ -0,0 +1,64 @@ +import store from "store"; +import { compose } from "@appsmith/utils"; +import { getAppsmithConfigs } from "ee/configs"; +import AnalyticsUtil from "ee/utils/AnalyticsUtil"; +import { isAirgapped } from "ee/utils/airgapHelpers"; +import type { InternalAxiosRequestConfig } from "axios"; + +import getQueryParamsObject from "utils/getQueryParamsObject"; +import { addRequestedByHeader } from "./addRequestedByHeader"; +import { increaseGitApiTimeout } from "./increaseGitApiTimeout"; +import { getCurrentGitBranch } from "selectors/gitSyncSelectors"; +import { getCurrentEnvironmentId } from "ee/selectors/environmentSelectors"; +import { addGitBranchHeader as _addGitBranchHeader } from "./addGitBranchHeader"; +import { addPerformanceMonitoringHeaders } from "./addPerformanceMonitoringHeaders"; +import { addEnvironmentHeader as _addEnvironmentHeader } from "./addEnvironmentHeader"; +import { blockAirgappedRoutes as _blockAirgappedRoutes } from "./blockAirgappedRoutes"; +import { addAnonymousUserIdHeader as _addAnonymousUserIdHeader } from "./addAnonymousUserIdHeader"; + +/** + * Note: Why can't we use store.getState() or isGapgapped() directly in the interceptor? + * The main reason is to easily test the interceptor. When we use store.getState() or isAirgapped() directly in the interceptor, + * we need to mock the store or isAirgapped() in the test file and it becomes difficult and messy mocking things just to test the interceptor. + */ +const blockAirgappedRoutes = (config: InternalAxiosRequestConfig) => { + const isAirgappedInstance = isAirgapped(); + + return _blockAirgappedRoutes(config, { isAirgapped: isAirgappedInstance }); +}; + +const addGitBranchHeader = (config: InternalAxiosRequestConfig) => { + const state = store.getState(); + const branch = getCurrentGitBranch(state) || getQueryParamsObject().branch; + + return _addGitBranchHeader(config, { branch }); +}; + +const addEnvironmentHeader = (config: InternalAxiosRequestConfig) => { + const state = store.getState(); + const activeEnv = getCurrentEnvironmentId(state); + + return _addEnvironmentHeader(config, { env: activeEnv }); +}; + +const addAnonymousUserIdHeader = (config: InternalAxiosRequestConfig) => { + const appsmithConfig = getAppsmithConfigs(); + const anonymousId = AnalyticsUtil.getAnonymousId(); + const segmentEnabled = appsmithConfig.segment.enabled; + + return _addAnonymousUserIdHeader(config, { anonymousId, segmentEnabled }); +}; + +export const apiRequestInterceptor = (config: InternalAxiosRequestConfig) => { + const interceptorPipeline = compose( + blockAirgappedRoutes, + addRequestedByHeader, + addGitBranchHeader, + increaseGitApiTimeout, + addEnvironmentHeader, + addAnonymousUserIdHeader, + addPerformanceMonitoringHeaders, + ); + + return interceptorPipeline(config); +}; diff --git a/app/client/src/api/interceptors/request/blockAirgappedRoutes.ts b/app/client/src/api/interceptors/request/blockAirgappedRoutes.ts new file mode 100644 index 00000000000..d8d4d54ee80 --- /dev/null +++ b/app/client/src/api/interceptors/request/blockAirgappedRoutes.ts @@ -0,0 +1,29 @@ +import type { InternalAxiosRequestConfig } from "axios"; +import { BLOCKED_ROUTES_REGEX } from "ee/constants/ApiConstants"; + +const blockAirgappedRoutes = ( + request: InternalAxiosRequestConfig, + options: { isAirgapped: boolean }, +) => { + const { url } = request; + const { isAirgapped } = options; + + if (isAirgapped && url && BLOCKED_ROUTES_REGEX.test(url)) { + request.adapter = async (config) => { + return new Promise((resolve) => { + resolve({ + data: null, + status: 200, + statusText: "OK", + headers: {}, + config, + request, + }); + }); + }; + } + + return request; +}; + +export { blockAirgappedRoutes }; diff --git a/app/client/src/api/interceptors/request/increaseGitApiTimeout.ts b/app/client/src/api/interceptors/request/increaseGitApiTimeout.ts new file mode 100644 index 00000000000..4aa20d7611c --- /dev/null +++ b/app/client/src/api/interceptors/request/increaseGitApiTimeout.ts @@ -0,0 +1,9 @@ +import type { InternalAxiosRequestConfig } from "axios"; + +export const increaseGitApiTimeout = (config: InternalAxiosRequestConfig) => { + if (config.url?.indexOf("/git/") !== -1) { + config.timeout = 1000 * 120; + } + + return config; +}; diff --git a/app/client/src/api/interceptors/request/index.ts b/app/client/src/api/interceptors/request/index.ts new file mode 100644 index 00000000000..6f9957f00ec --- /dev/null +++ b/app/client/src/api/interceptors/request/index.ts @@ -0,0 +1,8 @@ +export { addGitBranchHeader } from "./addGitBranchHeader"; +export { blockAirgappedRoutes } from "./blockAirgappedRoutes"; +export { addRequestedByHeader } from "./addRequestedByHeader"; +export { addEnvironmentHeader } from "./addEnvironmentHeader"; +export { apiRequestInterceptor } from "./apiRequestInterceptor"; +export { increaseGitApiTimeout } from "./increaseGitApiTimeout"; +export { addAnonymousUserIdHeader } from "./addAnonymousUserIdHeader"; +export { addPerformanceMonitoringHeaders } from "./addPerformanceMonitoringHeaders"; diff --git a/app/client/src/api/interceptors/response/apiFailureResponseInterceptor.ts b/app/client/src/api/interceptors/response/apiFailureResponseInterceptor.ts new file mode 100644 index 00000000000..eae6f616212 --- /dev/null +++ b/app/client/src/api/interceptors/response/apiFailureResponseInterceptor.ts @@ -0,0 +1,33 @@ +import type { AxiosError } from "axios"; +import type { ApiResponse, ErrorHandler } from "api/types"; + +import * as failureHandlers from "./failureHandlers"; + +export const apiFailureResponseInterceptor = async ( + error: AxiosError, +) => { + const handlers: ErrorHandler[] = [ + failureHandlers.handle413Error, + failureHandlers.handleOfflineError, + failureHandlers.handleCancelError, + failureHandlers.handleExecuteActionError, + failureHandlers.handleTimeoutError, + failureHandlers.handleServerError, + failureHandlers.handleUnauthorizedError, + failureHandlers.handleNotFoundError, + ]; + + for (const handler of handlers) { + const result = await handler(error); + + if (result !== null) { + return result; + } + } + + if (error?.response?.data.responseMeta) { + return Promise.resolve(error.response.data); + } + + return Promise.resolve(error); +}; diff --git a/app/client/src/api/interceptors/response/apiSuccessResponseInterceptor.ts b/app/client/src/api/interceptors/response/apiSuccessResponseInterceptor.ts new file mode 100644 index 00000000000..ca18a9ea432 --- /dev/null +++ b/app/client/src/api/interceptors/response/apiSuccessResponseInterceptor.ts @@ -0,0 +1,16 @@ +import { + validateJsonResponseMeta, + addExecutionMetaProperties, +} from "api/helpers"; +import type { AxiosResponse } from "axios"; +import { EXECUTION_ACTION_REGEX } from "ee/constants/ApiConstants"; + +export const apiSuccessResponseInterceptor = (response: AxiosResponse) => { + if (response?.config?.url?.match(EXECUTION_ACTION_REGEX)) { + return addExecutionMetaProperties(response); + } + + validateJsonResponseMeta(response); + + return response.data; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/handle413Error.ts b/app/client/src/api/interceptors/response/failureHandlers/handle413Error.ts new file mode 100644 index 00000000000..301b1c2c97a --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handle413Error.ts @@ -0,0 +1,25 @@ +import type { AxiosError } from "axios"; +import { + createMessage, + ERROR_413, + GENERIC_API_EXECUTION_ERROR, +} from "ee/constants/messages"; + +export const handle413Error = async (error: AxiosError) => { + if (error?.response?.status === 413) { + return Promise.reject({ + ...error, + clientDefinedError: true, + statusCode: "AE-APP-4013", + message: createMessage(ERROR_413, 100), + pluginErrorDetails: { + appsmithErrorCode: "AE-APP-4013", + appsmithErrorMessage: createMessage(ERROR_413, 100), + errorType: "INTERNAL_ERROR", // this value is from the server, hence cannot construct enum type. + title: createMessage(GENERIC_API_EXECUTION_ERROR), + }, + }); + } + + return null; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleCancelError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleCancelError.ts new file mode 100644 index 00000000000..f579d8bc90b --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleCancelError.ts @@ -0,0 +1,11 @@ +import axios from "axios"; +import type { AxiosError } from "axios"; +import { UserCancelledActionExecutionError } from "sagas/ActionExecution/errorUtils"; + +export async function handleCancelError(error: AxiosError) { + if (axios.isCancel(error)) { + throw new UserCancelledActionExecutionError(); + } + + return null; +} diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleExecuteActionError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleExecuteActionError.ts new file mode 100644 index 00000000000..6a1e0c4f277 --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleExecuteActionError.ts @@ -0,0 +1,14 @@ +import type { AxiosError, AxiosResponse } from "axios"; +import { addExecutionMetaProperties } from "api/helpers"; +import { EXECUTION_ACTION_REGEX } from "ee/constants/ApiConstants"; + +export function handleExecuteActionError(error: AxiosError) { + const isExecutionActionURL = + error.config && error?.config?.url?.match(EXECUTION_ACTION_REGEX); + + if (isExecutionActionURL) { + return addExecutionMetaProperties(error?.response as AxiosResponse); + } + + return null; +} diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleMissingResponseMeta.ts b/app/client/src/api/interceptors/response/failureHandlers/handleMissingResponseMeta.ts new file mode 100644 index 00000000000..4153a6f868b --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleMissingResponseMeta.ts @@ -0,0 +1,17 @@ +import type { AxiosError } from "axios"; +import * as Sentry from "@sentry/react"; +import type { ApiResponse } from "api/types"; + +export const handleMissingResponseMeta = async ( + error: AxiosError, +) => { + if (error.response?.data && !error.response.data.responseMeta) { + Sentry.captureException(new Error("Api responded without response meta"), { + contexts: { response: { ...error.response.data } }, + }); + + return Promise.reject(error.response.data); + } + + return null; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleNotFoundError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleNotFoundError.ts new file mode 100644 index 00000000000..21e2aa42f31 --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleNotFoundError.ts @@ -0,0 +1,34 @@ +import { + API_STATUS_CODES, + ERROR_CODES, + SERVER_ERROR_CODES, +} from "ee/constants/ApiConstants"; +import * as Sentry from "@sentry/react"; +import type { AxiosError } from "axios"; +import type { ApiResponse } from "api/types"; +import { is404orAuthPath } from "api/helpers"; + +export async function handleNotFoundError(error: AxiosError) { + if (is404orAuthPath()) return null; + + const errorData = + error?.response?.data.responseMeta ?? ({} as ApiResponse["responseMeta"]); + + if ( + errorData.status === API_STATUS_CODES.RESOURCE_NOT_FOUND && + errorData.error?.code && + (SERVER_ERROR_CODES.RESOURCE_NOT_FOUND.includes(errorData.error?.code) || + SERVER_ERROR_CODES.UNABLE_TO_FIND_PAGE.includes(errorData?.error?.code)) + ) { + Sentry.captureException(error); + + return Promise.reject({ + ...error, + code: ERROR_CODES.PAGE_NOT_FOUND, + message: "Resource Not Found", + show: false, + }); + } + + return null; +} diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleOfflineError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleOfflineError.ts new file mode 100644 index 00000000000..2fa9fa16492 --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleOfflineError.ts @@ -0,0 +1,13 @@ +import type { AxiosError } from "axios"; +import { createMessage, ERROR_0 } from "ee/constants/messages"; + +export const handleOfflineError = async (error: AxiosError) => { + if (!window.navigator.onLine) { + return Promise.reject({ + ...error, + message: createMessage(ERROR_0), + }); + } + + return null; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleServerError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleServerError.ts new file mode 100644 index 00000000000..2092d72b007 --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleServerError.ts @@ -0,0 +1,15 @@ +import type { AxiosError } from "axios"; +import { createMessage, ERROR_500 } from "ee/constants/messages"; +import { API_STATUS_CODES, ERROR_CODES } from "ee/constants/ApiConstants"; + +export const handleServerError = async (error: AxiosError) => { + if (error.response?.status === API_STATUS_CODES.SERVER_ERROR) { + return Promise.reject({ + ...error, + code: ERROR_CODES.SERVER_ERROR, + message: createMessage(ERROR_500), + }); + } + + return null; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleTimeoutError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleTimeoutError.ts new file mode 100644 index 00000000000..ffff3eafe76 --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleTimeoutError.ts @@ -0,0 +1,22 @@ +import type { AxiosError } from "axios"; +import { + ERROR_CODES, + TIMEOUT_ERROR_REGEX, + AXIOS_CONNECTION_ABORTED_CODE, +} from "ee/constants/ApiConstants"; +import { createMessage, SERVER_API_TIMEOUT_ERROR } from "ee/constants/messages"; + +export const handleTimeoutError = async (error: AxiosError) => { + if ( + error.code === AXIOS_CONNECTION_ABORTED_CODE && + error.message?.match(TIMEOUT_ERROR_REGEX) + ) { + return Promise.reject({ + ...error, + message: createMessage(SERVER_API_TIMEOUT_ERROR), + code: ERROR_CODES.REQUEST_TIMEOUT, + }); + } + + return null; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/handleUnauthorizedError.ts b/app/client/src/api/interceptors/response/failureHandlers/handleUnauthorizedError.ts new file mode 100644 index 00000000000..343ec7022e4 --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/handleUnauthorizedError.ts @@ -0,0 +1,34 @@ +import store from "store"; +import type { AxiosError } from "axios"; +import * as Sentry from "@sentry/react"; +import { is404orAuthPath } from "api/helpers"; +import { logoutUser } from "actions/userActions"; +import { AUTH_LOGIN_URL } from "constants/routes"; +import { API_STATUS_CODES, ERROR_CODES } from "ee/constants/ApiConstants"; + +export const handleUnauthorizedError = async (error: AxiosError) => { + if (is404orAuthPath()) return null; + + if (error.response?.status === API_STATUS_CODES.REQUEST_NOT_AUTHORISED) { + const currentUrl = `${window.location.href}`; + + store.dispatch( + logoutUser({ + redirectURL: `${AUTH_LOGIN_URL}?redirectUrl=${encodeURIComponent( + currentUrl, + )}`, + }), + ); + + Sentry.captureException(error); + + return Promise.reject({ + ...error, + code: ERROR_CODES.REQUEST_NOT_AUTHORISED, + message: "Unauthorized. Redirecting to login page...", + show: false, + }); + } + + return null; +}; diff --git a/app/client/src/api/interceptors/response/failureHandlers/index.ts b/app/client/src/api/interceptors/response/failureHandlers/index.ts new file mode 100644 index 00000000000..2352095f1de --- /dev/null +++ b/app/client/src/api/interceptors/response/failureHandlers/index.ts @@ -0,0 +1,9 @@ +export { handle413Error } from "./handle413Error"; +export { handleServerError } from "./handleServerError"; +export { handleCancelError } from "./handleCancelError"; +export { handleOfflineError } from "./handleOfflineError"; +export { handleTimeoutError } from "./handleTimeoutError"; +export { handleNotFoundError } from "./handleNotFoundError"; +export { handleUnauthorizedError } from "./handleUnauthorizedError"; +export { handleExecuteActionError } from "./handleExecuteActionError"; +export { handleMissingResponseMeta } from "./handleMissingResponseMeta"; diff --git a/app/client/src/api/interceptors/response/index.ts b/app/client/src/api/interceptors/response/index.ts new file mode 100644 index 00000000000..5177d545922 --- /dev/null +++ b/app/client/src/api/interceptors/response/index.ts @@ -0,0 +1,2 @@ +export { apiFailureResponseInterceptor } from "./apiFailureResponseInterceptor"; +export { apiSuccessResponseInterceptor } from "./apiSuccessResponseInterceptor"; diff --git a/app/client/src/api/services/AppThemingApi/api.ts b/app/client/src/api/services/AppThemingApi/api.ts new file mode 100644 index 00000000000..e7d22dfed85 --- /dev/null +++ b/app/client/src/api/services/AppThemingApi/api.ts @@ -0,0 +1,38 @@ +import { api } from "api/core"; +import type { AppTheme } from "entities/AppTheming"; + +const baseURL = "/v1"; + +export async function fetchThemes(applicationId: string) { + const url = `${baseURL}/themes/applications/${applicationId}`; + + return api.get(url); +} + +export async function fetchSelected(applicationId: string, mode = "EDIT") { + const url = `${baseURL}/themes/applications/${applicationId}/current`; + + return api.get(url, { params: { mode } }); +} + +export async function updateTheme(applicationId: string, theme: AppTheme) { + const url = `${baseURL}/themes/applications/${applicationId}`; + const payload = { + ...theme, + new: undefined, + }; + + return api.put(url, payload); +} + +export async function changeTheme(applicationId: string, theme: AppTheme) { + const url = `${baseURL}/applications/${applicationId}/themes/${theme.id}`; + + return api.patch(url, theme); +} + +export async function deleteTheme(themeId: string) { + const url = `${baseURL}/themes/${themeId}`; + + return api.delete(url); +} diff --git a/app/client/src/api/services/AppThemingApi/index.ts b/app/client/src/api/services/AppThemingApi/index.ts new file mode 100644 index 00000000000..d158c576401 --- /dev/null +++ b/app/client/src/api/services/AppThemingApi/index.ts @@ -0,0 +1 @@ +export * from "./api"; diff --git a/app/client/src/api/services/ConsolidatedPageLoadApi/api.ts b/app/client/src/api/services/ConsolidatedPageLoadApi/api.ts new file mode 100644 index 00000000000..4772853c901 --- /dev/null +++ b/app/client/src/api/services/ConsolidatedPageLoadApi/api.ts @@ -0,0 +1,20 @@ +import { api } from "api/core"; +import type { InitConsolidatedApi } from "sagas/InitSagas"; + +const BASE_URL = "v1/consolidated-api"; +const VIEW_URL = `${BASE_URL}/view`; +const EDIT_URL = `${BASE_URL}/edit`; + +export const getConsolidatedPageLoadDataView = async (params: { + applicationId?: string; + defaultPageId?: string; +}) => { + return api.get(VIEW_URL, { params }); +}; + +export const getConsolidatedPageLoadDataEdit = async (params: { + applicationId?: string; + defaultPageId?: string; +}) => { + return api.get(EDIT_URL, { params }); +}; diff --git a/app/client/src/api/services/ConsolidatedPageLoadApi/index.ts b/app/client/src/api/services/ConsolidatedPageLoadApi/index.ts new file mode 100644 index 00000000000..d158c576401 --- /dev/null +++ b/app/client/src/api/services/ConsolidatedPageLoadApi/index.ts @@ -0,0 +1 @@ +export * from "./api"; diff --git a/app/client/src/api/services/index.ts b/app/client/src/api/services/index.ts new file mode 100644 index 00000000000..b1e3b877481 --- /dev/null +++ b/app/client/src/api/services/index.ts @@ -0,0 +1,2 @@ +export * as AppThemingApi from "./AppThemingApi"; +export * as ConsolidatedPageLoadApi from "./ConsolidatedPageLoadApi"; diff --git a/app/client/src/api/types.ts b/app/client/src/api/types.ts new file mode 100644 index 00000000000..4ce60997eff --- /dev/null +++ b/app/client/src/api/types.ts @@ -0,0 +1,24 @@ +import type { AxiosError, AxiosResponse } from "axios"; + +export interface ApiResponseError { + code: string; + message: string; +} + +export interface ApiResponseMeta { + status: number; + success: boolean; + error?: ApiResponseError; +} + +export interface ApiResponse { + responseMeta: ApiResponseMeta; + data: T; + code?: string; +} + +export type AxiosResponseData = AxiosResponse>["data"]; + +export type ErrorHandler = ( + error: AxiosError, +) => Promise; diff --git a/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx b/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx new file mode 100644 index 00000000000..8e44395d5a0 --- /dev/null +++ b/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx @@ -0,0 +1,87 @@ +import React from "react"; +import { usePluginActionContext } from "PluginActionEditor/PluginActionContext"; +import type { BottomTab } from "components/editorComponents/EntityBottomTabs"; +import { getIDEViewMode } from "selectors/ideSelectors"; +import { useSelector } from "react-redux"; +import { EditorViewMode } from "ee/entities/IDE/constants"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { + createMessage, + DEBUGGER_ERRORS, + DEBUGGER_HEADERS, + DEBUGGER_LOGS, + DEBUGGER_RESPONSE, +} from "ee/constants/messages"; +import ErrorLogs from "components/editorComponents/Debugger/Errors"; +import DebuggerLogs from "components/editorComponents/Debugger/DebuggerLogs"; +import { PluginType } from "entities/Action"; +import { ApiResponse } from "PluginActionEditor/components/PluginActionResponse/components/ApiResponse"; +import { ApiResponseHeaders } from "PluginActionEditor/components/PluginActionResponse/components/ApiResponseHeaders"; +import { noop } from "lodash"; +import { EditorTheme } from "components/editorComponents/CodeEditor/EditorConfig"; +import { getErrorCount } from "selectors/debuggerSelectors"; +import { getApiPaneDebuggerState } from "selectors/apiPaneSelectors"; + +function usePluginActionResponseTabs() { + const { action, actionResponse, plugin } = usePluginActionContext(); + + const IDEViewMode = useSelector(getIDEViewMode); + const errorCount = useSelector(getErrorCount); + + const { responseTabHeight } = useSelector(getApiPaneDebuggerState); + + const tabs: BottomTab[] = []; + + if (IDEViewMode === EditorViewMode.FullScreen) { + tabs.push( + { + key: DEBUGGER_TAB_KEYS.ERROR_TAB, + title: createMessage(DEBUGGER_ERRORS), + count: errorCount, + panelComponent: , + }, + { + key: DEBUGGER_TAB_KEYS.LOGS_TAB, + title: createMessage(DEBUGGER_LOGS), + panelComponent: , + }, + ); + } + + if (plugin.type === PluginType.API) { + return tabs.concat([ + { + key: DEBUGGER_TAB_KEYS.RESPONSE_TAB, + title: createMessage(DEBUGGER_RESPONSE), + panelComponent: ( + + ), + }, + { + key: DEBUGGER_TAB_KEYS.HEADER_TAB, + title: createMessage(DEBUGGER_HEADERS), + panelComponent: ( + + ), + }, + ]); + } + + return tabs; +} + +export default usePluginActionResponseTabs; diff --git a/app/client/src/ce/api/ApiUtils.test.ts b/app/client/src/ce/api/ApiUtils.test.ts deleted file mode 100644 index c1848f77605..00000000000 --- a/app/client/src/ce/api/ApiUtils.test.ts +++ /dev/null @@ -1,127 +0,0 @@ -import { - apiRequestInterceptor, - apiSuccessResponseInterceptor, - apiFailureResponseInterceptor, - axiosConnectionAbortedCode, -} from "./ApiUtils"; -import type { AxiosRequestConfig, AxiosResponse } from "axios"; -import type { ActionExecutionResponse } from "api/ActionAPI"; -import { - createMessage, - ERROR_0, - SERVER_API_TIMEOUT_ERROR, -} from "ee/constants/messages"; -import { ERROR_CODES } from "ee/constants/ApiConstants"; -import * as Sentry from "@sentry/react"; - -describe("axios api interceptors", () => { - describe("Axios api request interceptor", () => { - it("adds timer to the request object", () => { - const request: AxiosRequestConfig = { - url: "https://app.appsmith.com/v1/api/actions/execute", - }; - const interceptedRequest = apiRequestInterceptor(request); - - expect(interceptedRequest).toHaveProperty("timer"); - }); - }); - - describe("Axios api response success interceptor", () => { - it("transforms an action execution response", () => { - const response: AxiosResponse = { - data: "Test data", - headers: { - "content-length": 123, - "content-type": "application/json", - }, - config: { - url: "https://app.appsmith.com/v1/api/actions/execute", - // @ts-expect-error: type mismatch - timer: 0, - }, - }; - - const interceptedResponse: ActionExecutionResponse = - apiSuccessResponseInterceptor(response); - - expect(interceptedResponse).toHaveProperty("clientMeta"); - expect(interceptedResponse.clientMeta).toHaveProperty("size"); - expect(interceptedResponse.clientMeta.size).toBe(123); - expect(interceptedResponse.clientMeta).toHaveProperty("duration"); - }); - - it("just returns the response data for other requests", () => { - const response: AxiosResponse = { - data: "Test data", - headers: { - "content-type": "application/json", - }, - config: { - url: "https://app.appsmith.com/v1/api/actions", - //@ts-expect-error: type mismatch - timer: 0, - }, - }; - - const interceptedResponse: ActionExecutionResponse = - apiSuccessResponseInterceptor(response); - - expect(interceptedResponse).toBe("Test data"); - }); - }); - - describe("Api response failure interceptor", () => { - beforeEach(() => { - jest.restoreAllMocks(); - }); - - it("checks for no internet errors", () => { - jest.spyOn(navigator, "onLine", "get").mockReturnValue(false); - const interceptedResponse = apiFailureResponseInterceptor({}); - - expect(interceptedResponse).rejects.toStrictEqual({ - message: createMessage(ERROR_0), - }); - }); - - it.todo("handles axios cancel gracefully"); - - it("handles timeout errors", () => { - const error = { - code: axiosConnectionAbortedCode, - message: "timeout of 10000ms exceeded", - }; - const interceptedResponse = apiFailureResponseInterceptor(error); - - expect(interceptedResponse).rejects.toStrictEqual({ - message: createMessage(SERVER_API_TIMEOUT_ERROR), - code: ERROR_CODES.REQUEST_TIMEOUT, - }); - }); - - it("checks for response meta", () => { - const sentrySpy = jest.spyOn(Sentry, "captureException"); - const response: AxiosResponse = { - data: "Test data", - headers: { - "content-type": "application/json", - }, - config: { - url: "https://app.appsmith.com/v1/api/user", - //@ts-expect-error: type mismatch - timer: 0, - }, - }; - - apiSuccessResponseInterceptor(response); - expect(sentrySpy).toHaveBeenCalled(); - - const interceptedFailureResponse = apiFailureResponseInterceptor({ - response, - }); - - expect(interceptedFailureResponse).rejects.toStrictEqual("Test data"); - expect(sentrySpy).toHaveBeenCalled(); - }); - }); -}); diff --git a/app/client/src/ce/api/ApiUtils.ts b/app/client/src/ce/api/ApiUtils.ts index b157db36686..9db9f45e1d7 100644 --- a/app/client/src/ce/api/ApiUtils.ts +++ b/app/client/src/ce/api/ApiUtils.ts @@ -1,289 +1,7 @@ -import { - createMessage, - ERROR_0, - ERROR_413, - ERROR_500, - GENERIC_API_EXECUTION_ERROR, - SERVER_API_TIMEOUT_ERROR, -} from "ee/constants/messages"; -import type { AxiosRequestConfig, AxiosResponse } from "axios"; -import axios from "axios"; -import { - API_STATUS_CODES, - ERROR_CODES, - SERVER_ERROR_CODES, -} from "ee/constants/ApiConstants"; -import log from "loglevel"; -import type { ActionExecutionResponse } from "api/ActionAPI"; -import store from "store"; -import { logoutUser } from "actions/userActions"; -import { AUTH_LOGIN_URL } from "constants/routes"; -import { getCurrentGitBranch } from "selectors/gitSyncSelectors"; -import getQueryParamsObject from "utils/getQueryParamsObject"; -import { UserCancelledActionExecutionError } from "sagas/ActionExecution/errorUtils"; -import AnalyticsUtil from "ee/utils/AnalyticsUtil"; -import { getAppsmithConfigs } from "ee/configs"; -import * as Sentry from "@sentry/react"; -import { CONTENT_TYPE_HEADER_KEY } from "constants/ApiEditorConstants/CommonApiConstants"; -import { isAirgapped } from "ee/utils/airgapHelpers"; -import { getCurrentEnvironmentId } from "ee/selectors/environmentSelectors"; import { UNUSED_ENV_ID } from "constants/EnvironmentContants"; -import { ID_EXTRACTION_REGEX } from "ee/constants/routes/appRoutes"; - -const executeActionRegex = /actions\/execute/; -const timeoutErrorRegex = /timeout of (\d+)ms exceeded/; - -export const axiosConnectionAbortedCode = "ECONNABORTED"; -const appsmithConfig = getAppsmithConfigs(); export const DEFAULT_ENV_ID = UNUSED_ENV_ID; -export const BLOCKED_ROUTES = [ - "v1/app-templates", - "v1/datasources/mocks", - "v1/usage-pulse", - "v1/applications/releaseItems", - "v1/saas", -]; - -export const BLOCKED_ROUTES_REGEX = new RegExp( - `^(${BLOCKED_ROUTES.join("|")})($|/)`, -); - -export const ENV_ENABLED_ROUTES = [ - `v1/datasources/${ID_EXTRACTION_REGEX}/structure`, - `/v1/datasources/${ID_EXTRACTION_REGEX}/trigger`, - "v1/actions/execute", - "v1/saas", -]; - -export const ENV_ENABLED_ROUTES_REGEX = new RegExp( - `^(${ENV_ENABLED_ROUTES.join("|")})($|/)`, -); - -// TODO: Fix this the next time the file is edited -// eslint-disable-next-line @typescript-eslint/no-explicit-any -const makeExecuteActionResponse = (response: any): ActionExecutionResponse => ({ - ...response.data, - clientMeta: { - size: response.headers["content-length"], - duration: Number(performance.now() - response.config.timer).toFixed(), - }, -}); - -const is404orAuthPath = () => { - const pathName = window.location.pathname; - - return /^\/404/.test(pathName) || /^\/user\/\w+/.test(pathName); -}; - -export const blockedApiRoutesForAirgapInterceptor = async ( - config: AxiosRequestConfig, -) => { - const { url } = config; - - const isAirgappedInstance = isAirgapped(); - - if (isAirgappedInstance && url && BLOCKED_ROUTES_REGEX.test(url)) { - return Promise.resolve({ data: null, status: 200 }); - } - - return config; -}; - -// Request interceptor will add a timer property to the request. -// this will be used to calculate the time taken for an action -// execution request -export const apiRequestInterceptor = (config: AxiosRequestConfig) => { - config.headers = config.headers ?? {}; - - // Add header for CSRF protection. - const methodUpper = config.method?.toUpperCase(); - - if (methodUpper && methodUpper !== "GET" && methodUpper !== "HEAD") { - config.headers["X-Requested-By"] = "Appsmith"; - } - - const state = store.getState(); - const branch = getCurrentGitBranch(state) || getQueryParamsObject().branch; - - if (branch && config.headers) { - config.headers.branchName = branch; - } - - if (config.url?.indexOf("/git/") !== -1) { - config.timeout = 1000 * 120; // increase timeout for git specific APIs - } - - if (ENV_ENABLED_ROUTES_REGEX.test(config.url?.split("?")[0] || "")) { - // Add header for environment name - const activeEnv = getCurrentEnvironmentId(state); - - if (activeEnv && config.headers) { - config.headers["X-Appsmith-EnvironmentId"] = activeEnv; - } - } - - const anonymousId = AnalyticsUtil.getAnonymousId(); - - appsmithConfig.segment.enabled && - anonymousId && - (config.headers["x-anonymous-user-id"] = anonymousId); - - return { ...config, timer: performance.now() }; -}; - -// On success of an API, if the api is an action execution, -// add the client meta object with size and time taken info -// otherwise just return the data -export const apiSuccessResponseInterceptor = ( - response: AxiosResponse, -): AxiosResponse["data"] => { - if (response.config.url) { - if (response.config.url.match(executeActionRegex)) { - return makeExecuteActionResponse(response); - } - } - - if ( - response.headers[CONTENT_TYPE_HEADER_KEY] === "application/json" && - !response.data.responseMeta - ) { - Sentry.captureException(new Error("Api responded without response meta"), { - contexts: { response: response.data }, - }); - } - - return response.data; -}; - -// Handle different api failure scenarios -// TODO: Fix this the next time the file is edited -// eslint-disable-next-line @typescript-eslint/no-explicit-any -export const apiFailureResponseInterceptor = async (error: any) => { - // this can be extended to other errors we want to catch. - // in this case it is 413. - if (error && error?.response && error?.response.status === 413) { - return Promise.reject({ - ...error, - clientDefinedError: true, - statusCode: "AE-APP-4013", - message: createMessage(ERROR_413, 100), - pluginErrorDetails: { - appsmithErrorCode: "AE-APP-4013", - appsmithErrorMessage: createMessage(ERROR_413, 100), - errorType: "INTERNAL_ERROR", // this value is from the server, hence cannot construct enum type. - title: createMessage(GENERIC_API_EXECUTION_ERROR), - }, - }); - } - - // Return error when there is no internet - if (!window.navigator.onLine) { - return Promise.reject({ - ...error, - message: createMessage(ERROR_0), - }); - } - - // Return if the call was cancelled via cancel token - if (axios.isCancel(error)) { - throw new UserCancelledActionExecutionError(); - } - - // Return modified response if action execution failed - if (error.config && error.config.url.match(executeActionRegex)) { - return makeExecuteActionResponse(error.response); - } - - // Return error if any timeout happened in other api calls - if ( - error.code === axiosConnectionAbortedCode && - error.message && - error.message.match(timeoutErrorRegex) - ) { - return Promise.reject({ - ...error, - message: createMessage(SERVER_API_TIMEOUT_ERROR), - code: ERROR_CODES.REQUEST_TIMEOUT, - }); - } - - if (error.response) { - if (error.response.status === API_STATUS_CODES.SERVER_ERROR) { - return Promise.reject({ - ...error, - code: ERROR_CODES.SERVER_ERROR, - message: createMessage(ERROR_500), - }); - } - - // The request was made and the server responded with a status code - // that falls out of the range of 2xx - if (!is404orAuthPath()) { - const currentUrl = `${window.location.href}`; - - if (error.response.status === API_STATUS_CODES.REQUEST_NOT_AUTHORISED) { - // Redirect to login and set a redirect url. - store.dispatch( - logoutUser({ - redirectURL: `${AUTH_LOGIN_URL}?redirectUrl=${encodeURIComponent( - currentUrl, - )}`, - }), - ); - Sentry.captureException(error); - - return Promise.reject({ - ...error, - code: ERROR_CODES.REQUEST_NOT_AUTHORISED, - message: "Unauthorized. Redirecting to login page...", - show: false, - }); - } - - const errorData = error.response.data.responseMeta ?? {}; - - if ( - errorData.status === API_STATUS_CODES.RESOURCE_NOT_FOUND && - (SERVER_ERROR_CODES.RESOURCE_NOT_FOUND.includes(errorData.error.code) || - SERVER_ERROR_CODES.UNABLE_TO_FIND_PAGE.includes(errorData.error.code)) - ) { - Sentry.captureException(error); - - return Promise.reject({ - ...error, - code: ERROR_CODES.PAGE_NOT_FOUND, - message: "Resource Not Found", - show: false, - }); - } - } - - if (error.response.data.responseMeta) { - return Promise.resolve(error.response.data); - } - - Sentry.captureException(new Error("Api responded without response meta"), { - contexts: { response: error.response.data }, - }); - - return Promise.reject(error.response.data); - } else if (error.request) { - // The request was made but no response was received - // `error.request` is an instance of XMLHttpRequest in the browser and an instance of - // http.ClientRequest in node.js - log.error(error.request); - } else { - // Something happened in setting up the request that triggered an Error - log.error("Error", error.message); - } - - log.debug(error.config); - - return Promise.resolve(error); -}; - // function to get the default environment export const getDefaultEnvId = () => { return DEFAULT_ENV_ID; diff --git a/app/client/src/ce/constants/ApiConstants.tsx b/app/client/src/ce/constants/ApiConstants.tsx index 75ad958e788..b1c7a6c7ee2 100644 --- a/app/client/src/ce/constants/ApiConstants.tsx +++ b/app/client/src/ce/constants/ApiConstants.tsx @@ -1,3 +1,7 @@ +import type { CreateAxiosDefaults } from "axios"; +import { ID_EXTRACTION_REGEX } from "constants/routes"; +import { UNUSED_ENV_ID } from "constants/EnvironmentContants"; + export const REQUEST_TIMEOUT_MS = 20000; export const DEFAULT_ACTION_TIMEOUT = 10000; export const DEFAULT_EXECUTE_ACTION_TIMEOUT_MS = 15000; @@ -5,6 +9,44 @@ export const DEFAULT_TEST_DATA_SOURCE_TIMEOUT_MS = 30000; export const DEFAULT_APPSMITH_AI_QUERY_TIMEOUT_MS = 60000; export const FILE_UPLOAD_TRIGGER_TIMEOUT_MS = 60000; +export const DEFAULT_AXIOS_CONFIG: CreateAxiosDefaults = { + baseURL: "/api/", + timeout: REQUEST_TIMEOUT_MS, + headers: { + "Content-Type": "application/json", + }, + withCredentials: true, +}; + +export const EXECUTION_ACTION_REGEX = /actions\/execute/; +export const TIMEOUT_ERROR_REGEX = /timeout of (\d+)ms exceeded/; +export const AXIOS_CONNECTION_ABORTED_CODE = "ECONNABORTED"; + +export const DEFAULT_ENV_ID = UNUSED_ENV_ID; + +export const BLOCKED_ROUTES = [ + "v1/app-templates", + "v1/datasources/mocks", + "v1/usage-pulse", + "v1/applications/releaseItems", + "v1/saas", +]; + +export const BLOCKED_ROUTES_REGEX = new RegExp( + `^(${BLOCKED_ROUTES.join("|")})($|/)`, +); + +export const ENV_ENABLED_ROUTES = [ + `v1/datasources/${ID_EXTRACTION_REGEX}/structure`, + `/v1/datasources/${ID_EXTRACTION_REGEX}/trigger`, + "v1/actions/execute", + "v1/saas", +]; + +export const ENV_ENABLED_ROUTES_REGEX = new RegExp( + `^(${ENV_ENABLED_ROUTES.join("|")})($|/)`, +); + export enum API_STATUS_CODES { REQUEST_NOT_AUTHORISED = 401, RESOURCE_NOT_FOUND = 404, diff --git a/app/client/src/ce/constants/messages.ts b/app/client/src/ce/constants/messages.ts index ce9dd82b126..b9ca94d7ffd 100644 --- a/app/client/src/ce/constants/messages.ts +++ b/app/client/src/ce/constants/messages.ts @@ -555,7 +555,9 @@ export const NO_LOGS = () => "No logs to show"; export const NO_ERRORS = () => "No signs of trouble here!"; export const DEBUGGER_ERRORS = () => "Errors"; export const DEBUGGER_RESPONSE = () => "Response"; +export const DEBUGGER_HEADERS = () => "Headers"; export const DEBUGGER_LOGS = () => "Logs"; + export const INSPECT_ENTITY = () => "Inspect entity"; export const INSPECT_ENTITY_BLANK_STATE = () => "Select an entity to inspect"; export const VALUE_IS_INVALID = (propertyPath: string) => diff --git a/app/client/src/ce/entities/FeatureFlag.ts b/app/client/src/ce/entities/FeatureFlag.ts index 69ac4b7e9c6..63d49c89f77 100644 --- a/app/client/src/ce/entities/FeatureFlag.ts +++ b/app/client/src/ce/entities/FeatureFlag.ts @@ -21,8 +21,6 @@ export const FEATURE_FLAG = { "license_git_branch_protection_enabled", license_git_continuous_delivery_enabled: "license_git_continuous_delivery_enabled", - release_git_autocommit_feature_enabled: - "release_git_autocommit_feature_enabled", license_widget_rtl_support_enabled: "license_widget_rtl_support_enabled", ab_one_click_learning_popover_enabled: "ab_one_click_learning_popover_enabled", @@ -68,7 +66,6 @@ export const DEFAULT_FEATURE_FLAG_VALUE: FeatureFlags = { release_drag_drop_building_blocks_enabled: false, release_table_cell_label_value_enabled: false, license_git_branch_protection_enabled: false, - release_git_autocommit_feature_enabled: false, license_git_continuous_delivery_enabled: false, license_widget_rtl_support_enabled: false, ab_one_click_learning_popover_enabled: false, diff --git a/app/client/src/ce/pages/Editor/AppPluginActionEditor/AppPluginActionEditor.tsx b/app/client/src/ce/pages/Editor/AppPluginActionEditor/AppPluginActionEditor.tsx index e5f9366c05c..bad7cdba93c 100644 --- a/app/client/src/ce/pages/Editor/AppPluginActionEditor/AppPluginActionEditor.tsx +++ b/app/client/src/ce/pages/Editor/AppPluginActionEditor/AppPluginActionEditor.tsx @@ -2,7 +2,7 @@ import React from "react"; import { PluginActionEditor, PluginActionForm, - PluginActionResponsePane, + PluginActionResponse, } from "PluginActionEditor"; import { ConvertToModuleDisabler, @@ -17,7 +17,7 @@ const AppPluginActionEditor = () => { - + ); diff --git a/app/client/src/ce/sagas/PageSagas.tsx b/app/client/src/ce/sagas/PageSagas.tsx index 2ab7c28753e..12e52ba930c 100644 --- a/app/client/src/ce/sagas/PageSagas.tsx +++ b/app/client/src/ce/sagas/PageSagas.tsx @@ -149,7 +149,7 @@ import type { LayoutSystemTypes } from "layoutSystems/types"; import { getIsAnvilLayout } from "layoutSystems/anvil/integrations/selectors"; import { convertToBasePageIdSelector } from "selectors/pageListSelectors"; import type { Page } from "entities/Page"; -import ConsolidatedPageLoadApi from "api/ConsolidatedPageLoadApi"; +import { ConsolidatedPageLoadApi } from "api"; export const checkIfMigrationIsNeeded = ( fetchPageResponse?: FetchPageResponse, diff --git a/app/client/src/components/editorComponents/ActionExecutionInProgressView.tsx b/app/client/src/components/editorComponents/ActionExecutionInProgressView.tsx index 64af215f18a..627d1f1de39 100644 --- a/app/client/src/components/editorComponents/ActionExecutionInProgressView.tsx +++ b/app/client/src/components/editorComponents/ActionExecutionInProgressView.tsx @@ -63,9 +63,7 @@ const ActionExecutionInProgressView = ({
- ), - [API_RESPONSE_TYPE_OPTIONS.RAW]: ( - - ), - }[responseType]; -}; - -const StyledText = styled(Text)` - &&&& { - margin-top: 0; - } -`; - -interface NoResponseProps { - isButtonDisabled: boolean | undefined; - isQueryRunning: boolean; - onRunClick: () => void; -} -export const NoResponse = (props: NoResponseProps) => ( - - no-response-yet -
- {EMPTY_RESPONSE_FIRST_HALF()} - - {EMPTY_RESPONSE_LAST_HALF()} -
-
-); - function ApiResponseView(props: Props) { const { actionResponse = EMPTY_RESPONSE, - apiName, currentActionConfig, disabled, isRunning, - responseDataTypes, - responseDisplayFormat, theme = EditorTheme.LIGHT, } = props; - const hasFailed = actionResponse.statusCode - ? actionResponse.statusCode[0] !== "2" - : false; const dispatch = useDispatch(); const errorCount = useSelector(getErrorCount); @@ -234,256 +63,55 @@ function ApiResponseView(props: Props) { }); }; - const messages = actionResponse?.messages; - let responseHeaders = {}; - - // if no headers are present in the response, use the default body text. - if (actionResponse.headers) { - Object.entries(actionResponse.headers).forEach(([key, value]) => { - if (isArray(value) && value.length < 2) - return (responseHeaders = { - ...responseHeaders, - [key]: value[0], + // update the selected tab in the response pane. + const updateSelectedResponseTab = useCallback( + (tabKey: string) => { + if (tabKey === DEBUGGER_TAB_KEYS.ERROR_TAB) { + AnalyticsUtil.logEvent("OPEN_DEBUGGER", { + source: "API_PANE", }); + } - return (responseHeaders = { - ...responseHeaders, - [key]: value, - }); - }); - } else { - // if the response headers is empty show an empty object. - responseHeaders = {}; - } - - const onResponseTabSelect = (tab: string) => { - dispatch( - setActionResponseDisplayFormat({ - id: currentActionConfig?.id || "", - field: "responseDisplayFormat", - value: tab, - }), - ); - }; - - let filteredResponseDataTypes: { key: string; title: string }[] = [ - ...responseDataTypes, - ]; - - if (!!actionResponse.body && !isArray(actionResponse.body)) { - filteredResponseDataTypes = responseDataTypes.filter( - (item) => item.key !== API_RESPONSE_TYPE_OPTIONS.TABLE, - ); - - if (responseDisplayFormat.title === API_RESPONSE_TYPE_OPTIONS.TABLE) { - onResponseTabSelect(filteredResponseDataTypes[0]?.title); - } - } - - const responseTabs = - filteredResponseDataTypes && - filteredResponseDataTypes.map((dataType, index) => { - return { - index: index, - key: dataType.key, - title: dataType.title, - panelComponent: responseTabComponent( - dataType.key, - actionResponse?.body, - responseTabHeight, - ), - }; - }); - - const segmentedControlOptions = - responseTabs && - responseTabs.map((item) => { - return { value: item.key, label: item.title }; - }); - - const [selectedControl, setSelectedControl] = useState( - segmentedControlOptions[0]?.value, + dispatch(setApiPaneDebuggerState({ open: true, selectedTab: tabKey })); + }, + [dispatch], ); - const selectedTabIndex = - filteredResponseDataTypes && - filteredResponseDataTypes.findIndex( - (dataType) => dataType.title === responseDisplayFormat?.title, - ); - - // update the selected tab in the response pane. - const updateSelectedResponseTab = useCallback((tabKey: string) => { - if (tabKey === DEBUGGER_TAB_KEYS.ERROR_TAB) { - AnalyticsUtil.logEvent("OPEN_DEBUGGER", { - source: "API_PANE", - }); - } - - dispatch(setApiPaneDebuggerState({ open: true, selectedTab: tabKey })); - }, []); - // update the height of the response pane on resize. - const updateResponsePaneHeight = useCallback((height: number) => { - dispatch(setApiPaneDebuggerState({ responseTabHeight: height })); - }, []); + const updateResponsePaneHeight = useCallback( + (height: number) => { + dispatch(setApiPaneDebuggerState({ responseTabHeight: height })); + }, + [dispatch], + ); - // get request timestamp formatted to human readable format. - const responseState = getUpdateTimestamp(actionResponse.request); - // action source for analytics. - const actionSource: SourceEntity = { - type: ENTITY_TYPE.ACTION, - name: currentActionConfig ? currentActionConfig.name : "API", - id: currentActionConfig?.id || "", - }; const tabs: BottomTab[] = [ { - key: "response", + key: DEBUGGER_TAB_KEYS.RESPONSE_TAB, title: createMessage(DEBUGGER_RESPONSE), panelComponent: ( - - - {Array.isArray(messages) && messages.length > 0 && ( - - {messages.map((msg, i) => ( - - {msg} - - ))} - - )} - {isRunning && ( - - )} - {hasFailed && !isRunning ? ( - - - - Your API failed to execute - {actionResponse.pluginErrorDetails && ":"} - - {actionResponse.pluginErrorDetails && ( - <> -
- {actionResponse.pluginErrorDetails.downstreamErrorMessage} -
- {actionResponse.pluginErrorDetails.downstreamErrorCode && ( - - )} - - )} - -
- {actionResponse.request && ( - e.stopPropagation()} - > - - - )} -
- ) : ( - - {isEmpty(actionResponse.statusCode) ? ( - - ) : ( - - {isString(actionResponse?.body) && - isHtml(actionResponse?.body) ? ( - - ) : responseTabs && - responseTabs.length > 0 && - selectedTabIndex !== -1 ? ( - - - { - setSelectedControl(value); - onResponseTabSelect(value); - }} - options={segmentedControlOptions} - value={selectedControl} - /> - - {responseTabComponent( - selectedControl || segmentedControlOptions[0]?.value, - actionResponse?.body, - responseTabHeight, - )} - - ) : null} - - )} - - )} -
+ ), }, { - key: "headers", - title: "Headers", + key: DEBUGGER_TAB_KEYS.HEADER_TAB, + title: createMessage(DEBUGGER_HEADERS), panelComponent: ( - - {hasFailed && !isRunning && ( - - {createMessage(CHECK_REQUEST_BODY)} - - )} - - {isEmpty(actionResponse.statusCode) ? ( - - ) : ( - - )} - - + ), }, ]; @@ -499,7 +127,7 @@ function ApiResponseView(props: Props) { { key: DEBUGGER_TAB_KEYS.LOGS_TAB, title: createMessage(DEBUGGER_LOGS), - panelComponent: , + panelComponent: , }, ); } @@ -508,7 +136,7 @@ function ApiResponseView(props: Props) { //TODO: move this to a common place const toggleHide = useCallback( () => dispatch(setApiPaneDebuggerState({ open: !open })), - [open], + [dispatch, open], ); return ( diff --git a/app/client/src/components/editorComponents/JSResponseView.tsx b/app/client/src/components/editorComponents/JSResponseView.tsx index 42543824be7..91d8519abe0 100644 --- a/app/client/src/components/editorComponents/JSResponseView.tsx +++ b/app/client/src/components/editorComponents/JSResponseView.tsx @@ -27,13 +27,13 @@ import { DEBUGGER_TAB_KEYS } from "./Debugger/helpers"; import type { BottomTab } from "./EntityBottomTabs"; import EntityBottomTabs from "./EntityBottomTabs"; import { getIsSavingEntity } from "selectors/editorSelectors"; -import { getJSResponseViewState } from "./utils"; +import { getJSResponseViewState, JSResponseState } from "./utils"; import { getFilteredErrors } from "selectors/debuggerSelectors"; +import { NoResponse } from "PluginActionEditor/components/PluginActionResponse/components/NoResponse"; import { - NoResponse, ResponseTabErrorContainer, ResponseTabErrorContent, -} from "./ApiResponseView"; +} from "PluginActionEditor/components/PluginActionResponse/components/ApiResponse"; import LogHelper from "./Debugger/ErrorLogs/components/LogHelper"; import LOG_TYPE from "entities/AppsmithConsole/logtype"; import type { Log, SourceEntity } from "entities/AppsmithConsole"; @@ -45,7 +45,7 @@ import { EditorViewMode } from "ee/entities/IDE/constants"; import ErrorLogs from "./Debugger/Errors"; import { isBrowserExecutionAllowed } from "ee/utils/actionExecutionUtils"; import JSRemoteExecutionView from "ee/components/JSRemoteExecutionView"; -import { IDEBottomView, ViewHideBehaviour } from "../../IDE"; +import { IDEBottomView, ViewHideBehaviour } from "IDE"; const ResponseTabWrapper = styled.div` display: flex; @@ -66,15 +66,6 @@ const NoReturnValueWrapper = styled.div` padding-top: ${(props) => props.theme.spaces[6]}px; `; -export enum JSResponseState { - IsExecuting = "IsExecuting", - IsDirty = "IsDirty", - IsUpdating = "IsUpdating", - NoResponse = "NoResponse", - ShowResponse = "ShowResponse", - NoReturnValue = "NoReturnValue", -} - interface ReduxStateProps { errorCount: number; } @@ -229,8 +220,8 @@ function JSResponseView(props: Props) { <> {responseStatus === JSResponseState.NoResponse && ( { - const doc = new DOMParser().parseFromString(str, "text/html"); - - return Array.from(doc.body.childNodes).some( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (node: any) => node.nodeType === 1, - ); -}; +export enum JSResponseState { + IsExecuting = "IsExecuting", + IsDirty = "IsDirty", + IsUpdating = "IsUpdating", + NoResponse = "NoResponse", + ShowResponse = "ShowResponse", + NoReturnValue = "NoReturnValue", +} /** * Returns state of the JSResponseview editor component diff --git a/app/client/src/constants/ApiEditorConstants/CommonApiConstants.ts b/app/client/src/constants/ApiEditorConstants/CommonApiConstants.ts index 978879ba5e5..eacd44f72e6 100644 --- a/app/client/src/constants/ApiEditorConstants/CommonApiConstants.ts +++ b/app/client/src/constants/ApiEditorConstants/CommonApiConstants.ts @@ -85,29 +85,14 @@ export const HTTP_METHODS_DEFAULT_FORMAT_TYPES: Record = { PATCH: POST_BODY_FORMAT_OPTIONS.JSON, }; -export const DEFAULT_PROVIDER_OPTION = "Business Software"; export const CONTENT_TYPE_HEADER_KEY = "content-type"; -export enum ApiResponseTypes { +export enum ResponseDisplayFormats { JSON = "JSON", TABLE = "TABLE", RAW = "RAW", } -// export const ApiResponseTypesOptions: -export const API_RESPONSE_TYPE_OPTIONS: { - [key in keyof typeof ApiResponseTypes]: string; -} = { - JSON: "JSON", - TABLE: "TABLE", - RAW: "RAW", -}; -export const POST_BODY_FORMATS = Object.values(POST_BODY_FORMAT_OPTIONS).map( - (option) => { - return option; - }, -); - export const POST_BODY_FORMAT_OPTIONS_ARRAY = Object.values( POST_BODY_FORMAT_OPTIONS, ); @@ -133,6 +118,4 @@ export interface MULTI_PART_DROPDOWN_OPTION { export const MULTI_PART_DROPDOWN_OPTIONS: MULTI_PART_DROPDOWN_OPTION[] = Object.values(MultiPartOptionTypes).map((value) => ({ label: value, value })); -export const DEFAULT_MULTI_PART_DROPDOWN_WIDTH = "77px"; -export const DEFAULT_MULTI_PART_DROPDOWN_HEIGHT = "100%"; export const DEFAULT_MULTI_PART_DROPDOWN_PLACEHOLDER = "Type"; diff --git a/app/client/src/ee/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx b/app/client/src/ee/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx new file mode 100644 index 00000000000..0e7b0e46546 --- /dev/null +++ b/app/client/src/ee/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx @@ -0,0 +1 @@ +export { default } from "ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs"; diff --git a/app/client/src/layoutSystems/anvil/common/AnvilFlexComponent.tsx b/app/client/src/layoutSystems/anvil/common/AnvilFlexComponent.tsx index f0d1f37c384..b59ee2bf8b3 100644 --- a/app/client/src/layoutSystems/anvil/common/AnvilFlexComponent.tsx +++ b/app/client/src/layoutSystems/anvil/common/AnvilFlexComponent.tsx @@ -15,7 +15,7 @@ import { Layers } from "constants/Layers"; import { noop } from "utils/AppsmithUtils"; import { convertFlexGrowToFlexBasis } from "../sectionSpaceDistributor/utils/spaceDistributionEditorUtils"; import styles from "./styles.module.css"; -import { AnvilDataAttributes } from "widgets/wds/constants"; +import { AnvilDataAttributes } from "modules/ui-builder/ui/wds/constants"; const anvilWidgetStyleProps: CSSProperties = { position: "relative", diff --git a/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilDnDListenerStates.ts b/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilDnDListenerStates.ts index 056c09f07ac..0b08fa248ba 100644 --- a/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilDnDListenerStates.ts +++ b/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilDnDListenerStates.ts @@ -15,7 +15,7 @@ import { getWidgetHierarchy } from "layoutSystems/anvil/utils/paste/utils"; import type { AnvilGlobalDnDStates } from "../../canvas/hooks/useAnvilGlobalDnDStates"; import { getWidgets } from "sagas/selectors"; import { useMemo } from "react"; -import { WDSZoneWidget } from "widgets/wds/WDSZoneWidget"; +import { WDSZoneWidget } from "modules/ui-builder/ui/wds/WDSZoneWidget"; import { useAnvilWidgetElevation } from "../../canvas/providers/AnvilWidgetElevationProvider"; interface AnvilDnDListenerStatesProps { diff --git a/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilWidgetDrop.ts b/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilWidgetDrop.ts index 8e39600bae3..9e36ffe8836 100644 --- a/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilWidgetDrop.ts +++ b/app/client/src/layoutSystems/anvil/editor/canvasArenas/hooks/useAnvilWidgetDrop.ts @@ -7,7 +7,7 @@ import type { AnvilHighlightInfo } from "layoutSystems/anvil/utils/anvilTypes"; import { useCallback } from "react"; import { useDispatch } from "react-redux"; import type { AnvilDnDListenerStates } from "./useAnvilDnDListenerStates"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; export const useAnvilWidgetDrop = ( canvasId: string, diff --git a/app/client/src/layoutSystems/anvil/editor/canvasArenas/utils/utils.ts b/app/client/src/layoutSystems/anvil/editor/canvasArenas/utils/utils.ts index e84c9ff65e1..f5e615b6f60 100644 --- a/app/client/src/layoutSystems/anvil/editor/canvasArenas/utils/utils.ts +++ b/app/client/src/layoutSystems/anvil/editor/canvasArenas/utils/utils.ts @@ -7,7 +7,7 @@ import WidgetFactory from "WidgetProvider/factory"; import type { CanvasWidgetsReduxState } from "reducers/entityReducers/canvasWidgetsReducer"; import type { DragDetails } from "reducers/uiReducers/dragResizeReducer"; import { AnvilDraggedWidgetTypesEnum } from "../types"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { HIGHLIGHT_SIZE } from "layoutSystems/anvil/utils/constants"; import { getWidgetHierarchy } from "layoutSystems/anvil/utils/paste/utils"; diff --git a/app/client/src/layoutSystems/anvil/editor/hooks/useAnvilWidgetStyles.ts b/app/client/src/layoutSystems/anvil/editor/hooks/useAnvilWidgetStyles.ts index 65dd6ecb5eb..80bf9d9e235 100644 --- a/app/client/src/layoutSystems/anvil/editor/hooks/useAnvilWidgetStyles.ts +++ b/app/client/src/layoutSystems/anvil/editor/hooks/useAnvilWidgetStyles.ts @@ -4,7 +4,7 @@ import { useSelector } from "react-redux"; import { useWidgetBorderStyles } from "layoutSystems/anvil/common/hooks/useWidgetBorderStyles"; import type { AppState } from "ee/reducers"; import { getIsNewWidgetBeingDragged } from "sagas/selectors"; -import { AnvilDataAttributes } from "widgets/wds/constants"; +import { AnvilDataAttributes } from "modules/ui-builder/ui/wds/constants"; export const useAnvilWidgetStyles = ( widgetId: string, diff --git a/app/client/src/layoutSystems/anvil/integrations/sagas/anvilDraggingSagas/anvilDraggingSagas.test.ts b/app/client/src/layoutSystems/anvil/integrations/sagas/anvilDraggingSagas/anvilDraggingSagas.test.ts index f99eee1953f..c0db3545bf0 100644 --- a/app/client/src/layoutSystems/anvil/integrations/sagas/anvilDraggingSagas/anvilDraggingSagas.test.ts +++ b/app/client/src/layoutSystems/anvil/integrations/sagas/anvilDraggingSagas/anvilDraggingSagas.test.ts @@ -6,9 +6,9 @@ import { LayoutComponentTypes } from "layoutSystems/anvil/utils/anvilTypes"; import { expectSaga } from "redux-saga-test-plan"; import { getWidgets } from "sagas/selectors"; import { registerWidgets } from "WidgetProvider/factory/registrationHelper"; -import { WDSSectionWidget } from "widgets/wds/WDSSectionWidget"; -import { WDSZoneWidget } from "widgets/wds/WDSZoneWidget"; -import { WDSButtonWidget } from "widgets/wds/WDSButtonWidget"; +import { WDSSectionWidget } from "modules/ui-builder/ui/wds/WDSSectionWidget"; +import { WDSZoneWidget } from "modules/ui-builder/ui/wds/WDSZoneWidget"; +import { WDSButtonWidget } from "modules/ui-builder/ui/wds/WDSButtonWidget"; import { getCanvasWidth, getIsAutoLayoutMobileBreakPoint, @@ -20,7 +20,7 @@ import { registerLayoutComponents } from "layoutSystems/anvil/utils/layouts/layo import { getIsAnvilLayout } from "../../selectors"; import { selectWidgetInitAction } from "actions/widgetSelectionActions"; import { SelectionRequestType } from "sagas/WidgetSelectUtils"; -import { WDSModalWidget } from "widgets/wds/WDSModalWidget"; +import { WDSModalWidget } from "modules/ui-builder/ui/wds/WDSModalWidget"; import { generateMockDataWithTwoSections } from "./mockData.helper"; import type { AnvilMoveWidgetsPayload } from "../../actions/actionTypes"; import { diff --git a/app/client/src/layoutSystems/anvil/integrations/sagas/anvilWidgetAdditionSagas/index.ts b/app/client/src/layoutSystems/anvil/integrations/sagas/anvilWidgetAdditionSagas/index.ts index e57da857c10..c121a458358 100644 --- a/app/client/src/layoutSystems/anvil/integrations/sagas/anvilWidgetAdditionSagas/index.ts +++ b/app/client/src/layoutSystems/anvil/integrations/sagas/anvilWidgetAdditionSagas/index.ts @@ -11,7 +11,7 @@ import { type ReduxAction, } from "ee/constants/ReduxActionConstants"; import type { WidgetProps } from "widgets/BaseWidget"; -import { WDS_V2_WIDGET_MAP } from "widgets/wds/constants"; +import { WDS_V2_WIDGET_MAP } from "modules/ui-builder/ui/wds/constants"; import { MAIN_CONTAINER_WIDGET_ID } from "constants/WidgetConstants"; import { getMainCanvasLastRowHighlight } from "../anvilDraggingSagas/helpers"; import { updateAndSaveAnvilLayout } from "layoutSystems/anvil/utils/anvilChecksUtils"; diff --git a/app/client/src/layoutSystems/anvil/layoutComponents/components/section/index.tsx b/app/client/src/layoutSystems/anvil/layoutComponents/components/section/index.tsx index d3b9766adfe..4b30af0c6b3 100644 --- a/app/client/src/layoutSystems/anvil/layoutComponents/components/section/index.tsx +++ b/app/client/src/layoutSystems/anvil/layoutComponents/components/section/index.tsx @@ -7,7 +7,7 @@ import { import WidgetRow from "../WidgetRow"; import { SectionRow } from "./SectionRow"; import type { FlexLayoutProps } from "../FlexLayout"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { SectionSpaceDistributor } from "layoutSystems/anvil/sectionSpaceDistributor/SectionSpaceDistributor"; class Section extends WidgetRow { diff --git a/app/client/src/layoutSystems/anvil/utils/anvilChecksUtils.ts b/app/client/src/layoutSystems/anvil/utils/anvilChecksUtils.ts index ebb3284f353..00bb19299d9 100644 --- a/app/client/src/layoutSystems/anvil/utils/anvilChecksUtils.ts +++ b/app/client/src/layoutSystems/anvil/utils/anvilChecksUtils.ts @@ -4,7 +4,7 @@ import { updateAnvilParentPostWidgetDeletion } from "layoutSystems/anvil/utils/l import type { FlattenedWidgetProps } from "WidgetProvider/constants"; import { MAIN_CONTAINER_WIDGET_ID } from "constants/WidgetConstants"; import type { CanvasWidgetsReduxState } from "reducers/entityReducers/canvasWidgetsReducer"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { updateSectionWithDefaultSpaceDistribution, updateSectionsDistributedSpace, diff --git a/app/client/src/layoutSystems/anvil/utils/constants.ts b/app/client/src/layoutSystems/anvil/utils/constants.ts index ca127656209..e00c88b9fd8 100644 --- a/app/client/src/layoutSystems/anvil/utils/constants.ts +++ b/app/client/src/layoutSystems/anvil/utils/constants.ts @@ -1,6 +1,6 @@ import { FlexLayerAlignment } from "layoutSystems/common/utils/constants"; import type { HighlightPayload, HighlightRenderInfo } from "./anvilTypes"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; export const MOBILE_BREAKPOINT = 480; diff --git a/app/client/src/layoutSystems/anvil/utils/layouts/update/mainCanvasLayoutUtils.ts b/app/client/src/layoutSystems/anvil/utils/layouts/update/mainCanvasLayoutUtils.ts index 73c01e719ae..0b389c9e68f 100644 --- a/app/client/src/layoutSystems/anvil/utils/layouts/update/mainCanvasLayoutUtils.ts +++ b/app/client/src/layoutSystems/anvil/utils/layouts/update/mainCanvasLayoutUtils.ts @@ -11,7 +11,7 @@ import LayoutFactory from "layoutSystems/anvil/layoutComponents/LayoutFactory"; import { call } from "redux-saga/effects"; import { severTiesFromParents, transformMovedWidgets } from "./moveUtils"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { MAIN_CONTAINER_WIDGET_ID } from "constants/WidgetConstants"; import { addNewAnvilWidgetToDSL } from "layoutSystems/anvil/integrations/sagas/anvilWidgetAdditionSagas/helpers"; diff --git a/app/client/src/layoutSystems/anvil/utils/layouts/update/sectionUtils.ts b/app/client/src/layoutSystems/anvil/utils/layouts/update/sectionUtils.ts index 741af57edff..9a4f5df405e 100644 --- a/app/client/src/layoutSystems/anvil/utils/layouts/update/sectionUtils.ts +++ b/app/client/src/layoutSystems/anvil/utils/layouts/update/sectionUtils.ts @@ -13,7 +13,7 @@ import type { CanvasWidgetsReduxState } from "reducers/entityReducers/canvasWidg import { call } from "redux-saga/effects"; import { severTiesFromParents, transformMovedWidgets } from "./moveUtils"; import type { FlattenedWidgetProps } from "WidgetProvider/constants"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { addNewAnvilWidgetToDSL } from "layoutSystems/anvil/integrations/sagas/anvilWidgetAdditionSagas/helpers"; export function* createSectionAndAddWidget( diff --git a/app/client/src/layoutSystems/anvil/utils/layouts/update/zoneUtils.ts b/app/client/src/layoutSystems/anvil/utils/layouts/update/zoneUtils.ts index ca50e6bda37..acffc109491 100644 --- a/app/client/src/layoutSystems/anvil/utils/layouts/update/zoneUtils.ts +++ b/app/client/src/layoutSystems/anvil/utils/layouts/update/zoneUtils.ts @@ -11,7 +11,7 @@ import { call } from "redux-saga/effects"; import { addWidgetsToChildTemplate } from "./additionUtils"; import type { FlattenedWidgetProps } from "WidgetProvider/constants"; import { isLargeWidget } from "../../widgetUtils"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { moveWidgets, severTiesFromParents, diff --git a/app/client/src/layoutSystems/anvil/utils/paste/sectionPasteUtils.ts b/app/client/src/layoutSystems/anvil/utils/paste/sectionPasteUtils.ts index d6e5098140a..f0b7ee22d6c 100644 --- a/app/client/src/layoutSystems/anvil/utils/paste/sectionPasteUtils.ts +++ b/app/client/src/layoutSystems/anvil/utils/paste/sectionPasteUtils.ts @@ -6,7 +6,7 @@ import type { } from "./types"; import { getDestinedParent } from "./destinationUtils"; import type { FlattenedWidgetProps } from "WidgetProvider/constants"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import type { LayoutProps } from "../anvilTypes"; import { all, call } from "redux-saga/effects"; import { addPastedWidgets } from "./utils"; diff --git a/app/client/src/layoutSystems/anvil/utils/sectionOperationUtils.ts b/app/client/src/layoutSystems/anvil/utils/sectionOperationUtils.ts index 7716fafb96a..f7febdf4c76 100644 --- a/app/client/src/layoutSystems/anvil/utils/sectionOperationUtils.ts +++ b/app/client/src/layoutSystems/anvil/utils/sectionOperationUtils.ts @@ -13,7 +13,7 @@ import { generateReactKey } from "utils/generators"; import type BaseLayoutComponent from "../layoutComponents/BaseLayoutComponent"; import LayoutFactory from "../layoutComponents/LayoutFactory"; import { defaultHighlightRenderInfo } from "../utils/constants"; -import { anvilWidgets } from "widgets/wds/constants"; +import { anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import { getUpdatedListOfWidgetsAfterAddingNewWidget } from "../integrations/sagas/anvilWidgetAdditionSagas"; /** diff --git a/app/client/src/layoutSystems/withLayoutSystemWidgetHOC.test.tsx b/app/client/src/layoutSystems/withLayoutSystemWidgetHOC.test.tsx index 0d7e7218631..899c47c16cf 100644 --- a/app/client/src/layoutSystems/withLayoutSystemWidgetHOC.test.tsx +++ b/app/client/src/layoutSystems/withLayoutSystemWidgetHOC.test.tsx @@ -3,9 +3,9 @@ import React from "react"; import * as editorSelectors from "selectors/editorSelectors"; import { WidgetTypeFactories } from "test/factories/Widgets/WidgetTypeFactories"; import { render } from "test/testUtils"; -import InputWidget from "widgets/InputWidgetV2/widget"; +import InputWidget from "widgets/InputWidgetV2"; import { ModalWidget } from "widgets/ModalWidget/widget"; -import { WDSModalWidget } from "widgets/wds/WDSModalWidget/widget"; +import { WDSModalWidget } from "modules/ui-builder/ui/wds//WDSModalWidget/widget"; import { withLayoutSystemWidgetHOC } from "./withLayoutSystemWidgetHOC"; import { LayoutSystemTypes } from "./types"; import * as layoutSystemSelectors from "selectors/layoutSystemSelectors"; diff --git a/app/client/src/widgets/wds/Container.tsx b/app/client/src/modules/ui-builder/ui/wds/Container.tsx similarity index 100% rename from app/client/src/widgets/wds/Container.tsx rename to app/client/src/modules/ui-builder/ui/wds/Container.tsx diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/__tests__/helpers.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/__tests__/helpers.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/__tests__/helpers.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/__tests__/helpers.test.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/component/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/component/types.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/config/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/config/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/config/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/config/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/constants.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/constants.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/constants.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/constants.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/helpers.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/helpers.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/types.ts diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSBaseInputWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSBaseInputWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSBaseInputWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/component/Container.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/Container.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/component/Container.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/Container.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/component/RecaptchaV2.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/RecaptchaV2.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/component/RecaptchaV2.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/RecaptchaV2.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/component/RecaptchaV3.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/RecaptchaV3.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/component/RecaptchaV3.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/RecaptchaV3.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/component/useRecaptcha.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/useRecaptcha.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/component/useRecaptcha.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/component/useRecaptcha.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSButtonWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSButtonWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSButtonWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSButtonWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/defaultSelectedValuesValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/defaultSelectedValuesValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/defaultSelectedValuesValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/defaultSelectedValuesValidation.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/helpers.ts similarity index 79% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/helpers.ts index 8437834c4e7..aa0f5fee748 100644 --- a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/helpers.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/helpers.ts @@ -1,4 +1,4 @@ -import type { Validation } from "widgets/wds/WDSInputWidget/widget/types"; +import type { Validation } from "modules/ui-builder/ui/wds/WDSInputWidget/widget/types"; import type { CheckboxGroupWidgetProps } from "./types"; diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxGroupWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxGroupWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSCheckboxWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCheckboxWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCheckboxWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.test.ts similarity index 94% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.test.ts index d53d00b39e5..2825bdf1270 100644 --- a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.test.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.test.ts @@ -1,4 +1,4 @@ -import type { WidgetProps } from "../../../../BaseWidget"; +import type { WidgetProps } from "widgets/BaseWidget"; import { handleWidgetTypeUpdate } from "./contentConfig"; describe("handleWidgetTypeUpdate", () => { diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.ts similarity index 97% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.ts index 9e41483d389..48eb11ad003 100644 --- a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/contentConfig.ts @@ -1,8 +1,8 @@ import { ValidationTypes } from "constants/WidgetValidation"; import { EvaluationSubstitutionType } from "entities/DataTree/dataTreeFactory"; import { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; -import type { PropertyUpdates } from "../../../../../WidgetProvider/constants"; -import type { WidgetProps } from "../../../../BaseWidget"; +import type { PropertyUpdates } from "WidgetProvider/constants"; +import type { WidgetProps } from "widgets/BaseWidget"; import type { WDSComboBoxWidgetProps } from "../../widget/types"; import { optionsCustomValidation } from "./validations"; diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts similarity index 98% rename from app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts index 356d2155a85..331cf8dae83 100644 --- a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts @@ -1,6 +1,6 @@ import type { ValidationResponse } from "constants/WidgetValidation"; import type { LoDashStatic } from "lodash"; -import type { WidgetProps } from "../../../../../BaseWidget"; +import type { WidgetProps } from "widgets/BaseWidget"; interface ValidationErrorMessage { name: string; diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/widget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/helpers.ts similarity index 78% rename from app/client/src/widgets/wds/WDSComboBoxWidget/widget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/helpers.ts index b50216697ad..175b9665e5d 100644 --- a/app/client/src/widgets/wds/WDSComboBoxWidget/widget/helpers.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/helpers.ts @@ -1,4 +1,4 @@ -import type { Validation } from "widgets/wds/WDSInputWidget/widget/types"; +import type { Validation } from "modules/ui-builder/ui/wds/WDSInputWidget/widget/types"; import type { WDSComboBoxWidgetProps } from "./types"; export function validateInput(props: WDSComboBoxWidgetProps): Validation { diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSComboBoxWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSComboBoxWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/types.ts similarity index 79% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/types.ts index 4ce49a6e856..283223c9c71 100644 --- a/app/client/src/widgets/wds/WDSCurrencyInputWidget/component/types.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/types.ts @@ -1,5 +1,5 @@ import type { CurrencyTypeOptions } from "constants/Currency"; -import type { BaseInputComponentProps } from "widgets/wds/WDSBaseInputWidget"; +import type { BaseInputComponentProps } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; export interface CurrencyInputComponentProps extends BaseInputComponentProps { currencyCode?: string; diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/component/utilities.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/utilities.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/component/utilities.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/utilities.test.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/component/utilities.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/utilities.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/component/utilities.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/component/utilities.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/defaultsConfig.ts similarity index 86% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/defaultsConfig.ts index bb423d8bc9d..1efd682612b 100644 --- a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/defaultsConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/defaultsConfig.ts @@ -1,4 +1,4 @@ -import { WDSBaseInputWidget } from "widgets/wds/WDSBaseInputWidget"; +import { WDSBaseInputWidget } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import { ResponsiveBehavior } from "layoutSystems/common/utils/constants"; import type { WidgetDefaultProps } from "WidgetProvider/constants"; diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/contentConfig.ts similarity index 96% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/contentConfig.ts index 4df85db375a..da27a0d53b8 100644 --- a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/contentConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/contentConfig.ts @@ -1,7 +1,7 @@ import { CurrencyTypeOptions } from "constants/Currency"; import { ValidationTypes } from "constants/WidgetValidation"; import { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; -import { propertyPaneContentConfig as WdsInputWidgetPropertyPaneContentConfig } from "widgets/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig"; +import { propertyPaneContentConfig as WdsInputWidgetPropertyPaneContentConfig } from "modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig"; import * as validations from "./validations"; import { countryToFlag } from "../../widget/helpers"; diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/constants.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/constants.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/constants.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/constants.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/derived.js b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/derived.js similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/derived.js rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/derived.js diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/derived.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/derived.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/derived.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/derived.test.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/helpers.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/helpers.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/helpers.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/helpers.test.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/helpers.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/helpers.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/index.test.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/index.test.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/index.test.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/index.test.tsx diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/index.tsx similarity index 98% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/index.tsx index 1e16db14cf9..f9087571fc1 100644 --- a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/index.tsx @@ -27,9 +27,9 @@ import type { } from "WidgetProvider/constants"; import * as config from "../config"; import type { CurrencyInputWidgetProps } from "./types"; -import { WDSBaseInputWidget } from "widgets/wds/WDSBaseInputWidget"; +import { WDSBaseInputWidget } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import { getCountryCodeFromCurrencyCode, validateInput } from "./helpers"; -import type { KeyDownEvent } from "widgets/wds/WDSBaseInputWidget/component/types"; +import type { KeyDownEvent } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/component/types"; class WDSCurrencyInputWidget extends WDSBaseInputWidget< CurrencyInputWidgetProps, diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/parsedDerivedProperties.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/parsedDerivedProperties.ts similarity index 100% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/parsedDerivedProperties.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/parsedDerivedProperties.ts diff --git a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/types.ts similarity index 78% rename from app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/types.ts index fa307c6099b..7a18144f1b4 100644 --- a/app/client/src/widgets/wds/WDSCurrencyInputWidget/widget/types.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/types.ts @@ -1,5 +1,5 @@ import type { CurrencyTypeOptions } from "constants/Currency"; -import type { BaseInputWidgetProps } from "widgets/wds/WDSBaseInputWidget"; +import type { BaseInputWidgetProps } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; export interface CurrencyInputWidgetProps extends BaseInputWidgetProps { countryCode?: string; diff --git a/app/client/src/widgets/wds/WDSEmailInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSEmailInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSEmailInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSEmailInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSEmailInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSEmailInputWidget/widget/index.tsx similarity index 84% rename from app/client/src/widgets/wds/WDSEmailInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSEmailInputWidget/widget/index.tsx index 721bb9e0e6e..f2c8d6380cb 100644 --- a/app/client/src/widgets/wds/WDSEmailInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSEmailInputWidget/widget/index.tsx @@ -1,7 +1,7 @@ -import { WDSInputWidget } from "widgets/wds/WDSInputWidget"; +import { WDSInputWidget } from "modules/ui-builder/ui/wds/WDSInputWidget"; import { EmailInputIcon, EmailInputThumbnail } from "appsmith-icons"; import { WIDGET_TAGS } from "constants/WidgetConstants"; -import { INPUT_TYPES } from "widgets/wds/WDSBaseInputWidget"; +import { INPUT_TYPES } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import type { WidgetBaseConfiguration } from "WidgetProvider/constants"; class WDSEmailInputWidget extends WDSInputWidget { diff --git a/app/client/src/widgets/wds/WDSHeadingWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSHeadingWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSHeadingWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSHeadingWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSHeadingWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSHeadingWidget/widget/index.tsx similarity index 95% rename from app/client/src/widgets/wds/WDSHeadingWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSHeadingWidget/widget/index.tsx index c044eedc467..0a6e0dbef3f 100644 --- a/app/client/src/widgets/wds/WDSHeadingWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSHeadingWidget/widget/index.tsx @@ -1,6 +1,6 @@ import { WIDGET_TAGS } from "constants/WidgetConstants"; import { ValidationTypes } from "constants/WidgetValidation"; -import { WDSParagraphWidget } from "widgets/wds/WDSParagraphWidget"; +import { WDSParagraphWidget } from "modules/ui-builder/ui/wds/WDSParagraphWidget"; import { HeadingIcon, HeadingThumbnail } from "appsmith-icons"; import { klonaRegularWithTelemetry } from "utils/helpers"; diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/component/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/component/types.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSIconButtonWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSIconButtonWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSIconButtonWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/component/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/component/types.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSInlineButtonsWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInlineButtonsWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInlineButtonsWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/component/index.tsx similarity index 97% rename from app/client/src/widgets/wds/WDSInputWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/component/index.tsx index 2f01a175e88..0f91268297b 100644 --- a/app/client/src/widgets/wds/WDSInputWidget/component/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/component/index.tsx @@ -3,7 +3,7 @@ import { isNil } from "lodash"; import { TextInput } from "@appsmith/wds"; import { Icon, TextArea } from "@appsmith/wds"; import { useDebouncedValue } from "@mantine/hooks"; -import { INPUT_TYPES } from "widgets/wds/WDSBaseInputWidget"; +import { INPUT_TYPES } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import type { InputComponentProps } from "./types"; diff --git a/app/client/src/widgets/wds/WDSInputWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/component/types.ts similarity index 84% rename from app/client/src/widgets/wds/WDSInputWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/component/types.ts index 6a254d53fa0..4b37c20b948 100644 --- a/app/client/src/widgets/wds/WDSInputWidget/component/types.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/component/types.ts @@ -1,5 +1,5 @@ import type { IconProps } from "@appsmith/wds"; -import type { InputType } from "widgets/wds/WDSBaseInputWidget/types"; +import type { InputType } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/types"; import type { BaseInputComponentProps } from "../../WDSBaseInputWidget"; diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.test.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/maxValueValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/maxValueValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/maxValueValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/maxValueValidation.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/minValueValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/minValueValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/propertyPaneConfig/validations/minValueValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/validations/minValueValidation.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/derived.js b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/derived.js similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/widget/derived.js rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/derived.js diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/derived.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/derived.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/widget/derived.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/derived.test.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/helper.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/helper.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/widget/helper.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/helper.test.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/helper.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/helper.ts similarity index 93% rename from app/client/src/widgets/wds/WDSInputWidget/widget/helper.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/helper.ts index 8bf1f2c2fe8..6d4e6cd3b3a 100644 --- a/app/client/src/widgets/wds/WDSInputWidget/widget/helper.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/helper.ts @@ -8,17 +8,17 @@ import { INPUT_INVALID_TYPE_ERROR, INPUT_TEXT_MAX_CHAR_ERROR, } from "ee/constants/messages"; -import type { InputType } from "widgets/wds/WDSBaseInputWidget"; +import type { InputType } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import type { WidgetProps } from "widgets/BaseWidget"; import type { InputWidgetProps, Validation } from "./types"; import { INPUT_TYPE_TO_WIDGET_TYPE_MAP, INPUT_TYPES, -} from "widgets/wds/WDSBaseInputWidget"; +} from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import type { PropertyUpdates } from "WidgetProvider/constants"; -import { getDefaultISDCode } from "widgets/wds/WDSPhoneInputWidget/constants"; -import { getDefaultCurrency } from "widgets/wds/WDSCurrencyInputWidget/constants"; +import { getDefaultISDCode } from "modules/ui-builder/ui/wds/WDSPhoneInputWidget/constants"; +import { getDefaultCurrency } from "modules/ui-builder/ui/wds/WDSCurrencyInputWidget/constants"; /** * parses text to number if inputType is number diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/index.tsx similarity index 97% rename from app/client/src/widgets/wds/WDSInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/index.tsx index 557c5ade3d5..5eec9a47efe 100644 --- a/app/client/src/widgets/wds/WDSInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/index.tsx @@ -11,9 +11,9 @@ import derivedProperties from "./parsedDerivedProperties"; import { WDSBaseInputWidget } from "../../WDSBaseInputWidget"; import type { DerivedPropertiesMap } from "WidgetProvider/factory"; import { EventType } from "constants/AppsmithActionConstants/ActionConstants"; -import type { KeyDownEvent } from "widgets/wds/WDSBaseInputWidget/component/types"; +import type { KeyDownEvent } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/component/types"; import type { WidgetBaseConfiguration } from "WidgetProvider/constants"; -import { INPUT_TYPES } from "widgets/wds/WDSBaseInputWidget/constants"; +import { INPUT_TYPES } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/constants"; class WDSInputWidget extends WDSBaseInputWidget { static type = "WDS_INPUT_WIDGET"; diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/parsedDerivedProperties.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/parsedDerivedProperties.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/widget/parsedDerivedProperties.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/parsedDerivedProperties.ts diff --git a/app/client/src/widgets/wds/WDSInputWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSInputWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSInputWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSKeyValueWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSKeyValueWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSKeyValueWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSKeyValueWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSKeyValueWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSKeyValueWidget/widget/index.tsx similarity index 91% rename from app/client/src/widgets/wds/WDSKeyValueWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSKeyValueWidget/widget/index.tsx index 492a94305d1..ddaf0dc7539 100644 --- a/app/client/src/widgets/wds/WDSKeyValueWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSKeyValueWidget/widget/index.tsx @@ -1,5 +1,5 @@ import { WIDGET_TAGS } from "constants/WidgetConstants"; -import { WDSInputWidget } from "widgets/wds/WDSInputWidget"; +import { WDSInputWidget } from "modules/ui-builder/ui/wds/WDSInputWidget"; import { KeyValueIcon, KeyValueThumbnail } from "appsmith-icons"; import type { WidgetBaseConfiguration } from "WidgetProvider/constants"; diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/helper.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/helper.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/helper.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/helper.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/configureMenuItemsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/configureMenuItemsConfig.ts similarity index 98% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/configureMenuItemsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/configureMenuItemsConfig.ts index 0e6686dfd5c..51a0ea072e7 100644 --- a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/configureMenuItemsConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/configureMenuItemsConfig.ts @@ -1,6 +1,6 @@ import { ValidationTypes } from "constants/WidgetValidation"; import { getKeysFromSourceDataForEventAutocomplete } from "../../helper"; -import type { MenuButtonWidgetProps } from "widgets/wds/WDSMenuButtonWidget/widget/types"; +import type { MenuButtonWidgetProps } from "modules/ui-builder/ui/wds/WDSMenuButtonWidget/widget/types"; /** * This is for the configuration of menu items when diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/index.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/menuItemsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/menuItemsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/menuItemsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/childPanels/menuItemsConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/sourceDataArrayValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/sourceDataArrayValidation.ts similarity index 91% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/sourceDataArrayValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/sourceDataArrayValidation.ts index 1973e9f1ddb..875e77267b8 100644 --- a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/sourceDataArrayValidation.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/propertyPaneConfig/validations/sourceDataArrayValidation.ts @@ -1,5 +1,5 @@ import type { ValidationResponse } from "constants/WidgetValidation"; -import type { MenuButtonWidgetProps } from "widgets/wds/WDSMenuButtonWidget/widget/types"; +import type { MenuButtonWidgetProps } from "modules/ui-builder/ui/wds/WDSMenuButtonWidget/widget/types"; /** * Checks if the source data array diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSMenuButtonWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMenuButtonWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMenuButtonWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSModalWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/index.tsx similarity index 97% rename from app/client/src/widgets/wds/WDSModalWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/index.tsx index 39eb3399454..7af7d3e668c 100644 --- a/app/client/src/widgets/wds/WDSModalWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/index.tsx @@ -8,7 +8,7 @@ import React from "react"; import { EventType } from "constants/AppsmithActionConstants/ActionConstants"; import { SelectionRequestType } from "sagas/WidgetSelectUtils"; import { ModalBody } from "@appsmith/wds"; -import { WDS_MODAL_WIDGET_CLASSNAME } from "widgets/wds/constants"; +import { WDS_MODAL_WIDGET_CLASSNAME } from "modules/ui-builder/ui/wds/constants"; import type { CanvasWidgetsReduxState } from "reducers/entityReducers/canvasWidgetsReducer"; import type { CopiedWidgetData, @@ -21,7 +21,7 @@ import { ModalLayoutProvider } from "layoutSystems/anvil/layoutComponents/ModalL import styles from "./styles.module.css"; import { getAnvilWidgetDOMId } from "layoutSystems/common/utils/LayoutElementPositionsObserver/utils"; import { widgetTypeClassname } from "widgets/WidgetUtils"; -import { AnvilDataAttributes } from "widgets/wds/constants"; +import { AnvilDataAttributes } from "modules/ui-builder/ui/wds/constants"; class WDSModalWidget extends BaseWidget { static type = "WDS_MODAL_WIDGET"; diff --git a/app/client/src/widgets/wds/WDSModalWidget/widget/styles.module.css b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/styles.module.css similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/widget/styles.module.css rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/styles.module.css diff --git a/app/client/src/widgets/wds/WDSModalWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSModalWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSModalWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSMultilineInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSMultilineInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSMultilineInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSMultilineInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSMultilineInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSMultilineInputWidget/widget/index.tsx similarity index 84% rename from app/client/src/widgets/wds/WDSMultilineInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSMultilineInputWidget/widget/index.tsx index 413950312c4..1859e07df50 100644 --- a/app/client/src/widgets/wds/WDSMultilineInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSMultilineInputWidget/widget/index.tsx @@ -1,7 +1,7 @@ import { WIDGET_TAGS } from "constants/WidgetConstants"; -import { WDSInputWidget } from "widgets/wds/WDSInputWidget"; +import { WDSInputWidget } from "modules/ui-builder/ui/wds/WDSInputWidget"; import type { WidgetBaseConfiguration } from "WidgetProvider/constants"; -import { INPUT_TYPES } from "widgets/wds/WDSBaseInputWidget/constants"; +import { INPUT_TYPES } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/constants"; import { MultilineInputIcon, MultilineInputThumbnail } from "appsmith-icons"; class WDSMultilineInputWidget extends WDSInputWidget { diff --git a/app/client/src/widgets/wds/WDSNumberInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSNumberInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSNumberInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSNumberInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSNumberInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSNumberInputWidget/widget/index.tsx similarity index 83% rename from app/client/src/widgets/wds/WDSNumberInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSNumberInputWidget/widget/index.tsx index 0f67165c9c9..7dac924d42a 100644 --- a/app/client/src/widgets/wds/WDSNumberInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSNumberInputWidget/widget/index.tsx @@ -1,8 +1,8 @@ import { WIDGET_TAGS } from "constants/WidgetConstants"; -import { WDSInputWidget } from "widgets/wds/WDSInputWidget"; +import { WDSInputWidget } from "modules/ui-builder/ui/wds/WDSInputWidget"; import { NumberInputIcon, NumberInputThumbnail } from "appsmith-icons"; import type { WidgetBaseConfiguration } from "WidgetProvider/constants"; -import { INPUT_TYPES } from "widgets/wds/WDSBaseInputWidget/constants"; +import { INPUT_TYPES } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/constants"; class WDSNumberInputWidget extends WDSInputWidget { static type = "WDS_NUMBER_INPUT_WIDGET"; diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/__tests__/helpers.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/__tests__/helpers.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/__tests__/helpers.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/__tests__/helpers.test.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/constants.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/constants.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/constants.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/constants.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/helpers.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/helpers.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSParagraphWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSParagraphWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSParagraphWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSPasswordInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPasswordInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPasswordInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPasswordInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSPasswordInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSPasswordInputWidget/widget/index.tsx similarity index 84% rename from app/client/src/widgets/wds/WDSPasswordInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSPasswordInputWidget/widget/index.tsx index a47776ab386..0c0e588dfbb 100644 --- a/app/client/src/widgets/wds/WDSPasswordInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSPasswordInputWidget/widget/index.tsx @@ -1,6 +1,6 @@ import { WIDGET_TAGS } from "constants/WidgetConstants"; -import { WDSInputWidget } from "widgets/wds/WDSInputWidget"; -import { INPUT_TYPES } from "widgets/wds/WDSBaseInputWidget/constants"; +import { WDSInputWidget } from "modules/ui-builder/ui/wds/WDSInputWidget"; +import { INPUT_TYPES } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/constants"; import type { WidgetBaseConfiguration } from "WidgetProvider/constants"; import { PasswordInputIcon, PasswordInputThumbnail } from "appsmith-icons"; diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/component/types.ts similarity index 73% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/component/types.ts index 77dc230cd11..dd9a9db896f 100644 --- a/app/client/src/widgets/wds/WDSPhoneInputWidget/component/types.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/component/types.ts @@ -1,5 +1,5 @@ import type { CountryCode } from "libphonenumber-js"; -import type { BaseInputComponentProps } from "widgets/wds/WDSBaseInputWidget"; +import type { BaseInputComponentProps } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; export interface PhoneInputComponentProps extends BaseInputComponentProps { dialCode?: string; diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/defaultsConfig.ts similarity index 86% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/defaultsConfig.ts index ce46e464562..1d85047574a 100644 --- a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/defaultsConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/defaultsConfig.ts @@ -1,4 +1,4 @@ -import { WDSBaseInputWidget } from "widgets/wds/WDSBaseInputWidget"; +import { WDSBaseInputWidget } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import { ResponsiveBehavior } from "layoutSystems/common/utils/constants"; import type { WidgetDefaultProps } from "WidgetProvider/constants"; diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/contentConfig.ts similarity index 96% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/contentConfig.ts index 12446c69935..e8284dc2da7 100644 --- a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/contentConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/contentConfig.ts @@ -2,7 +2,7 @@ import { ISDCodeOptions } from "constants/ISDCodes_v2"; import type { ISDCodeProps } from "constants/ISDCodes_v2"; import { ValidationTypes } from "constants/WidgetValidation"; import { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; -import { propertyPaneContentConfig as WdsInputWidgetPropertyPaneContentConfig } from "widgets/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig"; +import { propertyPaneContentConfig as WdsInputWidgetPropertyPaneContentConfig } from "modules/ui-builder/ui/wds/WDSInputWidget/config/propertyPaneConfig/contentConfig"; import { countryToFlag } from "../../widget/helpers"; import { defaultValueValidation } from "./validations"; diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.test.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/defaultValueValidation.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/constants.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/constants.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/constants.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/constants.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/widget/helpers.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/helpers.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/widget/helpers.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/helpers.test.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/widget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/helpers.ts similarity index 100% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/widget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/helpers.ts diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/index.tsx similarity index 97% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/index.tsx index 09b1ad53dd8..dc39829aee0 100644 --- a/app/client/src/widgets/wds/WDSPhoneInputWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/index.tsx @@ -11,11 +11,11 @@ import type { AnvilConfig, AutocompletionDefinitions, } from "WidgetProvider/constants"; -import { WDSBaseInputWidget } from "widgets/wds/WDSBaseInputWidget"; +import { WDSBaseInputWidget } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; import { AsYouType, parseIncompletePhoneNumber } from "libphonenumber-js"; import { EventType } from "constants/AppsmithActionConstants/ActionConstants"; -import type { KeyDownEvent } from "widgets/wds/WDSBaseInputWidget/component/types"; -import derivedProperties from "widgets/wds/WDSCurrencyInputWidget/widget/parsedDerivedProperties"; +import type { KeyDownEvent } from "modules/ui-builder/ui/wds/WDSBaseInputWidget/component/types"; +import derivedProperties from "modules/ui-builder/ui/wds/WDSCurrencyInputWidget/widget/parsedDerivedProperties"; import * as config from "../config"; import { PhoneInputComponent } from "../component"; diff --git a/app/client/src/widgets/wds/WDSPhoneInputWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/types.ts similarity index 72% rename from app/client/src/widgets/wds/WDSPhoneInputWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/types.ts index cae023b078e..8f3fef1991c 100644 --- a/app/client/src/widgets/wds/WDSPhoneInputWidget/widget/types.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSPhoneInputWidget/widget/types.ts @@ -1,5 +1,5 @@ import type { CountryCode } from "libphonenumber-js"; -import type { BaseInputWidgetProps } from "widgets/wds/WDSBaseInputWidget"; +import type { BaseInputWidgetProps } from "modules/ui-builder/ui/wds/WDSBaseInputWidget"; export interface PhoneInputWidgetProps extends BaseInputWidgetProps { dialCode?: string; diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/widget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/helpers.ts similarity index 78% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/widget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/helpers.ts index 2144de3055f..d5e01dec022 100644 --- a/app/client/src/widgets/wds/WDSRadioGroupWidget/widget/helpers.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/helpers.ts @@ -1,4 +1,4 @@ -import type { Validation } from "widgets/wds/WDSInputWidget/widget/types"; +import type { Validation } from "modules/ui-builder/ui/wds/WDSInputWidget/widget/types"; import type { RadioGroupWidgetProps } from "./types"; export function validateInput(props: RadioGroupWidgetProps): Validation { diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSRadioGroupWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSRadioGroupWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSRadioGroupWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/baseConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/baseConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/baseConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/baseConfig.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/defaultConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/defaultConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/defaultConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/defaultConfig.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/propertyPaneContent.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/propertyPaneContent.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/propertyPaneContent.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/propertyPaneContent.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/config/propertyPaneStyle.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/propertyPaneStyle.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/config/propertyPaneStyle.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/config/propertyPaneStyle.ts diff --git a/app/client/src/widgets/wds/WDSSectionWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSSectionWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSSectionWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/widget/index.tsx similarity index 96% rename from app/client/src/widgets/wds/WDSSectionWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/widget/index.tsx index 318c96c9d6b..0597440d9f4 100644 --- a/app/client/src/widgets/wds/WDSSectionWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSSectionWidget/widget/index.tsx @@ -23,9 +23,9 @@ import type { LayoutProps } from "layoutSystems/anvil/utils/anvilTypes"; import BaseWidget from "widgets/BaseWidget"; import type { ReactNode } from "react"; import React from "react"; -import { ContainerComponent } from "widgets/wds/Container"; +import { ContainerComponent } from "modules/ui-builder/ui/wds/Container"; import { LayoutProvider } from "layoutSystems/anvil/layoutComponents/LayoutProvider"; -import { Elevations, anvilWidgets } from "widgets/wds/constants"; +import { Elevations, anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import type { CanvasWidgetsReduxState } from "reducers/entityReducers/canvasWidgetsReducer"; import type { CopiedWidgetData, diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/contentConfig.ts similarity index 97% rename from app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/contentConfig.ts index 9466f1c8a93..a31fbc12e0b 100644 --- a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/contentConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/contentConfig.ts @@ -6,8 +6,8 @@ import { defaultOptionValidation, optionsCustomValidation, } from "./validations"; -import type { WidgetProps } from "../../../../BaseWidget"; -import type { PropertyUpdates } from "../../../../../WidgetProvider/constants"; +import type { WidgetProps } from "widgets/BaseWidget"; +import type { PropertyUpdates } from "WidgetProvider/constants"; type WidgetTypeValue = "SELECT" | "COMBOBOX"; diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts similarity index 96% rename from app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts index 463f49d9cc4..f5bf114adf5 100644 --- a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/defaultOptionValidation.ts @@ -1,6 +1,6 @@ import type { ValidationResponse } from "constants/WidgetValidation"; import type { LoDashStatic } from "lodash"; -import type { WidgetProps } from "../../../../../BaseWidget"; +import type { WidgetProps } from "widgets/BaseWidget"; interface ValidationErrorMessage { name: string; diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/propertyPaneConfig/validations/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/index.ts diff --git a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts similarity index 98% rename from app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts index 356d2155a85..331cf8dae83 100644 --- a/app/client/src/widgets/wds/WDSComboBoxWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/propertyPaneConfig/validations/optionsCustomValidation.ts @@ -1,6 +1,6 @@ import type { ValidationResponse } from "constants/WidgetValidation"; import type { LoDashStatic } from "lodash"; -import type { WidgetProps } from "../../../../../BaseWidget"; +import type { WidgetProps } from "widgets/BaseWidget"; interface ValidationErrorMessage { name: string; diff --git a/app/client/src/widgets/wds/WDSSelectWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSSelectWidget/widget/helpers.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/helpers.ts similarity index 78% rename from app/client/src/widgets/wds/WDSSelectWidget/widget/helpers.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/helpers.ts index 29a690d2845..c98beb7f15e 100644 --- a/app/client/src/widgets/wds/WDSSelectWidget/widget/helpers.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/helpers.ts @@ -1,4 +1,4 @@ -import type { Validation } from "widgets/wds/WDSInputWidget/widget/types"; +import type { Validation } from "modules/ui-builder/ui/wds/WDSInputWidget/widget/types"; import type { WDSSelectWidgetProps } from "./types"; export function validateInput(props: WDSSelectWidgetProps): Validation { diff --git a/app/client/src/widgets/wds/WDSSelectWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSSelectWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSelectWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSelectWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSStatsWidget/component/styles.module.css b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/component/styles.module.css similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/component/styles.module.css rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/component/styles.module.css diff --git a/app/client/src/widgets/wds/WDSStatsWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/component/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/component/types.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSStatsWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSStatsWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/widget/index.tsx similarity index 91% rename from app/client/src/widgets/wds/WDSStatsWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/widget/index.tsx index 413c51ced05..dbc79ec87e8 100644 --- a/app/client/src/widgets/wds/WDSStatsWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/widget/index.tsx @@ -7,8 +7,8 @@ import * as config from "../config"; import { StatsComponent } from "../component"; import type { StatsWidgetProps } from "./types"; import type { AnvilConfig } from "WidgetProvider/constants"; -import { Elevations } from "widgets/wds/constants"; -import { ContainerComponent } from "widgets/wds/Container"; +import { Elevations } from "modules/ui-builder/ui/wds/constants"; +import { ContainerComponent } from "modules/ui-builder/ui/wds/Container"; class WDSStatsWidget extends BaseWidget { constructor(props: StatsWidgetProps) { diff --git a/app/client/src/widgets/wds/WDSStatsWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSStatsWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSStatsWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSSwitchGroupWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchGroupWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchGroupWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/featuresConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/featuresConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/featuresConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/featuresConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSSwitchWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSSwitchWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSSwitchWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/Constants.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/Constants.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/Constants.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/Constants.test.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/Constants.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/Constants.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/Constants.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/Constants.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/StaticTable.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/StaticTable.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/StaticTable.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/StaticTable.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/Table.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/Table.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/Table.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/Table.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableBody/Row.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/Row.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableBody/Row.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/Row.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableBody/StaticTableBody.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/StaticTableBody.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableBody/StaticTableBody.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/StaticTableBody.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableBody/context.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/context.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableBody/context.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/context.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableBody/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableBody/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableBody/index.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/PageNumberInput.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/PageNumberInput.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/PageNumberInput.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/PageNumberInput.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/Pagination.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/Pagination.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/Pagination.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/Pagination.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/Search.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/Search.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/Search.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/Search.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/TableColumnHeader.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/TableColumnHeader.tsx similarity index 98% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/TableColumnHeader.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/TableColumnHeader.tsx index cd9d1776a7d..95e284d03b3 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/TableColumnHeader.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/TableColumnHeader.tsx @@ -1,6 +1,6 @@ import { Checkbox } from "@appsmith/wds"; import React, { memo } from "react"; -import { getDragHandlers } from "widgets/wds/WDSTableWidget/widget/utilities"; +import { getDragHandlers } from "modules/ui-builder/ui/wds/WDSTableWidget/widget/utilities"; import { HeaderCell } from "../cellComponents/HeaderCell"; import type { ReactTableColumnProps } from "../Constants"; import { CheckboxState, StickyType } from "../Constants"; diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/index.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/styles.module.css b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/styles.module.css similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableHeader/styles.module.css rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableHeader/styles.module.css diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/TableStyledWrappers.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableStyledWrappers.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/TableStyledWrappers.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/TableStyledWrappers.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/ButtonCell.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/ButtonCell.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/ButtonCell.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/ButtonCell.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/EmptyCell.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/EmptyCell.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/EmptyCell.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/EmptyCell.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/HeaderCell.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/HeaderCell.tsx similarity index 98% rename from app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/HeaderCell.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/HeaderCell.tsx index 3d7e4e03542..446a52ddec5 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/HeaderCell.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/HeaderCell.tsx @@ -2,7 +2,7 @@ import type { Key } from "react"; import React, { useCallback, memo } from "react"; import { MULTISELECT_CHECKBOX_WIDTH, StickyType } from "../Constants"; -import { isColumnTypeEditable } from "widgets/wds/WDSTableWidget/widget/utilities"; +import { isColumnTypeEditable } from "modules/ui-builder/ui/wds/WDSTableWidget/widget/utilities"; import { Flex, Icon, IconButton, Menu, MenuTrigger, Text } from "@appsmith/wds"; interface HeaderProps { diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/PlainTextCell.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/PlainTextCell.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/PlainTextCell.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/PlainTextCell.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/URLCell.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/URLCell.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/URLCell.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/URLCell.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/cellComponents/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/cellComponents/index.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/component/styles.module.css b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/styles.module.css similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/component/styles.module.css rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/component/styles.module.css diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Basic.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Basic.ts similarity index 92% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Basic.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Basic.ts index 1002eb3496e..085a83c93e6 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Basic.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Basic.ts @@ -1,6 +1,9 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes, ICON_NAMES } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { + ColumnTypes, + ICON_NAMES, +} from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { hideByColumnType, updateIconAlignment, diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Color.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Color.ts similarity index 92% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Color.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Color.ts index 7f195322388..05f99a1f291 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Color.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Color.ts @@ -4,8 +4,8 @@ import capitalize from "lodash/capitalize"; import { ColumnTypes, type TableWidgetProps, -} from "widgets/wds/WDSTableWidget/constants"; -import { showByColumnType } from "widgets/wds/WDSTableWidget/widget/propertyUtils"; +} from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { showByColumnType } from "modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils"; export default { sectionName: "Color", diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Data.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Data.ts similarity index 98% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Data.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Data.ts index 2a4f624497a..02ad9a96df7 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Data.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Data.ts @@ -1,9 +1,9 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { ColumnTypes, DateInputFormat, -} from "widgets/wds/WDSTableWidget/constants"; +} from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { get } from "lodash"; import { getBasePropertyPath, diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DateProperties.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DateProperties.ts similarity index 90% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DateProperties.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DateProperties.ts index 03cc814701d..076c936117e 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DateProperties.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DateProperties.ts @@ -1,6 +1,6 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { get } from "lodash"; import { allowedFirstDayOfWeekRange } from "../../../widget/propertyUtils"; import { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DiscardButtonproperties.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DiscardButtonproperties.ts similarity index 97% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DiscardButtonproperties.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DiscardButtonproperties.ts index ef60029c600..a8a983a6ac1 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DiscardButtonproperties.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/DiscardButtonproperties.ts @@ -1,7 +1,7 @@ import { get } from "lodash"; import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { hideByColumnType, getBasePropertyPath, diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Events.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Events.ts similarity index 96% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Events.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Events.ts index cfd62aa8d6c..a061dfa73d0 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Events.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Events.ts @@ -1,5 +1,5 @@ -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { get } from "lodash"; import { getBasePropertyPath, diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/General.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/General.ts similarity index 94% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/General.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/General.ts index fdb04dc0e98..3f7ffca4cad 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/General.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/General.ts @@ -1,6 +1,6 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { hideByColumnType } from "../../../widget/propertyUtils"; import { BUTTON_VARIANTS } from "@appsmith/wds"; import { objectKeys } from "@appsmith/utils"; diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/SaveButtonProperties.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/SaveButtonProperties.ts similarity index 97% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/SaveButtonProperties.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/SaveButtonProperties.ts index 1965074b923..ead2bafb7f2 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/SaveButtonProperties.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/SaveButtonProperties.ts @@ -1,13 +1,13 @@ import { get } from "lodash"; import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { hideByColumnType, getBasePropertyPath, } from "../../../widget/propertyUtils"; import { ButtonVariantTypes } from "components/constants"; import { ICON_NAMES } from "WidgetProvider/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; export default { sectionName: "Save Button", diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/TextFormatting.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/TextFormatting.ts similarity index 88% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/TextFormatting.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/TextFormatting.ts index 89bea8b8bc6..d8e5ab771d5 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/TextFormatting.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/TextFormatting.ts @@ -1,10 +1,10 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { hideByColumnType, showByColumnType, } from "../../../widget/propertyUtils"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; export default { sectionName: "Text formatting", diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validation.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validation.ts similarity index 90% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validation.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validation.ts index 73fc0c137f5..ba52ff0cc8f 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validation.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validation.ts @@ -1,4 +1,4 @@ -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { get } from "lodash"; import { hideByColumnType } from "../../../widget/propertyUtils"; import commonValidations from "./Validations/Common"; diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Common.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Common.ts similarity index 90% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Common.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Common.ts index 90e86b39fc4..8c4a9bbb861 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Common.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Common.ts @@ -1,10 +1,10 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { showByColumnType, getColumnPath, -} from "widgets/wds/WDSTableWidget/widget/propertyUtils"; +} from "modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils"; export default [ { diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Date.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Date.ts similarity index 80% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Date.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Date.ts index 77a355147ba..9a90cc6e6a6 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Date.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Date.ts @@ -1,9 +1,9 @@ -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { getColumnPath, hideByColumnType, -} from "widgets/wds/WDSTableWidget/widget/propertyUtils"; +} from "modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils"; export default [ { diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Number.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Number.ts similarity index 85% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Number.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Number.ts index a76da2d429c..a11b4be63be 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Number.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/Validations/Number.ts @@ -1,10 +1,10 @@ import { ValidationTypes } from "constants/WidgetValidation"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { ColumnTypes } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { ColumnTypes } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { hideByColumnType, getColumnPath, -} from "widgets/wds/WDSTableWidget/widget/propertyUtils"; +} from "modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils"; export default [ { diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/PanelConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/contentConfig.ts similarity index 98% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/contentConfig.ts index 6eb12b504b6..866ee8e5501 100644 --- a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/contentConfig.ts +++ b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/contentConfig.ts @@ -2,8 +2,8 @@ import type { PropertyPaneConfig } from "constants/PropertyControlConstants"; import { ValidationTypes } from "constants/WidgetValidation"; import { EvaluationSubstitutionType } from "entities/DataTree/dataTreeFactory"; import { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; -import type { TableWidgetProps } from "widgets/wds/WDSTableWidget/constants"; -import { InlineEditingSaveOptions } from "widgets/wds/WDSTableWidget/constants"; +import type { TableWidgetProps } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; +import { InlineEditingSaveOptions } from "modules/ui-builder/ui/wds/WDSTableWidget/constants"; import { composePropertyUpdateHook } from "widgets/WidgetUtils"; import { tableDataValidation, diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/constants.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/constants.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/constants.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/constants.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/constants/data.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/constants/data.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/constants/data.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/constants/data.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/constants/messages.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/constants/messages.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/constants/messages.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/constants/messages.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/index.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/derived.js b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/derived.js similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/derived.js rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/derived.js diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/derived.test.js b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/derived.test.js similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/derived.test.js rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/derived.test.js diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/parseDerivedProperties.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/parseDerivedProperties.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/parseDerivedProperties.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/parseDerivedProperties.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/propertyUtils.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/propertyUtils.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils.test.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/propertyUtils.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/propertyUtils.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/propertyUtils.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/reactTableUtils/getColumnsPureFn.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/reactTableUtils/getColumnsPureFn.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/reactTableUtils/getColumnsPureFn.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/reactTableUtils/getColumnsPureFn.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/reactTableUtils/transformDataPureFn.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/reactTableUtils/transformDataPureFn.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/reactTableUtils/transformDataPureFn.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/reactTableUtils/transformDataPureFn.tsx diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/utilities.test.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/utilities.test.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/utilities.test.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/utilities.test.ts diff --git a/app/client/src/widgets/wds/WDSTableWidget/widget/utilities.ts b/app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/utilities.ts similarity index 100% rename from app/client/src/widgets/wds/WDSTableWidget/widget/utilities.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSTableWidget/widget/utilities.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/component/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/component/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/component/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/component/index.tsx diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/component/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/component/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/component/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/component/types.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/defaultsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/defaultsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/defaultsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/defaultsConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/metaConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/metaConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/metaConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/metaConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/contentConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/contentConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/contentConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/contentConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/index.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/styleConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/styleConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/styleConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/propertyPaneConfig/styleConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/settersConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/settersConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/config/settersConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/config/settersConfig.ts diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/widget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/widget/index.tsx diff --git a/app/client/src/widgets/wds/WDSToolbarButtonsWidget/widget/types.ts b/app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/widget/types.ts similarity index 100% rename from app/client/src/widgets/wds/WDSToolbarButtonsWidget/widget/types.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSToolbarButtonsWidget/widget/types.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/index.tsx similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/index.tsx diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/anvilConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/anvilConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/anvilConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/anvilConfig.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/autocompleteConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/autocompleteConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/autocompleteConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/autocompleteConfig.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/baseConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/baseConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/baseConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/baseConfig.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/defaultConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/defaultConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/defaultConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/defaultConfig.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/index.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/index.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/index.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/index.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/methodsConfig.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/methodsConfig.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/methodsConfig.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/methodsConfig.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/propertyPaneContent.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/propertyPaneContent.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/propertyPaneContent.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/propertyPaneContent.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/config/propertyPaneStyle.ts b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/propertyPaneStyle.ts similarity index 100% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/config/propertyPaneStyle.ts rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/config/propertyPaneStyle.ts diff --git a/app/client/src/widgets/wds/WDSZoneWidget/widget/index.tsx b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/index.tsx similarity index 96% rename from app/client/src/widgets/wds/WDSZoneWidget/widget/index.tsx rename to app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/index.tsx index 1d71c311dfb..3c252e8d910 100644 --- a/app/client/src/widgets/wds/WDSZoneWidget/widget/index.tsx +++ b/app/client/src/modules/ui-builder/ui/wds/WDSZoneWidget/widget/index.tsx @@ -22,9 +22,9 @@ import BaseWidget from "widgets/BaseWidget"; import type { WidgetProps, WidgetState } from "widgets/BaseWidget"; import type { LayoutProps } from "layoutSystems/anvil/utils/anvilTypes"; import type { ContainerWidgetProps } from "widgets/ContainerWidget/widget"; -import { ContainerComponent } from "widgets/wds/Container"; +import { ContainerComponent } from "modules/ui-builder/ui/wds/Container"; import { LayoutProvider } from "layoutSystems/anvil/layoutComponents/LayoutProvider"; -import { Elevations, anvilWidgets } from "widgets/wds/constants"; +import { Elevations, anvilWidgets } from "modules/ui-builder/ui/wds/constants"; import type { CanvasWidgetsReduxState } from "reducers/entityReducers/canvasWidgetsReducer"; import type { CopiedWidgetData, diff --git a/app/client/src/widgets/wds/constants.ts b/app/client/src/modules/ui-builder/ui/wds/constants.ts similarity index 97% rename from app/client/src/widgets/wds/constants.ts rename to app/client/src/modules/ui-builder/ui/wds/constants.ts index 6a540de37c9..94cd6d91555 100644 --- a/app/client/src/widgets/wds/constants.ts +++ b/app/client/src/modules/ui-builder/ui/wds/constants.ts @@ -1,4 +1,4 @@ -import { getCanvasClassName } from "../../utils/generators"; +import { getCanvasClassName } from "../../../../utils/generators"; export const anvilWidgets = { SECTION_WIDGET: "SECTION_WIDGET", diff --git a/app/client/src/pages/Editor/APIEditor/CommonEditorForm.tsx b/app/client/src/pages/Editor/APIEditor/CommonEditorForm.tsx index 3c7467e0718..b542cdfbd04 100644 --- a/app/client/src/pages/Editor/APIEditor/CommonEditorForm.tsx +++ b/app/client/src/pages/Editor/APIEditor/CommonEditorForm.tsx @@ -147,8 +147,6 @@ export interface CommonFormProps { actionName: string; apiId: string; apiName: string; - headersCount: number; - paramsCount: number; // TODO: Fix this the next time the file is edited // eslint-disable-next-line @typescript-eslint/no-explicit-any settingsConfig: any; @@ -212,20 +210,15 @@ function CommonEditorForm(props: CommonFormPropsWithExtraParams) { const { actionConfigurationHeaders, actionConfigurationParams, - actionName, actionResponse, autoGeneratedActionConfigHeaders, closeEditorLink, formName, handleSubmit, - headersCount, hintMessages, isRunning, onRunClick, - paramsCount, pluginId, - responseDataTypes, - responseDisplayFormat, settingsConfig, } = props; @@ -256,6 +249,8 @@ function CommonEditorForm(props: CommonFormPropsWithExtraParams) { getPlugin(state, pluginId ?? ""), ); + if (!currentActionConfig) return null; + // this gets the url of the current action's datasource const actionDatasourceUrl = currentActionConfig?.datasource?.datasourceConfiguration?.url || ""; @@ -341,9 +336,7 @@ function CommonEditorForm(props: CommonFormPropsWithExtraParams) { datasourceHeaders={props.datasourceHeaders} datasourceParams={props.datasourceParams} formName={formName} - headersCount={headersCount} paginationUiComponent={props.paginationUIComponent} - paramsCount={paramsCount} pushFields={isChangePermitted} showSettings theme={EditorTheme.LIGHT} @@ -351,13 +344,10 @@ function CommonEditorForm(props: CommonFormPropsWithExtraParams) { diff --git a/app/client/src/pages/Editor/APIEditor/GraphQL/GraphQLEditorForm.tsx b/app/client/src/pages/Editor/APIEditor/GraphQL/GraphQLEditorForm.tsx index 91ee9aeb719..cc502267e6f 100644 --- a/app/client/src/pages/Editor/APIEditor/GraphQL/GraphQLEditorForm.tsx +++ b/app/client/src/pages/Editor/APIEditor/GraphQL/GraphQLEditorForm.tsx @@ -203,48 +203,6 @@ export default connect( const currentActionDatasourceId = selector(state, "datasource.id"); - const headers = selector(state, "actionConfiguration.headers"); - let headersCount = 0; - - if (Array.isArray(headers)) { - const validHeaders = headers.filter( - (value) => value.key && value.key !== "", - ); - - headersCount += validHeaders.length; - } - - if (Array.isArray(datasourceHeaders)) { - const validHeaders = datasourceHeaders.filter( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (value: any) => value.key && value.key !== "", - ); - - headersCount += validHeaders.length; - } - - const params = selector(state, "actionConfiguration.queryParameters"); - let paramsCount = 0; - - if (Array.isArray(params)) { - const validParams = params.filter( - (value) => value.key && value.key !== "", - ); - - paramsCount = validParams.length; - } - - if (Array.isArray(datasourceParams)) { - const validParams = datasourceParams.filter( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (value: any) => value.key && value.key !== "", - ); - - paramsCount += validParams.length; - } - const actionConfigurationBody = selector(state, "actionConfiguration.body") || ""; @@ -274,8 +232,6 @@ export default connect( currentActionDatasourceId, datasourceHeaders, datasourceParams, - headersCount, - paramsCount, hintMessages, datasources: state.entities.datasources.list.filter( (d) => d.pluginId === props.pluginId, diff --git a/app/client/src/pages/Editor/APIEditor/RestAPIForm.tsx b/app/client/src/pages/Editor/APIEditor/RestAPIForm.tsx index 80f1fe349c2..1435dca07e8 100644 --- a/app/client/src/pages/Editor/APIEditor/RestAPIForm.tsx +++ b/app/client/src/pages/Editor/APIEditor/RestAPIForm.tsx @@ -107,55 +107,6 @@ export default connect((state: AppState, props: { pluginId: string }) => { const currentActionDatasourceId = selector(state, "datasource.id"); const actionName = getApiName(state, apiId) || ""; - const headers = selector(state, "actionConfiguration.headers"); - let headersCount = 0; - - if (Array.isArray(headers)) { - const validHeaders = headers.filter( - (value) => value.key && value.key !== "", - ); - - headersCount += validHeaders.length; - } - - if (Array.isArray(datasourceHeaders)) { - const validHeaders = datasourceHeaders.filter( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (value: any) => value.key && value.key !== "", - ); - - headersCount += validHeaders.length; - } - - if (Array.isArray(autoGeneratedActionConfigHeaders)) { - const validHeaders = autoGeneratedActionConfigHeaders.filter( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (value: any) => value.key && value.key !== "", - ); - - headersCount += validHeaders.length; - } - - const params = selector(state, "actionConfiguration.queryParameters"); - let paramsCount = 0; - - if (Array.isArray(params)) { - const validParams = params.filter((value) => value.key && value.key !== ""); - - paramsCount = validParams.length; - } - - if (Array.isArray(datasourceParams)) { - const validParams = datasourceParams.filter( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (value: any) => value.key && value.key !== "", - ); - - paramsCount += validParams.length; - } const responses = getActionResponses(state); const actionResponse = responses[apiId]; @@ -184,8 +135,6 @@ export default connect((state: AppState, props: { pluginId: string }) => { currentActionDatasourceId, datasourceHeaders, datasourceParams, - headersCount, - paramsCount, hintMessages, datasources: state.entities.datasources.list.filter( (d) => d.pluginId === props.pluginId, diff --git a/app/client/src/pages/Editor/QueryEditor/BindDataButton.tsx b/app/client/src/pages/Editor/QueryEditor/BindDataButton.tsx index 64d6e8d5493..56271b6f31d 100644 --- a/app/client/src/pages/Editor/QueryEditor/BindDataButton.tsx +++ b/app/client/src/pages/Editor/QueryEditor/BindDataButton.tsx @@ -26,7 +26,7 @@ import { FEATURE_FLAG } from "ee/entities/FeatureFlag"; import { getHasManagePagePermission } from "ee/utils/BusinessFeatures/permissionPageHelpers"; import { getWidgets } from "sagas/selectors"; import type { FlattenedWidgetProps } from "reducers/entityReducers/canvasWidgetsStructureReducer"; -import { WDS_V2_WIDGET_MAP } from "widgets/wds/constants"; +import { WDS_V2_WIDGET_MAP } from "modules/ui-builder/ui/wds/constants"; import { getNextWidgetName } from "sagas/WidgetOperationUtils"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import { addSuggestedWidget } from "actions/widgetActions"; diff --git a/app/client/src/pages/Editor/QueryEditor/QueryResponseTab.tsx b/app/client/src/pages/Editor/QueryEditor/QueryResponseTab.tsx index 1c366da805e..ba147dc5bb3 100644 --- a/app/client/src/pages/Editor/QueryEditor/QueryResponseTab.tsx +++ b/app/client/src/pages/Editor/QueryEditor/QueryResponseTab.tsx @@ -3,12 +3,12 @@ import { useDispatch, useSelector } from "react-redux"; import ReactJson from "react-json-view"; import { apiReactJsonProps, - NoResponse, - responseTabComponent, ResponseTabErrorContainer, ResponseTabErrorContent, ResponseTabErrorDefaultMessage, -} from "components/editorComponents/ApiResponseView"; +} from "PluginActionEditor/components/PluginActionResponse/components/ApiResponse"; +import { ResponseFormatTabs } from "PluginActionEditor/components/PluginActionResponse/components/ResponseFormatTabs"; +import { NoResponse } from "PluginActionEditor/components/PluginActionResponse/components/NoResponse"; import LogAdditionalInfo from "components/editorComponents/Debugger/ErrorLogs/components/LogAdditionalInfo"; import LogHelper from "components/editorComponents/Debugger/ErrorLogs/components/LogHelper"; import LOG_TYPE from "entities/AppsmithConsole/logtype"; @@ -102,6 +102,8 @@ const QueryResponseTab = (props: Props) => { const { responseDataTypes, responseDisplayFormat } = actionResponseDisplayDataFormats(actionResponse); + let output: Record[] | string = ""; + const responseBodyTabs = responseDataTypes && responseDataTypes.map((dataType, index) => { @@ -109,10 +111,12 @@ const QueryResponseTab = (props: Props) => { index: index, key: dataType.key, title: dataType.title, - panelComponent: responseTabComponent( - dataType.key, - output, - responseTabHeight, + panelComponent: ( + ), }; }); @@ -163,9 +167,6 @@ const QueryResponseTab = (props: Props) => { let error = runErrorMessage; let hintMessages: Array = []; let showPreparedStatementWarning = false; - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - let output: Record[] | null = null; // Query is executed even once during the session, show the response data. if (actionResponse) { @@ -326,17 +327,19 @@ const QueryResponseTab = (props: Props) => { suggestedWidgets={actionResponse?.suggestedWidgets} /> - {responseTabComponent( - selectedControl || segmentedControlOptions[0]?.value, - output, - responseTabHeight, - )} + )} {!output && !error && ( )} diff --git a/app/client/src/pages/Editor/gitSync/GitSettingsModal/TabGeneral/DangerZone.tsx b/app/client/src/pages/Editor/gitSync/GitSettingsModal/TabGeneral/DangerZone.tsx index d7f5a870147..c32b7ab5c23 100644 --- a/app/client/src/pages/Editor/gitSync/GitSettingsModal/TabGeneral/DangerZone.tsx +++ b/app/client/src/pages/Editor/gitSync/GitSettingsModal/TabGeneral/DangerZone.tsx @@ -15,9 +15,8 @@ import { setIsDisconnectGitModalOpen, setGitSettingsModalOpenAction, } from "actions/gitSyncActions"; -import { FEATURE_FLAG } from "ee/entities/FeatureFlag"; import { Button, Divider, Text } from "@appsmith/ads"; -import React from "react"; +import React, { useCallback } from "react"; import { useDispatch, useSelector } from "react-redux"; import { getAutocommitEnabledSelector, @@ -26,7 +25,6 @@ import { } from "selectors/gitSyncSelectors"; import styled from "styled-components"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; -import { useFeatureFlag } from "utils/hooks/useFeatureFlag"; import { useHasConnectToGitPermission, useHasManageAutoCommitPermission, @@ -71,9 +69,6 @@ const StyledDivider = styled(Divider)` function DangerZone() { const isConnectToGitPermitted = useHasConnectToGitPermission(); const isManageAutoCommitPermitted = useHasManageAutoCommitPermission(); - const isAutocommitFeatureEnabled = useFeatureFlag( - FEATURE_FLAG.release_git_autocommit_feature_enabled, - ); const isAutocommitToggling = useSelector(getIsAutocommitToggling); const isAutocommitEnabled = useSelector(getAutocommitEnabledSelector); const gitMetadataLoading = useSelector(getGitMetadataLoadingSelector); @@ -82,7 +77,7 @@ function DangerZone() { const currentApp = useSelector(getCurrentApplication); - const handleDisconnect = () => { + const handleDisconnect = useCallback(() => { AnalyticsUtil.logEvent("GS_DISCONNECT_GIT_CLICK", { source: "GIT_CONNECTION_MODAL", }); @@ -94,9 +89,9 @@ function DangerZone() { }), ); dispatch(setIsDisconnectGitModalOpen(true)); - }; + }, [currentApp?.id, currentApp?.name, dispatch]); - const handleToggleAutocommit = () => { + const handleToggleAutocommit = useCallback(() => { if (isAutocommitEnabled) { dispatch(setGitSettingsModalOpenAction({ open: false })); dispatch(setIsAutocommitModalOpen(true)); @@ -104,10 +99,9 @@ function DangerZone() { dispatch(toggleAutocommitEnabledInit()); AnalyticsUtil.logEvent("GS_AUTO_COMMIT_ENABLED"); } - }; + }, [dispatch, isAutocommitEnabled]); - const showAutoCommit = - isAutocommitFeatureEnabled && isManageAutoCommitPermitted; + const showAutoCommit = isManageAutoCommitPermitted; const showDisconnect = isConnectToGitPermitted; const showDivider = showAutoCommit && showDisconnect; @@ -128,7 +122,7 @@ function DangerZone() { {createMessage(AUTOCOMMIT_MESSAGE)}