1 | import _curry1 from "./internal/_curry1.js";
|
2 | import constructN from "./constructN.js";
|
3 | /**
|
4 | * Wraps a constructor function inside a curried function that can be called
|
5 | * with the same arguments and returns the same type.
|
6 | *
|
7 | * @func
|
8 | * @memberOf R
|
9 | * @since v0.1.0
|
10 | * @category Function
|
11 | * @sig (* -> {*}) -> (* -> {*})
|
12 | * @param {Function} fn The constructor function to wrap.
|
13 | * @return {Function} A wrapped, curried constructor function.
|
14 | * @see R.invoker
|
15 | * @example
|
16 | *
|
17 | * // Constructor function
|
18 | * function Animal(kind) {
|
19 | * this.kind = kind;
|
20 | * };
|
21 | * Animal.prototype.sighting = function() {
|
22 | * return "It's a " + this.kind + "!";
|
23 | * }
|
24 | *
|
25 | * const AnimalConstructor = R.construct(Animal)
|
26 | *
|
27 | * // Notice we no longer need the 'new' keyword:
|
28 | * AnimalConstructor('Pig'); //=> {"kind": "Pig", "sighting": function (){...}};
|
29 | *
|
30 | * const animalTypes = ["Lion", "Tiger", "Bear"];
|
31 | * const animalSighting = R.invoker(0, 'sighting');
|
32 | * const sightNewAnimal = R.compose(animalSighting, AnimalConstructor);
|
33 | * R.map(sightNewAnimal, animalTypes); //=> ["It's a Lion!", "It's a Tiger!", "It's a Bear!"]
|
34 | */
|
35 |
|
36 | var construct =
|
37 | /*#__PURE__*/
|
38 | _curry1(function construct(Fn) {
|
39 | return constructN(Fn.length, Fn);
|
40 | });
|
41 |
|
42 | export default construct; |
\ | No newline at end of file |