UNPKG

razorpay

Version:
231 lines (180 loc) 5.08 kB
"use strict"; /* * DOCS: https://razorpay.com/docs/invoices/ */ var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _require = require('../utils/razorpay-utils'), normalizeDate = _require.normalizeDate; module.exports = function invoicesApi(api) { var BASE_URL = "/invoices", MISSING_ID_ERROR = "Invoice ID is mandatory"; /** * Invoice entity gets used for both Payment Links and Invoices system. * Few of the methods are only meaningful for Invoices system and * calling those for against/for a Payment Link would throw * Bad request error. */ return { create: function create() { var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var callback = arguments[1]; /* * Creates invoice of any type(invoice|link|ecod). * * @param {Object} params * @param {Function} callback * * @return {Promise} */ var url = BASE_URL; return api.post({ url: url, data: params }, callback); }, edit: function edit(invoiceId) { var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var callback = arguments[2]; /* * Patches given invoice with new attributes * * @param {String} invoiceId * @param {Object} params * @param {Function} callback * * @return {Promise} */ var url = BASE_URL + "/" + invoiceId; if (!invoiceId) { return Promise.reject("Invoice ID is mandatory"); } return api.patch({ url: url, data: params }, callback); }, issue: function issue(invoiceId, callback) { /* * Issues drafted invoice * * @param {String} invoiceId * @param {Function} callback * * @return {Promise} */ if (!invoiceId) { return Promise.reject(MISSING_ID_ERROR); } var url = BASE_URL + "/" + invoiceId + "/issue"; return api.post({ url: url }, callback); }, delete: function _delete(invoiceId, callback) { /* * Deletes drafted invoice * * @param {String} invoiceId * @param {Function} callback * * @return {Promise} */ if (!invoiceId) { return Promise.reject(MISSING_ID_ERROR); } var url = BASE_URL + "/" + invoiceId; return api.delete({ url: url }, callback); }, cancel: function cancel(invoiceId, callback) { /* * Cancels issued invoice * * @param {String} invoiceId * @param {Function} callback * * @return {Promise} */ if (!invoiceId) { return Promise.reject(MISSING_ID_ERROR); } var url = BASE_URL + "/" + invoiceId + "/cancel"; return api.post({ url: url }, callback); }, fetch: function fetch(invoiceId, callback) { /* * Fetches invoice entity with given id * * @param {String} invoiceId * @param {Function} callback * * @return {Promise} */ if (!invoiceId) { return Promise.reject(MISSING_ID_ERROR); } var url = BASE_URL + "/" + invoiceId; return api.get({ url: url }, callback); }, all: function all() { var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var callback = arguments[1]; /* * Fetches multiple invoices with given query options * * @param {Object} invoiceId * @param {Function} callback * * @return {Promise} */ var from = params.from, to = params.to, count = params.count, skip = params.skip, url = BASE_URL; if (from) { from = normalizeDate(from); } if (to) { to = normalizeDate(to); } count = Number(count) || 10; skip = Number(skip) || 0; return api.get({ url: url, data: _extends({}, params, { from: from, to: to, count: count, skip: skip }) }, callback); }, notifyBy: function notifyBy(invoiceId, medium, callback) { /* * Send/re-send notification for invoice by given medium * * @param {String} invoiceId * @param {String} medium * @param {Function} callback * * @return {Promise} */ if (!invoiceId) { return Promise.reject(MISSING_ID_ERROR); } if (!medium) { return Promise.reject("`medium` is required"); } var url = BASE_URL + "/" + invoiceId + "/notify_by/" + medium; return api.post({ url: url }, callback); } }; };