{"id":15554131,"url":"https://github.com/entando/entando-webui","last_synced_at":"2026-05-01T01:31:40.092Z","repository":{"id":42452032,"uuid":"430868832","full_name":"entando/entando-webui","owner":"entando","description":"Monorepo containing all packages and apps for the Entando WebUI project.","archived":false,"fork":false,"pushed_at":"2022-04-05T11:23:08.000Z","size":1365,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":7,"default_branch":"master","last_synced_at":"2026-04-17T00:28:37.056Z","etag":null,"topics":["nextjs","webui"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/entando.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2021-11-22T21:22:41.000Z","updated_at":"2022-02-01T14:09:57.000Z","dependencies_parsed_at":"2022-09-10T15:01:52.029Z","dependency_job_id":null,"html_url":"https://github.com/entando/entando-webui","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/entando/entando-webui","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/entando%2Fentando-webui","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/entando%2Fentando-webui/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/entando%2Fentando-webui/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/entando%2Fentando-webui/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/entando","download_url":"https://codeload.github.com/entando/entando-webui/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/entando%2Fentando-webui/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32482460,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-30T13:12:12.517Z","status":"ssl_error","status_checked_at":"2026-04-30T13:12:06.837Z","response_time":57,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["nextjs","webui"],"created_at":"2024-10-02T14:43:48.696Z","updated_at":"2026-05-01T01:31:40.070Z","avatar_url":"https://github.com/entando.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Entando WebUI\n\n\u003e This project is still in closed Beta. Proceed at your own risk!\n\u003e \n\u003e Reach out at [developers@entando.com](developers@entando.com) if you need any help.\n\nThis project is a monorepo that contains all apps and packages used in the WebUI Architecture in Entando 7.\n\nThe WebUI project is an _**optional**_ direct replacement of the PortalUI, which was the renderization engine used in Entando 6 and older versions.\n\nAt the end of the day it's an opinionated [Next.js 12](https://nextjs.org/blog/next-12) app with out of the box integrations with everything you build inside [App Builder](https://dev.entando.org/v6.3.2/docs/concepts/#entando-app-builder).\n\nIt not only supports all pre-existing features but now supports more modern Web Frameworks and gives Developers full control over the deployed code. **It's Low Code meets Pro Code!**\n\n## Architecture\n\nPortalUI acted as the Entando Engine that rendered the pages that were configured through App Builder and Admin Console.\n\nIn **Entando 7**, we leverage this Architecture by bringing a new and faster engine built using Next.js 12 (the SDK for the Web!).\n\nThe WebUI Engine brings a techonology upgrade beyond limits for Entando App Developers. It not only brings a new and modern way of building Entando Apps but also allows a smooth migration path from PortalUI pages by acting as a reverse proxy to PortalUI running in headless mode (REST API only).\n\n![WebUI Architecture using PortalUI in headless mode](./assets/images/WebUI%20Architecture.png \"WebUI Architecture\")\n_**Figure:** WebUI Architecture using PortalUI in headless mode_\n\n## DevOps\n\nWith this new Architecture we propose a new step in the normal Entando User workflow experience.\n\nPreviously Users edited pages in Draft mode and then Published them to Production. We now propose a Deploy step that bundles everything that was Published and pushes it to Production during a Build, Test \u0026 Optimize phase.\n\nThis allows Entando Users to work in Scoped Projects and look at Entando from a DevOps perspective. Projects can be features or campaigns, for example, and allow teams to be more agile and move faster!\n\nAlso, by Introducing this new Step we allow Entando to have an Optimization phase where we leverage all features of Next.js, like [SSG, ISR or SSR](https://nextjs.org/docs/basic-features/pages) and allows Developers to implement Unit, Integration or even E2E tests in their apps, delivering high quality apps to production!\n\n![WebUI Environment Propagation Workflow](assets/images/WebUI%20Env%20Propagation.png \"WebUI Environment Propagation Workflow\")\n_**Figure:** WebUI Environment Propagation Workflow_\n\n## Development\n\nThis project is a monorepo managed using Yarn Workspaces and contains all Libraries, Microservices, UI Components and Next.js Starter Applications used in this new Architecture.\n\nWe provide a simple way to bootstrap a Development Environment using `yarn dev` but feel free to add or propose your own scripts. Check the [package.json](https://github.com/entando/entando-webui/blob/master/package.json) for more details.\n\n### Environment Variables\n\nBefore starting configure the `.env` files inside the following sub projects:\n - [services/app-management-service](https://github.com/entando/entando-webui/blob/master/services/app-management-service)\n - [starters/quickstart-nextjs-starter](https://github.com/entando/entando-webui/blob/master/starters/quickstart-nextjs-starter)\n\n### Project Stucture\n\n```\n\u003e packages\n \u003e app-engine-client         \u003c-- Client integrations with Keycloak and Entando Core APIs\n \u003e app-management-service    \u003c-- Microservice used to Manage Entando Apps\n\u003e starters                   \u003c-- Starter Templates used in Demos\n \u003e quickstart-nextjs-starter \u003c-- Example Starter Template used in the Quickstart Tutorial\npackage.json                 \u003c-- Project manifest\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fentando%2Fentando-webui","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fentando%2Fentando-webui","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fentando%2Fentando-webui/lists"}