Я пытаюсь использовать модуль реагировать на сортировку в моем проекте, но у меня возникли проблемы с импортом компонента в мое приложение со следующей ошибкой:
Error: Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: object.
Check the render method of DragDropContext(SortableTreeWithoutDndContext)
Вот мой код:
import React, { Component } from "react";
import SortableTree from "react-sortable-tree";
export default class Dialog extends Component {
constructor(props) {
super(props);
this.state = {
treeData: [{ title: "Chicken", children: [{ title: "Egg" }] }]
};
}
render() {
return (
<div style={{ height: 400 }}>
<SortableTree
treeData={this.state.treeData}
onChange={treeData => this.setState({ treeData })}
/>
</div>
);
}
}
Вот мой конфиг babelrc
{
"presets": ["@babel/preset-env", "@babel/preset-react"],
"plugins": [
"@babel/plugin-proposal-class-properties",
"react-hot-loader/babel",
[
"import",
{ "libraryName": "antd", "libraryDirectory": "es", "style": "css" }
]
]
}
И webpack.config.js
odule.exports = {
resolve: {
extensions: ["*", ".js", ".jsx", ".json"],
alias: {
Assets: path.resolve(__dirname, "assets"),
src: path.resolve(__dirname, "src")
}
},
devtool: "cheap-module-eval-source-map",
entry: [
"@babel/polyfill",
"./src/webpack-public-path",
"react-hot-loader/patch",
"webpack-hot-middleware/client?reload=true",
`${APP_DIR}/index.js`
],
target: "web",
mode: "development",
output: {
path: BUILD_DIR,
publicPath: "/",
filename: "bundle.js"
},
plugins: [
new HardSourceWebpackPlugin(),
new webpack.HotModuleReplacementPlugin(),
new webpack.NoEmitOnErrorsPlugin(),
new HtmlWebpackPlugin({
template: "src/index.html",
filename: "index.html",
minify: {
removeComments: true,
collapseWhitespace: true
},
inject: true
}),
new webpack.DefinePlugin({
"process.env.WORKSPACE_ID": JSON.stringify(
"17099f3e-640b-4294-a916-6aa199277c4c"
)
})
],
module: {
rules: [
{
test: /\.jsx?$/,
exclude: /node_modules/,
use: ["babel-loader"]
},
{
test: /antd.*\.css$/,
use: [
"style-loader",
"css-loader",
{
loader: "postcss-loader",
options: {
config: {
path: "./postcss.config.js"
}
}
}
]
},
{
test: /\.eot(\?v=\d+.\d+.\d+)?$/,
use: ["file-loader"]
},
{
test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
use: [
{
loader: "url-loader",
options: {
limit: 10000,
mimetype: "application/font-woff"
}
}
]
},
{
test: /\.[ot]tf(\?v=\d+.\d+.\d+)?$/,
use: [
{
loader: "url-loader",
options: {
limit: 10000,
mimetype: "application/octet-stream"
}
}
]
},
{
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
use: [
{
loader: "url-loader",
options: {
limit: 10000,
mimetype: "image/svg+xml"
}
}
]
},
{
test: /\.(jpe?g|jpg|png|gif|ico)$/i,
use: [
{
loader: "file-loader",
options: {
name: "[name].[ext]"
}
}
]
},
{
test: /\.(jpe?g|jpg|png|gif)$/i,
use: [
{
loader: "url-loader"
}
]
},
{
test: /\.css$/,
exclude: /antd.*\.css$/,
use: [
"style-loader",
"css-loader",
{
loader: "postcss-loader",
options: {
config: {
path: "./postcss.config.js"
}
}
}
]
},
{
test: /(\.scss|\.sass)$/,
use: [
"style-loader",
{
loader: "css-loader",
options: {
modules: true,
sourceMap: true,
localIdentName: "[name]__[local]___[hash:base64:5]"
}
},
{
loader: "postcss-loader",
options: {
plugins: () => [require("autoprefixer")],
sourceMap: true
}
},
{
loader: "sass-loader",
options: {
includePaths: [path.resolve(__dirname, "src", "scss")],
sourceMap: true
}
}
]
},
{
test: /\.less$/,
loaders: "style-loader!css-loader!less-loader",
query: {
modifyVars: themeVariables
}
}
]
}
У меня установлены последние модули babel, и я проверилтот же компонент в другом проекте, где он работал нормально.Я знаю, что это связано с моей конфигурацией, но, похоже, я не знаю, в чем проблема.