UNPKG

moltres-utils

Version:
61 lines (49 loc) 2.21 kB
"use strict"; require("core-js/modules/es6.object.define-property"); Object.defineProperty(exports, "__esModule", { value: true }); exports.dispatchableAppend = exports.baseAppend = exports.default = void 0; var _concat = _interopRequireDefault(require("./concat")); var _curry = _interopRequireDefault(require("../common/curry")); var _dispatchable = _interopRequireDefault(require("../common/dispatchable")); var _isString = _interopRequireDefault(require("../lang/isString")); var _resolveWith = _interopRequireDefault(require("../common/resolveWith")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var baseAppend = function baseAppend(value, arrayLike) { if ((0, _isString.default)(arrayLike)) { return (0, _concat.default)(arrayLike, value); } return (0, _concat.default)(arrayLike, [value]); }; exports.baseAppend = baseAppend; var dispatchableAppend = (0, _dispatchable.default)('append', baseAppend); /** * Returns a new list containing the contents of the given list, followed by the given value. * * This method dispatches to the `append` method of the `arrayLike` argument if it exists. * * This method will auto upgrade to async and resolve the `arrayLike` value if the `arrayLike` value is a Promise. * * @function * @since v0.0.3 * @category data * @param {*} value The value to add to the end of the new list. * @param {Array|string} arrayLike The array like value of elements to add a new item to. * @return {Array|string} A new array or string containing the elements of the old list followed by `value`. * @example * * append('tests', ['write', 'more']) //=> ['write', 'more', 'tests'] * append('tests', []) //=> ['tests'] * append(['tests'], ['write', 'more']) //=> ['write', 'more', ['tests']] * append('tests', 'write more ') //=> 'write more tests' */ exports.dispatchableAppend = dispatchableAppend; var append = (0, _curry.default)(function (value, arrayLike) { return (0, _resolveWith.default)(function (resolvedArrayLike) { return dispatchableAppend(value, resolvedArrayLike); }, arrayLike); }); var _default = append; exports.default = _default; //# sourceMappingURL=append.js.map