Мне нужно вставить data-attr для реагирования компонента во время компиляции веб-пакета.Например, у меня есть этот компонент:
export const MyComponent = (props: any) => {
return (
<div>bla bla</div>
);
};
И после компиляции мне нужно это:
export const MyComponent = (props: any) => {
return (
<div data-attr="some data">bla bla</div>
);
};
Я написал следующий плагин (который, я думаю, почти завершен, но я не могу найтиспособ вставить атрибут):
export class ReactAttrGeneratorPlugin implements webpack.Plugin {
public apply({ hooks }: webpack.Compiler) {
hooks.compilation.tap(
"ReactAttrGeneratorPlugin",
(compilation) => {
compilation.dependencyFactories.set(ConstDependency, new NullFactory());
compilation.dependencyTemplates.set(ConstDependency, new ConstDependency.Template());
});
hooks.normalModuleFactory.tap('ReactAttrGeneratorPlugin', (factory) => {
factory.hooks.parser.for('javascript/auto').tap('ReactAttrGeneratorPlugin', (parser, options) => {
parser.hooks.statement.tap('ReactAttrGeneratorPlugin', (statement:any) => {
if (this.isOwnComponent(parser) && statement.type === 'ReturnStatement') {
const div = statement.argument.arguments[0];
/** What do I need here, to insert attribute to div? **/
}
});
});
});
}
private isOwnComponent(parser: any) {
return parser.state &&
parser.state.module &&
parser.state.module.resource.indexOf('node_modules') === -1 &&
parser.state.module.resource.endsWith('tsx');
}
}