University of Minnesota's webpack-based toolkit for building Primo VE customization packages.
When planning our migration from Primo to Primo VE, we discovered that VE does not support central packages in single-institution, multi-campus Alma environments. To work around this limitation, we are using a custom build tool for our Primo customization packages.
- Make sure Node.js version 18+ is installed.
- Clone this repository.
- From the project's root directory, run npm install.
Run npm start to launch a development proxy server and preview the customization packages in the UMN Libraries production server. To preview a view, go to http://localhost:8080/discovery/search?vid={view_code} (e.g. http://localhost:8080/discovery/search?vid=01UMN_INST:TWINCITIES). If you need to modify the email template, you can preview an example at http://localhost:8080/discovery/email-template?lang=en&vid={view_code}&dirName.
Set the PROXY_TARGET environment variable to preview the customizations in a different Primo environment (e.g. PROXY_TARGET=https://umn.primo.exlibrisgroup.com npm start).
The color theme is generated with the primo-color-theme tool. To modify the color theme, edit src/shared/color-theme/colors.json and then run npm run color-theme. This will rebuild the src/shared/color-theme/generated-theme.css file. It's a good practice to regenerate the color theme whenever Primo VE is upgraded.
Note: The color variables defined in src/shared/color-theme/colors.js are available globally in any sass/scss file.
Run npm run build to create production-ready deployment packages. A zip file for each view will be created under dist/packages/. To deploy a package, upload its zip file in the Manage Customization Package tab in Alma (under Discovery > Manage Views > {view_code}).
This project uses Babel to compile TypeScript. Babel is a fast compiler, but it doesn't perform type checking. Run npm test:types to perform type checking on all TypeScript files using the standard tcs compiler.
Run npm run test:unit to execute the unit tests using headless Karma. The Karma configuration file is karma.config.cjs.
You could also use npm test to run type checking and unit tests in one step.
Per angular convention, unit tests (spec files) are located in the same directory as the implementation. For instance:
src/
  ...
    foo/
      foo.component.ts
      foo.component.spec.ts
Note: we're now using Cypress instead of Protractor for end-to-end tests.
Run npm run test:e2e to launch the local dev server and execute the end-to-end tests. The Cypress configuration and test files are in the cypress/ directory.
If you care to use the Cypress GUI, you can launch it with npm cy:open.
The files under src/shared/ are intended to be shared across all views. Any view-specific customizations belong under src/views/. As much as possible the src/shared/components are structured to match the Primo component tree.
src
├── @types
├── shared
│  ├── color-theme
│  ├── components
│  ├── filters
│  ├── html
│  ├── img
│  └── services
└── views
    ├── 01UMN_INST-CROOKSTON
    │  ├── html
    │  └── img
    ├── 01UMN_INST-DULUTH
    │  ├── components
    │  ├── html
    │  └── img
    ├── 01UMN_INST-MORRIS
    │  ├── components
    │  ├── html
    │  └── img
    └── 01UMN_INST-TWINCITIES
       ├── components
       ├── html
       └── img
At build time, a Primo customization package is created for each view. Each view's TypeScript/JavaScript files are bundled into a single js/custom.js file, and each view's SCSS/CSS files are bundled into a single css/custom1.css file. All assets from the following directories are copied to the package as-is:
- src/shared/html/
- src/shared/img/
- src/views/*/html/
- src/views/*/img/
Build output:
dist
├── 01UMN_INST-CROOKSTON
│  ├── css
│  ├── html
│  ├── img
│  └── js
├── 01UMN_INST-DULUTH
│  ├── css
│  ├── html
│  ├── img
│  └── js
├── 01UMN_INST-MORRIS
│  ├── css
│  ├── html
│  ├── img
│  └── js
├── 01UMN_INST-TWINCITIES
│  ├── css
│  ├── html
│  ├── img
│  └── js
└── packages
   ├── 01UMN_INST-CROOKSTON.zip
   ├── 01UMN_INST-DULUTH.zip
   ├── 01UMN_INST-MORRIS.zip
   └── 01UMN_INST-TWINCITIES.zip
This project uses Browserslist to target JavaScript and CSS compatibility. This helps to reduce bundle bloat by omitting polyfills for unsupported browsers such as Internet Explorer 11. The targeted browsers are defined in .browserslistrc.