8.25.0 • Published 8 months ago

neo-app v8.25.0

Weekly downloads
123
License
MIT
Repository
github
Last release
8 months ago

neo.mjs create-app

Create a new neo.mjs app (workspace) using the 1-liner:

npx neo-app

npx neo-app works on macOS, Linux and Windows 10. If errors occur for your local environment, please file an issue.

Please ensure you have node & npm installed (npx is available for npm 5.2+).

You do not need to clone this repository or globally install the neo-app npm package.

Please take a couple of minutes to read this README.md file first.

Content

  1. Quick Overview
  2. Script Options
  3. Starting a local web-server
  4. Viewing your app in development mode
  5. Viewing your app in dist modes
  6. Workspace Content
  7. package.json Scripts
  8. Working on your new neo.mjs App
  9. Learning neo.mjs
  10. Feedback and Questions
  11. Alternative options to create an App
  12. Kudos

Quick Overview

npx neo-app

Running the script will prompt 3 questions: 1. Choose a workspace folder name. This folder will get created inside the terminal / CMD folder you are in. You can rename it later on if needed. 2. Choose an app name (Pascal Case) 3. Choose the themes you want to use (you can change this later on inside the neo-config.json)

Script Options

You can pass additional params to the script:

Choose a workspace folder name:

npx neo-app -w workspace

Choose an app name:

npx neo-app -n MyApp

Choose the themes:

npx neo-app -t both

Of course, you can combine the options, e.g.:

npx neo-app -w workspace -n MyApp -t both

Starting a local web-server

By default, npx neo-app will start a webpack dev-server right after the build.

A new browser tab should open right away:

In case you do not want to start the dev-server automatically, you can use the -s option:

npx neo-app -s false

You can use a different web-server of your choice (e.g. webstorm) or you can start the default one manually later:

cd workspace

npm run server-start

Viewing your app in development mode

The dev mode works in all major browsers (Chromium, Firefox & Safari).

To view your new app, you can navigate to:

http://localhost:8096/apps/myapp/

The beauty inside this screen is: 1. You can see 4 threads inside the bottom left edge of the console 2. Your app as well as most parts of neo.mjs run within the App thread 3. You get the real JS modules directly into your browser 1. No need to transpile JS code in this mode 2. No need for source-maps

Viewing your app in dist modes

dist/development is using webpack based builds (source-maps, not minified)

http://localhost:8096/dist/development/apps/myapp/

dist/production is using webpack based builds (no source-maps, minified)

http://localhost:8096/dist/production/apps/myapp/

Workspace Content

Using the script will create the following content:

  1. .gitignore has a basic setup excluding IDE related files, the dist folder & the package-lock.json
  2. apps contains the source files of your new app. You can create multiple apps as needed.
  3. buildScripts contains meta-infos (in theory this could get stored inside the neo.mjs node_module, but then every framework version update would require to re-create it)
  4. dist contains the development & production builds of your app, as well as the docs app
  5. docs contains a copy of the neo.mjs non dist version of the docs app. This version does show documentation views of your app as well as all neo.mjs examples
  6. node_modules => all related dependencies which are required for the build scripts & the dev-server
  7. package.json => a dummy version; feel free to change it

package.json Scripts

"server-start": "webpack-dev-server --open",
"build-all": "node ./node_modules/neo.mjs/buildScripts/buildAll.js -n",
"build-all-questions": "node ./buildScripts/buildAll.js",
"build-my-apps": "node ./node_modules/neo.mjs/buildScripts/webpack/buildMyApps.js",
"build-themes": "node ./node_modules/neo.mjs/buildScripts/webpack/buildThemes.js",
"build-threads": "node ./node_modules/neo.mjs/buildScripts/webpack/buildThreads.js",
"create-app": "node ./node_modules/neo.mjs/buildScripts/createApp.js",
"generate-docs-json": "node ./node_modules/neo.mjs/buildScripts/docs/jsdocx.js",
"test": "echo \"Error: no test specified\" && exit 1"

You need to enter the workspace folder inside your terminal / CMD.

cd workspace

You can run each script via

npm run \<script-name>

Some IDEs like webstorm can show npm scripts as a toolbox, so you can just click on them instead.

  1. server-start: Starts the webpack dev-server
  2. build-all: npm install & builds literally everything.
  3. build-all-questions: same as build all, but you can choose what to build using the inquirer interface.
  4. build-themes: builds the themes for dev and / or prod and lets you choose if want to use CSS variables.
  5. build-threads: builds main, data & vdom (or any combinations) for dev and / or prod.
  6. create-app: add an additional app to your project. You can also trigger npx neo-app multiple times.
  7. generate-docs-json: When you change your app code (e.g. adding new files) and want to see those changes inside the Docs app, you need to run this script to update the content.

