npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

whalegistic

v0.1.14

Published

Whalegistic is a E-Commerce platform and this package is the connection between Whalegistic platform API and users websites

Downloads

43

Readme

Welcome to WHALEGISTIC

This is a platform to help E-Commerce businesses, Wholesalers, Distributors and developers to start selling products as fast as possible and to manage their products, promotions, stocks and everything related with an E-Commerce store. Whalegistic is currently evolving to bring a better experience for people that want to start their Online Store.

With this in mind, we created a way for developers to connect with our platform and fetch all the information necessary to build an online store in no time. Get the products, group them by color or size, search for promotions, show your clients the available stock, fetch all your product collections, create orders and search for already existing order for specific clients.

Quickstart

In order for you to be able to use this tool you will need to create an account at Whalegistic. To do soo, navigate to our website Whalegistic Website and create an account in this url Whalegistic Registration (Note: if is asking for you to send a registration request is because we are still in the Beta phase and we need to review your application).

After you have an account create an Store > then go to settings > navigate to API > and create your first API keys. You will need those keys in order to access your account through the API. Don't show them to anyone out of your trust!

To install Whalegistic API tool just run the following command:

npm install whalegistic

After that you can connect with your account using Whalegistic API library and your API keys. In the following sections it will be explained how to do that!

Connect to Whalegistic

In order to connect to Whalegistic you will need both the secret and the public key. This is your login method to Whalegistic. From then on you will be able to connect to Whalegistic using the whale variable:

var Whalegistic = require('whalegistic');

var whale = new Whalegistic(
    WHALEGISTIC_SECRET_KEY, 
    WHALEGISTIC_PUBLIC_KEY
);

It is only necessary to do this once, in order to receive the necessary credentials to be used with Whalegistic API.

Requests

IMPORTANT NOTES!!!

If you have to send a request with an object inside that same request object, for example, the getProducts function has the search_obj and search_by_names parameters that are JSON objects. This need to be converted to string in order to be able to be sent. This can be done with the help of the function JSON.stringify({ OBJECT }).

Get Brands

Get all the Brands created on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {} // no parameters

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		brands: // array of all brands objects
	}

Send request code:

var response = await whale.getBrands(request_parameters)

Get Categories

Get all the Product's Categories created on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		categories: // array of all categories objects
	}

Send request code:

var response = await whale.getCategories(request_parameters)

Get Collections

Get all the Product's Collections created on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		collections: // array of all collections objects
	}

Send request code:

var response = await whale.getCollections(request_parameters)

Get Store

Get all the necessary information to display on your Online Store. Normally this is the stepping stone for starting showing all the different filters like the different brands, categories, collections and products. This is a combination of multiple functions.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		min_price: // lowest price for the searched products
		max_price: // highest price for the searched products
		offset: // offset of products ex: 20 will skip the first 20 products
		limit: // limit of products ex: 40 will send back 40 products
		promotions:
		search_by_names: [
			Products: // name of products searching for
			Brands: // brand name of products searching for
			Categories: // categories name of products searching for
			Collections: // collections name of products searching for
		]
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
{
	products: // array of products objects
	max_product_price: // the highest product price
	number_products: // total number of products
	brands: // array of all the brands objects
	categories: // array of all the categories objects
	collections: // array of all the collections objects
}

Send request code:

var response = await whale.getStore(request_parameters)

Get Products

Get all the products created on your Whalegistic Store and filtered by the parameters sent by the request. It is returned an Array of products, the highest priced product price and the total number of products you have available.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		min_price: // lowest price for the searched products
		max_price: // highest price for the searched products
		offset: // offset of products ex: 2 will skip the first 2 products
		limit: // limit of products ex: 4 will send back 4 products
		promotions:
		search_obj: {
			Products_IDs: // array of products ids ex: [1, 2, 3, ...]
			Name: // name of products searching for
			SKU: // SKU of product searching for
			Models_IDs: // array of models ids of products searching for ex: [1, 2, 3, ...]
			Brands: // array of brands ids of products searching for ex: [1, 2, 3, ...]
			Categories: // array of categories ids of products searching for ex: [1, 2, 3, ...]
		}
		search_by_names: {
			Products: // name of products searching for
			Brands: // brand name of products searching for
			Categories: // categories name of products searching for
			Collections: // collections name of products searching for
		}
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
{
	succ: // true or false if request was successfull. If false it sends the Error
	products: // array of products objects
	max_product_price: // the highest product price
	number_products: // total number of products
}

