0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-20 21:32:31 -05:00
logto/packages/elements
2024-07-26 19:48:09 +08:00
..
src fix(elements): fix user context tag name (#6346) 2024-07-26 19:48:09 +08:00
xliff feat(elements): init user provider 2024-07-22 11:42:51 +08:00
.gitignore
index.html feat(elements): update name 2024-07-22 11:44:24 +08:00
lit-localize.json
package.json feat(elements): update name 2024-07-22 11:44:24 +08:00
README.md feat(elements): init modal and input 2024-07-22 11:36:44 +08:00
tsconfig.json
tsup.config.ts feat(elements): init modal and input 2024-07-22 11:36:44 +08:00
web-dev-server.config.js feat(elements): init modal and input 2024-07-22 11:36:44 +08:00

Logto elements

A collection of Web Components for building better applications with Logto.

Warning

This package is still under development and not yet published to npm.

Development

  • The standard dev script is useful for testing the Logto integration when you are working with the workspace's dev script. How ever, the dev integration has some issues like duplicate registration and stale element cache. It's not easy to overcome them at the moment.
  • Run the start script to start a quick development server that serves the elements via index.html.

Internationalization

The elements are using @lit/localize for internationalization. The translations are stored in the xliff directory. There's no need to update that directory for new phrases, unless you can add the translations at the same time. See Localization for more information.

Update translations

  1. Run lit-localize extract to extract and sync the translations from the source code to the xliff directory.
  2. Translate the phrases in the xliff directory.
  3. Run lit-localize build to build the translations into the src/generated directory.

Important

lit-localize build is required to build the bundle with the translations.

Convention

Although @lit/localize gives us the flexibility to write localized strings in a casual way, we should follow a convention to keep the translations consistent.

When using msg(), a human-readable ID should be used, and it is highly recommended to also write the description to give the translators (or LLMs) more context.

// ✅ Good
msg('Not set', {
  id: 'general.fallback-title',
  desc: 'A fallback title when the title or heading of a component is not provided.',
})

// ❌ Bad
msg('Not set')