Reference client for Jasper KM.
Jasper-UI is the reference client for the Jasper Knowledge Management Server
To start the server, client and database with a single admin user, run the quickstart docker compose file.
As the reference client for the jasper protocol this project is designed to expose all features of the jasper protocol with a user experience supporting devs and power users.
This client allows you to expressively annotate links with tags and your own ontology.
It can be left unmodded to act as a general purpose database or admin tool.
With modding single purpose UIs can be derived for prototyping, one-off use, or micro-frontends.
Modding can also augment existing general purpose functionality. See src/app/mods for bundled mods.
Other mod distributions may be compatible with this client or require a different client.
The same network can be used by multiple clients and unsupported features are silently ignored.
General Purpose Usage:
- RSS Reader
- AI Chat
- Bulletin Board
- Discussion Forum
- Wiki / Knowledge Base
- Business Workflow Automation
- Continuous Offsite Backups
Markdown editor with support for rendering both markdown and HTML.
- Use #tagto create a tag link. Add a space for the usual markdown H1 "# Title".
- Any links in markdown will automatically be added to either sources or alternate URLs
- Use [1]or[[1]]to reference existing sources. The number will be the 1-based index of the source.
- Use [alt1]or[[alt1]]to reference alternate URLs. Use[alt1](url)to add an alternate URL. The number will be the 1-based index of the alternate URLs.
- Using +user/charliewith the inbox plugin installed will addplugin/inbox/user/charlieto the tags. Use#+user/charlieinstead to simply link to the user without notifying them.
- Use ^to create superscripts. Use in combination with source references for standard reference style such as^[1]or^[[1]].
- Any links to a ref or tag will render a toggle button to expand inline (any link that starts
with /ref/or/tag/, with or without the server host and base path).
- Links of the form will add a ref entry inline.
- Links of the form will embed the contents of the Ref if it exists, or attempt to embed the url directly if it is an image, audio, video, or embeddable sites.
- Links of the form will add a toggle button that will expand to show the contents of the Ref if it exists, or attempt to show the content directly if it is an image, audio, video, and embeddable sites.
- Links of the form will add results of a tag query inline.
- Perform any tag query while performing a full text search and multi-column sort
- Displays title from tag Ext if present
- Displays sidebar markdown from tag Ext if present
- Displays pinned Refs from tag Ext if present
- Adds Modmail button that sends a DM to plugin/inbox/tag
- Root Mod:
- Pinned links: Display these links at the top of this tag's page.
- Sidebar: (optional) Custom markdown content for the sidebar. LaTeX and emojis are supported if plugins are installed.
- Themes: (optional) Set a custom theme for a tag page. Will remain active until a different tag page is visited.
 
- User: (matches user/) Store user generated data:- Inbox: last notified time (for use with the inbox plugin)
- Subscriptions: List of tags to show on your home page
- Themes: (optional) Override the theme for the entire site. Will cause custom tag themes to be ignored.
 
- Home Page: Enables a home page where you can subscribe to various tags or queries and see them there. Adds a for Requires user mod
- Inbox: Enables notifications when installed. You receive a notification when someone posts a
response to yours. Activates the envelope icon button in the settings area of the client.
Requires the inbox field in the user template. When posting a response the client will add (for
example with +user/charlie)plugin/inbox/user/charlieto the tags. This will cause it to show up in+user/charlie's notifications. Users also receive notifications for all tags they have write access to (tag modmail). This tag is also the convention by which you may address a Ref "To:" another user. Does not add data to a Ref.
- Comment: Enables comments and comment threads when installed. Allows sorting Refs by number
of comments. Comments are created with plugin/commentandinternaltags. (theinternaltag prevents the comment from showing up on@*). Adds a deleted field to the ref to mark the comment as deleted. This is used to prevent breaking a comment thread by actually removing a node when a comment is deleted.
- Thumbnail: Enables the Ref thumbnail when installed. When a Ref is tagged plugin/thumbnail, the Ref has an image that can be used as a thumbnail. Adds optional url, width, height, and time fields to the Ref. If the url field is not specified, the url of the Ref will be the image thumbnail.
- Latex: Enables KaTeX processing on the Ref comment markdown. Does not add data to a Ref. KaTeX support for sidebar content is always enabled if this plugin is installed.
- Graph: Enable the knowledge graph tab in the client UI when this is installed. Adds data to refs to override how they are graphed.
- QR: Enables the QR embed when installed. When the plugin/qris applied to a Ref, the Ref has a URL to be converted into a QR code. The QR code is shown when the embed toggle is pressed. Adds optional URL field to the Ref to use for the QR code, if this is unspecified the URL of the Ref will be used.
- Embed: Enables the iframe embed when installed. When the plugin/embed is applied to a Ref,
the Ref has a URL that can be used in an iframe. The iframe is shown when the embed toggle is
pressed. Adds optional URL field to the Ref to use for the iframe, if this is unspecified the
URL of the Ref will be used. Currently implemented for:
- YouTube
- X/Twitter
- BitChute
 