Send request code:

var response = await whale.getProducts(request_parameters)

Get Models

Get all the Models created on your Whalegistic Store. The Models are the parent Product that can store all your products information, photos and video to make easier to create new products that are associated to a specific Model.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		offset: // offset of products ex: 2 will skip the first 2 products
		limit: // limit of products ex: 4 will send back 4 products
		search_obj: {
			model_name: // name of models searching for
			model_mid: // MID of models searching for
			brand_name: // brand name of models searching for
			category_name: // categories of models searching for
		}
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		models: // array of all models objects
	}

Send request code:

var response = await whale.getModels(request_parameters)

Get Products from Collection

Get all the products on a Collection created on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		collections: // array of collections id's ex: [1, 2, 3, ...]
		offset: // offset of products ex: 2 will skip the first 2 products
		limit: // limit of products ex: 4 will send back 4 products
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		products: // array of all products objects
		total_products_count: // total number of products on that collection
		max_price: // highest price of a product on that collection
	}

Send request code:

var response = await whale.getCollectionProducts(request_parameters)

Get Related Products

Get all the products that are related to a specific product that is sent as a request parameter. This related products are chosen based on the amount of purchases were made together with the target product. If there is no products that were purchase together with the target product, this will be filled with random products until there is a specific pattern of related products.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		product_id: // desired product id
		offset: // offset of products ex: 2 will skip the first 2 products
		limit: // limit of products ex: 4 will send back 4 products
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		products: // array of all products objects
	}

Send request code:

var response = await whale.getRelatedProducts(request_parameters)

Get Product by Slug

Get a specific products, created on your Whalegistic Store, based on its customized URL Slug. This is ideal for Webstores that want to have the name of the desire product on the website url for better SEO.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		product_slug: // desired product's url slug
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		product: // product's object
	}

Send request code:

var response = await whale.getProductBySlug(request_parameters)

Get Client

Get a specific Client object created on your Whalegistic Store or by the API.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		client_id: // id of the desired client
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		client: // client's object
	}

Send request code:

var response = await whale.getClient(request_parameters)

Create New Client

Create a new Client object on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		name: // client's name
		email: // client's email
		phone: // client's phone
		del_address: // client's delivery address
		del_city: // client's delivery city
		del_country: // client's delivery country
		del_zip: // client's delivery zip code
		vat_num: // client's delivery VAT number
		inv_name: // client's invoice name
		inv_address: // client's invoice address
		inv_city: // client's invoice city
		inv_country: // client's invoice country
		inv_zip_code: // client's invoice zip code
		inv_vat_number: // client's invoice VAT number
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		obj_insert: // object that was inserted with its ID
	}

Send request code:

var response = await whale.createClient(request_parameters)

Update Client

Update a new Client object on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		client_id: // id of the desired client
		client_name: // client's name
		client_email: // client's email
		client_phone: // client's phone contact
		client_vat_number: // client's VAT number
		delivery_address: // client's delivery address
		delivery_city: // client's delivery city
		delivery_country: // client's delivery country
		delivery_zip_code: // client's delivery zip code
		invoice_address: // client's invoice address
		invoice_city: // client's invoice city
		invoice_country: // client's invoice country
		invoice_zip_code: // client's invoice zip code
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
	}

Send request code:

var response = await whale.updateClient(request_parameters)

Get Client's Orders

Get a specific Client's orders objects created on your Whalegistic Store or by the API.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		client_id: // id of the desired client
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		orders: // array of all orders objects
	}

Send request code:

var response = await whale.getClientOrders(request_parameters)

Get Client Profile

Get a specific Client's orders objects and its profile as well created on your Whalegistic Store or by the API.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		client_id: // id of the desired client
	}

This is what the return object looks like:

Return:
{
	client: // the client's object
	client_orders: // an array of the client's orders objects
}

Send request code:

var response = await whale.getClientProfile(request_parameters)

Create New Contact

Create a new contact from a client on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		name: // contact name
		email: // valid contact email
		about: // what the contact is about
		message: // the contact message
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		obj_insert: // object that was inserted with its ID
	}

Send request code:

var response = await whale.createContact(request_parameters)

Create New Newsletter

