PromucFlow_constructor/app/client/src/layoutSystems/withLayoutSystemWidgetHOC.tsx
Valera Melnikov a2bfe450b6
chore: enable no-explicit-any rule (#35321)
## Description
-  Enabled the rule `@typescript-eslint/no-explicit-any`
- Suppressed errors with comment
```
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
```

Fixes #35308 

## Automation

/ok-to-test tags="@tag.All"

### 🔍 Cypress test results
<!-- This is an auto-generated comment: Cypress test results  -->
> [!TIP]
> 🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉
> Workflow run:
<https://github.com/appsmithorg/appsmith/actions/runs/10181176984>
> Commit: 7fc604e24fa234da7ab2ff56e0b1c715268796ee
> <a
href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=10181176984&attempt=2"
target="_blank">Cypress dashboard</a>.
> Tags: `@tag.All`
> Spec:
> <hr>Wed, 31 Jul 2024 15:00:45 UTC
<!-- end of auto-generated comment: Cypress test results  -->


## Communication
Should the DevRel and Marketing teams inform users about this change?
- [ ] Yes
- [x] No
2024-07-31 18:41:28 +03:00

65 lines
2.4 KiB
TypeScript

import type { RenderModes } from "constants/WidgetConstants";
import React from "react";
import { useSelector } from "react-redux";
import { getRenderMode } from "selectors/editorSelectors";
import { getLayoutSystemType } from "selectors/layoutSystemSelectors";
import type { WidgetProps } from "widgets/BaseWidget";
import { getAutoLayoutSystem } from "./autolayout";
import { getFixedLayoutSystem } from "./fixedlayout";
import type { LayoutSystem } from "./types";
import { LayoutSystemTypes } from "./types";
import { getAnvilLayoutSystem } from "./anvil";
/**
*
* @param renderMode - render mode specifies whether the application is in edit/deploy mode.
* @param layoutSystemType - layout system of the application.
* @returns
* @property — widgetSystem - widget specific wrappers and enhancers of a layout system
* @property — canvasSystem - canvas specific implementation and enhancers of a layout system
*/
export const getLayoutSystem = (
renderMode: RenderModes,
layoutSystemType: LayoutSystemTypes,
): LayoutSystem => {
switch (layoutSystemType) {
case LayoutSystemTypes.ANVIL:
return getAnvilLayoutSystem(renderMode);
case LayoutSystemTypes.AUTO:
return getAutoLayoutSystem(renderMode);
default:
return getFixedLayoutSystem(renderMode);
}
};
const LayoutSystemWrapper = ({
Widget,
widgetProps,
}: {
widgetProps: WidgetProps;
Widget: (props: WidgetProps) => JSX.Element;
}) => {
const renderMode = useSelector(getRenderMode);
const layoutSystemType = useSelector(getLayoutSystemType);
// based on layoutSystemType and renderMode
// get the layout system wrapper(adds layout system specific functionality) and
// properties enhancer(adds/modifies properties of a widget based on layout system)
const { widgetSystem } = getLayoutSystem(renderMode, layoutSystemType);
const { propertyEnhancer, WidgetWrapper } = widgetSystem;
const enhancedProperties = propertyEnhancer(widgetProps);
return (
<WidgetWrapper {...enhancedProperties}>
<Widget {...enhancedProperties} />
</WidgetWrapper>
);
};
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
export const withLayoutSystemWidgetHOC = (Widget: any) => {
return function LayoutWrappedWidget(props: WidgetProps) {
return <LayoutSystemWrapper Widget={Widget} widgetProps={props} />;
};
};