<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: sutriptaroy</title>
    <description>The latest articles on DEV Community by sutriptaroy (@sutriptaroy).</description>
    <link>https://dev.to/sutriptaroy</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F299296%2F6f9707ad-8acb-46ea-915a-4d9cd7994ba9.jpeg</url>
      <title>DEV Community: sutriptaroy</title>
      <link>https://dev.to/sutriptaroy</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/sutriptaroy"/>
    <language>en</language>
    <item>
      <title>React SSR webpack problem</title>
      <dc:creator>sutriptaroy</dc:creator>
      <pubDate>Mon, 23 Dec 2019 12:38:10 +0000</pubDate>
      <link>https://dev.to/sutriptaroy/react-ssr-webpack-problem-51ba</link>
      <guid>https://dev.to/sutriptaroy/react-ssr-webpack-problem-51ba</guid>
      <description>&lt;p&gt;I'm facing problem with SSR webpack. In client side webpack is not implmenting the react class component behaviour correctly, I guess. Could anyone help my out of this???&lt;/p&gt;

&lt;p&gt;webpack.client.js ---&lt;/p&gt;

&lt;p&gt;const path = require('path')&lt;/p&gt;

&lt;p&gt;module.exports = {&lt;br&gt;
    mode: 'development',&lt;br&gt;
    target: 'node',&lt;br&gt;
    entry: './config/client.js',&lt;br&gt;
    output: {&lt;br&gt;
        filename: 'client_bundle.js',&lt;br&gt;
        path: path.resolve(__dirname, 'build/public'),&lt;br&gt;
        publicPath: '/build/public'&lt;br&gt;
    },&lt;br&gt;
    module: {&lt;br&gt;
        rules: [&lt;br&gt;
            {&lt;br&gt;
                test: [/.svg$/, /.gif$/, /.jpe?g$/, /.png$/],&lt;br&gt;
                loader: "file-loader",&lt;br&gt;
                options: {&lt;br&gt;
                    name: "public/media/[name].[ext]",&lt;br&gt;
                    publicPath: url =&amp;gt; url.replace(/public/, "")&lt;br&gt;
                }&lt;br&gt;
            },&lt;br&gt;
            {&lt;br&gt;
                test: /.js$/,&lt;br&gt;
                loader: 'babel-loader',&lt;br&gt;
                exclude: '/node_modules/',&lt;br&gt;
                options: {&lt;br&gt;
                    presets: [&lt;br&gt;
                        '@babel/preset-react',&lt;br&gt;
                        ['@babel/preset-env', {&lt;br&gt;
                            targets: {browsers: ['last 2 versions']}&lt;br&gt;
                        }]&lt;br&gt;
                    ]&lt;br&gt;
                }&lt;br&gt;
            }&lt;br&gt;
        ]&lt;br&gt;
    }&lt;br&gt;
}&lt;/p&gt;

&lt;p&gt;server.js ---&lt;/p&gt;

&lt;p&gt;/* suffs ...&lt;/p&gt;

&lt;p&gt;app.get('*', (req, res) =&amp;gt; {&lt;br&gt;
    const context = {}&lt;/p&gt;

&lt;div class="highlight"&gt;&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const content = ReactDOMServer.renderToString(
    &amp;lt;StaticRouter location={req.url} context={context}&amp;gt;
        &amp;lt;App /&amp;gt;
    &amp;lt;/StaticRouter&amp;gt;
);

const helmet = Helmet.renderStatic();

const html = `
    &amp;lt;!DOCTYPE html&amp;gt;
    &amp;lt;html lang="en"&amp;gt;
        &amp;lt;head&amp;gt;
            &amp;lt;meta charset="utf-8" /&amp;gt;
            &amp;lt;meta name="viewport" content="width=device-width, initial-scale=1" /&amp;gt;
            &amp;lt;meta name="theme-color" content="#48afd9" /&amp;gt;
            &amp;lt;link rel="stylesheet" type="text/css" href="/static/styles.css" /&amp;gt;
            ${helmet.title.toString()}
            ${helmet.meta.toString()}
        &amp;lt;/head&amp;gt;
        &amp;lt;body&amp;gt;
            &amp;lt;div id="edtalk-main"&amp;gt;
                ${content}
            &amp;lt;/div&amp;gt;
            &amp;lt;script src="client_bundle.js"&amp;gt;&amp;lt;/script&amp;gt;
        &amp;lt;/body&amp;gt;
    &amp;lt;/html&amp;gt;
`;
res.send(html)
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

&lt;p&gt;})&lt;/p&gt;

&lt;p&gt;... stuffs ***/&lt;/p&gt;

&lt;p&gt;With this I'm not able to implement onClick, DidMount method in react class component, while functional components are working fine.&lt;/p&gt;

</description>
      <category>react</category>
    </item>
  </channel>
</rss>
