React component for viewing different types of files (HTML, media, documents, etc.).
Install NPM dependencies:
npm install
Additionally, to get the fallback (non-native) PDF renderer working, you will need to reference some dependencies from the CDN. These must be referenced before referencing the css and js files containing the code for this component.
If switching to a newer version of pdf.js, pdf.settings.js may need to be updated.
<link rel="stylesheet" href="https://s.brightspace.com/lib/pdf.js/1.2.109/pdf_viewer.css">
<link rel="stylesheet" type="text/css" href="dist/app.css">
<script src="https://s.brightspace.com/lib/pdf.js/1.2.109/pdf.settings.js"></script>
<script src="https://s.brightspace.com/lib/pdf.js/1.2.109/compatibility.js"></script>
<script src="https://s.brightspace.com/lib/pdf.js/1.2.109/pdf.js"></script>
<script src="https://s.brightspace.com/lib/pdf.js/1.2.109/pdf_viewer.js"></script>
<script src="dist/app.js"></script>
If you want to incorporate this component and build it from source you will also need to use browserify-shim to configure the PDFJS global variable.
(in package.json)
"browserify": {
"transform": [
"browserify-shim"
]
},
"browserify-shim": {
"pdfjs": "global:PDFJS"
}
This project uses the Jest unit testing framework. To run the unit tests:
npm run test:unit
Code is also linted using eslint:
npm run lint
Both unit tests and linting is performed during CI builds as part of the test
script:
npm test
Included is a sample application which allows you to launch the file viewer with many different file types. To build the sample application, run:
npm run build-sample
To serve the sample application, run:
npm run serve
Then open http://localhost:8080/
in your browser.
FileViewer has the following parameters:
progressCallback
Takes a callback function, which should accept 2 parameters, the first reflecting the progress, and the second reflecting the accuracy of the progress value.
- progress: A number between 0 and 100 indicating the percentage loaded.
- accuracy: The accuracy of the returned progress value, currently we choose between two options:
certain
: indicates that progress will be a number between 0 and 100guess
: indicates that progress will be a number between 0 and 100, and that the progress may not be accuratenone
: indicates that it will only pass in progress values of 0 or 100
resizeCallback ( size, sizeKnown )
- A callback reporting on the size of the viewer's contents.
size
- A
string
value for the size of the viewer if we can find it out. null
if the viewer should just be sized to the container height.
sizeKnown
- True if the size is known.
- False if the size is not known.
$ # npm help 1 version
$ # npm help 7 semver
$ npm version [major|minor|patch|premajor|preminor|prepatch|prerelease] -m "chore(version) bump %s"
$ git push upstream master --tags
Contributions are welcome, please submit a pull request!
This repository is configured with EditorConfig and eslint rules and contributions should make use of them.