API.js is a JavaScript library that helps FoxCommerce customers create powerful, customized storefronts on top of the FoxCommerce API. It does this by creating an easy abstraction of available API operations and by providing convenient helper methods.
This API layer is framework agnostic as we don't to impose a framework decision such as React or Angular on customers.
API.js will be build in ES6 and transpiled to ES5. It won't use ES7 features.
Principles:
- The library should have simple method names that match core API methods, or simplifications or sugar on the core API.
- It should make instantiation/authentication as simple as possible.
- It should deal with Async, probably a Fetch/Promise-based model.
- As a rule of thumb,
.then()
should be left to the implementation of the library [ie. not in this codebase]. Possible exception here is Auth section, storage ofjwt
tokens, handling oAuth redirects etc.
You can log requests via settings DEBUG env variable to foxapi
:
DEBUG=foxapi npm test
Before submitting your PR:
- make sure flow and lint have no complaints. Run
make test
- to conform with our code style, run
make fmt
. This will prettify your code and fix any light-weight lint problems. Note: don't forget to commit the changes made by prettier
To facilitate lint fixing, consider running yarn fix-lint
import FoxCommAPI from `FoxComm/api-js`
const FxC = new FoxCommAPI({ args }) // args could include API domain & path data, public_key, etc