Submit a new Newsletter subscription from a client on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		email: // desired email to add to the newsletter list
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		obj_insert: // object that was inserted with its ID
	}

Send request code:

var response = await whale.createNewsletter(request_parameters)

Get Shipping Rates

Get all the Shipping Costs Rates available on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {} // no parameters

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		shipping_costs: // array of all shipping costs objects
	}

Send request code:

var response = await whale.getShippingRates(request_parameters)

Get a specific Shipping Rate

Get a specific Shipping Cost Rate and its Tax Conversions available on your Whalegistic Store.

This is what the request parameters looks like:

Parameters:
	var request_parameters = { // it's necessary to choose one of the two
		country_name: // value of the country name
		country_code: // 2 digit country indentifier ex: "US", "GB", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		shipping: // shipping cost object
		conversion_taxes: // array of all tax conversions objects
	}

Send request code:

var response = await whale.getShippingRate(request_parameters)

Get Promo Code

Get a specific Promo Code on your Whalegistic Store. Basically this could be used to verify if the promo code exists.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		promo_code: // target promo code value
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		promo_code: // promo code object
	}

Send request code:

var response = await whale.getPromoCode(request_parameters)

Get Order

Get a specific order created on your Whalegistic Store, by the platform or by the API.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		order_id: // id of the desired order
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		order: // order object
	}

Send request code:

var response = await whale.getOrder(request_parameters)

Get Order Total

This function simply calculates the total price, tax, shipping and promotions based on the different parameters sent. It returns also all the products with all the necessary information needed for creating that order from that specific products and characteristics.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		products: [ // array of products ID's as an object
			{
				id: // id of the product
				quantity: // quantity of the product
			}, 
			{...} // other object
		]
		shipping_country: // shipping country name to where this order will be sent
		shipping: // default shipping cost if there is no shipping country
		language: // 2 digit language code for translation ex: "EN", "FR", ...
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		total_value: // total price for this order
		vat_value: // total VAT value for this order
		shipping: // shipping price for this order
		currency: // currency of this order
		products: // array of products objects on this order
		promo_code: // promo code this order
	}

Send request code:

var response = await whale.getTotal(request_parameters)

Create New Order

Create a new order based on the parameters sent. This will also create the client if there is no information already in the system on your Whalegistic Store. The client is created and connected to this order by the email address.

This is what the request parameters looks like:

Parameters:
	var request_parameters = {
		products: [ // array of products ID's as an object
			{
				id: // id of the product
				quantity: // quantity of the product
			}, 
			{...} // other object
		]
		del_name: // delivery client's name
		del_email: // delivery client's email
		del_phone: // delivery client's phone contact
		del_address: // delivery client's address
		del_city: // delivery client's city
		del_country: // delivery client's country
		del_zip_code: // delivery client's zip code
		inv_name: // invoice client's name
		inv_address: // invoice client's address
		inv_city: // invoice client's city
		inv_country: // invoice client's country
		inv_zip_code: // invoice client's zip code
		inv_vat_number: // invoice client's VAT number
		payment_status: // "paid" or "not paid"
		shipping: // default shipping cost if the country is not found
		promo_code_id // order promo code id value (don't need to send both promo_code_id and promo_code together)
		promo_code // order promo code value
		is_pvp: // True for an PVP priced or False for a reseller priced order
	}

This is what the return object looks like:

Return:
	{
		succ: // true or false if request was successfull. If false it sends the Error
		new_order: // order object
		order_products: // array of products objects on the new order
		promo_code: // promo code object
	}

Send request code:

var response = await whale.createOrder(request_parameters)

Report Errors

If, during the utilization of Whalegistic App any error is found, please let us know! We depend on testers and developers to help us develop our platform and libraries.

You can contact us by email or by the contact form located on Whalegistic's Website specific for reporting errors - Error Reporting.

You can also contact Whalegistic with our normal contact form for suggestions that you may have for our platform - Contact Form.

Final Thoughts

Whalegistic is still an young project with big projects and plans ahead. If you would like what we are developing and want to help us develop Whalegistic and improve our project please feel free to contact us whenever you wish with any suggestions and solutions.

We also have our Slack Site if anyone that want to join our team and discuss further Whalegistic application and how it can grow into a better and bigger platform for E-Commerce.

Any help is welcomed and necessary!

In name of all the Whalegistic Team, Many thanks for your support!