使用 API 调用创建自耕农生成器

bre*_*uts 5 javascript node.js yeoman typescript yeoman-generator

我已经创建了一个可以正常工作的 Yeoman 生成器,现在我需要用另外两个问题来扩展它。

这个问题我已经有了

async prompting() {
  const prompts = [
    {
      name: "appName",
      message: "Project name: ",
      type: "input",
      default: this.props!.appName,
      validate(input: string) {
        const appName = validateAppName(input);
        return !appName[1] ? appName[0] : true;
      },
    },
    {
      type: "list",
      name: "tech",
      message: "Which tech?”,
      default: “cloud”,
      choices: [{ name: “cloud”}, { name: “onPrem” }}],
    },
    },
  ];
Run Code Online (Sandbox Code Playgroud)

现在我需要添加其他问题,例如您要创建项目的命名空间

{
  type: “list”,
  name: "namespace",
  suggestOnly: false,
  message: "which namespace: ",
  source: Namespace.searchNS,
  when: () => !isEmpty(this.namespace!.namespaceInstances),
  validate(val: boolean) {
    return val
      ? true
      : "choose a namespace where services are provisioned ";
  },
},
Run Code Online (Sandbox Code Playgroud)

并且用户应该选择一个命名空间(这里的技巧是我需要运行一些逻辑,即 rest 调用以取回命名空间列表),对于这个命名空间,我需要添加另一个问题。即对于用户选择的命名空间,我需要提供服务列表。

使用服务列表,类似这样的东西。

{
    name: "serviceInstanceName",
    type: "rawlist",
    message:
      "Choose a service instance ",
    default: this.props!.namespace,
    choices: srvInstanceList,
    when: () =>
      srvInstanceList !== undefined && !isEmpty(srvInstanceList),
  },
Run Code Online (Sandbox Code Playgroud)

我需要做什么:

  1. 运行 API (rest) 调用以获取命名空间列表,并将其作为列表显示给用户
  1. 当用户选择一个特定的命名空间时,我需要做一个新的rest调用来获取这个命名空间中的所有服务
  2. 用户选择服务

我应该把每个问题的逻辑放在哪里并将其传递给下一个问题

Dip*_*hah 1

我没有任何代码示例来支持答案,但如果我是你,我会:

  1. 运行 API(其余)调用以获取命名空间列表,将其作为列表显示给用户
  2. 当用户选择特定名称空间时,我需要执行新的休息调用以获取该名称空间中的所有服务
  3. 用户选择服务

对于与命名空间相关的问题,请使用choices属性和返回函数来加载所有命名空间。同样,对于与服务相关的问题,使用choices属性和返回函数将加载命名空间中的所有服务。

这是有关以下内容的文档choices

choice:(数组|函数)选择数组或返回选择数组的函数。如果定义为函数,第一个参数将是当前询问者会话的答案。数组值可以是简单的数字、字符串或包含名称(在列表中显示)、值(在答案哈希中保存)和简短(在选择后显示)属性的对象。

在该函数中,您将获得第一个参数,其中包含用户对之前问题给出的答案。

此外,您可以使用when问题中的属性来确定是否应根据以前的答案询问或跳过该问题。

参考: https: //github.com/SBoudrias/Inquirer.js/blob/master/README.md