index.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. const Uppy = require('@uppy/core')
  2. const Dashboard = require('@uppy/dashboard')
  3. const Instagram = require('@uppy/instagram')
  4. const GoogleDrive = require('@uppy/google-drive')
  5. const Url = require('@uppy/url')
  6. const Webcam = require('@uppy/webcam')
  7. const Tus = require('@uppy/tus')
  8. require('@uppy/core/dist/style.css')
  9. require('@uppy/dashboard/dist/style.css')
  10. require('@uppy/url/dist/style.css')
  11. require('@uppy/webcam/dist/style.css')
  12. const TUS_ENDPOINT = 'https://tusd.tusdemo.net/files/'
  13. const uppy = new Uppy({
  14. debug: true,
  15. meta: {
  16. username: 'John',
  17. license: 'Creative Commons',
  18. },
  19. })
  20. .use(Dashboard, {
  21. trigger: '#pick-files',
  22. target: '#upload-form',
  23. inline: true,
  24. replaceTargetContent: true,
  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. restrictions: { requiredMetaFields: ['caption'] },
  33. })
  34. .use(GoogleDrive, { target: Dashboard, companionUrl: 'http://localhost:3020' })
  35. .use(Instagram, { 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. // You can optinally enable the Golden Retriever plugin — it will
  40. // restore files after a browser crash / accidental closed window
  41. // see more at https://uppy.io/docs/golden-retriever/
  42. //
  43. // .use(GoldenRetriever, { serviceWorker: true })
  44. uppy.on('complete', (result) => {
  45. if (result.failed.length === 0) {
  46. console.log('Upload successful 😀')
  47. } else {
  48. console.warn('Upload failed 😞')
  49. }
  50. console.log('successful files:', result.successful)
  51. console.log('failed files:', result.failed)
  52. })
  53. // uncomment if you enable Golden Retriever
  54. //
  55. /* eslint-disable compat/compat */
  56. // if ('serviceWorker' in navigator) {
  57. // navigator.serviceWorker
  58. // .register('/sw.js')
  59. // .then((registration) => {
  60. // console.log('ServiceWorker registration successful with scope: ', registration.scope)
  61. // })
  62. // .catch((error) => {
  63. // console.log('Registration failed with ' + error)
  64. // })
  65. // }
  66. /* eslint-enable */