moltres-utils
Version:
Utils for Moltres apps
61 lines (49 loc) • 2.21 kB
JavaScript
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
;