Starter Kit used to generate a Bullhorn Extension configuration
- Fork this repository
- Run
npm install
once - Update
repository
property inextension.json
andname
property inpackage.json
- Replace the files inside
src
with your own- Field Interactions should live in
src/field-interactions/{entity-name}/{field-name}/*
- e.g.
src/field-interactions/candidate/custom-text-1/my-interactions.ts
- e.g.
- Page Interactions should live in
src/page-interactions/record/{page-interaction-type}/*
- e.g.
src/page-interactions/add-edit-presave/my-interaction.ts
- e.g.
- You can check the
/extension.json
file to confirm the specific directories/patterns used to retrieve files
- Field Interactions should live in
- Populate your environment files
- You can add arbitrary application parameters to these files, which will be injected into all extracted interactions
- e.g.
"admin.usertype.id": "12,13,14"
will replace any occurences of${admin.usertype.id}
with12,13,14
- Because of string interpolation in ES6, be sure to only use single quotes when injecting variables...
'
, not`
- e.g.
- By default there is one environment file for prod and one for staging, with corresponding npm jobs
- The
deploy
job usesenvironment.prod.json
,deploy:staging
usesenvironment.staging.json
- More environments can be added by adding new environment files and new npm jobs in
package.json
. Copy an existing npm job and change the final parameter to the name of your environment - e.g. making a job
will expect a file
"deploy:qa": "node bin/build-and-upload.js qa"
environment.qa.json
to exist in theenvironments
folder
- The
- Configure your users that will be used to deploy your interactions
- you can provide an array of
users
- each user object should have a
username
,password
, andprivateLabelId
parameter - Running the corresponding job deploys all Field and Page Interactions to every users' Private Label in the file
- In order to handle uniqueness within the Bullhorn database, the script will
- Only deploy Page Interactions for the first user in the array
- Change the name of the extension being deployed to include the privateLabelId
- e.g. this file will deploy all interactions for both Private Labels 22 and 33. If the
extension.json
name
parameter has a value ofmyclient-interactions
, Private Label 22 will get an extension with namemyclient-22-interactions
, etc.{ "users": [ { "username": "my.username.1", "password": "myPassword123", "privateLabelId": "22" }, { "username": "my.username.2", "password": "myPassword123", "privateLabelId": "33" } ] }
- each user object should have a
- you can provide an array of
- You can add arbitrary application parameters to these files, which will be injected into all extracted interactions
- In case you want eslint rules to fix a specific file for you then run
eslint --fix ${relative_path}
.
- e.g.
eslint --fix src/field-interactions/candidate/custom-text-1/my-interactions.ts