Dashboard.js 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. const Uppy = require('@uppy/core/src')
  2. const Dashboard = require('@uppy/dashboard/src')
  3. const Instagram = require('@uppy/instagram/src')
  4. const Dropbox = require('@uppy/dropbox/src')
  5. const GoogleDrive = require('@uppy/google-drive/src')
  6. const Url = require('@uppy/url/src')
  7. const Webcam = require('@uppy/webcam/src')
  8. const Tus = require('@uppy/tus/src')
  9. // const XHRUpload = require('@uppy/xhr-upload/src')
  10. const Form = require('@uppy/form/src')
  11. const TUS_ENDPOINT = 'https://master.tus.io/files/'
  12. // const XHR_ENDPOINT = 'https://api2.transloadit.com'
  13. module.exports = () => {
  14. const uppyDashboard = Uppy({
  15. debug: true,
  16. meta: {
  17. username: 'John',
  18. license: 'Creative Commons'
  19. }
  20. })
  21. .use(Dashboard, {
  22. trigger: '#pick-files',
  23. // inline: true,
  24. target: '.foo',
  25. metaFields: [
  26. { id: 'license', name: 'License', placeholder: 'specify license' },
  27. { id: 'caption', name: 'Caption', placeholder: 'add caption' }
  28. ],
  29. showProgressDetails: true,
  30. proudlyDisplayPoweredByUppy: true,
  31. note: '2 files, images and video only'
  32. })
  33. .use(GoogleDrive, { target: Dashboard, companionUrl: 'http://localhost:3020' })
  34. .use(Instagram, { target: Dashboard, companionUrl: 'http://localhost:3020' })
  35. .use(Dropbox, { target: Dashboard, companionUrl: 'http://localhost:3020' })
  36. .use(Url, { target: Dashboard, companionUrl: 'http://localhost:3020' })
  37. .use(Webcam, { target: Dashboard })
  38. .use(Tus, { endpoint: TUS_ENDPOINT })
  39. // .use(XHRUpload, { endpoint: XHR_ENDPOINT })
  40. .use(Form, { target: '#upload-form' })
  41. // .use(GoldenRetriever, {serviceWorker: true})
  42. uppyDashboard.on('complete', (result) => {
  43. if (result.failed.length === 0) {
  44. console.log('Upload successful 😀')
  45. } else {
  46. console.warn('Upload failed 😞')
  47. }
  48. console.log('successful files:', result.successful)
  49. console.log('failed files:', result.failed)
  50. })
  51. const modalTrigger = document.querySelector('#pick-files')
  52. if (modalTrigger) modalTrigger.click()
  53. /* eslint-disable compat/compat */
  54. if ('serviceWorker' in navigator) {
  55. navigator.serviceWorker
  56. .register('/sw.js')
  57. .then((registration) => {
  58. console.log('ServiceWorker registration successful with scope: ', registration.scope)
  59. })
  60. .catch((error) => {
  61. console.log('Registration failed with ' + error)
  62. })
  63. }
  64. /* eslint-enable */
  65. }