keycloak-scim/js/apps/account-ui
Alexander Schwartz c47083abb2 Translated using Weblate (German)
Translation: Keycloak/Account UI
Translate-URL: https://hosted.weblate.org/projects/keycloak/account-ui/de/

Translated using Weblate (German)

Translation: Keycloak/Theme base/account
Translate-URL: https://hosted.weblate.org/projects/keycloak/theme-baseaccount/de/

Co-authored-by: Alexander Schwartz <alexander.schwartz@gmx.net>
Signed-off-by: Alexander Schwartz <alexander.schwartz@gmx.net>
2024-05-06 17:57:43 +02:00
..
maven-resources added missing translations (#28775) 2024-04-17 09:03:35 +02:00
maven-resources-community/theme/keycloak.v3/account/messages Translated using Weblate (German) 2024-05-06 17:57:43 +02:00
public Add missing translations for WebAuthN in Account Console (#26384) 2024-01-22 16:04:22 +00:00
src Generate translations for locales via built-in Java functionality (#29125) 2024-05-06 09:30:14 +02:00
test Use a typeahead select where there are ten or more options (#28512) 2024-04-18 16:18:00 -04:00
.gitignore changed name and added version number (#28157) 2024-04-19 14:10:34 -04:00
index.html Promote Account Console v3 to default and deprecate v2 (#25852) 2024-01-11 19:42:10 +01:00
package.json Upgrade dependencies to latest version (#29012) 2024-04-24 15:36:20 +01:00
playwright.config.ts Use browser router for Account Console (#22192) 2024-03-04 12:38:28 +00:00
pom.xml Only have one instance of the plugin (#28999) 2024-04-24 08:46:29 +02:00
README.md changed name and added version number (#28157) 2024-04-19 14:10:34 -04:00
tsconfig.json Move ESLint configuration to project root (#28639) 2024-04-12 08:34:18 +00:00
vite.config.ts changed name and added version number (#28157) 2024-04-19 14:10:34 -04:00

Keycloak Account UI

This project is the next generation of the Keycloak Account UI. It is written with React and PatternFly 4 and uses Vite.

Features

Contains all the "pages" from the account-ui as re-usable components, all the functions to save and the side menu to use in your own build of the account-ui

Install

npm i @keycloak/keycloak-account-ui

Usage

To use these pages you'll need to add KeycloakProvider in your component hierarchy to setup what client, realm and url to use.

import { KeycloakProvider } from "@keycloak/keycloak-account-ui";

//...

<KeycloakProvider environment={{
      authUrl: "http://localhost:8080",
      realm: "master",
      clientId: "security-admin-console"
  }}>
  {/* rest of you application */}
</KeycloakProvider>

Translation

For the translation we use react-i18next you can set it up as described on their website. If you want to use the translations that are provided then you need to add i18next-http-backend to your project and add:


backend: {
  loadPath: `http://localhost:8180/resources/master/account/{{lng}}`,
  parse: (data: string) => {
    const messages = JSON.parse(data);

    const result: Record<string, string> = {};
    messages.forEach((v) => (result[v.key] = v.value));
    return result;
  },
},

to the i18next config object.

Save functions

If you want to build your own "pages" you can still reuse the save functions:

  • deleteConsent
  • deleteCredentials
  • deleteSession
  • getApplications
  • getCredentials
  • getDevices
  • getGroups
  • getLinkedAccounts
  • getPermissionRequests
  • getPersonalInfo
  • getSupportedLocales
  • linkAccount
  • savePersonalInfo
  • unLinkAccount

Example:

import { savePersonalInfo, useEnvironment } from "@keycloak/keycloak-account-ui";

//...
function App() {
  // the save function also needs to have the context so that it knows where to POST
  // this hook gives us access to the `KeycloakProvider` context
  const context = useEnvironment();
  const submit = async (data) => {
    try {
      await savePersonalInfo(context, data);
    } catch (error) {
      // Error contains `name` and `value` of the server side errors
      // and your app will have better error handling ;)
      console.error(error);
    }
}
// ...

Building

To build a library instead of an app you need to add the LIB=true environment variable.

LIB=true pnpm run build