Lucky - TypeScript

Set up TypeScript in a Lucky Application
Icons/chart bar
Used 356 times
Created by
S Stephen Dolan

Usage
From within a Lucky application with the bloat gem installed, run:
bloat with https://railsbytes.com/script/zl0sNL

See an example of using this here: https://youtu.be/ty-rdD-UsUM

Run this command in your Rails app directory in the terminal:

rails app:template LOCATION="https://railsbytes.com/script/zl0sNL"
Template Source

Review the code before running this template on your machine.

def set_up_tsconfig
  create_file "tsconfig.json" do<<~EOF
    {
      "compilerOptions": {
        "declaration": false,
        "emitDecoratorMetadata": true,
        "experimentalDecorators": true,
        "esModuleInterop": true,
        "lib": ["es6", "dom"],
        "module": "es6",
        "moduleResolution": "node",
        "baseUrl": ".",
        "typeRoots": ["node_modules/@types"],
        "paths": {
          "*": ["node_modules/*", "app/js/*"]
        },
        "sourceMap": true,
        "target": "es5",
        "strict": true,
        "alwaysStrict": true
      },
      "exclude": ["node_modules", "lib", "public"],
      "compileOnSave": false
    }
  	EOF
  end
end

def set_up_eslintrc
  create_file ".eslintrc.js" do<<~EOF
    module.exports = {
      root: true,
      parser: '@typescript-eslint/parser',
      plugins: [
        '@typescript-eslint',
      ],
      extends: [
        'eslint:recommended',
        'plugin:@typescript-eslint/recommended',
      ],
    };
  	EOF
  end
end

def convert_webpack_mix_to_typescript
  gsub_file "webpack.mix.js",
  	'.js("src/js/app.js", "public/js")',
    '.ts("src/js/app.ts", "public/js/app.js")'
end

def yarn_dev(*packages)
  run("yarn add -D #{packages.join(" ")}")
end

# Add necessary DefinitelyTyped packages to package.json
say "Adding required yarn packages for TypeScript web development...", :yellow
yarn_dev "@types/node", "@types/webpack-env", "typescript", "ts-loader"
say "Done.", :green

say "Adding tsconfig.json file for TypeScript configuration...", :yellow
set_up_tsconfig
say "Done.", :green

say "Telling webpack.mix.js to process TypeScript...", :yellow
convert_webpack_mix_to_typescript
say "Done.", :green

say "Converting src/js/app.js to src/js/app.ts...", :yellow
run "mv src/js/app.js src/js/app.ts"
say "Done.", :green

if yes?("Would you like to set up ESLint for TypeScript development? [y/N]", :yellow)
  say "Installing required ESLint yarn packages for TypeScript...", :yellow
  yarn_dev "eslint", "@typescript-eslint/parser", "@typescript-eslint/eslint-plugin"
  set_up_eslintrc
  say "Done.", :green
end

say "All done! Restart your server with `lucky dev` to start using TypeScript!"
Comments

Sign up or Login to leave a comment.