A generic, reusable web component that can be added to any New Jersey page to get quick, in-page feedback from the user. This is inspired by the CA Design System's similar component. It is mobile-responsive, accessible (tested with axe tool), and supports English and Spanish language. See the Feedback API Github repository for the code that handles and saves this data.
-
Rating: At the bottom of a webpage, the widget asks user to rate their experience of the page with "Yes" and "No" buttons. Upon clicking an option, the rating is saved to a Google Sheet and Google Analytics (along with page URL, and submission datetime).
Note: See
only-save-rating-to-analytics
attribute below for customization. -
[OPTIONAL] Comment: Widget asks user to optionally share feedback in a free text field. Upon submitting, this text is recorded to Google Sheets.
Note: Users often have specific questions about their situation rather than feedback.
Note: See
contact-link
attribute below for customization. -
[OPTIONAL] Email: Widget asks user to optionally share their email to join a user testing group. Upon submitting, this email is recorded to Google Sheets.
User Submission Type | Required? | Saved to Google Analytics? | Saved to Google Sheets? |
---|---|---|---|
Rating | Yes | Yes | Yes, customizable |
Comment | No | No | Yes |
No | No | Yes |
The component supports both English and Spanish content and offers users the ability to toggle between the two. To switch the language used within the component, use JavaScript to send a custom event using the code below:
// sending a custom changeLanguage event in a click handler for a language toggle button
document.getElementById("languageButton").addEventListener("click", (e) => {
const customEvent = new CustomEvent("changeLanguage", {
detail: "es" /* "en" for English or "es" for Spanish */,
bubbles: true,
});
e.target.dispatchEvent(customEvent);
});
Attribute | Description | Possible values | Defaults to | Example | Recommendations |
---|---|---|---|---|---|
contact-link |
A string that can be used to set a custom URL that users are directed to if they have a specific question that they would like to have addressed. | Any URL | NJ Contact Us page URL | innovation homepage repo | N/A |
only-save-rating-to-analytics |
A boolean that can be used to save ratings without comments only to Google Analytics rather than saving to the Google Sheets database | "true" or "false" |
"false" |
UI Claim Status web app repo | Setting to "true" is recommended for high traffic pages |
show-comment-disclaimer |
A boolean that can be used to determine whether disclaimer text should be displayed in the feedback widget when users are prompted to submit a comment. This disclaimer will direct users to a separate contact form link if they have specific questions. | "true" or "false" |
"true" |
N/A | N/A |
skip-email-step |
A boolean that can be used to determine whether to prompt the user to enter their email to join a testing group after submitting a comment. | "true" or "false" |
"false" |
N/A | N/A |
- Install the latest version of the widget via the command
npm i @newjersey/feedback-widget --save
. - In the file where you would like to add a reference to the widget (likely
App.tsx
/App.jsx
in a Create React App project), import the Javascript file to be used:
import "@newjersey/feedback-widget/feedback-widget.min.js";
- If using TypeScript, add the following type definition to the same file you imported
declare global {
namespace JSX {
interface IntrinsicElements {
"feedback-widget": React.DetailedHTMLProps<
React.HTMLAttributes<HTMLElement>,
HTMLElement
>;
}
}
}
- Render the feedback widget by adding the following to your HTML/JSX
<feedback-widget
contact-link="https://www.example.com/contact"
></feedback-widget>
- Load the JS file from a CDN link by adding a script tag to your HTML. You can change the version number after the @ sign to match your desired release (https://github.com/newjersey/feedback-widget/releases).
<script
src="https://unpkg.com/@newjersey/[email protected]/feedback-widget.min.js"
defer
></script>
- Render the feedback widget by adding the following tag in your HTML (likely at the bottom of the page). It's just like using any other HTML tag.
<feedback-widget
contact-link="https://www.example.com/contact"
></feedback-widget>
Before pushing changes to feedback-widget.js
, make sure you update the minified file:
npm install uglify-js -g
(global install, not part of npm project)cd feedback-widget && nvm use 16
uglifyjs feedback-widget.js -c -o feedback-widget.min.js
- Go the the Draft Release action, click "Run workflow" (you need write permissions to do this). Choose the branch (
main
) and the semver level of the new version (patch, minor, major). - Confirm this worked by checking that
package.json
version has been bumped and a draft release for this version is available in the Releases page. - Click to Edit the new release, and update the description if needed. Click "Publish." This will trigger the publish-release Github Actions workflow.
- Once the workflow is completed, confirm that the package is updated on NPM registry.
Additional documentation related to using the feedback widget and data collected. Note that this documentation is restricted only to New Jersey Office of Innovation team members.