Blame view

node_modules/inquirer/lib/objects/choices.js 2.89 KB
ce4c83ff   wxy   初始提交
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
  'use strict';
  var assert = require('assert');
  var _ = require('lodash');
  var Separator = require('./separator');
  var Choice = require('./choice');
  
  /**
   * Choices collection
   * Collection of multiple `choice` object
   * @constructor
   * @param {Array} choices  All `choice` to keep in the collection
   */
  
  var Choices = module.exports = function (choices, answers) {
    this.choices = choices.map(function (val) {
      if (val.type === 'separator') {
        if (!(val instanceof Separator)) {
          val = new Separator(val.line);
        }
        return val;
      }
      return new Choice(val, answers);
    });
  
    this.realChoices = this.choices
      .filter(Separator.exclude)
      .filter(function (item) {
        return !item.disabled;
      });
  
    Object.defineProperty(this, 'length', {
      get: function () {
        return this.choices.length;
      },
      set: function (val) {
        this.choices.length = val;
      }
    });
  
    Object.defineProperty(this, 'realLength', {
      get: function () {
        return this.realChoices.length;
      },
      set: function () {
        throw new Error('Cannot set `realLength` of a Choices collection');
      }
    });
  };
  
  /**
   * Get a valid choice from the collection
   * @param  {Number} selector  The selected choice index
   * @return {Choice|Undefined} Return the matched choice or undefined
   */
  
  Choices.prototype.getChoice = function (selector) {
    assert(_.isNumber(selector));
    return this.realChoices[selector];
  };
  
  /**
   * Get a raw element from the collection
   * @param  {Number} selector  The selected index value
   * @return {Choice|Undefined} Return the matched choice or undefined
   */
  
  Choices.prototype.get = function (selector) {
    assert(_.isNumber(selector));
    return this.choices[selector];
  };
  
  /**
   * Match the valid choices against a where clause
   * @param  {Object} whereClause Lodash `where` clause
   * @return {Array}              Matching choices or empty array
   */
  
  Choices.prototype.where = function (whereClause) {
    return _.filter(this.realChoices, whereClause);
  };
  
  /**
   * Pluck a particular key from the choices
   * @param  {String} propertyName Property name to select
   * @return {Array}               Selected properties
   */
  
  Choices.prototype.pluck = function (propertyName) {
    return _.map(this.realChoices, propertyName);
  };
  
  // Expose usual Array methods
  Choices.prototype.indexOf = function () {
    return this.choices.indexOf.apply(this.choices, arguments);
  };
  Choices.prototype.forEach = function () {
    return this.choices.forEach.apply(this.choices, arguments);
  };
  Choices.prototype.filter = function () {
    return this.choices.filter.apply(this.choices, arguments);
  };
  Choices.prototype.find = function (func) {
    return _.find(this.choices, func);
  };
  Choices.prototype.push = function () {
    var objs = _.map(arguments, function (val) {
      return new Choice(val);
    });
    this.choices.push.apply(this.choices, objs);
    this.realChoices = this.choices.filter(Separator.exclude);
    return this.choices;
  };