Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dkm94/vulcan-getting-started
https://github.com/dkm94/vulcan-getting-started
meteor meteorjs vulcan vulcanjs
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/dkm94/vulcan-getting-started
- Owner: dkm94
- License: mit
- Created: 2021-11-18T12:38:25.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2021-11-19T04:36:51.000Z (about 3 years ago)
- Last Synced: 2024-10-31T03:42:22.982Z (3 months ago)
- Topics: meteor, meteorjs, vulcan, vulcanjs
- Language: JavaScript
- Homepage:
- Size: 890 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: license.md
Awesome Lists containing this project
README
# Vulcan Starter
This kit gives you all you need to quickly learn Vulcan and launch your own projects.
Other resources:
- [Vulcan Docs](http://docs.vulcanjs.org)
- [Vulcan Slack](http://slack.vulcanjs.org)**Table of Contents**
- [Quick Install](#quick-install)
- [Step 1 - Clone](#step-1---clone)
- [Step 2 – Run](#step-2--run)
- [Getting Started Tutorial](#getting-started-tutorial)
- [Other Examples](#other-examples)
- [Complete Install](#complete-install)
- [Critical prerequisite](#critical-prerequisite)
- [Step 1 - Preparation](#step-1---preparation)
- [Step 2 - Test Vulcan installation](#step-2---test-vulcan-installation)
- [Step 3 - Prepare your project](#step-3---prepare-your-project)
- [Step 4 - Test your project installation](#step-4---test-your-project-installation)## Quick Install
If you already have Meteor up and running, read this section. Otherwise, read the [Complete Install](#complete-install) section.
#### Step 1 - Clone
```
git clone [email protected]:VulcanJS/Vulcan-Starter.git
cd Vulcan-Starter
```(or, using `https`: `git clone https://github.com/VulcanJS/Vulcan-Starter.git`)
#### Step 2 – Run
```
npm install
npm start
```## Getting Started Tutorial
When you first run this repo, you'll see the first step of Vulcan's interactive Getting Started tutorial.
![https://d3vv6lp55qjaqc.cloudfront.net/items/0I2W3G1i2K3z0p052c02/Screen%20Shot%202018-02-03%20at%2011.16.53.png?X-CloudApp-Visitor-Id=43642&v=807ac6f9](https://d3vv6lp55qjaqc.cloudfront.net/items/0I2W3G1i2K3z0p052c02/Screen%20Shot%202018-02-03%20at%2011.16.53.png?X-CloudApp-Visitor-Id=43642&v=807ac6f9)
This interactive tutorial will guide you through Vulcan basics, such as:
- Creating routes.
- Registering components.
- Defining a schema.
- Loading data.
- Generating forms.All while modifying the code of the tutorial itself! How meta!
## Other Examples
Additionally, this repo also contains the following example apps:
- **Simple Example**: build a simple paginated list of movies [[video]](http://docs.vulcanjs.org/example-simple.html).
- **Movies Example**: like the Simple example, but more in-depth [[video+tutorial]](http://docs.vulcanjs.org/example-movies.html).
- **Permissions Example**: manage user roles in Vulcan [[video]](http://docs.vulcanjs.org/example-permissions.html).
- **Instagram Example**: create a simple Instagram clone [[video]](http://docs.vulcanjs.org/example-instagram.html).
- **Interfaces Example**: using GraphQL interfaces.
- **Reactions Example**: implement Facebook-style reactions & voting.
- **Forum Example**: a full-fledged Hacker News-style forum codebase [[docs]](http://docs.vulcanjs.org/example-forum.html).
- **Customization Example**: how to customize other Vulcan packages, based on the Forum Example [[video+tutorial]](http://docs.vulcanjs.org/example-customization.html).## Complete Install
The *Complete Install* steps will get you going on a freshly built Ubuntu desktop machine (including installing Node, Meteor, etc.) using the "[two-repo](http://docs.vulcanjs.org/#Two-Repo-Install)" install.
The steps below assume a machine that has not previously been used for software development.
They were tested Oct 15/2017, on an 8Gb Qemu/KVM virtual machine running a freshly installed Xubuntu Desktop 16.04 LTS.
Expect other environments to behave differently but, sufficiently similar that, adaptation should not be difficult.#### Critical prerequisite
Note that, to use the scripts below, you **must already have** SSH access to GitHub. You'll need that in any case for properly managing version control of your project. Learn more at [GiHub Bootcamp : Connecting to GitHub with SSH](https://help.github.com/articles/connecting-to-github-with-ssh/)
#### Step 1 - Preparation
# Specify where things should go
export NEW_PROJECT_NAME="myVulcan"; # a name for your new project
export PROJECTS_DIRECTORY="${HOME}/projects"; # the installation path for your new project
export VULCAN_HOME="${PROJECTS_DIRECTORY}/Vulcan"; # the path to the root of your Vulcan installation# Prepare dependencies
sudo apt install -y git curl build-essential;
# Need git for managing your project's source code.
# Need curl to get the other stuff.
# Need C++ build tools for fast bcrypt installation# Install 'meteor'
curl https://install.meteor.com/ | sh;# Sanity check your Meteor installation
echo -e "\nMeteor version...";
meteor --version;
export METEOR_NODE_VERSION=$(meteor node --version);
echo -e "Meteor Node version...\n ${METEOR_NODE_VERSION}";# Install 'nvm', so as to be able to easily switch NodeJs versions
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.5/install.sh | bash;# Prepare to use 'nvm' immediately
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion# Set Meteor version of Node as your default for NodeJS work outside of Meteor
nvm install ${METEOR_NODE_VERSION};
nvm alias default ${METEOR_NODE_VERSION};# Create a projects folder and step into it
mkdir -p ${PROJECTS_DIRECTORY}
cd ${PROJECTS_DIRECTORY}# Clone Vulcan core into its own folder and step into it
git clone [email protected]:VulcanJS/Vulcan.git# install and pre-cache all of Vulcan's NodeJS dependencies
cd ${VULCAN_HOME};
meteor npm install;#### Step 2 - Test Vulcan installation
Check it works with a browser at http://localhost:3033
then kill it with <ctrl-c># Run Vulcan so it pre-caches all its Meteor dependencies
[ -f settings.json ] || cp sample_settings.json settings.json;
meteor --port 3033 --settings settings.json;#### Step 3 - Prepare your project
cd ${PROJECTS_DIRECTORY};
# Clone Vulcan starter kit as your named project
git clone [email protected]:VulcanJS/Vulcan-Starter.git ${NEW_PROJECT_NAME}# Step in your project folder
cd ${NEW_PROJECT_NAME};# Make sure your app uses the same Meteor release as Vulcan
cp ${VULCAN_HOME}/.meteor/release ./.meteor;# install and pre-cache all of your named app's NodeJS dependencies
# meteor npm install --save cross-fetch;
meteor npm install;# Tell Meteor to refer to the Vulcan sister folder for packages that Vulcan supplies
export METEOR_PACKAGE_DIRS=../Vulcan/packages;
echo "Vulcan's Meteor packages folder : ${METEOR_PACKAGE_DIRS}.";#### Step 4 - Test your project installation
Check it works with a browser at http://localhost:3000
then kill it with <ctrl-c># Run your Vulcan project
[ -f settings.json ] || cp sample_settings.json settings.json;
meteor --port 3000 --settings settings.json