Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

react-templates, TypeScript, Webpack #238

Open
davidrapin opened this issue Apr 11, 2018 · 1 comment
Open

react-templates, TypeScript, Webpack #238

davidrapin opened this issue Apr 11, 2018 · 1 comment

Comments

@davidrapin
Copy link

Hi,

This is a question and/or an issue, since at this stage I'm not sure if I'm doing something wrong.
I can't seem to make react-templates, TypeScript and Webpack work together.

webpack.config.js:

module.exports = {
  // [...]
  resolve: {
    extensions: ['.js', '.jsx', '.ts', '.tsx', '.rt', '.es6', '.json', '.scss', '.css'],
    plugins: [ new TsconfigPathsPlugin() ]
  },
  // [...]
   module: {
    rules: [
      {
        test: /\.tsx?$/,
        loader: 'ts-loader',
        include: SRC_FOLDER,
        exclude: ['/node_modules/']
      },
      {
        test: /\.rt$/,
        loader: 'react-templates-loader?modules=commonjs',
        include: SRC_FOLDER,
      }
    ]
  }
}

TemplateExample.ts:

import * as React from 'react';
import { RouteComponentProps } from "react-router";
import template = require('./TemplateExample.rt');

export interface TemplateExample extends RouteComponentProps<any> {}
export class TemplateExample extends React.Component<TemplateExample, any> {

    getWorld(): string {
        return 'World!';
    }

    render() {
        return template.apply(this);
    }
}

 TemplateExample.rt:

<div>
    <strong>Hello {this.getWorld()} :)</strong>
</div>

Of course, both TemplateExample.ts and  TemplateExample.rt are in the same folder.

Error message

ERROR in /Users/david/Code/platypus/client/src/components/_Integration/TemplateExample.ts
./src/components/_Integration/TemplateExample.ts
[tsl] ERROR in /Users/david/Code/platypus/client/src/components/_Integration/TemplateExample.ts(11,27)
      TS2307: Cannot find module '/Users/david/Code/platypus/client/src/components/_Integration/TemplateExample.rt'.

I tried to change the modules option of the Webpack loader to typescript , in which case I get this error (which clarifies that the issue is not with the location of the template file):

ERROR in ./src/components/_Integration/TemplateExample.rt
Module parse failed: Unexpected token (1:13)
You may need an appropriate loader to handle this file type.
| import React = require('react');
| import _ = require('lodash');
| export = function() { return React.createElement('div',{},React.createElement('strong',{},"Hello ",(this.getWorld())," :)")) };
 @ ./src/components/_Integration/TemplateExample.ts 20:15-46
 @ ./src/components/Router.tsx
 @ ./src/components/App.tsx
 @ ./src/components/Root.tsx
 @ ./src/app.tsx
 @ multi ./src/app.tsx

Any feedback would be welcome!

@idok
Copy link
Contributor

idok commented Apr 24, 2018

Here is a working sample
https://github.com/wix/react-templates-ts

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants