main.js 2.2 KB

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