ToolJet/frontend/src/Editor/WidgetManager/components.js

45 lines
1.3 KiB
JavaScript
Raw Normal View History

import { widgets } from './widgetConfig';
const universalProps = {
properties: {},
general: {
Feature/component property validation (#2782) * Initial architecture for component property validation * Coerce to default and log invalid properties * eslint rule:frontend for specifying the path to the @types/ * removes comment for eslint-disable-next-line * reverts 27946f1 & adding a temporary fix * Remove incorrect property validations * Avoid race condiiton in setting state for error logs * Fix issue where only one error got logged * Flush out any errors that are logged * Remove unnecessary console.log * Add validations for Table properties * Add support for multiple validations * Add validation for chart component * Add validation for modal * Set default value common to all validation schemas for component properties * Add validations for password widget * Add validations for datepicker * Add information about default value on validation error message * Remove unwanted console.log * Do not validate properties on Viewer * Use meta information from widget config instead of component state to validate * Do not coerce to default values while validating * Do not validate existing components * Update package-lock.json in sync with develop * Add validation for general properties * Add support for size validation of component properties and styles * Add support for min and max spec in size validation * Support pattern validation for string properties * Make size validation specifiable along with type specification * Component validation optimizations * Remove unnecessary comments * Remove unnecessary default value param from validation * Fixed visibility style validation bug * Added custom validation to PDF & Custom component * property/style validation statistics * values changed to string * validation button group widget * bugfix * Added property validation to timeline widget * Added visibility prop validation to timeline widget * steps property/style validation * svg component property validation * component property validation numberinput * bugfix * validation textarea * validation vertical divider * property validation html widget * validation :: checkbox * image property validation * validation :: rangeslider widget * validation :: circular progress bar * validation spinner * added props and style validation * tags validation * validation :: pagination * timer :: validation * validation :: toggle * validation :: divider * validation :: radiobutton * added props and style validation * validation:: iframe * validation :: password input * validation:: code editor * validation :: listview * validation :: star rating * validation :: modal * validation :: qrscanner * validation :: datepicker * multiselect :: validation * added union validation for border radius * added props and style validation * added props and styles validation * added props and styles validations * added props and styles validations * added props and style validations * added props and styles validations * added prop and style validations * added props and styles validations * Added ID validation to steps widget * Removed default value * Added validation key to SVG widget * Removed default value * table validations * table validations * removing default value * removing defaultval * removing default val * removing default val * padding validation update * updating number validation * updatin number validation * validation updates * border validation * border radius validation * number input validation * validation updates * border radius validation * validation update * Updated misspelled schema text * Updated Tabs validation schema * Updated tooltip element schema * Updated validation for multi select * Updated validation for dropdown * Updated validation for text widget * Rectified mispelled validation * Fixed : validation not working for format * Added Array validation to chart widget * format prop bug fix * draft complete :: table validation * Fixed misspelled text * Don't validate properties that are not defined on widgetConfig Co-authored-by: arpitnath <[email protected]> Co-authored-by: Kavin Venkatachalam <[email protected]> Co-authored-by: stepinfwd <[email protected]> Co-authored-by: manishkushare <[email protected]> Co-authored-by: Kavin Venkatachalam <50441969+[email protected]>
2022-07-19 13:21:45 +00:00
tooltip: { type: 'code', displayName: 'Tooltip', validation: { schema: { type: 'string' } } },
},
others: {},
events: {},
styles: {},
Feature/component property validation (#2782) * Initial architecture for component property validation * Coerce to default and log invalid properties * eslint rule:frontend for specifying the path to the @types/ * removes comment for eslint-disable-next-line * reverts 27946f1 & adding a temporary fix * Remove incorrect property validations * Avoid race condiiton in setting state for error logs * Fix issue where only one error got logged * Flush out any errors that are logged * Remove unnecessary console.log * Add validations for Table properties * Add support for multiple validations * Add validation for chart component * Add validation for modal * Set default value common to all validation schemas for component properties * Add validations for password widget * Add validations for datepicker * Add information about default value on validation error message * Remove unwanted console.log * Do not validate properties on Viewer * Use meta information from widget config instead of component state to validate * Do not coerce to default values while validating * Do not validate existing components * Update package-lock.json in sync with develop * Add validation for general properties * Add support for size validation of component properties and styles * Add support for min and max spec in size validation * Support pattern validation for string properties * Make size validation specifiable along with type specification * Component validation optimizations * Remove unnecessary comments * Remove unnecessary default value param from validation * Fixed visibility style validation bug * Added custom validation to PDF & Custom component * property/style validation statistics * values changed to string * validation button group widget * bugfix * Added property validation to timeline widget * Added visibility prop validation to timeline widget * steps property/style validation * svg component property validation * component property validation numberinput * bugfix * validation textarea * validation vertical divider * property validation html widget * validation :: checkbox * image property validation * validation :: rangeslider widget * validation :: circular progress bar * validation spinner * added props and style validation * tags validation * validation :: pagination * timer :: validation * validation :: toggle * validation :: divider * validation :: radiobutton * added props and style validation * validation:: iframe * validation :: password input * validation:: code editor * validation :: listview * validation :: star rating * validation :: modal * validation :: qrscanner * validation :: datepicker * multiselect :: validation * added union validation for border radius * added props and style validation * added props and styles validation * added props and styles validations * added props and styles validations * added props and style validations * added props and styles validations * added prop and style validations * added props and styles validations * Added ID validation to steps widget * Removed default value * Added validation key to SVG widget * Removed default value * table validations * table validations * removing default value * removing defaultval * removing default val * removing default val * padding validation update * updating number validation * updatin number validation * validation updates * border validation * border radius validation * number input validation * validation updates * border radius validation * validation update * Updated misspelled schema text * Updated Tabs validation schema * Updated tooltip element schema * Updated validation for multi select * Updated validation for dropdown * Updated validation for text widget * Rectified mispelled validation * Fixed : validation not working for format * Added Array validation to chart widget * format prop bug fix * draft complete :: table validation * Fixed misspelled text * Don't validate properties that are not defined on widgetConfig Co-authored-by: arpitnath <[email protected]> Co-authored-by: Kavin Venkatachalam <[email protected]> Co-authored-by: stepinfwd <[email protected]> Co-authored-by: manishkushare <[email protected]> Co-authored-by: Kavin Venkatachalam <50441969+[email protected]>
2022-07-19 13:21:45 +00:00
validate: true,
generalStyles: {
boxShadow: { type: 'boxShadow', displayName: 'Box Shadow' },
},
definition: {
others: {},
events: [],
styles: {},
Feature/multi page applications (Task ID - CU-2h1bfvw) (#4729) * Add routes for multi-page apps * Modify Editor, Viewer and Inspector to accept new app structure * Show a page selector on left side bar * Align component deletion logic with new app schema * Make subcontainer work with multi-page apps * Load components state properly in viewer * Use UUID instead of handle for pages * Display sidebar on viewer to switch pages * Add proper URL suffixing for pages in viewer * Add action to switch page * Revert translation file back to its pre-existing linting * Fix bug that caused modal to not open/close * Add support for query params in page switch * Fix the issue that caused navigation to fail while accessed via slug * Add missing SwitchPage file * Add support for page level variables * Add migration to convert existing apps to new schema * Add rollback for converting multi-page definitions back to single-page * Fix migration for multi-page apps * Adapt import/export service for multi-pages * [improvements] Multi-page applications (#4755) * UI updates for page selector popup card * delete page * delete page check: if only one page exits * switch to home page if the selected page is removed * adds and switch to new page * updating page name * updates to home page and starting page * handle updating the home page when home page is deleted * search box for filtering pages and minor style updates for the page handler card * header search box style fixes * for creating a new page, page handle needs to be unique * seperating into smaller components * updated pinned icon for page selector styles and settinf styles * Leftsidebar header ui component * handle dark theme * page handle ui and dark theme fixes for page menu * page handler edit modal * pinned state and update pinned state for menu options triggered * dark theme fixes for edit modal * handle on update should not be empty or prev * page handler updater * added loading state for saving * handles cancels * fixes slug ui * fixes crash for older app versions * updates the query params when handle gets an update * update homePage to homePageId * removes console.log * go back to the popover for modal close * fixes: Difficult to select page * fixes: Difficult to select the three-dot menu * fixes: on visiting the root url, navigate to homepage on viewer * adds tooltip for url * updates the page selector sidebar with sync with query manager * refactor and cleanup * refactor and cleanup * Compute component state when page is switched * modal should not close on click outside * disable save button if there is not change in the page handle input * should show/hide page menu when hovered * page icon * updates delete icon for disabled state * query manager should always be on top of page selector * checks if homePage key exists in pages def * updates page handler menu * updates the clear icon * page handler menu position * page handler menu position * handle icon * alert msg * global settings handler for updating viewer page navigation * show/hode page navigation for viewer * info text for toggle * Multipages:with sortable list [DnD] (#4783) * applied sortable list * on sort updates the definitions * fixies: app crash for dnd * viwer: canvas width should be 100% when navigation drawer is disbaled * fixes: homepage/startpage reload * clean up Co-authored-by: Sherfin Shamsudeen <[email protected]> * Multipage UI viewer (#4801) * new ui changes for viewer pages * fixes postions for debugger and datasources popover * removes console.log * Multipage : hide page and unhide page feature (#4803) * adds: ability to hide pages * hides pages in viewer * unhide page * hide icon * allow accessing hidden pages from url * add: duplicate page (#4802) * add: duplicate page * do not copy the same references from the original page * page name and page handler should be unique for duplicate pages too * Add support for on-page-load events * Add icon from page settings menu item * Convert existing templates to multi-page schema * error logs for page level and app level errors (#4842) * Adapt comments feature for multi-pages * [Bugfix] multipage - page menu interactions (#4844) * fixes: menu popup interaction * fixes: on modal input focus, we switch the page * Adapt multi-player to multi-pages * Add editingPageId to ymap * Log self, others and editor props in real-time avatar generation * Save editing page id to appDef * Add editingPageId to presence in RealtimeCursors * adds no results ui for empty search results (#4869) * page icon updated (#4870) * fixes:Version switching crashes if the target version does not contain the current page (#4868) * Remove unnecessary setting of editingPageId on ymap * Remove unnecessary console.log * [Bugfix] Multipages: widget inspector event popover unmounts (#4887) * introduced a local state for events * cleaned up inspector.jsx * fixes: table widget inspector event accordion * Do not run switchPage twice when viewer is loaded * Preview should open the currently editing page * Properly place navigation and canvas in viewer * Update app definition whenever event manager changes are made * Add support for browser back and forward button in multi-pages * Rename handleBackButton to handlePageSwitchingBasedOnURLparam * Add support for cut/copy/paste and clone * Fix the crash caused by boxShadow * Add support for background colors in viewer in multi-pages * Run queries to be run on load on viewer, in multi-pages * Fix issue that caused inspector popovers to collapse * resolves workspace vars in viewer mode (#4892) * Multipage : Navigation for Mobile-ui (#4814) * refactored to components * burger menu for mobile ui * merge conflict fix for hidden pages * hamburger menu positioned in the header * viewer header reafctored * viewer mobile page manu styles * handles dark theme * mobile menu with dark mode toggle in the footer * components are moved to page level, handle for mobile layout * style fixes * removing unwanted code block * dark theme fixes * style fixes * fixes: events are sortable (#4895) * fixes: events are sortable * Remove uneccesarily repeated call of setEvents in EventManager Co-authored-by: Sherfin Shamsudeen <[email protected]> * renamed settings to Event handlers (#4898) * updates the page setting title to Page Events * temp commit * Add support for setting max width in percentage * fixes: paramUpdates for boxes: 🙌🏻 * [Bugfix] Multipage - viewer canvas dark theme (#4897) * fixes: darktheme bg for viewer canvas * reverts canvas size * Fix for inspector bouncing back to previous values * resolves pages variables in pythong and js transformation (#4905) * csa support to event manager for pages (#4907) * Add support for setting canvas width in percentages * Persist page level variables across page switches * latest definitions is merged with the current appdef (#4914) * latest definitions is merged with the current appdef * mutating the local obj * cleanup * iterate through pages for new versions are created Co-authored-by: Arpit <[email protected]>
2022-12-08 12:21:09 +00:00
generalStyles: {
boxShadow: { value: '0px 0px 0px 0px #00000040' },
},
},
};
const combineProperties = (widget, universal, isArray = false) => {
return {
Feature/component property validation (#2782) * Initial architecture for component property validation * Coerce to default and log invalid properties * eslint rule:frontend for specifying the path to the @types/ * removes comment for eslint-disable-next-line * reverts 27946f1 & adding a temporary fix * Remove incorrect property validations * Avoid race condiiton in setting state for error logs * Fix issue where only one error got logged * Flush out any errors that are logged * Remove unnecessary console.log * Add validations for Table properties * Add support for multiple validations * Add validation for chart component * Add validation for modal * Set default value common to all validation schemas for component properties * Add validations for password widget * Add validations for datepicker * Add information about default value on validation error message * Remove unwanted console.log * Do not validate properties on Viewer * Use meta information from widget config instead of component state to validate * Do not coerce to default values while validating * Do not validate existing components * Update package-lock.json in sync with develop * Add validation for general properties * Add support for size validation of component properties and styles * Add support for min and max spec in size validation * Support pattern validation for string properties * Make size validation specifiable along with type specification * Component validation optimizations * Remove unnecessary comments * Remove unnecessary default value param from validation * Fixed visibility style validation bug * Added custom validation to PDF & Custom component * property/style validation statistics * values changed to string * validation button group widget * bugfix * Added property validation to timeline widget * Added visibility prop validation to timeline widget * steps property/style validation * svg component property validation * component property validation numberinput * bugfix * validation textarea * validation vertical divider * property validation html widget * validation :: checkbox * image property validation * validation :: rangeslider widget * validation :: circular progress bar * validation spinner * added props and style validation * tags validation * validation :: pagination * timer :: validation * validation :: toggle * validation :: divider * validation :: radiobutton * added props and style validation * validation:: iframe * validation :: password input * validation:: code editor * validation :: listview * validation :: star rating * validation :: modal * validation :: qrscanner * validation :: datepicker * multiselect :: validation * added union validation for border radius * added props and style validation * added props and styles validation * added props and styles validations * added props and styles validations * added props and style validations * added props and styles validations * added prop and style validations * added props and styles validations * Added ID validation to steps widget * Removed default value * Added validation key to SVG widget * Removed default value * table validations * table validations * removing default value * removing defaultval * removing default val * removing default val * padding validation update * updating number validation * updatin number validation * validation updates * border validation * border radius validation * number input validation * validation updates * border radius validation * validation update * Updated misspelled schema text * Updated Tabs validation schema * Updated tooltip element schema * Updated validation for multi select * Updated validation for dropdown * Updated validation for text widget * Rectified mispelled validation * Fixed : validation not working for format * Added Array validation to chart widget * format prop bug fix * draft complete :: table validation * Fixed misspelled text * Don't validate properties that are not defined on widgetConfig Co-authored-by: arpitnath <[email protected]> Co-authored-by: Kavin Venkatachalam <[email protected]> Co-authored-by: stepinfwd <[email protected]> Co-authored-by: manishkushare <[email protected]> Co-authored-by: Kavin Venkatachalam <50441969+[email protected]>
2022-07-19 13:21:45 +00:00
...universal,
...widget,
properties: { ...universal.properties, ...widget.properties },
general: { ...universal.general, ...widget.general },
others: { ...universal.others, ...widget.others },
events: isArray ? [...universal.events, ...widget.events] : { ...universal.events, ...widget.events },
styles: { ...universal.styles, ...widget.styles },
generalStyles: { ...universal.generalStyles, ...widget.generalStyles },
exposedVariables: { ...universal.exposedVariables, ...widget.exposedVariables },
};
};
export const componentTypes = widgets.map((widget) => {
return {
...combineProperties(widget, universalProps),
definition: combineProperties(widget.definition, universalProps.definition, true),
};
});