- Audio: Enables the audio embed when installed. When the plugin/audiois applied to a Ref, the Ref has a URL that points to an audio file. The audio player is shown when the embed toggle is pressed. Adds optional URL field to the Ref to use for the audio file, if this is unspecified the URL of the Ref will be used. This plugin will be suggested when you submit a link ending in an audio file extension.
- Video: Enables the video embed when installed. When the plugin/videois applied to a Ref, the Ref has a URL that points to a video file. The video player is shown when the embed toggle is pressed. Adds optional URL field to the Ref to use for the video file, if this is unspecified the URL of the Ref will be used. This plugin will be suggested when you submit a link ending in a video file extension.
- Image: Enables the image embed when installed. When the plugin/imageis applied to a Ref, the Ref has a URL that points to an image file. The image is shown when the embed toggle is pressed. Adds optional URL field to the Ref to use for the image file, if this is unspecified the URL of the Ref will be used. This plugin will be suggested when you submit a link ending in an image file extension.
- Wiki: Enables adding Wiki Refs when installed. When creating a wiki the URL will be
wiki://Page_name. You can link to a Wiki page using the double[[bracket syntax]]in all markdown fields. Does not add data to the Ref.
- Poll: Enables polls in the embeds when installed. When a Ref is tagged plugin/polldata is added to specify the options and their description text. Voting is done by adding a Ref response tagged withplugin/poll/response/tagand the response field, with tag being the response to the poll.
- Delta: (matches delta/) Apply a server side script to transform this Ref into a new Ref. Adds data to the tag Ext to contain the code or service reference and config.
- Queue: (matches queue/) Work Queue for assigning or tracking work and paying workers. Requires the invoice plugin to pay workers. Adds data:- Approvers: list of user tags to send invoices to
- Bounty: (optional) payment for responses to items in the queue.
- Max Age: (optional) max age Refs in the queue to be considered active. Refs in the queue older than this will have an expired icon when viewed from the queue tag page.
 