Working on your new neo.mjs App

It is recommended to use the development mode (non dist version) for developing your App(s). This way you can just reload the App page whenever you change the code base. No need for source-maps and a very smooth debugging experience.

You ideally want to start with changing the view/MainContainer.mjs file.

Once you get to a point where you want to test your changes inside the dist versions, take a look at: package.json Scripts.

Learning neo.mjs

Take a look into the new Learning Section

Feedback and Questions

Feel free to use one of these options (or both): Slack Channel Invite Link Discord Chat Invite Link

Alternative options to create an App

  1. Use npx neo-app
  2. Clone or fork the neo.mjs workspace (if there are any issues with npx neo-app)
  3. In case you want to get the neomjs/neo repository running locally, please take a look at the neo.mjs Getting Started Guide. Step 6 creates a new App inside neo/apps

Kudos

The npx neo-app script is deeply inspired by Create React App.

Copyright (c) 2019 - today, Tobias Uhlig

8.12.0

9 months ago

8.13.0

9 months ago

8.14.1

9 months ago

8.5.0

9 months ago

8.25.0

8 months ago

8.0.0

10 months ago

7.10.0

1 year ago

7.8.0

1 year ago

7.0.6

1 year ago

7.13.0

1 year ago

7.0.4

1 year ago

7.0.3

1 year ago

7.9.1

1 year ago

7.15.0

1 year ago

7.14.0

1 year ago

6.17.2

1 year ago

6.17.1

1 year ago

6.15.12

1 year ago

6.26.0

1 year ago

6.36.1

1 year ago

6.36.0

1 year ago

7.0.2

1 year ago

6.22.0

1 year ago

6.19.1

1 year ago

6.19.2

1 year ago

6.15.11

2 years ago

6.15.7

2 years ago

6.15.5

2 years ago

6.15.2

2 years ago

6.15.1

2 years ago

6.15.0

2 years ago

6.7.4

2 years ago

6.8.3

2 years ago

6.8.2

2 years ago

6.10.1

2 years ago

6.10.0

2 years ago

5.10.13

2 years ago

5.5.12

2 years ago

5.0.1

3 years ago

5.0.0

3 years ago

4.8.3

3 years ago

4.7.3

3 years ago

4.3.11

3 years ago

4.3.29

3 years ago

4.3.6

3 years ago

4.3.8

3 years ago

4.3.7

3 years ago

4.2.2

3 years ago

4.2.1

3 years ago

4.2.0

3 years ago

4.1.0

3 years ago

4.1.1

3 years ago

4.0.9

3 years ago

4.0.8

3 years ago

4.0.19

3 years ago

4.0.10

3 years ago

4.0.16

3 years ago

4.0.15

3 years ago

4.0.18

3 years ago

4.0.12

3 years ago

4.0.11

3 years ago

4.0.14

3 years ago

4.0.13

3 years ago

3.2.6

4 years ago

3.2.5

4 years ago

3.2.4

4 years ago

4.0.6

4 years ago

4.0.0

4 years ago

4.0.2

4 years ago

3.2.8

4 years ago

3.2.7

4 years ago

3.2.3

4 years ago

3.1.3

4 years ago

3.1.2

4 years ago

3.1.1

4 years ago

3.1.0

4 years ago

3.1.7

4 years ago

3.1.6

4 years ago

3.1.5

4 years ago

3.1.4

4 years ago

3.1.9

4 years ago

3.1.8

4 years ago

3.0.0

4 years ago

3.1.12

4 years ago

3.1.11

4 years ago

3.1.14

4 years ago

3.1.13

4 years ago

3.1.15

4 years ago

3.1.10

4 years ago

2.3.5

4 years ago

2.3.4

4 years ago

2.3.3

4 years ago

2.3.2

4 years ago

2.3.0

4 years ago

2.2.19

4 years ago

2.2.18

4 years ago

2.2.17

4 years ago

2.2.16

4 years ago

2.2.15

4 years ago

2.2.13

4 years ago

2.2.12

4 years ago

2.2.11

4 years ago

2.2.10

4 years ago

2.2.9

4 years ago

2.2.8

4 years ago

2.2.7

4 years ago

2.2.6

4 years ago

2.1.16

4 years ago

2.1.17

4 years ago

2.1.14

4 years ago

2.1.15

4 years ago

2.1.13

4 years ago

2.1.18

4 years ago

2.1.19

4 years ago

2.1.25

4 years ago

2.1.26

4 years ago

2.1.23

4 years ago

2.1.24

4 years ago

2.1.22

4 years ago

2.2.1

4 years ago

2.2.0

4 years ago

2.2.3

4 years ago

2.2.2

4 years ago

2.2.5

4 years ago

