All Projects → neos → Neos Ui

neos / Neos Ui

Licence: gpl-3.0
Neos CMS UI written in ReactJS with Immutable data structures.

Programming Languages

javascript
184084 projects - #8 most used programming language

Projects that are alternatives of or similar to Neos Ui

Joomla Cms
Home of the Joomla! Content Management System
Stars: ✭ 3,995 (+1578.57%)
Mutual labels:  hacktoberfest, content-management
Starter Lapis
Cutting edge starter kit
Stars: ✭ 72 (-69.75%)
Mutual labels:  immutablejs, redux-saga
React Social Network
Simple React Social Network
Stars: ✭ 409 (+71.85%)
Mutual labels:  immutablejs, redux-saga
next-react-boilerplate
🔥 NextJS with additional tech feature like react-boilerplate. Demo >>
Stars: ✭ 20 (-91.6%)
Mutual labels:  redux-saga, immutablejs
Strapi
🚀 Open source Node.js Headless CMS to easily build customisable APIs
Stars: ✭ 41,786 (+17457.14%)
Mutual labels:  hacktoberfest, content-management
Katello
Katello integrates open source systems management tools into a single solution for controlling the lifecycle of your machines.
Stars: ✭ 312 (+31.09%)
Mutual labels:  hacktoberfest, content-management
React Native Spaceviewer
See and search upcoming and previous rocket space launches! Built with React Native, using Detox E2E tests, Fastlane and Github Actions for app store deployment.
Stars: ✭ 61 (-74.37%)
Mutual labels:  hacktoberfest, redux-saga
molecule
⚛️ –  – ⚛️ Boilerplate for cross platform web/native react apps with electron.
Stars: ✭ 95 (-60.08%)
Mutual labels:  redux-saga, immutablejs
Ts React Boilerplate
Universal React App with Redux 4, Typescript 3, and Webpack 4
Stars: ✭ 104 (-56.3%)
Mutual labels:  hacktoberfest, redux-saga
Molecule
⚛️ – :atom: – ⚛️ Boilerplate for cross platform web/native react apps with electron.
Stars: ✭ 95 (-60.08%)
Mutual labels:  immutablejs, redux-saga
abilitysheet
This app is ability sheet for beatmania iidx music of level 12.
Stars: ✭ 38 (-84.03%)
Mutual labels:  redux-saga, immutablejs
React Next Boilerplate
🚀 A basis for reducing the configuration of your projects with nextJS, best development practices and popular libraries in the developer community.
Stars: ✭ 129 (-45.8%)
Mutual labels:  hacktoberfest, redux-saga
Laravel 8 Simple Cms
Laravel 8 content management system for starters.
Stars: ✭ 444 (+86.55%)
Mutual labels:  hacktoberfest, content-management
React Eyepetizer
react版「Eyepetizer」开眼短视频
Stars: ✭ 83 (-65.13%)
Mutual labels:  immutablejs, redux-saga
Reactnativetemplate
Our example of simple application using ReactNative and some recommendations
Stars: ✭ 127 (-46.64%)
Mutual labels:  immutablejs, redux-saga
Neos Development Collection
The unified repository containing the Neos core packages, used for Neos development.
Stars: ✭ 235 (-1.26%)
Mutual labels:  hacktoberfest, content-management
Awesome Digitalocean
A curated list of amazingly awesome DigitalOcean resources inspired by Awesome Sysadmin
Stars: ✭ 236 (-0.84%)
Mutual labels:  hacktoberfest
Amplitude Javascript
JavaScript SDK for Amplitude
Stars: ✭ 234 (-1.68%)
Mutual labels:  hacktoberfest
11ty Website
Documentation site for the Eleventy static site generator.
Stars: ✭ 236 (-0.84%)
Mutual labels:  hacktoberfest
Devo
A Chrome and Firefox extension that displays GitHub Trending, Hacker News, Product Hunt and Designer News on every new tab.
Stars: ✭ 236 (-0.84%)
Mutual labels:  hacktoberfest

@neos/neos-ui

CircleCI Dependency Status Known Vulnerabilities Slack Forum Twitter

The next generation Neos CMS interface written in ReactJS and a ton of other fun technology.

Versioning

This repository follows the same versioning scheme as Neos itself, with the only exception that the 4.0 branch works with all Neos 4.x releases. Release roadmap is available here

That means:

  • All bugfixes go to the lowest maintained branch
  • All new features go only to master
  • New minor and major releases are made in sync with Neos/Flow. Bugfix releases may be available independantly

Currently maintained versions

  • NeosCMS version 4.x: branch 4.0
  • NeosCMS version 5.0: branch 5.0
  • NeosCMS version 5.1: branch 5.1
  • NeosCMS version 5.2: branch 5.2
  • NeosCMS version 5.3: branch 5.3
  • NeosCMS version 7.0: branch 7.0
  • latest development happens in master

Browser support

The new interface supports all evergreen (i.e. self-updating) browsers, including: Chrome, Firefox, Safari, Edge, Opera and other webkit-based browsers.

In order to get IE11 to work, please switch to CKEditor 4, as CKEditor 5 doesn't support it. But doing so is highly discouraged, so where possibly encourage your editors to use modern browsers.

If you discover bugs in any of the supported browsers, please report them!

Features

  • Better editing experience for responsive websites.
  • Faster load times for the backend.
  • No reload constraint for the correct stylesheets on multi-site systems.
  • Updated Font-Awesome to v5.0 (old icon names are migrated on the fly).

Installation and usage

The new UI is already included in the base Neos distribution. If you don't have it installed yet, follow these steps:

  1. You need to have Neos CMS 3.3 or newer up & running.

  2. Run the following command:

