Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/grand-stack/grand-stack-starter
Simple starter project for GRANDstack full stack apps
https://github.com/grand-stack/grand-stack-starter
api apollo getting-started grandstack graphql neo4j react starter-project
Last synced: 4 months ago
JSON representation
Simple starter project for GRANDstack full stack apps
- Host: GitHub
- URL: https://github.com/grand-stack/grand-stack-starter
- Owner: grand-stack
- License: apache-2.0
- Archived: true
- Created: 2017-10-23T10:05:32.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2022-01-22T13:00:04.000Z (almost 3 years ago)
- Last Synced: 2024-09-23T09:02:51.371Z (4 months ago)
- Topics: api, apollo, getting-started, grandstack, graphql, neo4j, react, starter-project
- Language: TypeScript
- Homepage: https://grandstack.io/docs/getting-started-grand-stack-starter.html
- Size: 13.3 MB
- Stars: 504
- Watchers: 21
- Forks: 161
- Open Issues: 53
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-starred - grand-stack/grand-stack-starter - Simple starter project for GRANDstack full stack apps (api)
README
[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://grandstack.io/deploy-starter-netlify) [![Deploy to Vercel](https://vercel.com/button)](https://grandstack.io/deploy-starter-vercel) [![Provision Neo4j](https://grandstack.io/img/provision-neo4j.png)](https://sandbox.neo4j.com/?usecase=blank-sandbox)
# GRANDstack Starter
```
npx create-grandstack-app myNewApp
```This project is a starter for building a [GRANDstack](https://grandstack.io) (GraphQL, React, Apollo, Neo4j Database) application. There are two components to the starter, the web frontend application (in React and Angular flavors) and the API app (GraphQL server).
The starter represents a **business reviews dashboard**. You need to adjust the GraphQL schema, the seed data, database index creation, and the UI components for your use-case.
[![Hands On With The GRANDstack Starter](http://img.youtube.com/vi/rPC71lUhK_I/0.jpg)](http://www.youtube.com/watch?v=1JLs166lPcA 'Hands On With The GRANDstack Starter')
_Hands On With The GRANDstack Starter Video_
## Quickstart
The easiest way to get started with the GRANDstack Starter is to create a Neo4j Sandbox instance and use the `create-grandstack-app` command line tool.
(If you have a running Neo4j database on localhost via Neo4j Desktop or a Neo4j server installation, change the password in `api/.env`)
### 1. Create A Neo4j Instance
#### Option :one: - Sandbox
[Neo4j Sandbox](https://neo4j.com/sandbox) allows you to create a free hosted Neo4j instance private to you that can be used for development.
After signing in to Neo4j Sandbox, click the `+ New Project` button and select the "Blank Sandbox" option. In the next step we'll use the connection credentials from the "Connection details" tab to connect our GraphQL API to this Neo4j instance.
![Neo4j Sandbox connection details](img/neo4j-sandbox.png)
#### Option :two: - Desktop
If you instead would like to use [Neo4j Desktop](https://neo4j.com/download/). The process will be almost the same with a minor detour. Install Neo4j Desktop for your chosen OS and then make a new blank graph for your project. It will require you to put in a password and username. Remember those.
Next you need to go to open the manage screen from the options in the 3 dot stack menu
![New desktop graph, manage tab](img/desktop-new-graph.png)
And install the apoc plugin, green button at the top of the list.
![Plugins](img/apoc-install.png)
After that you can return to setting up your app with the credentials from the prior steps.
### 2. Run the `create-grandstack-app` CLI
```
npx create-grandstack-app myNewApp
```or with Yarn
```
yarn create grandstack-app myNewApp
```![create grandstack app output](img/create-grandstack-app.png)
This will create a new directory `myNewApp`, download the latest release of the GRANDstack Starter, install dependencies and prompt for your connection credentials for Neo4j to connect to the GraphQL API.
### 3. Seed the database (optional)
Make sure your application is running locally with `npm start` or `yarn start`, open another terminal and run
```
npm run seedDb
```or with Yarn
```
yarn run seedDb
```### 4. Open In Browser
![Grandstack app running in browser](img/grandstack-app.png)
The GRANDstack Starter is a monorepo that includes a GraphQL API application and client web applications for React (default) and Angular for a business reviews dashboard.
### `/` - Project Root
The root directory contains some global configuration and scripts:
- `npm run start` and `npm run build`
- ESLint (.eslintrc.json) for code linting
- Prettier (.prettierrc.json) for code formatting
- Git hooks for applying formatting on commit### [`/api`](./api)
![](img/graphql-playground.png)
This directory contains the GraphQL API application using Apollo Server and the Neo4j GraphQL Library.
- Change environment variable settings in `.env`:
```
# Use this file to set environment variables with credentials and configuration options
# This file is provided as an example and should be replaced with your own values
# You probably don't want to check this into version control!NEO4J_URI=bolt://localhost:7687
NEO4J_USER=neo4j
NEO4J_PASSWORD=letmein# Uncomment this line to enable encrypted driver connection for Neo4j
#NEO4J_ENCRYPTED=true# Uncomment this line to specify a specific Neo4j database (v4.x+ only)
#NEO4J_DATABASE=neo4jGRAPHQL_SERVER_HOST=0.0.0.0
GRAPHQL_SERVER_PORT=4001
GRAPHQL_SERVER_PATH=/graphql```
### [`/web-react`](./web-react)
![](img/grandstack-app.png)
The frontend React web application is found in this directory.
It includes:
- Material UI
- React router
- Apollo Client / React Hooks
- Create React App### [`/web-angular`](./web-angular)
![](web-angular/img/angular-ui.jpg)
A UI built with [Angular](https://angular.io), [Apollo](https://www.apollographql.com/docs/angular/) and the [Clarity Design System](https://clarity.design) is also available.
_Start the Angular UI server_
```
cd ./web-angular && npm start
```### [`/mobile_client_flutter`](./mobile_client_flutter)
![](img/grandstack-flutter.png)
A mobile client built with [Flutter](https://flutter.dev) which supports Android, iOS, and web. See the [README](./mobile_client_flutter/README.md) for detailed setup instructions.
```
cd ./mobile_client_flutter && flutter run
```### [`/web-react-ts`](./web-react-ts)
A UI built with [CRA](https://reactjs.org/docs/create-a-new-react-app.html)
_Start the React dev server_
```
cd ./web-react-ts && npm start
```## Deployment
### Netlify
This monorepo can be deployed to Netlify. The frontend application will be served over Netlify's CDN and the GraphQL API will be provisioned as a serverless GraphQL API lambda function deployed to AWS (via Netlify). A netlify.toml file is included with the necessary build configurations. The following environment variables must be set in Netlify (either via the Netlify web UI or via the command line tool)
```
NEO4J_URI
NEO4J_USER
NEO4J_PASSWORD
```See the "Hands On With The GRANDStack Starter" video linked at the beginning of this README for a walkthrough of deploying to Netlify.
### Vercel
Vercel can be used with monorepos such as grand-stack-starter. [`vercel.json`](https://github.com/grand-stack/grand-stack-starter/blob/master/vercel.json) defines the configuration for deploying with Vercel.
1. get [vercel cli](https://vercel.com/download)
2. Set the vercel secrets for your Neo4j instance:```
vercel secret add grand_stack_starter_neo4j_uri bolt://
vercel secret add grand_stack_starter_neo4j_user
vercel secret add grand_stack_starter_neo4j_password
```3. Run `vercel`
## Docker Compose
You can quickly start via:
```
docker-compose up -d
```If you want to load the example DB after the services have been started:
```
docker-compose run api npm run seedDb
```See [the project releases](https://github.com/grand-stack/grand-stack-starter/releases) for the changelog.
You can find instructions for other ways to use Neo4j (Neo4j Desktop, Neo4j Aura, and other cloud services) in the [Neo4j directory README.](./neo4j)
This project is licensed under the Apache License v2.
Copyright (c) 2020 Neo4j, Inc.