Skip to content

Latest commit

 

History

History
232 lines (161 loc) · 11.1 KB

README.md

File metadata and controls

232 lines (161 loc) · 11.1 KB

BigCommerce Point of Sale Foundation

🚀 This open-sourced POS showcases how custom in-store apps could be built using the BigCommerce platform.

💰 Pre-integrated into Stripe Terminal, including connection to multiple terminals at a single location.

Register Screen Checkout Screen
App Preview App Preview

Prerequisites

You will need the following:

Getting started

  1. Start by forking the point-of-sale-foundation repository.
  2. Navigate to the root directory of your project and install npm packages.
npm install

BigCommerce setup

  1. Create BigCommerce store: go to https://www.bigcommerce.com/essentials/ and signup for a free trial if you don't have one.

  2. The Bigcommerce store you are connected to must have "Pickup in Store" as a shipping option for orders to be created on the POS. Go to "Settings -> Shipping" in your admin to turn it on.

  3. Create BigCommerce v2/v3 API credentials. Go to Advanced Settings > API Accounts and create and API Account with these scopes:

Customers: MODIFY
Information & settings: READ-ONLY
Orders: MODIFY
Create payments: CREATE
Get payment methods: READ-ONLY
Products: READ-ONLY
Carts: MODIFY
Checkouts: MODIFY
Channel Settings: MODIFY
Storefront API tokens: MANAGE
  1. Copy the ACCESS_TOKEN, CLIENT ID, and CLIENT SECRET credentials. In a later step, you will need these credentials to update BC_APP_CLIENT_ID, BC_APP_SECRET, and BC_AUTH_TOKEN environment variables in the .env file.

Stripe setup

  1. Go to your Stripe dashboard: https://dashboard.stripe.com/test/developers
  2. Copy the Stripe secret key. In a later step, you will use the secret key to update the environment variable STRIPE_SECRET_KEY in the .env file.
  3. Go to "More > Terminal" in the dashboard. Press "Get Started" when asked to activate the Terminal section.
  4. Add a location, then click on the location row to manage details.
  5. Add a new reader to the location.

Set up database

This app works with MongoDB. The provider setting in the /prisma/schema.prisma should be set to mongodb.

POS-provider-mongodb

We highly recommend using MongoDB, but if you would like to use another type of database, you will need to update the configuration to work with the database of your choice. View the available database options here: https://www.prisma.io/docs/reference/tools-and-interfaces/prisma-schema/data-sources/

