Невозможно настроить React Pre Hook с параметрами, переданными «npm start» - PullRequest
0 голосов
/ 02 февраля 2020

У меня есть совершенно новый проект, созданный с:

$ npx create-react-app test-react-app && cd test-react-app && npm start

здесь репо: https://github.com/tlg-265/test-react-app

Я создал новый скрипт: /prepare-project.js с следующее содержимое:

let project = 'ferrari' // replace this value with the one passed via: $ npm start [what to put here?]

console.log(`########################`);
console.log(`###### The current project is: ${project} ######`);
console.log(`########################`);

Содержимое файла: /package.json:

{
  "name": "test-react-app",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^4.2.4",
    "@testing-library/react": "^9.3.2",
    "@testing-library/user-event": "^7.1.2",
    "react": "^16.12.0",
    "react-dom": "^16.12.0",
    "react-scripts": "3.3.1"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject",
    "prestart": "node prepare-project.js"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}

, где вы можете видеть, что я настроил pre hook:

"prestart": "node prepare-project.js"

Моя цель - выполнить:

$ npm start [what to put here?]

, поэтому внутри скрипта: /prepare-project.js Я могу прочитать это значение.

Я пробовал:

$ node prepare-project.js --project=mclaren

безуспешно при попытке прочитать это значение из скрипта: prepare-project.js.

Есть идеи, как этого добиться?

Спасибо!

1 Ответ

1 голос
/ 02 февраля 2020

Вы можете использовать модуль yargs для разбора аргументов командной строки, а затем вы можете использовать child_process для выполнения вашей команды. Вот как должен выглядеть ваш код, вы можете добавить свой собственный лог c.

const yargs = require('yargs');
const { execSync } = require('child_process');

const argv = yargs
    .option('project', {
        alias: 'p',
        description: 'name of the project',
        type: 'string',
    })
    .help()
    .alias('help', 'h')
    .argv;

console.log(argv.project);
console.log(`npm start --project=${argv.project}`);
const output = execSync(`npm start --project=${argv.project}`);
console.log(output)
...