A framework-agnostic widget library.
This is a monorepo organised with multiple npm packages:
core
contains the framework agnostic sources
Then for each supported framework, a corresponding package is present with framework-specific code. Each of them contains the lib
folder, with components using the core
, and the demo
folder, hosting the demo application.
angular
contains Angular sources, with the server running on port 4200react
contains React sources, with the server running on port 3000svelte
contains Svelte sources, with the server running on port 3001
Finally, two other npm packages are available for testing purposes:
base-po
contains a base class for page objects when writing end-to-end tests with Playwrightpage-objects
contains page objects for each AgnosUI widget
If you want to play with AgnosUI on your own machine:
- Clone the project
- Run
npm install
- Use commands below
Several commands are available in the different workspaces. In order to avoid to repeatedly enter the same thing for each workspace, the command will be run on every workspace directly. If needed, you can filter them by entering the workspace names.
For example:
npm run dev
will run the taskdev
on the workspacesdemo
,angular
,react
andsvelte
.npm run dev demo svelte
will run the taskdev
on the workspacesdemo
andsvelte
.
-
npm run dev
will run the servers in dev mode (workspaces :demo
,angular
,react
,svelte
). -
npm run dev angular
runs the Angular demo on http://localhost:4200 -
npm run dev react
runs the React demo on http://localhost:3000 -
npm run dev svelte
runs the Svelte demo on http://localhost:3001
The preview mode is used to run the servers that will serve a build version of the applications.
npm run preview
(workspaces :demo
,angular
,react
,svelte
).
Vitest is the test runner used to run the unit tests of the core sources
npm run tdd
: run the TDD in watch mode (workspaces :core
,angular
,eslint-plugin
).npm run tdd:ui
: run the TDD in the watch mode, with a UI (workspaces :core
,eslint-plugin
)npm run test:coverage
: run the unit tests with the coverage report (workspaces :core
,eslint-plugin
)
It's also possible to filter test by their pathname. For example, npm run tdd core rating
will run the tdd task of the core
workspace, for the rating
only,
The end-to-end (e2e) tests are performed with Playwright. The setup is done to run the same specs on Chromium, Firefox and Webkit, on the three demos (Angular, React and Svelte) to ensure that everything works the same in each combination.
You can use some specific keyworks to filter the tests:
angular
,react
orsvelte
will select a specific framework,chromium
,firefox
orwebkit
will select a specific browser,- Any other word will filter the tests by filename.
For example:
npm run e2e
: run the full e2e suite for all the browsers, all the applications,npm run e2e angular
: run all the specs for Angular in all browsers,npm run e2e svelte chromium
: run all the specs for Svelte in Chromium,npm run e2e firefox react select
: run all the specs with the 'select' filename, for React in Firefox,