2.2.4

4 years ago

2.0.7

5 years ago

2.0.9

4 years ago

2.0.8

5 years ago

2.0.1

5 years ago

2.1.9

4 years ago

2.1.12

4 years ago

2.1.10

4 years ago

2.1.11

4 years ago

2.1.2

4 years ago

2.0.15

4 years ago

2.1.1

4 years ago

2.0.16

4 years ago

2.1.4

4 years ago

2.0.13

4 years ago

2.1.3

4 years ago

2.0.14

4 years ago

2.1.6

4 years ago

2.0.11

4 years ago

2.1.5

4 years ago

2.0.12

4 years ago

2.1.8

4 years ago

2.1.7

4 years ago

2.0.10

4 years ago

2.1.0

4 years ago

2.0.19

4 years ago

2.0.17

4 years ago

2.0.18

4 years ago

2.0.20

4 years ago

2.0.21

4 years ago

1.5.16

5 years ago

1.5.5

5 years ago

1.5.4

5 years ago

1.5.3

5 years ago

1.5.2

5 years ago

1.5.1

5 years ago

1.5.7

5 years ago

1.5.6

5 years ago

1.5.14

5 years ago

1.5.15

5 years ago

1.5.0

5 years ago

1.1.22

5 years ago

1.1.21

5 years ago

1.1.20

5 years ago

1.1.19

5 years ago

1.1.18

5 years ago

1.1.17

5 years ago

1.1.16

5 years ago

1.1.15

5 years ago

1.1.14

5 years ago

1.1.13

5 years ago

1.1.12

5 years ago

1.1.11

5 years ago

1.1.10

5 years ago

1.1.9

5 years ago

1.1.8

5 years ago

1.1.7

5 years ago

1.1.6

5 years ago

1.1.5

5 years ago

1.1.4

5 years ago

1.1.3

5 years ago

1.1.2

5 years ago

1.1.1

5 years ago

1.1.0

5 years ago

1.0.98

5 years ago

1.0.97

5 years ago

1.0.96

5 years ago

1.0.95

5 years ago

1.0.94

5 years ago

1.0.93

5 years ago

1.0.92

5 years ago

1.0.91

5 years ago

1.0.90

5 years ago

1.0.89

5 years ago

1.0.88

5 years ago

1.0.87

5 years ago

1.0.86

5 years ago

1.0.85

5 years ago

1.0.83

5 years ago

1.0.82

5 years ago

1.0.81

5 years ago

1.0.79

5 years ago

1.0.80

5 years ago

1.0.78

5 years ago

1.0.77

5 years ago

1.0.76

5 years ago

1.0.75

5 years ago

1.0.74

5 years ago

1.0.73

5 years ago

1.0.72

6 years ago

1.0.71

6 years ago

1.0.69

6 years ago

1.0.70

6 years ago

1.0.68

6 years ago

1.0.67

6 years ago

1.0.66

6 years ago

1.0.65

6 years ago

1.0.64

6 years ago

1.0.63

6 years ago

1.0.62

6 years ago

1.0.61

6 years ago

1.0.60

6 years ago

1.0.55

6 years ago

1.0.59

6 years ago

1.0.58

6 years ago

1.0.57

6 years ago

1.0.56

6 years ago

1.0.51

6 years ago

1.0.54

6 years ago

1.0.53

6 years ago

1.0.52

6 years ago

1.0.50

6 years ago

1.0.49

6 years ago

1.0.47

6 years ago

1.0.46

6 years ago

1.0.45

6 years ago

1.0.44

6 years ago

1.0.43

6 years ago

1.0.42

6 years ago

1.0.41

6 years ago

1.0.39

6 years ago

1.0.40

6 years ago

1.0.38

6 years ago

1.0.37

6 years ago

1.0.36

6 years ago

1.0.35

6 years ago

1.0.34

6 years ago

1.0.33

6 years ago

1.0.32

6 years ago

1.0.31

6 years ago

1.0.30

6 years ago

1.0.29

6 years ago

1.0.28

6 years ago

1.0.27

6 years ago

1.0.26

6 years ago

1.0.25

6 years ago

1.0.24

6 years ago

1.0.23

6 years ago

1.0.22

6 years ago

1.0.21

6 years ago

1.0.20

6 years ago

1.0.19

6 years ago

1.0.18

6 years ago

1.0.17

6 years ago

1.0.16

6 years ago

1.0.15

6 years ago

1.0.14

6 years ago

1.0.13

6 years ago

1.0.12

6 years ago

1.0.11

6 years ago

1.0.10

6 years ago

1.0.9

6 years ago

1.0.8

6 years ago

1.0.7

6 years ago

1.0.6

6 years ago

1.0.5

6 years ago

1.0.3

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago