Foundation Entity Management
API
Entity Management
Introduction
The Entity Management micro-front-end is used to connect to a resource on the back end and manage it from the front end. Handlers can be set up for create, update, and delete events; after adding an event, a button appears to perform the action. There is a list of pre-defined events and resources to manage, but you can manage custom resources that you create on the back-end too.
:::tip
The buttons are conditionally accessed, based on the specified events. For example, if the current user is only able to edit the entities, then you should only set the edit event on the entity-manager - you need to conditionally set the events based on user authorisations.
:::
Two core components are used to manage the entities - the grid and the form. The grid contains an entity on each row and data in each column.
Example grid used to manage counterparties
data:image/s3,"s3://crabby-images/957c6/957c6bcfd46aabfd028eb63495e89f9e6fa427e7" alt="Example entity management grid"
The other component is the form, and this is used to update an existing entity or create a new one. An example form is shown here.
data:image/s3,"s3://crabby-images/4fa2d/4fa2d21b629b9b49a2c5f50f6bae0f74ff58a9a9" alt="Example entity management form"
Set-up
To enable this micro-front-end in your application, follow the steps below.
- Add
@genesislcap/foundation-entity-management
as a dependency in your package.json file. Whenever you change the dependencies of your project, ensure you run the $ npm run bootstrap
command again. For more info see the package.json basics page.
{
...
"dependencies": {
"@genesislcap/foundation-entity-management": "latest"
},
...
}
- Import and declare the class in the page of the class where you wish to use the Entity Manager. Then add the entity management into the template html where required:
import { EntityManagement, } from '@genesislcap/foundation-entity-management';
EntityManagement;
export const AdminTemplate: ViewTemplate = html`
<zero-tabs>
<zero-tab-panel slot="tabpanel">
<zero-error-boundary>
<entity-management
resourceName="ALL_COUNTERPARTYS"
title="Counterparty Management"
updateEvent="EVENT_COUNTERPARTY_MODIFY"
deleteEvent="EVENT_COUNTERPARTY_DELETE"
createEvent="EVENT_COUNTERPARTY_INSERT"
></entity-management>
</zero-error-boundary>
</zero-tab-panel>
<zero-tab-panel slot="tabpanel">
<zero-error-boundary>
<entity-management
resourceName="ALL_USERS"
title="User Management"
updateEvent="EVENT_AMEND_USER"
deleteEvent="EVENT_DELETE_USER"
createEvent="EVENT_INSERT_USER"
></entity-management>
</zero-error-boundary>
</zero-tab-panel>
</zero-tabs>
`;
Config
The functionality of the Entity Manager is customised through the properties you set on it in the HTML. This section covers the main properties that you need to customise. For a full list of all of the properties, see here.
Title
title
customises the title of the entity list so that the user can see what resource they are managing.
Resource
resourceName
refers to the name of either a DATASERVER
query, a ReqRep
definition or a specific EVENT_HANDLER
. This essentially is the resource to be managed. In the above example, we use ALL_COUNTERPARTYS
which is a SDATASERVER
query, as, by convention, they all start with ALL_
.
Events
createEvent
, updateEvent
, deleteEvent
are set to be the events on the back end that handle the specific actions, such as deleting counterparty data. For the create and update functionality, these also define the resource in which the form is populated when the user is creating or updating an entity. After adding an event, a button for performing the selected action appears.
Datasource configuration
Set this object to configure how the Entity Manager interacts with the resource. See here.
Persist column state
persist-column-state-key
is a string value. It is used to control how the column states are persisted through actions such as page changes or refreshes. If no persist-column-state-key
property is set, then the behaviour will be to not persist the column state, and the grid will revert back to its default state every time the user navigates away from it.
:::warning
The string defines the key in which the serialised state of the columns is stored in an object in session storage. Therefore, if you are setting multiple Entity Managers in your application to persist the state you need to use unique keys or you will get undefined behaviour.
:::
User Management
The User Management micro front-end is used to manage the users on the front end. Two core components are used to manage the entities:
The grid contains an entity on each row and data in each column.
:::info
User Management is a concrete use case of the Entity Management micro front-end, which is provided as part of foundation-ui
.
:::
Here is an example grid view for managing users:
data:image/s3,"s3://crabby-images/8f6d1/8f6d18eb7f6e374dd232b31395fbe2df65ff8823" alt="Example user management grid"
Set-up
To enable this micro-front-end in your application, follow the steps below:
- Add
@genesislcap/foundation-entity-management
as a dependency in your package.json file. Whenever you change the dependencies of your project, ensure you run the $ npm run bootstrap
command again. You can find more information in the package.json basics page.
{
...
"dependencies": {
"@genesislcap/foundation-entity-management": "latest"
},
...
}
- Import and declare the class in the page of the class where you wish to use the user manager. Then add User Management to the template html where required:
import { Users, } from '@genesislcap/foundation-entity-management';
Users;
export const AdminTemplate: ViewTemplate = html`
<zero-tabs>
<zero-tab-panel slot="tabpanel">
<zero-error-boundary>
<user-management></user-management>
</zero-error-boundary>
</zero-tab-panel>
</zero-tabs>
`;
Config
You can customise the functionality of User Management through the properties you set in the html. This section covers the main properties that you can customise. For a full list of all of the properties, see here.
Columns
The primary way to configure the User Management functionality is via the columns that are displayed on the grid.
<user-management></user-management>
The default columns are contained in the UserColumnConfig variable. The Entity
and Status
columns are always added to the grid.
To configure the columns yourself, set the columns
attribute when you define the User Management in the html. You can mix in your custom column config with the default user columns config, using the javascript spread
operator.
<user-management :columns=${() => [...UsersColumnConfig, ...userColumns]}>
</user-management>
To see a more verbose version of this example, see the second example here.
Permissions
In contrast to Entity Management, we have a different way of displaying buttons and performing actions here. In this case, they are displayed if the user has the appropriate permissions from the server.
INSERT_USER
- the user can add new usersDELETE_USER
- the user can delete usersAMEND_USER
- the user can update existing users
Persist column state
persist-column-state-key
is a string value, which is used to control how the column states are persisted through actions such as page changes or refreshes. When using this micro front-end, it is set to entity_profiles_management
.
:::info
For more info on persist-column-state-key
see the section in the entity management.
:::
Profile Management
The Profile Management micro-front-end is used to manage the profiles on the front end. Two core components are used to manage the profiles - the grid and the form.
:::info
Profile Management is a concrete use case of the Entity Management micro front-end, which is provided as part of foundation-ui
.
:::
Example grid view when managing profiles.
data:image/s3,"s3://crabby-images/5f63d/5f63d398ad1a97d96e811132f60e1b29a74d6837" alt="Example profile management grid"
Set-up
To enable this micro-front-end in your application, follow the steps below.
- Add
@genesislcap/foundation-entity-management
as a dependency in your package.json file. Whenever you change the dependencies of your project, ensure you run the bootstrap command again. You can find more information in the package.json basics page.
{
...
"dependencies": {
"@genesislcap/foundation-entity-management": "latest"
},
...
}
- Import and declare the class in the page of the class where you wish to use the Profile Manager. Then add the profile management into the template html where required:
import { Profiles } from '@genesislcap/foundation-entity-management';
Profiles;
export const AdminTemplate: ViewTemplate = html`
<zero-tabs>
<zero-tab-panel slot="tabpanel">
<zero-error-boundary>
<profile-management></profile-management>
</zero-error-boundary>
</zero-tab-panel>
</zero-tabs>
`;
Config
The functionality of the profile manager is customised through the properties you set in the html. This section covers the main properties that you will want to customise. For a full list of all of the properties, see here.
Permissions
In contrast to Entity Management, we have a different way of displaying buttons and performing actions here. In this case, they are displayed if the user has the appropriate permissions from the server.
INSERT_PROFILE
- the user can add new profilesDELETE_PROFILE
- the user can delete profilesAMEND_PROFILE
- the user can update existing profiles
Persist column state
persist-column-state-key
is a string value which is used to control how the column states are persisted through actions such as page changes or refreshes. If no persist-column-state-key
property is set, then the behaviour will be to not persist the column state, and the grid will revert back to its default state every time the user navigates away from it.
:::info
For more information on persist-column-state-key
see the section in the Entity Management page.
:::
License
Note: this project provides front end dependencies and uses licensed components listed in the next section, thus licenses for those components are required during development. Contact Genesis Global for more details.