Coder Social home page Coder Social logo

taobataoma / imean Goto Github PK

View Code? Open in Web Editor NEW
9.0 3.0 3.0 3.03 MB

iMEAN.JS - Full-Stack JavaScript Using Sequelize, Express, AngularJS, and Node.js - origin of meanjs/mean

License: Other

JavaScript 77.94% HTML 20.76% CSS 0.79% Shell 0.51%
meanjs angularjs express sequelize ui-cropper

imean's Introduction

iMEAN.JS - Full-Stack JavaScript Using Sequelize, Express, AngularJS, and Node.js - origin of meanjs/mean

iMEAN is a full-stack JavaScript open-source solution, which provides a solid starting point for Sequelize, Node.js, Express, and AngularJS based applications. The idea is to solve the common issues with connecting those frameworks, build a robust framework to support daily development needs, and help developers use better practices while working with popular JavaScript components.

Before You Begin

Before you begin we recommend you read about the basic building blocks that assemble a iMEAN application:

Prerequisites

Make sure you have installed all of the following prerequisites on your development machine:

$ npm install -g bower

Downloading iMEAN

There are several ways you can get the iMEAN boilerplate:

Cloning The GitHub Repository

The recommended way to get iMEAN is to use git to directly clone the iMEAN repository:

$ git clone https://github.com/taobataoma/imean.git

This will clone the latest version of the iMEAN repository to a imean folder.

Downloading The Repository Zip File

Another way to use the iMEAN boilerplate is to download a zip copy from the master branch on GitHub. You can also do this using the wget command:

$ wget https://github.com/taobataoma/imean/archive/master.zip -O imean.zip; unzip imean.zip; rm imean.zip

Don't forget to rename imean-master after your project name.

Quick Install

Once you've downloaded the boilerplate and installed all the prerequisites, you're just a few steps away from starting to develop your MEAN application.

The boilerplate comes pre-bundled with a package.json and bower.json files that contain the list of modules you need to start your application.

To install the dependencies, run this in the application folder from the command-line:

$ npm install

This command does a few things:

  • First it will install the dependencies needed for the application to run.
  • If you're running in a development environment, it will then also install development dependencies needed for running your application.
  • When the npm packages install process is over, npm will initiate a bower install command to install all the front-end modules needed for the application
  • To update these packages later on, just run npm update

Configure Sequelize with MySQL

All the development configure items in config/env/default.js

  db: {
    host: 'localhost',
    port: 3306,
    name: 'imean',
    username: 'admin',
    password: '',

    option: {
      enableSequelizeLog: false,
      FORCE_DB_SYNC: false
    }
  }

If you start with production environment, please modify the configure in config/env/production.js

iMEAN runing with ui-cropper

When user to change profile picture, iMEAN use ui-cropper to crop the image, like this: profile-picture

Running Your Application

Run your application using npm:

$ npm start

Your application should run on port 3000 with the development environment configuration, so in your browser just go to http://localhost:3000

That's it! Your application should be running. To proceed with your development, check the other sections in this documentation. If you encounter any problems, try the Troubleshooting section.

Explore config/env/development.js for development environment configuration options.

Running in Production mode

To run your application with production environment configuration:

$ npm run start:prod

Explore config/env/production.js for production environment configuration options.

Running with TLS (SSL)

Application will start by default with secure configuration (SSL mode) turned on and listen on port 8443. To run your application in a secure manner you'll need to use OpenSSL and generate a set of self-signed certificates. Unix-based users can use the following command:

$ npm run generate-ssl-certs

Windows users can follow instructions found here. After you've generated the key and certificate, place them in the config/sslcerts folder.

Finally, execute prod task npm run start:prod

  • enable/disable SSL mode in production environment change the secure option in config/env/production.js

Running your application with Gulp

The iMEAN project integrates Gulp as build tools and task automation.

We have wrapped Gulp tasks with npm scripts so that regardless of the build tool running the project is transparent to you.

To use Gulp directly, you need to first install it globally:

$ npm install gulp -g

Then start the development environment with:

$ gulp

To run your application with production environment configuration, execute gulp as follows:

$ gulp prod

It is also possible to run any Gulp tasks using npm's run command and therefore use locally installed version of gulp, for example: npm run gulp eslint

Getting Started With iMEAN

You have your application running, but there is a lot of stuff to understand. Because iMEAN is origin on meanjs/mean, We recommend you go over the Official Documentation. In the docs we'll try to explain both general concepts of MEAN components and give you some guidelines to help you improve your development process. We tried covering as many aspects as possible, and will keep it updated by your request. You can also help us develop and improve the documentation by checking out the gh-pages branch of this repository.

Contributing

We welcome pull requests from the community! Just be sure to read the contributing doc to get started.

Online support

License

The MIT License

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.