This app showcases the use of the Laserfiche UI Components library to build a single page application (SPA) that interacts with Laserfiche cloud repository using the REST Repository API.
This application uses the <lf-login>
UI component to initiate an OAuth2 flow to authenticate the user. SPA OAuth2 applications must first be registered in the Laserfiche account devconsole as SPA.
This particular application is built using React, but Laserfiche UI Components are framework-agnostic and support other frameworks such as Angular, Vue, and no-framework HTML5.
This project depends on the following libraries
- From NPM:
- From lfxstatic (via NPM)
We welcome contributions and feedback. Please follow our contributing guidelines.
- Visual Studio Code
- Node 16 (LTS)
- all other React pre-reqs are in the local package.json
- Clone the repo
- Create a new Single Page App in devconsole for USA, Canada, or Europe (depending on your region) and add the authentication redirect URI (e.g.: https://myapp.example.com/lf-sample-app/, http://localhost:3000). This redirect URI in the devconsole must match the REDIRECT_URI variable in
src/app/config.ts
, which must match the host address.- Select required scope(s) needed to read and write to the repository in the 'Authentication' tab ("repository.Read" and "repository.Write" ). Scopes are case-sensitive and space-delimited.
- Note that in order to access the devconsole, your user account must have been given Developer Console Administrator Access Rights by an Account Administrator. Otherwise you will see a message along the lines of "You do not have permission to view the developer console."
- Open folder (containing package.json) with Visual Studio Code
- In
src/config.ts
update the REDIRECT_URI and CLIENT_ID with the app client_id and redirect_uri as registered in step 1. You only need to update HOST_NAME if you are not using cloud production (laserfiche.com). - Update the REGIONAL_DOMAIN if you need are using a different environment (i.e. laserfiche.ca).
- In VS Code, open a New Terminal window.
- Run
npm install
in root folder. This command installs dependencies packages. - Run
npm start
in root folder. This runs the project on localhost. You can also younpm run build
depending on how you want to host the application. See below for details.
Run npm run build
to build the project. The build artifacts will be stored in the build/
directory.
- This application should be hosted in a web server or CDN so that can be reached at URL: https://myapp.example.com/lf-sample-app/ OR run using npm start on localhost
- IMPORTANT security considerations: this application should not share HTTP origin (domain or subdomain) with other untrusted web pages to avoid leaking sensitive information such as Access Tokens via local store.
- On a Windows machine you can use IIS Service Manager and create a new web application or virtual directory to publish the
build/
folder - It is recommended to configure IIS website to use HTTPS and disable HTTP
- Browse to https://myapp.example.com/lf-sample-app/ and sign-in
- Build warnings "Failed to parse source map from ...": See React discussion