composer require neos/neos-ui
  1. Now you are all set up and you can login to the new interface as usual via /neos route.

Updating

composer update neos/neos-ui

Installing dev-master

For trying out the new UI, we recommend you to run the regularily released beta releases. However, if you want to stay on bleeding-edge, or want to help out developing, you'll need the dev-master release. You can install the master release using:

composer require neos/neos-ui-compiled:dev-master neos/neos-ui:dev-master

Contributing

Please follow the respective guides for contributing on OSX and on Linux.

on Windows

  1. Ensure you have the relevant version installed (see above).

  2. Please install Docker for Windows.

  3. Run docker-compose up.

  4. Inside Configuration/Settings.yaml, set the following property for disabling the pre-compiled files:

Neos:
  Neos:
    Ui:
      frontendDevelopmentMode: true
  1. Get an overview about the codebase. We've recorded an introduction on YouTube which gets you acquainted with the basics. Additionally, please get in touch with us on Slack in the channel #project-ui-rewrite. We're eager to help you get started!

on OSX / Linux

In order to start contributing on OSX / Linux, follow the following steps:

  1. Ensure you have the relevant version installed (see above).

  2. We require Chrome as well as the yarn(https://yarnpkg.com/en/) command and GNU Make(https://www.gnu.org/software/make/) to be installed on your system.

  3. The currently supported version of node is defined in .nvmrc file. If you have nvm installed, you can just run nvm install && nvm use from the project directory.

  4. Inside Configuration/Settings.yaml, set the following property for disabling the pre-compiled files:

Neos:
  Neos:
    Ui:
      frontendDevelopmentMode: true
  1. Run the initialization script:
make setup
  1. Get an overview about the codebase. We've recorded an introduction on YouTube which gets you acquainted with the basics. Additionally, please get in touch with us on Slack in the channel #project-ui-rewrite. We're eager to help you get started!

Guideline for PR and commit messages

Please see our guideline on how to write meaningful descriptions for your contributions.

Doing upmerges

To do the upmerge run the following commands

git checkout 5.0 && git fetch && git reset --hard origin/5.0 && git merge --no-ff --no-commit origin/4.0
# review and `git commit`
git checkout 5.1 && git fetch && git reset --hard origin/5.1 && git merge --no-ff --no-commit origin/5.0
# review and `git commit`
git checkout 5.2 && git fetch && git reset --hard origin/5.2 && git merge --no-ff --no-commit origin/5.1
# review and `git commit`
git checkout 5.3 && git fetch && git reset --hard origin/5.3 && git merge --no-ff --no-commit origin/5.2
# review and `git commit`
git checkout 7.0 && git fetch && git reset --hard origin/7.0 && git merge --no-ff --no-commit origin/5.3
# review and `git commit`
git checkout master && git fetch && git reset --hard origin/master && git merge --no-ff --no-commit origin/7.0
# review and `git commit`

Development commands

Command Description
make clean delete all node_modules in every subdirectory.
make build Runs the development build.
make build-watch Watches the source files for changes and runs a build in case.
make build-watch-poll Watches (and polls) the source files on a file share. Should preferably be used when working an a VM for example.
make storybook Starts the storybook server on port 9001.
make lint Executes make lint-js and make lint-editorconfig.
make lint-js Runs test in all subpackages via lerna.
make lint-editorconfig Tests if all files respect the .editorconfig.
make test Executes the test on all source files.
make test-e2e Executes integration tests.
Custom webpack live reload options

If you are developing inside a virtual machine and you are running the watch command on your local system it is may be needed for you to adjust the live reload optons.

This can be done by putting an .webpack.livereload.local.js inside the repository root.

An example file would look like this:

module.exports = {
    protocol: 'http',
    port: '123',
    hostname: 'localhost'
};

Writing unit tests

The unit tests are executed with jest. To run the unit tests, execute make test in your shell.

Adding unit tests is fairly simple, just create a file on the same tree level as your changed/new feature, named [filename].spec.js and karma will execute all tests found within the spec file, other than that, just orient yourself on the existing tests.

Use it.only(() => {}) and describe.only(() => {}) if you want to run a specific test and not the whole test suite.

Integration tests

To setup end-to-end tests locally you have got to do the same things described in CircleCI workflow, namely take the test disribution and composer install in it, put the right branch into Neos.Neos.Ui folder and run webserver and mysql server with the same config as described in the test distribution's Settings.yaml (or adjust it).

For executing the end to end tests on a Mac with catalina or higher you need to permit screen recording. Open 'System Preferences > Security & Privacy > Privacy > Screen Recording' and check 'TestCafe Browser Tools' in the application list.

Debugging integration tests
  • View the recording via Sauce Labs. You can find the url in the beginning of the test output.
  • Observe Flow exceptions and logs in build artifacts.
  • You can trigger a SSH enabled build via the CircleCI interface and then login.
Just the end to end tests fail

It can happen that end to end tests fail caused by cached sources. So if you change PHP code for instance and don't adjust the composer.json it can happen that your new code change is not used because it is not part of the cache. In this case we need to flush the CircleCI caches manualy.

We have introduced an environment variable called CACHE_VERSION. We need to change the variable to to new timestamp for instance to invalidate the caches.

  1. go to https://app.circleci.com/settings/project/github/neos/neos-ui and login
  2. open the project settings and choose Environment Variables
  3. Delete the CACHE_VERSION and create a new one with the value of the current timestamp

Retrigger the build and it should work.

Releasing

You only need to trigger the jenkins release with the version you want to release. After jenkins has finished you need release a new version on github.

License

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].