A simple to use popup for collecting feedback from users about issues with the site that they are using. Currently it captures a screenshot of the page the user is browsing, the users OS and browser name + versions and also a personal message from the user. It then sends all data to an API.
More features to come!
To use the popup in your project run
yarn add feedback-popup
Import the popup into your project, create a new instance of it and then call the WidgetButton method on it.
import FeedbackPopup from 'feedback-popup';
var newFeedbackPopup = new FeedbackPopup(widgetTitle, title, snapshotBody, placeholderText, emailEndpoint);
newFeedbackPopup.buttonWidget();
"Widget button title", "Header welcome message", "div-id-to-screenshot", "Text area placeholder text", "API URL"
Also make sure to add the html below to the component or page that you want the popup to appear on
<div class="feedback-popup js-feedback-popup" data-html2canvas-ignore="true">
<div class="js-feedback-popup-btn-show"></div>
<div class="js-feedback-popup-content"></div>
<div class="js-feedback-popup-confirmation"></div>
</div>
If you want to use the styles included with this project be sure to import the main.scss file into your main stylesheet.
The popup now sends an object using axios to the URL of you chosen API. The object sent includes the below keys:
userPlatform
userFeedback
screenshotIncluded
userScreenshot
There are various ways that this plugin can be updated both in the code and in the UX. Some of my ideas are listed below. If you have requests then please repost an issue and I'll see what I can do
- Typescript
- Testing
- Update Gulp to version 4
- Choice to use server or personal email endpoint
Clone this project to get involved
[email protected]:TommyScribble/feedback-popup.git
Node.js =10.22.0 must be installed as this is currently using Gulp v3 for dev
- Running
yarn
in the app's root directory will install everything you need for development. - Rename indexOLD.js to index.js.
- In src/index.js comment the code for the axios call & switch the
exports.module
to anexport default
by switching the comments at the bottom of the file
yarn start
will run the app's development server at http://localhost:3000, automatically reloading the page on every JS change.yarn gulp
will proxy the server to http://localhost:3001, compile the SCSS and automatically reload the page on every SCSS change
-
node_modules/babel-cli/bin/babel.js src --out-dir lib
will transpile the js to es5 in the /lib folder. Then copy the styles folder into the /lib folderTo create a development build, set the
NODE_ENV
environment variable todevelopment
while running this command. -
yarn run clean
will delete built resources.