donations-box
v1.0.0-rc.10
Published
A widget to ask for donations.
Downloads
2
Readme
About
donations-box is a widget for developers who want to list all their donation links, in a single place.
Features
- No Javascript required.
- No frames.
- Easy to use.
- Configurable.
- Minified already.
- Open Source.
Installation
- Via NPM:
npm i donations-box -g
. - Via YARN:
yarn global add donations-box
.
Usage
To add this widget to your site:
- Install it.
- Create a new file called
donations-box.config.js
, in the root of your project. - Set your donation links and your desired configurations. See here.
- Write
<!-- donations-box -->
where you want to include this widget. - Call the CLI or the JS version, during you build process.
And that's it!
If everything works as expected, you should see a new file in public/css
called donations-box.min.css
, and your files where you wrote <!-- donations-box -->
with the Donations Box's markup.
CLI
Run donations-box my-file
.
Where my-file
is where you want to add the widget to.
Options
If you need to change anything, try setting any of the following options:
donations-box <files...> [options]
Inject the donations box's markup in the given files.
Positionals:
files Files to inject the donations box's markup. (Globs supported).
Options:
--help Show help [boolean]
--version Show version number [boolean]
--config Path to your configuration file. See the Configure section in the
README file to know more.
[required] [default: "donations-box.config.js"]
--assetsDir Directory in which the assets for this project will be stored.
E.g: The css file. [default: "public"]
--token String to be replaced by the donations box's markup.
[default: "<!-- donations-box -->"]
JS
const donationsBox = require('donations-box');
(async () => {
try {
/**
* All CLI positionals, and options are supported, except "help", and "version". None is optional.
*
* To know more about each option, run `donations-box --help` from the CLI.
*
* @param {!object} options
* @param {!string} options.files
* @param {!string} options.config
* @param {!string} options.assetsDir
* @param {!string} options.token
*
* @returns {Promise}.
*/
await donationsBox({
files: '',
config: '',
assetsDir: '',
token: ''
});
}
catch (
/** @type {BuildError|CopyError|InjectionError} */
exception
) {
/**
* Check exception#name and act accordingly, if you want.
*
* @example
* const {name} = exception;
*
* if (name === 'BuildError') { console.error('Error building assets.'); }
* else if (name === 'CopyError') { console.error('Error copying assets.'); }
* else if (name === 'InjectionError') { console.error('Error injecting markup.'); }
*/
}
})();
Configuration
Configuration is done using a js
or a json
file, but a js
file is recommended.
The only requirement is that the js
file should export an object with your configurations.
Below are the supported configurations (remember that all the options are used for display purposes):
module.exports = {
/**
* If a truthy value is given, open all links in a new window.
*
* @type {?boolean}
*/
'openInNewWindow': false,
/**
* [Optional]
*
* The reason why you're asking for donations.
*
* @type {?string}
*/
'headline': '',
/**
* [Optional]
*
* A disclaimer about your donations.
*
* Any HTML tag is valid, but it will be added within a <small> element.
*
* @type {?string}
*/
'disclaimer': '',
/**
* [Only available if headline is set]
*
* If true, always show the donations. Javascript is not used.
* If false, show a button to open the donations. Requires Javascript
* to work.
* If "auto", show a button to open the donations if Javascript
* is enabled, otherwise show the donations.
*
* @type {?boolean|?string}
*/
'open': true,
/**
* [Only available if headline and disclaimer are set]
*
* Show this number of columns, when the widget is open, on larger screens.
*
* Min value: 1
* Max value: 2
* Default value: 2
* Invalid becomes: 2
*
* @type {?number}
*/
'maxColumns': 2,
/**
* The person/company who is asking for donations.
*
* @type {!object}
*/
'beneficiary': {
/**
* The display name for the beneficiary.
*
* @type {!string}
*/
'alias': 'Donations Box',
/**
* The url to the beneficiary's website,
* or something similar.
*
* @type {!string}
*/
'href': '/beneficiary.html',
/**
* Options for the beneficiary's logo/icon.
*
* @type {!object}
*/
'icon': {
/**
* [Available if "html" is not set]
*
* Url to the image.
*
* @type {!string}
*/
'src': '/favicon.svg',
/**
* [Available if "html" is not set]
*
* Icon's description.
*
* @type {!string}
*/
'alt': 'Donations Box icon',
/**
* [Available if "html" is not set]
*
* Url to visit, on click.
*
* @type {!string}
*/
'href': '/beneficiary.html?icon',
/**
* [Optional]
*
* Add your own markup to load the image.
*
* @type {?string}
*/
'html': null
}
},
/**
* An object containing payment providers as keys,
* and payment specific options as values.
*
* @type {!object}
*/
'donations': {
/**
* Payment options.
*
* @type {!object[]}
*/
'Stripe': [{
/**
* Type of payment: "one-off" or "recurrent".
*
* @type {!string}
*/
'type': 'one-off',
/**
* The url where you actually make the donation.
* It usually includes the description of your donation
* (usually referred as "product") and some payment options.
*
* @type {!string}
*/
'href': '/donate.html',
/**
* The title for your donation/product.
*
* @type {!string}
*/
'title': 'Buy me 1 coffee',
/**
* The available amounts for your donation.
*
* If "type" is set to "one-off", it will use the first amount
* and ignore the others.
*
* @type {!object[]|object}
*/
'amounts': [{
/**
* The url for your donation/product.
*
* Defaults to donation.href.
*
* @type {?string}
*/
'href': '/donate.html',
/**
* The requested amount.
*
* @type {!number}
*/
'value': 3,
/**
* [Available only on "recurrent" donations].
*
* The periodicity of the payment:
* "Daily", "Monthly", "Yearly", ...
*
* The only requirement for this value is that
* is should fill the blanks in the following text:
* "billed ________".
*
* @type {?string}
*/
'periodicity': 'Daily',
/**
* [Optional]
*
* Options for a QR code.
*
* @type {?object}
*/
'qr': {
/**
* Url for the image.
*
* @type {!string}
*/
'src': '/img/monero-qr.png',
/**
* Image's description.
*
* @type {!string}
*/
'alt': 'Donations Box\'s Monero QR Code',
/**
* [Optional]
*
* A valid img[srcset] attribute value.
*
* Useful to show different images on retina displays,
* for example.
*
* @type {?string}
*/
'srcset': '/img/monero-qr.png 2x',
/**
* If a truthy value is given, the qr code will
* appear on focus/hover.
*
* @type {?boolean}
*/
'animate': false
},
/**
* Options for the used currency.
*
* Since this value could get repetitive, it's
* recommended to use a javascript file and
* use a variable here instead. Maybe future
* versions will allow setting a string here,
* but for now it requires an object.
*
* @type {!object}
*/
'currency': {
/**
* The symbol for the currency.
*
* @type {?string}
*/
'symbol': '$',
/**
* The name of the currency.
*
* @type {!string}
*/
'name': 'Dollars',
/**
* The abbreviation for the currency's name.
*
* @type {!string}
*/
'abbr': 'USD'
}
}]
}]
}
};
License
This project is under the MIT License, unless otherwise stated.