Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/JorgenVatle/atshop-service-models
π Service models for the ATShop 2.0 API. Enables blazing fast and intuitive interaction with the data layer of ATShop.
https://github.com/JorgenVatle/atshop-service-models
Last synced: 2 months ago
JSON representation
π Service models for the ATShop 2.0 API. Enables blazing fast and intuitive interaction with the data layer of ATShop.
- Host: GitHub
- URL: https://github.com/JorgenVatle/atshop-service-models
- Owner: JorgenVatle
- License: isc
- Created: 2019-06-12T02:20:46.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-07-04T19:34:00.000Z (6 months ago)
- Last Synced: 2024-10-01T09:27:45.836Z (4 months ago)
- Language: TypeScript
- Size: 630 KB
- Stars: 4
- Watchers: 1
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-blazingly-fast - atshop-service-models - π Service models for the ATShop 2.0 API. Enables blazing fast and intuitive interaction with the data layer of ATShop. (TypeScript)
README
# TypeScript Service Models for ATShop 2.0
A collection of models for interacting with the ATShop API. Easily **c**reate, **r**ead, **u**pdate and **d**elete
ATShop resources.[![npm](https://img.shields.io/npm/v/atshop-service-models.svg)](https://www.npmjs.com/package/atshop-service-models)
[![node](https://img.shields.io/node/v/atshop-service-models.svg)](https://www.npmjs.com/package/atshop-service-models)> **NOTICE** This is still very much a work in progress. The documentation for this package is mostly provided
exclusively through TypeScript type hints.## Installation & Setup
There's a couple steps to getting started with `atshop-service-models`.### 1. Install
Just pull in the package through npm.
```bash
npm install atshop-service-models
```### 2. Install dependencies.
Depending on where you're implementing these models, you'll also need to pull in and setup a
[Feathers](https://feathersjs.com/) client.
```bash
npm install @feathersjs/feathers @feathersjs/socketio-client socket.io-client
```### 3. Setting up the Feathers client.
To set up `atshop-service-models`, you'll first need to get your API client up and running.
```typescript
import Feathers from '@feathersjs/feathers';
import FeathersIO from '@feathersjs/socketio-client';
import SockeIO from 'socket.io-client';const SocketClient = FeathersIO(SockeIO('https://api.atshop.io'));
const FeathersClient = Feathers();FeathersClient.configure(SocketClient);
```### 4. Setting up `atshop-service-models`
```typescript
import { ATShopServiceModels } from 'atshop-service-models';FeathersClient.configure(ATShopServiceModels());
```#### Setup complete!
Since we're using [FeatherJS](https://feathersjs.com/) as our API intermediary, `atshop-service-models` can run in
either a browser or on your Node.js server. This can be very handy if you're deploying your own storefront and don't
want to depend on any backend other than [ATShop.io](https://atshop.io).## Shops
### Fetch a shop by domain or ID.
```typescript
import { ShopModel } from 'atshop-service-models';// Fetch a shop by subdomain: (e.g. test-shop.atshop.io)
let Shop = await ShopModel.find({ domain: 'test-shop' }).fetchOne();// Fetch a shop by custom domain: (e.g. example.com)
Shop = await ShopModel.find({ customDomain: 'example.com' });// Fetch a shop by ID
Shop = await ShopModel.get('ZBAWZE4LzB4RoguGY');
```### Fetch a shop's products.
```typescript
const products = await Shop.products.fetch(); // Returns an instance of PaginatedServiceModel.products.data.forEach((product) => {
console.log(product.name); // Product name.
console.log(product.description); // Product description markdown.
console.log(product.minQuantity); // Minimum order quantity for the product.
console.log(product.stockCount); // Remaining stock.
console.log(product.value); // Dinero.js instance of the product price.
// https://sarahdayan.github.io/dinero.js/
});
```### Fetch a shop's categories
```typescript
const categories = await Shop.categories.fetch();categories.data.forEach((category) => {
console.log(category.title); // Category heading
console.log(category.slug); // Category slug
console.log(category.position); // Position of category relative to other categories.
});
```## Orders
### Get an order by ID
```typescript
import { OrderModel } from 'atshop-service-models';const order = await OrderModel.get('orderIdHere');
console.log(await order.product); // Product ordered.
console.log(await order.humanValue()); // Order value in a human format.
console.log(order.quantity); // Quantity of product ordered.
console.log(order.description); // Order description.
```## Models
All `atshop-service-models` models come equipped with a set of reusable methods and properties that are used to
interact with the API.- `static App` Global Feathers.js application object `atshop-service-models`
- `static service` Feathers.js service object for the current model.
- `static create(data)` Create a new resource for the current model. Returns an instance of self.
- `static find(query)` Build a query for the current model. Returns an instance of `PaginatedServiceModel`.
- `static get(_id)` Fetch a single entry from the service by ID.
- `patch(data)` Merge the given data with the current model instance and send the changes to the API.
- `delete()` Delete the current model entry.## Adding your own properties and methods
You can rather easily extend a model with your own functionality if you have any implementation specific needs.
```typescript
import { OrderModel as OrderServiceModel } from 'atshop-service-models';class OrderModel extends OrderServiceModel {
get emailer() {
return new MyEmailerService({ defaultEmail: this.email });
}
sendThankYouEmail() {
this.emailer.send({ message: 'Thank you for placing an order!' });
}
}// Send email.
OrderModel.get('someOrderId').then((order) => order.sendThankYouEmail());
```To ensure your model is utilized for for future relationship calls. (e.g. `ShopModel.products`), you'll need to
register it during the [configuration process](#4-setting-up-atshop-service-models).
```typescript
FeathersClient.configure(ATShopServiceModels({
models: {
OrderModel, // Referencing the OrderModel you see up above.
}
}));
```
Now, any relationship that returns an OrderModel (e.g. `OrderFeedbackModel.order`) will be an instance of your custom
`OrderModel`.### TypeScript users:
If you're a TypeScript user, you'll likely need to override the return types of model to model relationships.
```typescript
class MyCustomProductModel extends ProductModel {
// "Belongs to" and "has one" relationships return a promise.
shop!: Promise // Now you'll get proper type-hinting for any calls to the shop relationship on MyCustomProductModel.
}class MyCustomShopModel extends ShopModel {
// "Has many" relationships return instances of PagiantedServiceModel.
products!: PaginatedServiceModel
}
```## Hooking into real-time events
If you're using the [Feathers Socket.io client](https://docs.feathersjs.com/api/client/socketio.html) as described in
the above setup instructions, you'll be able to listen for changes made to ATShop resources. This isn't strictly a
feature of `atshop-service-models` as this functionality is provided directly by the [Feathers](https://feathersjs.com/)
instance you passed `atshop-service-models` during setup.All model instances are equipped with a static `service` getter that returns a [Feathers Service](https://docs.feathersjs.com/api/services.html)
object specific to the model's associated service. This is where we derive the real-time functionality from in the
below example.```typescript
import { OrderModel } from 'atshop-service-models';// Do note that you will receive events for all orders that are created for shops you have administrative permissions for.
OrderModel.service.on('created', async (orderData) => {
const order = new OrderModel(orderData);
const product = await order.product;
const stock = await product.stockForSale.count();
console.log(`An order was created by ${order.email}, you'll have ${stock - order.quantity} stock left after the order has been paid for.`)
})
```See the [Feathers Events](https://docs.feathersjs.com/api/events.html) documentation for more information on this.
## License
This repository is licensed under the ISC license.Copyright (c) 2019, JΓΈrgen Vatle.