- Table: Enabled the table embed when installed. When the plugin/tableis applied to a Ref, the Ref contains tabular data. The tabular data is shown when the embed toggle is pressed. Adds an optional field to the Ref to use for the tabular data, if this is unspecified the URL of the Ref will be used to point to a TSV file.
- Chart: Enabled the graph embed when installed. When the plugin/chartis applied to a Ref, the Ref contains tabular data. The tabular data rendered in a graph is shown when the embed toggle is pressed. Adds fields to the ref for defining the chart type, labels, and location of the data in the table. Adds an optional field to the Ref to use for the tabular data, if this is unspecified the URL of the Ref will be used to point to a TSV file.
- Voting: Enables voting and sorting by vote when installed. Requires additions to the user template to hold votes. This adds two new sort fields to the UI: Top and Hot. Top sorts by vote total, and Hot applies an exponential time decay when sorting. If the inbox plugin is enabled there is a tab on the index page to view the refs you voted on. Can be configured to allow positive or both positive and negative votes. Voting on a Ref adds it to a list in your user extension. Does not add data to a Ref.
- Analytics: Enables engagement tracking when installed. Reports links clicked, Refs expanded, Ref action taken, Refs viewed, and queries searched. Adds data to the Ref to override analytic tracking for that ref.
- Geo: Enables a map in the embeds that displays GeoJson when installed. When a Ref is tagged
plugin/geo, the Ref includes some GeoJson. The map is shown when the embed toggle is pressed. Adds an optional field to the Ref to use for the GeoJson, if this is unspecified the URL of the Ref will be used to point to a GeoJson file.
- GeoPackage: Enables a map in the embeds that displays GeoPackage when installed. When a
Ref is tagged plugin/geopackage, the Ref includes some GeoPackage. The map is shown when the embed toggle is pressed. Adds an optional field to the Ref to use for the GeoPackage, if this is unspecified the URL of the Ref will be used to point to a GeoPackage file.
- Invoice: Enables invoice support in the client when installed. When invoices are created they
will be tagged plugin/invoice. When the inbox plugin is installed there is a tab on the inbox page to show invoices addressed to you. Requires the QR plugin to send QR invoices. If the Work Queue template is installed, any invoices can include a Work Queue to address the invoice to all work queue approvers. Does not add data to a Ref.
Jasper-UI is available in the following distributions:
Config settings are loaded at runtime from assets/config.json. When using a docker image, a config file will be generated from environment variables:
| Config field | Docker Env | Description | Example Value | 
|---|---|---|---|
| title | JASPER_TITLE | Name to display in the title bar. | Jasper | 
| version | JASPER_VERSION | Version string to display as a tooltip in the footer. | v1.0.0 | 
| api | JASPER_API | URL of the API server (no trailing slash) | //jasperkm.info | 
| JASPER_API_PROXY | Backend host to proxy on /api. SetsJASPER_APIto. | http://web:80 | |
| logout | JASPER_LOGOUT | Optional URL to log out. | //jasperkm.info/oauth2/sign_out?rd=https%3A%2F%2Fauth.jasperkm.info%2Fauthn%2Fauthentication%2Flogout | 
| login | JASPER_LOGIN | Optional URL to log in. A redirect ( ?rd=) will be appended with the current page. | //jasperkm.info/oauth2/sign_in | 
| signup | JASPER_SIGNUP | Optional URL to sign up. | https://auth.jasperkm.info/authn/registration/form | 
| scim | JASPER_SCIM | Enable SCIM user management interface. | false | 
| websockets | JASPER_WEBSOCKETS | Enable websocket STOMP connections. | false | 
| support | JASPER_SUPPORT | Optional tag to send help requests to. | false | 
| allowedSchemes | JASPER_ALLOWED_SCHEMES | Allow clickable links for certain schemas. | ["http:", "https:", "ftp:", "tel:", "mailto:"] | 
| modSeals | JASPER_MOD_SEALS | Seals which may only be added via ROLE_MOD or above. | ["seal", "_seal", "+seal", "_moderated"] | 
| editorSeals | JASPER_EDITOR_SEALS | Seals which may only be added via ROLE_EDITOR or above. | ["plugin/qc"] | 
| maxPlugins | JASPER_MAX_PLUGINS | Maximum number of plugins to load before giving up and writing an error to the console. | 1000 | 
| maxTemplates | JASPER_MAX_TEMPLATES | Maximum number of templates to load before giving up and writing an error to the console. | 1000 | 
| maxOrigins | JASPER_MAX_ORIGINS | Maximum number of origins to load before giving up and writing an error to the console. | 1000 | 
| fetchBatch | JASPER_FETCH_BATCH | Batch size for fetching plugins, templates, and origins. | 50 | 
| token | JASPER_TOKEN | Set client bearer token. | |
| prefetch | JASPER_PREFETCH | Prefetch proxied urls. Needed when not using cookies as image requests will not be authenticated. | false | 
| BASE_HREF | Set the base href for the SPA. | /j/ | |
| JASPER_LOCALE | One of 'en', or 'ja'. Default is 'en'. | ja' | |
| CSP_DEFAULT_SRC | Additional URLS to add to the default content security policy. | https://accounts.google.com https://www.googleapis.com | |
| CSP_SCRIPT_SRC | Additional URLS to add to the script-src content security policy. | ||
| CSP_STYLE_SRC | Additional URLS to add to the style-src content security policy. | ||
| CSP_CONNECT_SRC | Additional URLS to add to the connect-src content security policy. | ||
| CSP_FONT_SRC | Additional URLS to add to the font-src content security policy. | 
This project was generated with Angular CLI version 13.3.0.
Run ng serve for a dev server. Navigate to http://localhost:4200/. The
application will automatically reload if you change any of the source files.
Run ng generate component component-name to generate a new component.
You can also use
ng generate directive|pipe|service|class|guard|interface|enum|module.
To update the localization file after new text is added run
ng extract-i18n --output-path src/locale.
Run
xmlstarlet ed -N x="urn:oasis:names:tc:xliff:document:1.2" -d "//x:context-group" src/locale/messages.xlf > src/locale/messages.<locale here>.xlf
to generate a new translation file. Then add it to the locales array in angular.json.
Run ng build to build the project. The build artifacts will be stored in the
dist/ directory.
Run ng test to execute the unit tests via Karma.
Run ng e2e to execute the end-to-end tests via a platform of your choice. To
use this command, you need to first add a package that implements end-to-end
testing capabilities.
To get more help on the Angular CLI use ng help or go check out the
Angular CLI Overview and Command Reference page.