mirror of
https://github.com/MrXujiang/h5-Dooring.git
synced 2026-01-08 12:58:11 +00:00
80 lines
2.0 KiB
TypeScript
80 lines
2.0 KiB
TypeScript
import React, { useMemo, memo, ReactNode, useContext, CSSProperties } from 'react';
|
|
import { useDrag } from 'react-dnd';
|
|
import schemaH5 from 'components/BasicShop/schema';
|
|
import schemaPc from 'components/BasicPcShop/schema';
|
|
import styles from './index.less';
|
|
import { dooringContext } from '@/layouts';
|
|
|
|
interface TargetBoxProps {
|
|
item: any;
|
|
children: ReactNode;
|
|
canvasId: string;
|
|
}
|
|
|
|
const TargetBox = memo((props: TargetBoxProps) => {
|
|
const { item } = props;
|
|
const context = useContext(dooringContext);
|
|
const schema = useMemo(() => {
|
|
if (context.theme === 'h5') {
|
|
return schemaH5;
|
|
} else {
|
|
return schemaPc;
|
|
}
|
|
}, [context.theme]);
|
|
const [{ isDragging }, drag] = useDrag({
|
|
item: {
|
|
type: item.type,
|
|
config: schema[item.type as keyof typeof schema].config,
|
|
h: item.h,
|
|
editableEl: schema[item.type as keyof typeof schema].editData,
|
|
category: item.category,
|
|
x: item.x || 0,
|
|
},
|
|
collect: monitor => ({
|
|
isDragging: monitor.isDragging(),
|
|
}),
|
|
});
|
|
|
|
const containerStyle: CSSProperties = useMemo(
|
|
() => ({
|
|
opacity: isDragging ? 0.4 : 1,
|
|
cursor: 'move',
|
|
height: '140px',
|
|
}),
|
|
[isDragging],
|
|
);
|
|
return (
|
|
<>
|
|
<div style={{ width: '50%', padding: '10px' }}>
|
|
<div className={styles.module} style={{ ...containerStyle }} ref={drag}>
|
|
<div
|
|
style={{
|
|
height: '110px',
|
|
display: 'flex',
|
|
justifyContent: 'center',
|
|
alignItems: 'center',
|
|
flexDirection: 'column',
|
|
overflow: 'hidden',
|
|
}}
|
|
>
|
|
{props.children}
|
|
</div>
|
|
<div
|
|
style={{
|
|
height: '30px',
|
|
lineHeight: '30px',
|
|
textAlign: 'center',
|
|
backgroundColor: 'rgba(245, 245, 245, 1)',
|
|
color: 'rgba(118, 118, 118, 1)',
|
|
}}
|
|
>
|
|
{props.item.displayName}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</>
|
|
);
|
|
});
|
|
|
|
export default TargetBox;
|