Mongo Cloud (https://cloud.mongodb.com) generates the DATABASE_URL as shown in the setup instructions below. In a later step, you will need the DATABASE_URL to update the environment variable in .env file.

Click on the arrow below and follow the Mongo Cloud setup instructions.

Guide on setting up Mongo Cloud
  1. Click here and log in. If you don't have an account, you can click SignUp.

  2. On the left-hand sidebar, click "Database Access" > "ADD NEW DATABASE USER".

    a. Fill in your username and password, and leave all remaining fields as is.

    b. Click "Add User".

  3. On the left-hand sidebar, click "Network Access" > "ADD IP ADDRESS".

    a. Enter an IP address in the "Access List Entry" field. We recommend using 0.0.0.0/0 so you can connect from anywhere.

    pos-ip-address

    b. Click "Confirm".

  4. On the left-hand sidebar, click "Database".

    a. Click the "Connect" button in your running cluster.

    b. Click "Connect your application" in the popup modal.

    c. Copy the connection string and replace <password> with the password and <username> with the username created in step 2a. Also add "myFirstDatabase" to the connection string as shown below.

    mongodb+srv://<username>:<password>@cluster0.jfohhb8.mongodb.net/myFirstDatabase?retryWrites=true&w=majority

Note: This MongoDB connection string is what you should use to update the DATABASE_URL variable in the .env file.

pos-connection-string

Create local environment file

  1. Create a .env file in the root directory of your project.
  2. Copy the content of .env-sample to .env.
cp .env.sample .env

At a minimum, the following .env variables need to be updated for the app to sucessfully run.

  • DATABASE_URL
  • BC_STORE_HASH, BC_AUTH_TOKEN, BC_CHANNEL_ID, BC_GQL_URL, BC_APP_CLIENT_ID, and BC_APP_SECRET`
  • STRIPE_SECRET_KEY

Create and seed database

  1. Once you set up your Mongo Cloud account, create the database and seed it with data by doing the following:
  $ npx prisma db push

  $ npm run seed
  1. Generate a new prisma client using your database provider settings.
  $ npx prisma generate

Note: npx prisma generate is what creates the DB tables and initial client. If you miss this step, you'll see errors about prisma missing.

  1. Now you'll be able to access this database locally via a visual editor and verify you have created the table correctly.
  $ npx prisma studio

Note: You can also use Mongo Compass as your database GUI. Download and install to connect: Mongo Compass

  1. Run app
npm run dev

Now, the app will be running locally!

Login as an admin role here: http://localhost:3000/signin (the default admin PIN in the seed data is: 1234)

Once logged in, navigate to the "Settings" screen to save your store address. The app uses your store address for checkout tax calculations. You will receive the following error if you do not supply the store address.

pos-missing-store-address

Connecting to a reader in the POS

On the main register screen, press the 'wifi' icon, which will read all of your terminals from Stripe and check if they are active on your network.

Press "Connect" for the active terminal you'd like to use to take payment at checkout.

Key areas of codebase

  • /backend
    • Where the auth and various API services live. These are used within the internal API endpoints to keep routes secure and reach out to external APIs.
  • /prisma
    • Where the DB models and initial seed data live. Prisma uses this to generate DB clients for the app.
  • /shared
    • Where the types are located.
  • /src/pages
  • /src/pages/api
  • /src/providers
    • Where the context providers used within pages and components live.
    • Most are built using the concept of an 'ActionBuilder' that manages execution, loading status, and data setting consistently.
      • /{provider}/context.ts: The types used throughout the provider
      • /{provider}/index.ts: The actions available to the pages and components using the context providers
      • /{provider}/ methods.ts: The functions used within the actions to fetch / modify data

Contributing

Want to help expand this foundation? We'd love to collaborate! To kick-off, here's a breakdown of items we've itemized as either potential improvements to the existing codebase or features worth adding.

  • Improvements:
    • Improve error handling and types within try/catch in the employee service: backend/services/employee.service.ts
    • Create types for CreatePaymentIntentResponse and CapturePaymentIntentResponse: src/providers/CartProvider/context.ts
    • Move the transaction success screen shown when payment is completed to be its own component: src/components/modules/Orders/TenderDialog.tsx
    • Move numeric entry pad functionality into component: src/components/modules/Orders/TenderCash.tsx
    • Incorporate more graceful error handling for API calls and supply a generic method to show error messages on the FE
    • Add the shared component to handle loading indicators (overall and within buttons)
    • Create types for customer lookup actions in src/providers/CartProvider
    • Utilize the BigCommerce API Client types instead of the custom types (pending release of new client)
    • Prevent loading of the app if environment variables or BigCommerce store setup is invalid, along with instructions on how to fix
  • Features:
    • Ship-to-Customer checkout flow (creation / selection of shipping address)
    • Customer management section
    • Recall and finalize the payment on incomplete orders
    • Receipt Printer Hardware Support
    • Barcode Scanner Hardware Support
    • Cash Drawer Support
    • Product Lookup / Search
    • Basic Loyalty / Gift Card integration
    • Support for Multi-location Inventory, unlocking BOPIS (Buy Online, Pickup in Store)
    • Selection of store currency from the list of transactional currencies active on the POS channel
    • Returns, refunds, and store credit flows
    • Shift Change Operations

Learn more

Additional point of sale solutions

Check out the wide variety of POS apps on the BigCommerce App Marketplace.

The BigCommerce platform

Looking to help the world's leading brands and the next generation of successful merchants take flight? To learn more about developing on top of the BigCommerce platform, take a look at the following resources: