@instructure/canvas-rce 5.11.1 → 5.12.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (505) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/babel-register.js +0 -7
  3. package/babel.config.cjs.js +0 -7
  4. package/babel.config.js +0 -9
  5. package/es/canvasFileBrowser/FileBrowser.js +6 -1
  6. package/es/common/fileUrl.js +3 -4
  7. package/es/defaultTinymceConfig.js +1 -1
  8. package/{lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/Lti13ContentItemJson.js → es/elementDenylist.js} +2 -6
  9. package/es/enhance-user-content/doc_previews.js +4 -0
  10. package/es/enhance-user-content/enhance_user_content.js +4 -59
  11. package/es/enhance-user-content/external_links.js +75 -0
  12. package/es/enhance-user-content/mathml.js +9 -7
  13. package/es/getThemeVars.js +4 -3
  14. package/es/getTranslations.js +77 -1
  15. package/es/index.js +1 -1
  16. package/es/rce/RCEWrapper.js +5 -2328
  17. package/es/rce/StatusBar.js +8 -2
  18. package/es/rce/contentInsertion.js +5 -2
  19. package/es/rce/plugins/instructure_documents/components/DocumentsPanel.js +3 -9
  20. package/es/rce/plugins/instructure_equation/EquationEditorModal/index.js +1 -1
  21. package/es/rce/plugins/instructure_equation/EquationEditorModal/styles.js +3 -11
  22. package/es/rce/plugins/instructure_equation/mathlive/index.js +5 -13
  23. package/es/rce/plugins/instructure_html_view/plugin.js +2 -2
  24. package/es/rce/plugins/instructure_icon_maker/components/SavedIconMakerList.js +3 -2
  25. package/es/rce/plugins/instructure_image/ImageList/Image.js +2 -2
  26. package/es/rce/plugins/instructure_image/Images/index.js +3 -10
  27. package/es/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialog.js +3 -0
  28. package/es/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/ResourceLinkContentItem.js +3 -1
  29. package/es/rce/plugins/instructure_record/AudioOptionsTray/TrayController.js +26 -1
  30. package/es/rce/plugins/instructure_record/AudioOptionsTray/index.js +9 -3
  31. package/es/rce/plugins/instructure_record/MediaPanel/index.js +3 -9
  32. package/es/rce/plugins/instructure_record/VideoOptionsTray/TrayController.js +27 -2
  33. package/es/rce/plugins/instructure_record/VideoOptionsTray/index.js +35 -6
  34. package/es/rce/plugins/shared/fileShape.js +81 -9
  35. package/es/rce/plugins/shared/fileTypeUtils.js +6 -0
  36. package/es/rce/tinymce.oxide.content.min.css.js +732 -0
  37. package/es/rce/tinymce.oxide.skin.min.css.js +7 -0
  38. package/es/rcs/api.js +6 -4
  39. package/es/sidebar/store/configureStore.js +2 -2
  40. package/{lib/translations/locales/tg.js → es/translations/locales/ab.js} +1 -1
  41. package/es/translations/locales/cs.js +27 -0
  42. package/es/translations/locales/cs_CZ.js +27 -0
  43. package/{lib/translations/locales/sv_SE.js → es/translations/locales/da_DK.js} +2 -2
  44. package/{lib/translations/locales/se.js → es/translations/locales/en_NZ.js} +2 -2
  45. package/es/translations/locales/en_SE.js +26 -0
  46. package/es/translations/locales/en_US.js +26 -0
  47. package/es/translations/locales/hu_HU.js +27 -0
  48. package/{lib/translations/locales/ms.js → es/translations/locales/id.js} +632 -632
  49. package/{lib/translations/locales/th.js → es/translations/locales/id_ID.js} +1 -2
  50. package/{lib/translations/locales/vi_VN.js → es/translations/locales/ko_KR.js} +2 -2
  51. package/es/translations/locales/lt.js +26 -0
  52. package/es/translations/locales/lt_LT.js +26 -0
  53. package/es/translations/locales/mn_MN.js +26 -0
  54. package/es/translations/locales/nl_NL.js +27 -0
  55. package/{lib/translations/locales/es_GT.js → es/translations/locales/ro.js} +3 -3
  56. package/es/translations/locales/ru.js +2375 -32
  57. package/es/translations/locales/sv.js +2379 -30
  58. package/es/translations/locales/th.js +2401 -1
  59. package/es/translations/locales/tl_PH.js +26 -0
  60. package/es/translations/locales/tr.js +3 -0
  61. package/es/translations/locales/vi.js +2396 -8
  62. package/es/translations/locales/zh_TW.Big5.js +27 -0
  63. package/{lib/translations/locales/th_TH.js → es/translations/locales/zh_TW.js} +2 -2
  64. package/jest.config.js +0 -7
  65. package/package.json +9 -11
  66. package/scripts/build.js +1 -7
  67. package/scripts/publish_to_npm.sh +26 -0
  68. package/canvas/README.md +0 -84
  69. package/canvas/locales/en.json +0 -934
  70. package/canvas/package.json +0 -189
  71. package/es/common/scroll.js +0 -45
  72. package/es/types/inst-ui.d.js +0 -18
  73. package/es/types/ts-migration.js +0 -1
  74. package/lib/bridge/Bridge.js +0 -287
  75. package/lib/bridge/index.js +0 -21
  76. package/lib/canvasFileBrowser/FileBrowser.js +0 -452
  77. package/lib/canvasFileBrowser/en-US.js +0 -234
  78. package/lib/common/FlashAlert.js +0 -263
  79. package/lib/common/browser.js +0 -40
  80. package/lib/common/components/FileTree/File.js +0 -64
  81. package/lib/common/components/FileTree/Folder.js +0 -110
  82. package/lib/common/components/FileTree/index.js +0 -84
  83. package/lib/common/components/FileTree/styles.js +0 -72
  84. package/lib/common/components/Loading.js +0 -83
  85. package/lib/common/fileUrl.js +0 -153
  86. package/lib/common/getCookie.js +0 -32
  87. package/lib/common/incremental-loading/LoadMoreButton.js +0 -40
  88. package/lib/common/incremental-loading/LoadingIndicator.js +0 -36
  89. package/lib/common/incremental-loading/LoadingStatus.js +0 -47
  90. package/lib/common/incremental-loading/index.js +0 -21
  91. package/lib/common/incremental-loading/useIncrementalLoading.js +0 -58
  92. package/lib/common/indicate.js +0 -75
  93. package/lib/common/mimeClass.js +0 -120
  94. package/lib/common/natcompare.js +0 -47
  95. package/lib/common/scroll.js +0 -45
  96. package/lib/defaultTinymceConfig.js +0 -160
  97. package/lib/enhance-user-content/doc_previews.js +0 -233
  98. package/lib/enhance-user-content/enhance_user_content.js +0 -396
  99. package/lib/enhance-user-content/index.js +0 -21
  100. package/lib/enhance-user-content/instructure_helper.js +0 -207
  101. package/lib/enhance-user-content/jqueryish_funcs.js +0 -88
  102. package/lib/enhance-user-content/mathml.js +0 -397
  103. package/lib/enhance-user-content/media_comment_thumbnail.js +0 -130
  104. package/lib/format-message.js +0 -30
  105. package/lib/getThemeVars.js +0 -45
  106. package/lib/getTranslations.js +0 -264
  107. package/lib/index.js +0 -51
  108. package/lib/rce/AlertMessageArea.js +0 -47
  109. package/lib/rce/DraggingBlocker.js +0 -43
  110. package/lib/rce/KeyboardShortcutModal.js +0 -88
  111. package/lib/rce/RCE.js +0 -150
  112. package/lib/rce/RCEGlobals.js +0 -62
  113. package/lib/rce/RCEWrapper.js +0 -4278
  114. package/lib/rce/RCEWrapperProps.js +0 -130
  115. package/lib/rce/RceHtmlEditor.js +0 -142
  116. package/lib/rce/ResizeHandle.js +0 -102
  117. package/lib/rce/RestoreAutoSaveModal.js +0 -82
  118. package/lib/rce/ShowOnFocusButton/index.js +0 -93
  119. package/lib/rce/StatusBar.js +0 -380
  120. package/lib/rce/__mocks__/_mockCryptoEs.js +0 -124
  121. package/lib/rce/__mocks__/styleMock.js +0 -18
  122. package/lib/rce/__mocks__/tinymceReact.js +0 -55
  123. package/lib/rce/alertHandler.js +0 -46
  124. package/lib/rce/contentInsertion.js +0 -322
  125. package/lib/rce/contentInsertionUtils.js +0 -85
  126. package/lib/rce/contentRendering.js +0 -145
  127. package/lib/rce/customEvents.js +0 -18
  128. package/lib/rce/editorLanguage.js +0 -101
  129. package/lib/rce/indicatorRegion.js +0 -49
  130. package/lib/rce/normalizeLocale.js +0 -50
  131. package/lib/rce/normalizeProps.js +0 -29
  132. package/lib/rce/plugins/instructure-ui-icons/plugin.js +0 -122
  133. package/lib/rce/plugins/instructure_condensed_buttons/core/ListUtils.js +0 -24
  134. package/lib/rce/plugins/instructure_condensed_buttons/plugin.js +0 -27
  135. package/lib/rce/plugins/instructure_condensed_buttons/ui/alignment-button.js +0 -63
  136. package/lib/rce/plugins/instructure_condensed_buttons/ui/directionality-button.js +0 -48
  137. package/lib/rce/plugins/instructure_condensed_buttons/ui/indent-outdent-button.js +0 -41
  138. package/lib/rce/plugins/instructure_condensed_buttons/ui/list-button.js +0 -145
  139. package/lib/rce/plugins/instructure_condensed_buttons/ui/subscript-superscript-button.js +0 -56
  140. package/lib/rce/plugins/instructure_documents/clickCallback.js +0 -23
  141. package/lib/rce/plugins/instructure_documents/components/DocumentsPanel.js +0 -126
  142. package/lib/rce/plugins/instructure_documents/components/Link.js +0 -219
  143. package/lib/rce/plugins/instructure_documents/plugin.js +0 -123
  144. package/lib/rce/plugins/instructure_equation/EquationEditorModal/advancedOnlySyntax.js +0 -25
  145. package/lib/rce/plugins/instructure_equation/EquationEditorModal/advancedPreference.js +0 -51
  146. package/lib/rce/plugins/instructure_equation/EquationEditorModal/index.js +0 -321
  147. package/lib/rce/plugins/instructure_equation/EquationEditorModal/latexTextareaUtil.js +0 -116
  148. package/lib/rce/plugins/instructure_equation/EquationEditorModal/parseLatex.js +0 -91
  149. package/lib/rce/plugins/instructure_equation/EquationEditorModal/styles.js +0 -46
  150. package/lib/rce/plugins/instructure_equation/EquationEditorToolbar/buttons.js +0 -728
  151. package/lib/rce/plugins/instructure_equation/EquationEditorToolbar/index.js +0 -84
  152. package/lib/rce/plugins/instructure_equation/MathIcon/index.js +0 -41
  153. package/lib/rce/plugins/instructure_equation/MathIcon/svgs.js +0 -236
  154. package/lib/rce/plugins/instructure_equation/clickCallback.js +0 -53
  155. package/lib/rce/plugins/instructure_equation/mathlive/index.js +0 -36
  156. package/lib/rce/plugins/instructure_equation/plugin.js +0 -69
  157. package/lib/rce/plugins/instructure_fullscreen/plugin.js +0 -50
  158. package/lib/rce/plugins/instructure_html_view/clickCallback.js +0 -21
  159. package/lib/rce/plugins/instructure_html_view/plugin.js +0 -37
  160. package/lib/rce/plugins/instructure_icon_maker/clickCallback.js +0 -57
  161. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ColorSection.js +0 -82
  162. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/CreateIconMakerForm.js +0 -56
  163. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Footer.js +0 -78
  164. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Group.js +0 -36
  165. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Header.js +0 -110
  166. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/Course.js +0 -169
  167. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/ImageOptions.js +0 -186
  168. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/ImageSection.js +0 -243
  169. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/ModeSelect.js +0 -64
  170. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/MultiColor/index.js +0 -73
  171. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/MultiColor/svg.js +0 -298
  172. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SVGList.js +0 -86
  173. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SVGThumbnail.js +0 -55
  174. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SingleColor/index.js +0 -70
  175. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SingleColor/svg.js +0 -317
  176. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/Upload.js +0 -149
  177. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/index.js +0 -18
  178. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/propTypes.js +0 -32
  179. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/utils.js +0 -25
  180. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Preview.js +0 -60
  181. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ShapeSection.js +0 -87
  182. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/TextSection.js +0 -139
  183. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/index.js +0 -18
  184. package/lib/rce/plugins/instructure_icon_maker/components/IconMakerTray.js +0 -323
  185. package/lib/rce/plugins/instructure_icon_maker/components/SavedIconMakerList.js +0 -90
  186. package/lib/rce/plugins/instructure_icon_maker/plugin.js +0 -110
  187. package/lib/rce/plugins/instructure_icon_maker/reducers/imageSection.js +0 -194
  188. package/lib/rce/plugins/instructure_icon_maker/reducers/svgSettings.js +0 -98
  189. package/lib/rce/plugins/instructure_icon_maker/registerEditToolbar.js +0 -56
  190. package/lib/rce/plugins/instructure_icon_maker/svg/clipPath.js +0 -25
  191. package/lib/rce/plugins/instructure_icon_maker/svg/constants.js +0 -100
  192. package/lib/rce/plugins/instructure_icon_maker/svg/font.js +0 -25
  193. package/lib/rce/plugins/instructure_icon_maker/svg/image.js +0 -354
  194. package/lib/rce/plugins/instructure_icon_maker/svg/index.js +0 -122
  195. package/lib/rce/plugins/instructure_icon_maker/svg/metadata.js +0 -48
  196. package/lib/rce/plugins/instructure_icon_maker/svg/settings.js +0 -179
  197. package/lib/rce/plugins/instructure_icon_maker/svg/shape.js +0 -316
  198. package/lib/rce/plugins/instructure_icon_maker/svg/text.js +0 -468
  199. package/lib/rce/plugins/instructure_icon_maker/svg/utils.js +0 -70
  200. package/lib/rce/plugins/instructure_icon_maker/utils/IconMakerClose.js +0 -45
  201. package/lib/rce/plugins/instructure_icon_maker/utils/IconMakerFormHasChanges.js +0 -83
  202. package/lib/rce/plugins/instructure_icon_maker/utils/addIconMakerAttributes.js +0 -28
  203. package/lib/rce/plugins/instructure_icon_maker/utils/iconValidation.js +0 -35
  204. package/lib/rce/plugins/instructure_icon_maker/utils/iconsLabels.js +0 -375
  205. package/lib/rce/plugins/instructure_icon_maker/utils/useDebouncedValue.js +0 -59
  206. package/lib/rce/plugins/instructure_image/ImageEmbedOptions.js +0 -202
  207. package/lib/rce/plugins/instructure_image/ImageList/Image.js +0 -106
  208. package/lib/rce/plugins/instructure_image/ImageList/index.js +0 -69
  209. package/lib/rce/plugins/instructure_image/ImageOptionsTray/TrayController.js +0 -166
  210. package/lib/rce/plugins/instructure_image/ImageOptionsTray/index.js +0 -246
  211. package/lib/rce/plugins/instructure_image/Images/index.js +0 -129
  212. package/lib/rce/plugins/instructure_image/clickCallback.js +0 -24
  213. package/lib/rce/plugins/instructure_image/plugin.js +0 -157
  214. package/lib/rce/plugins/instructure_links/clickCallback.js +0 -22
  215. package/lib/rce/plugins/instructure_links/components/AccordionSection.js +0 -60
  216. package/lib/rce/plugins/instructure_links/components/CollectionPanel.js +0 -84
  217. package/lib/rce/plugins/instructure_links/components/Link.js +0 -213
  218. package/lib/rce/plugins/instructure_links/components/LinkOptionsDialog/LinkOptionsDialogController.js +0 -127
  219. package/lib/rce/plugins/instructure_links/components/LinkOptionsDialog/index.js +0 -141
  220. package/lib/rce/plugins/instructure_links/components/LinkOptionsTray/LinkOptionsTrayController.js +0 -125
  221. package/lib/rce/plugins/instructure_links/components/LinkOptionsTray/index.js +0 -245
  222. package/lib/rce/plugins/instructure_links/components/LinkSet.js +0 -195
  223. package/lib/rce/plugins/instructure_links/components/LinksPanel.js +0 -100
  224. package/lib/rce/plugins/instructure_links/components/NavigationPanel.js +0 -141
  225. package/lib/rce/plugins/instructure_links/components/NoResults.js +0 -87
  226. package/lib/rce/plugins/instructure_links/components/propTypes.js +0 -41
  227. package/lib/rce/plugins/instructure_links/plugin.js +0 -294
  228. package/lib/rce/plugins/instructure_links/validateURL.js +0 -70
  229. package/lib/rce/plugins/instructure_media_embed/clickCallback.js +0 -48
  230. package/lib/rce/plugins/instructure_media_embed/components/Embed.js +0 -68
  231. package/lib/rce/plugins/instructure_media_embed/plugin.js +0 -36
  232. package/lib/rce/plugins/instructure_paste/pasteMenuCommand.js +0 -117
  233. package/lib/rce/plugins/instructure_paste/plugin.js +0 -174
  234. package/lib/rce/plugins/instructure_rce_external_tools/ExternalToolsEnv.js +0 -169
  235. package/lib/rce/plugins/instructure_rce_external_tools/RceToolWrapper.js +0 -225
  236. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialog.js +0 -294
  237. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialogModal.js +0 -46
  238. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialogTray.js +0 -79
  239. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolSelectionDialog/ExternalToolSelectionDialog.js +0 -153
  240. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolSelectionDialog/ExternalToolSelectionItem.js +0 -94
  241. package/lib/rce/plugins/instructure_rce_external_tools/components/util/ExpandoText.js +0 -90
  242. package/lib/rce/plugins/instructure_rce_external_tools/components/util/ToolLaunchIframe.js +0 -35
  243. package/lib/rce/plugins/instructure_rce_external_tools/dialog-helper.js +0 -29
  244. package/lib/rce/plugins/instructure_rce_external_tools/helpers/tags.js +0 -55
  245. package/lib/rce/plugins/instructure_rce_external_tools/jquery/jquery.dropdownList.js +0 -172
  246. package/lib/rce/plugins/instructure_rce_external_tools/lti11-content-items/RceLti11ContentItem.js +0 -203
  247. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/RceLti13ContentItem.js +0 -111
  248. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/BaseLinkContentItem.js +0 -79
  249. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/HtmlFragmentContentItem.js +0 -47
  250. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/ImageContentItem.js +0 -57
  251. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/LinkContentItem.js +0 -26
  252. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/ResourceLinkContentItem.js +0 -45
  253. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/processEditorContentItems.js +0 -67
  254. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/rceLti13ContentItemFromJson.js +0 -48
  255. package/lib/rce/plugins/instructure_rce_external_tools/plugin.js +0 -112
  256. package/lib/rce/plugins/instructure_rce_external_tools/util/addParentFrameContextToUrl.js +0 -27
  257. package/lib/rce/plugins/instructure_record/AudioOptionsTray/TrayController.js +0 -127
  258. package/lib/rce/plugins/instructure_record/AudioOptionsTray/index.js +0 -148
  259. package/lib/rce/plugins/instructure_record/MediaPanel/index.js +0 -129
  260. package/lib/rce/plugins/instructure_record/VideoOptionsTray/TrayController.js +0 -215
  261. package/lib/rce/plugins/instructure_record/VideoOptionsTray/index.js +0 -321
  262. package/lib/rce/plugins/instructure_record/clickCallback.js +0 -105
  263. package/lib/rce/plugins/instructure_record/mediaTranslations.js +0 -94
  264. package/lib/rce/plugins/instructure_record/plugin.js +0 -173
  265. package/lib/rce/plugins/instructure_studio_media_options/plugin.js +0 -42
  266. package/lib/rce/plugins/instructure_wordcount/clickCallback.js +0 -49
  267. package/lib/rce/plugins/instructure_wordcount/components/WordCountModal.js +0 -88
  268. package/lib/rce/plugins/instructure_wordcount/plugin.js +0 -30
  269. package/lib/rce/plugins/instructure_wordcount/utils/countContent.js +0 -78
  270. package/lib/rce/plugins/instructure_wordcount/utils/tableContent.js +0 -40
  271. package/lib/rce/plugins/shared/CanvasContentTray.js +0 -580
  272. package/lib/rce/plugins/shared/CheckerboardStyling.js +0 -25
  273. package/lib/rce/plugins/shared/ColorInput.js +0 -233
  274. package/lib/rce/plugins/shared/ConditionalTooltip.js +0 -32
  275. package/lib/rce/plugins/shared/ContentSelection.js +0 -269
  276. package/lib/rce/plugins/shared/DimensionUtils.js +0 -66
  277. package/lib/rce/plugins/shared/DimensionsInput/DimensionInput.js +0 -62
  278. package/lib/rce/plugins/shared/DimensionsInput/index.js +0 -161
  279. package/lib/rce/plugins/shared/DimensionsInput/useDimensionsState.js +0 -220
  280. package/lib/rce/plugins/shared/ErrorBoundary.js +0 -54
  281. package/lib/rce/plugins/shared/EventUtils.js +0 -39
  282. package/lib/rce/plugins/shared/Filter.js +0 -353
  283. package/lib/rce/plugins/shared/FixedContentTray.js +0 -115
  284. package/lib/rce/plugins/shared/ImageCropper/DirectionRegion.js +0 -67
  285. package/lib/rce/plugins/shared/ImageCropper/Modal.js +0 -153
  286. package/lib/rce/plugins/shared/ImageCropper/Preview.js +0 -148
  287. package/lib/rce/plugins/shared/ImageCropper/constants.js +0 -39
  288. package/lib/rce/plugins/shared/ImageCropper/controls/CustomNumberInput.js +0 -83
  289. package/lib/rce/plugins/shared/ImageCropper/controls/ResetControls.js +0 -38
  290. package/lib/rce/plugins/shared/ImageCropper/controls/RotationControls.js +0 -89
  291. package/lib/rce/plugins/shared/ImageCropper/controls/ShapeControls.js +0 -82
  292. package/lib/rce/plugins/shared/ImageCropper/controls/ZoomControls.js +0 -111
  293. package/lib/rce/plugins/shared/ImageCropper/controls/index.js +0 -61
  294. package/lib/rce/plugins/shared/ImageCropper/controls/useDebouncedNumericValue.js +0 -94
  295. package/lib/rce/plugins/shared/ImageCropper/controls/utils.js +0 -41
  296. package/lib/rce/plugins/shared/ImageCropper/imageCropUtils.js +0 -149
  297. package/lib/rce/plugins/shared/ImageCropper/index.js +0 -18
  298. package/lib/rce/plugins/shared/ImageCropper/propTypes.js +0 -26
  299. package/lib/rce/plugins/shared/ImageCropper/reducers/imageCropper.js +0 -72
  300. package/lib/rce/plugins/shared/ImageCropper/shape.js +0 -27
  301. package/lib/rce/plugins/shared/ImageCropper/svg/index.js +0 -89
  302. package/lib/rce/plugins/shared/ImageCropper/svg/shape.js +0 -125
  303. package/lib/rce/plugins/shared/ImageCropper/svg/utils.js +0 -26
  304. package/lib/rce/plugins/shared/ImageCropper/useKeyMouseEvents.js +0 -233
  305. package/lib/rce/plugins/shared/ImageCropper/useMouseWheel.js +0 -66
  306. package/lib/rce/plugins/shared/ImageOptionsForm.js +0 -140
  307. package/lib/rce/plugins/shared/LinkDisplay.js +0 -96
  308. package/lib/rce/plugins/shared/PreviewIcon.js +0 -112
  309. package/lib/rce/plugins/shared/Previewable.js +0 -22
  310. package/lib/rce/plugins/shared/RceFileBrowser.js +0 -106
  311. package/lib/rce/plugins/shared/StoreContext.js +0 -57
  312. package/lib/rce/plugins/shared/StudioLtiSupportUtils.js +0 -71
  313. package/lib/rce/plugins/shared/UnknownFileTypePanel.js +0 -29
  314. package/lib/rce/plugins/shared/Upload/CategoryProcessor.js +0 -27
  315. package/lib/rce/plugins/shared/Upload/ComputerPanel.js +0 -334
  316. package/lib/rce/plugins/shared/Upload/SvgCategoryProcessor.js +0 -35
  317. package/lib/rce/plugins/shared/Upload/UploadFile.js +0 -171
  318. package/lib/rce/plugins/shared/Upload/UploadFileModal.js +0 -273
  319. package/lib/rce/plugins/shared/Upload/UrlPanel.js +0 -38
  320. package/lib/rce/plugins/shared/Upload/UsageRightsSelectBox.js +0 -172
  321. package/lib/rce/plugins/shared/Upload/doFileUpload.js +0 -77
  322. package/lib/rce/plugins/shared/__mocks__/screenfull.js +0 -24
  323. package/lib/rce/plugins/shared/buildDownloadUrl.js +0 -31
  324. package/lib/rce/plugins/shared/compressionUtils.js +0 -98
  325. package/lib/rce/plugins/shared/dateUtils.js +0 -28
  326. package/lib/rce/plugins/shared/fileShape.js +0 -57
  327. package/lib/rce/plugins/shared/fileTypeUtils.js +0 -133
  328. package/lib/rce/plugins/shared/fileUtils.js +0 -25
  329. package/lib/rce/plugins/shared/linkUtils.js +0 -89
  330. package/lib/rce/plugins/shared/round.js +0 -25
  331. package/lib/rce/plugins/shared/trayUtils.js +0 -34
  332. package/lib/rce/plugins/shared/useDataUrl.js +0 -76
  333. package/lib/rce/plugins/tinymce-a11y-checker/components/ColorField.js +0 -86
  334. package/lib/rce/plugins/tinymce-a11y-checker/components/checker.js +0 -558
  335. package/lib/rce/plugins/tinymce-a11y-checker/components/color-picker.js +0 -59
  336. package/lib/rce/plugins/tinymce-a11y-checker/components/placeholder-svg.js +0 -90
  337. package/lib/rce/plugins/tinymce-a11y-checker/components/pointer.js +0 -32
  338. package/lib/rce/plugins/tinymce-a11y-checker/node-checker.js +0 -54
  339. package/lib/rce/plugins/tinymce-a11y-checker/plugin.js +0 -90
  340. package/lib/rce/plugins/tinymce-a11y-checker/rules/__mocks__/index.js +0 -53
  341. package/lib/rce/plugins/tinymce-a11y-checker/rules/adjacent-links.js +0 -129
  342. package/lib/rce/plugins/tinymce-a11y-checker/rules/headings-sequence.js +0 -200
  343. package/lib/rce/plugins/tinymce-a11y-checker/rules/headings-start-at-h2.js +0 -67
  344. package/lib/rce/plugins/tinymce-a11y-checker/rules/img-alt-filename.js +0 -63
  345. package/lib/rce/plugins/tinymce-a11y-checker/rules/img-alt-length.js +0 -49
  346. package/lib/rce/plugins/tinymce-a11y-checker/rules/img-alt.js +0 -61
  347. package/lib/rce/plugins/tinymce-a11y-checker/rules/index.js +0 -31
  348. package/lib/rce/plugins/tinymce-a11y-checker/rules/large-text-contrast.js +0 -51
  349. package/lib/rce/plugins/tinymce-a11y-checker/rules/list-structure.js +0 -144
  350. package/lib/rce/plugins/tinymce-a11y-checker/rules/paragraphs-for-headings.js +0 -61
  351. package/lib/rce/plugins/tinymce-a11y-checker/rules/small-text-contrast.js +0 -75
  352. package/lib/rce/plugins/tinymce-a11y-checker/rules/table-caption.js +0 -54
  353. package/lib/rce/plugins/tinymce-a11y-checker/rules/table-header-scope.js +0 -52
  354. package/lib/rce/plugins/tinymce-a11y-checker/rules/table-header.js +0 -81
  355. package/lib/rce/plugins/tinymce-a11y-checker/utils/colors.js +0 -43
  356. package/lib/rce/plugins/tinymce-a11y-checker/utils/describe.js +0 -66
  357. package/lib/rce/plugins/tinymce-a11y-checker/utils/dom.js +0 -160
  358. package/lib/rce/plugins/tinymce-a11y-checker/utils/indicate.js +0 -83
  359. package/lib/rce/plugins/tinymce-a11y-checker/utils/rgb-hex.js +0 -57
  360. package/lib/rce/plugins/tinymce-a11y-checker/utils/strings.js +0 -40
  361. package/lib/rce/root.js +0 -58
  362. package/lib/rce/sanitizePlugins.js +0 -32
  363. package/lib/rce/style.js +0 -843
  364. package/lib/rce/tinyRCE.js +0 -66
  365. package/lib/rce/transformContent.js +0 -73
  366. package/lib/rce/userOS.js +0 -31
  367. package/lib/rce/wrapInitCb.js +0 -78
  368. package/lib/rcs/api.js +0 -670
  369. package/lib/rcs/buildError.js +0 -98
  370. package/lib/rcs/fake.js +0 -621
  371. package/lib/sidebar/actions/all_files.js +0 -29
  372. package/lib/sidebar/actions/data.js +0 -105
  373. package/lib/sidebar/actions/documents.js +0 -107
  374. package/lib/sidebar/actions/files.js +0 -167
  375. package/lib/sidebar/actions/filter.js +0 -63
  376. package/lib/sidebar/actions/flickr.js +0 -60
  377. package/lib/sidebar/actions/images.js +0 -153
  378. package/lib/sidebar/actions/links.js +0 -23
  379. package/lib/sidebar/actions/media.js +0 -142
  380. package/lib/sidebar/actions/session.js +0 -34
  381. package/lib/sidebar/actions/ui.js +0 -49
  382. package/lib/sidebar/actions/upload.js +0 -550
  383. package/lib/sidebar/containers/Sidebar.js +0 -67
  384. package/lib/sidebar/containers/sidebarHandlers.js +0 -73
  385. package/lib/sidebar/dragHtml.js +0 -49
  386. package/lib/sidebar/reducers/all_files.js +0 -35
  387. package/lib/sidebar/reducers/collection.js +0 -72
  388. package/lib/sidebar/reducers/collections.js +0 -52
  389. package/lib/sidebar/reducers/documents.js +0 -89
  390. package/lib/sidebar/reducers/files.js +0 -38
  391. package/lib/sidebar/reducers/filter.js +0 -61
  392. package/lib/sidebar/reducers/flickr.js +0 -51
  393. package/lib/sidebar/reducers/folder.js +0 -92
  394. package/lib/sidebar/reducers/folders.js +0 -39
  395. package/lib/sidebar/reducers/images.js +0 -115
  396. package/lib/sidebar/reducers/index.js +0 -57
  397. package/lib/sidebar/reducers/media.js +0 -84
  398. package/lib/sidebar/reducers/newPageLinkExpanded.js +0 -30
  399. package/lib/sidebar/reducers/noop.js +0 -21
  400. package/lib/sidebar/reducers/rootFolderId.js +0 -30
  401. package/lib/sidebar/reducers/session.js +0 -33
  402. package/lib/sidebar/reducers/ui.js +0 -87
  403. package/lib/sidebar/reducers/upload.js +0 -206
  404. package/lib/sidebar/store/configureStore.js +0 -26
  405. package/lib/sidebar/store/initialState.js +0 -173
  406. package/lib/translations/locales/ar.js +0 -2427
  407. package/lib/translations/locales/ca.js +0 -2427
  408. package/lib/translations/locales/cy.js +0 -2427
  409. package/lib/translations/locales/da-x-k12.js +0 -2427
  410. package/lib/translations/locales/da.js +0 -2427
  411. package/lib/translations/locales/de.js +0 -2427
  412. package/lib/translations/locales/el.js +0 -459
  413. package/lib/translations/locales/en-AU-x-unimelb.js +0 -2427
  414. package/lib/translations/locales/en-GB-x-ukhe.js +0 -2427
  415. package/lib/translations/locales/en.js +0 -2427
  416. package/lib/translations/locales/en_AU.js +0 -2427
  417. package/lib/translations/locales/en_CA.js +0 -2426
  418. package/lib/translations/locales/en_CY.js +0 -2426
  419. package/lib/translations/locales/en_GB.js +0 -2427
  420. package/lib/translations/locales/es.js +0 -2427
  421. package/lib/translations/locales/es_ES.js +0 -2427
  422. package/lib/translations/locales/fa_IR.js +0 -615
  423. package/lib/translations/locales/fi.js +0 -2427
  424. package/lib/translations/locales/fr.js +0 -2427
  425. package/lib/translations/locales/fr_CA.js +0 -2427
  426. package/lib/translations/locales/he.js +0 -486
  427. package/lib/translations/locales/ht.js +0 -2426
  428. package/lib/translations/locales/hu.js +0 -2007
  429. package/lib/translations/locales/hy.js +0 -444
  430. package/lib/translations/locales/is.js +0 -2426
  431. package/lib/translations/locales/it.js +0 -2427
  432. package/lib/translations/locales/ja.js +0 -2427
  433. package/lib/translations/locales/ko.js +0 -342
  434. package/lib/translations/locales/mi.js +0 -2426
  435. package/lib/translations/locales/nb-x-k12.js +0 -2427
  436. package/lib/translations/locales/nb.js +0 -2427
  437. package/lib/translations/locales/nl.js +0 -2427
  438. package/lib/translations/locales/nn.js +0 -2247
  439. package/lib/translations/locales/pl.js +0 -2427
  440. package/lib/translations/locales/pt.js +0 -2427
  441. package/lib/translations/locales/pt_BR.js +0 -2427
  442. package/lib/translations/locales/ru.js +0 -84
  443. package/lib/translations/locales/sl.js +0 -2427
  444. package/lib/translations/locales/sv-x-k12.js +0 -2427
  445. package/lib/translations/locales/sv.js +0 -78
  446. package/lib/translations/locales/tr.js +0 -684
  447. package/lib/translations/locales/uk_UA.js +0 -519
  448. package/lib/translations/locales/vi.js +0 -39
  449. package/lib/translations/locales/zh-Hans.js +0 -2427
  450. package/lib/translations/locales/zh-Hant.js +0 -2427
  451. package/lib/translations/locales/zh.js +0 -2427
  452. package/lib/translations/locales/zh_HK.js +0 -2427
  453. package/lib/translations/tinymce/ar_SA.js +0 -211
  454. package/lib/translations/tinymce/bg_BG.js +0 -419
  455. package/lib/translations/tinymce/ca.js +0 -419
  456. package/lib/translations/tinymce/cs.js +0 -419
  457. package/lib/translations/tinymce/cy.js +0 -418
  458. package/lib/translations/tinymce/da.js +0 -419
  459. package/lib/translations/tinymce/de.js +0 -419
  460. package/lib/translations/tinymce/el.js +0 -261
  461. package/lib/translations/tinymce/en_GB.js +0 -230
  462. package/lib/translations/tinymce/es.js +0 -419
  463. package/lib/translations/tinymce/fa_IR.js +0 -390
  464. package/lib/translations/tinymce/fi.js +0 -19
  465. package/lib/translations/tinymce/fr_FR.js +0 -419
  466. package/lib/translations/tinymce/he_IL.js +0 -420
  467. package/lib/translations/tinymce/hu_HU.js +0 -419
  468. package/lib/translations/tinymce/hy.js +0 -419
  469. package/lib/translations/tinymce/it.js +0 -419
  470. package/lib/translations/tinymce/ja.js +0 -419
  471. package/lib/translations/tinymce/ko_KR.js +0 -419
  472. package/lib/translations/tinymce/nb_NO.js +0 -419
  473. package/lib/translations/tinymce/nl.js +0 -419
  474. package/lib/translations/tinymce/pl.js +0 -419
  475. package/lib/translations/tinymce/pt_BR.js +0 -419
  476. package/lib/translations/tinymce/pt_PT.js +0 -419
  477. package/lib/translations/tinymce/ro.js +0 -418
  478. package/lib/translations/tinymce/ru.js +0 -436
  479. package/lib/translations/tinymce/ru_RU.js +0 -71
  480. package/lib/translations/tinymce/sl.js +0 -462
  481. package/lib/translations/tinymce/sr.js +0 -278
  482. package/lib/translations/tinymce/sv_SE.js +0 -419
  483. package/lib/translations/tinymce/th.js +0 -479
  484. package/lib/translations/tinymce/tr_TR.js +0 -389
  485. package/lib/translations/tinymce/uk_UA.js +0 -278
  486. package/lib/translations/tinymce/vi_VN.js +0 -277
  487. package/lib/translations/tinymce/zh_CN.js +0 -419
  488. package/lib/translations/tinymce/zh_TW.js +0 -419
  489. package/lib/types/inst-ui.d.js +0 -18
  490. package/lib/types/ts-migration.js +0 -1
  491. package/lib/util/DeepPartialNullable.js +0 -1
  492. package/lib/util/ExtractRequired.js +0 -1
  493. package/lib/util/TypedDict.js +0 -131
  494. package/lib/util/assertNever.js +0 -44
  495. package/lib/util/elem-util.js +0 -26
  496. package/lib/util/encrypted-storage.js +0 -84
  497. package/lib/util/file-url-util.js +0 -44
  498. package/lib/util/fullscreenHelpers.js +0 -27
  499. package/lib/util/instui-icon-helper.js +0 -31
  500. package/lib/util/loadingPlaceholder.js +0 -436
  501. package/lib/util/simpleCache.js +0 -41
  502. package/lib/util/string-util.js +0 -48
  503. package/lib/util/textarea-editing-util.js +0 -87
  504. package/lib/util/tinymce-plugin-util.js +0 -52
  505. package/lib/util/url-util.js +0 -138
@@ -1,171 +0,0 @@
1
- import _pt from "prop-types";
2
- // @ts-nocheck
3
-
4
- /*
5
- * Copyright (C) 2019 - present Instructure, Inc.
6
- *
7
- * This file is part of Canvas.
8
- *
9
- * Canvas is free software: you can redistribute it and/or modify it under
10
- * the terms of the GNU Affero General Public License as published by the Free
11
- * Software Foundation, version 3 of the License.
12
- *
13
- * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
14
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15
- * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
16
- * details.
17
- *
18
- * You should have received a copy of the GNU Affero General Public License along
19
- * with this program. If not, see <http://www.gnu.org/licenses/>.
20
- */
21
- import React, { useEffect, useState } from 'react';
22
- import ReactDOM from 'react-dom';
23
- import { px } from '@instructure/ui-utils';
24
- import indicatorRegion from '../../../indicatorRegion';
25
- import { isAudioOrVideo, isImage } from '../fileTypeUtils';
26
- import indicate from '../../../../common/indicate';
27
- import { StoreProvider } from '../StoreContext';
28
- import Bridge from '../../../../bridge';
29
- import UploadFileModal from './UploadFileModal';
30
- import RCEWrapper from '../../../RCEWrapper';
31
- export const UploadFilePanelIds = ['COMPUTER', 'URL'];
32
-
33
- /**
34
- * Handles uploading data based on what type of data is submitted.
35
- */
36
- export const handleSubmit = function (editor, accept, selectedPanel, uploadData, storeProps, source) {
37
- let afterInsert = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : () => undefined;
38
- Bridge.focusEditor(RCEWrapper.getByEditor(editor)); // necessary since it blurred when the modal opened
39
-
40
- const {
41
- altText,
42
- isDecorativeImage,
43
- displayAs
44
- } = (uploadData === null || uploadData === void 0 ? void 0 : uploadData.imageOptions) || {};
45
-
46
- switch (selectedPanel) {
47
- case 'COMPUTER':
48
- {
49
- var _uploadData$usageRigh;
50
-
51
- const {
52
- theFile
53
- } = uploadData;
54
- const fileMetaData = {
55
- parentFolderId: 'media',
56
- name: theFile.name,
57
- size: theFile.size,
58
- contentType: theFile.type,
59
- domObject: theFile,
60
- altText,
61
- isDecorativeImage,
62
- displayAs,
63
- usageRights: (uploadData === null || uploadData === void 0 ? void 0 : (_uploadData$usageRigh = uploadData.usageRights) === null || _uploadData$usageRigh === void 0 ? void 0 : _uploadData$usageRigh.usageRight) === 'choose' ? undefined : uploadData === null || uploadData === void 0 ? void 0 : uploadData.usageRights
64
- };
65
- let tabContext = 'documents';
66
-
67
- if (isImage(theFile.type)) {
68
- tabContext = 'images';
69
- } else if (isAudioOrVideo(theFile.type)) {
70
- tabContext = 'media';
71
- }
72
-
73
- storeProps.startMediaUpload(tabContext, fileMetaData);
74
- break;
75
- }
76
-
77
- case 'URL':
78
- {
79
- const {
80
- fileUrl
81
- } = uploadData;
82
- let editorHtml;
83
-
84
- if (displayAs !== 'link' && /image/.test(accept)) {
85
- editorHtml = editor.dom.createHTML('img', {
86
- src: fileUrl,
87
- alt: altText,
88
- ...(isDecorativeImage ? {
89
- role: 'presentation'
90
- } : null)
91
- });
92
- } else {
93
- editorHtml = editor.dom.createHTML('a', {
94
- href: fileUrl
95
- }, altText || fileUrl);
96
- }
97
-
98
- editor.insertContent(editorHtml);
99
- break;
100
- }
101
-
102
- default:
103
- throw new Error('Selected Panel is invalid');
104
- // Should never get here
105
- }
106
-
107
- const element = editor.selection.getEnd();
108
- element.addEventListener('load', () => indicate(indicatorRegion(editor, element)));
109
- afterInsert();
110
- };
111
- export function UploadFile(_ref) {
112
- let {
113
- accept,
114
- editor,
115
- label,
116
- panels,
117
- onDismiss,
118
- requireA11yAttributes = true,
119
- trayProps,
120
- canvasOrigin,
121
- onSubmit = handleSubmit,
122
- preselectedFile = undefined
123
- } = _ref;
124
- const [modalBodyWidth, setModalBodyWidth] = useState(undefined);
125
- const [modalBodyHeight, setModalBodyHeight] = useState(undefined);
126
- const [theFile] = useState(preselectedFile);
127
- const bodyRef = React.useRef();
128
- trayProps = trayProps || Bridge.trayProps.get(editor); // the panels get rendered inside tab panels. it's difficult for them to
129
- // figure out how much space they have to work with, and I'd like the previews
130
- // not to trigger scrollbars in the modal's body. Get the Modal.Body's size
131
- // and to the ComputerPanel how much space it has so it can render the file preview
132
-
133
- useEffect(() => {
134
- if (bodyRef.current) {
135
- // eslint-disable-next-line react/no-find-dom-node
136
- const thebody = ReactDOM.findDOMNode(bodyRef.current);
137
- const sz = thebody === null || thebody === void 0 ? void 0 : thebody.getBoundingClientRect();
138
- sz.height -= px('3rem'); // leave room for the tabs
139
-
140
- setModalBodyWidth(sz.width);
141
- setModalBodyHeight(sz.height);
142
- }
143
- }, [modalBodyHeight, modalBodyWidth]);
144
- return /*#__PURE__*/React.createElement(StoreProvider, Object.assign({}, trayProps, {
145
- canvasOrigin: canvasOrigin
146
- }), contentProps => /*#__PURE__*/React.createElement(UploadFileModal, {
147
- ref: bodyRef // @ts-ignore
148
- ,
149
- preselectedFile: theFile,
150
- editor: editor,
151
- trayProps: trayProps,
152
- contentProps: contentProps,
153
- canvasOrigin: canvasOrigin,
154
- onSubmit: onSubmit,
155
- onDismiss: onDismiss,
156
- panels: panels,
157
- label: label,
158
- accept: accept,
159
- modalBodyWidth: modalBodyWidth,
160
- modalBodyHeight: modalBodyHeight,
161
- requireA11yAttributes: requireA11yAttributes
162
- }));
163
- }
164
- UploadFile.propTypes = {
165
- accept: _pt.oneOfType([_pt.arrayOf(_pt.string), _pt.string]),
166
- label: _pt.string.isRequired,
167
- panels: _pt.array,
168
- requireA11yAttributes: _pt.bool,
169
- trayProps: _pt.object,
170
- canvasOrigin: _pt.string
171
- };
@@ -1,273 +0,0 @@
1
- /*
2
- * Copyright (C) 2020 - present Instructure, Inc.
3
- *
4
- * This file is part of Canvas.
5
- *
6
- * Canvas is free software: you can redistribute it and/or modify it under
7
- * the terms of the GNU Affero General Public License as published by the Free
8
- * Software Foundation, version 3 of the License.
9
- *
10
- * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
11
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12
- * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
13
- * details.
14
- *
15
- * You should have received a copy of the GNU Affero General Public License along
16
- * with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
18
- import React, { Suspense, useState } from 'react';
19
- import { arrayOf, bool, func, number, object, oneOf, oneOfType, string } from 'prop-types';
20
- import { Modal } from '@instructure/ui-modal';
21
- import { Button, CloseButton } from '@instructure/ui-buttons';
22
- import { Heading } from '@instructure/ui-heading';
23
- import { Spinner } from '@instructure/ui-spinner';
24
- import { Tabs } from '@instructure/ui-tabs';
25
- import { ToggleDetails } from '@instructure/ui-toggle-details';
26
- import formatMessage from '../../../../format-message';
27
- import { instuiPopupMountNode } from '../../../../util/fullscreenHelpers';
28
- import RceApiSource from '../../../../rcs/api';
29
- import ImageOptionsForm from '../ImageOptionsForm';
30
- import UsageRightsSelectBox from './UsageRightsSelectBox';
31
- import { View } from '@instructure/ui-view';
32
- const ComputerPanel = /*#__PURE__*/React.lazy(() => import('./ComputerPanel'));
33
- const UrlPanel = /*#__PURE__*/React.lazy(() => import('./UrlPanel'));
34
-
35
- function shouldBeDisabled(_ref, selectedPanel, usageRightNotSet) {
36
- let {
37
- fileUrl,
38
- theFile,
39
- error
40
- } = _ref;
41
-
42
- if (error || usageRightNotSet && selectedPanel === 'COMPUTER') {
43
- return true;
44
- }
45
-
46
- switch (selectedPanel) {
47
- case 'COMPUTER':
48
- return !theFile || theFile.error;
49
-
50
- case 'URL':
51
- return !fileUrl;
52
-
53
- default:
54
- return false;
55
- // When in doubt, don't disable (but we shouldn't get here either)
56
- }
57
- }
58
-
59
- const UploadFileModal = /*#__PURE__*/React.forwardRef((_ref2, ref) => {
60
- var _contentProps$session;
61
-
62
- let {
63
- preselectedFile,
64
- editor,
65
- contentProps,
66
- trayProps,
67
- canvasOrigin,
68
- onSubmit,
69
- onDismiss,
70
- panels,
71
- label,
72
- accept,
73
- modalBodyWidth,
74
- modalBodyHeight,
75
- requireA11yAttributes = true
76
- } = _ref2;
77
- const [theFile, setFile] = useState(preselectedFile);
78
- const [error, setError] = useState(null);
79
- const [fileUrl, setFileUrl] = useState('');
80
- const [selectedPanel, setSelectedPanel] = useState(panels[0]);
81
- const [usageRightsState, setUsageRightsState] = React.useState({
82
- usageRight: 'choose',
83
- ccLicense: '',
84
- copyrightHolder: ''
85
- }); // Image options props
86
-
87
- const [altText, setAltText] = useState('');
88
- const [isDecorativeImage, setIsDecorativeImage] = useState(false);
89
- const [displayAs, setDisplayAs] = useState('embed'); // even though usage rights might be required by the course, canvas has no place
90
- // on the user to store it. Only Group and Course.
91
-
92
- const requiresUsageRights = (contentProps === null || contentProps === void 0 ? void 0 : (_contentProps$session = contentProps.session) === null || _contentProps$session === void 0 ? void 0 : _contentProps$session.usageRightsRequired) && /(?:course|group)/.test(trayProps.contextType);
93
-
94
- function handleAltTextChange(event) {
95
- setAltText(event.target.value);
96
- }
97
-
98
- function handleIsDecorativeChange(event) {
99
- setIsDecorativeImage(event.target.checked);
100
- }
101
-
102
- function handleDisplayAsChange(event) {
103
- setDisplayAs(event.target.value);
104
- }
105
-
106
- const submitDisabled = shouldBeDisabled({
107
- fileUrl,
108
- theFile,
109
- error
110
- }, selectedPanel, requiresUsageRights && usageRightsState.usageRight === 'choose'); // Load the necessary session values, if not already loaded
111
-
112
- const loadSession = contentProps.loadSession;
113
- React.useEffect(() => {
114
- loadSession();
115
- }, [loadSession]);
116
- const source = trayProps.source || new RceApiSource({
117
- jwt: trayProps.jwt,
118
- refreshToken: trayProps.refreshToken,
119
- host: trayProps.host,
120
- canvasOrigin
121
- });
122
- return /*#__PURE__*/React.createElement(Modal, {
123
- "data-mce-component": true,
124
- as: "form",
125
- label: label,
126
- mountNode: instuiPopupMountNode,
127
- size: "large",
128
- overflow: "fit",
129
- onDismiss: onDismiss,
130
- onSubmit: e => {
131
- e.preventDefault();
132
-
133
- if (submitDisabled) {
134
- return false;
135
- }
136
-
137
- onSubmit(editor, accept, selectedPanel, {
138
- fileUrl,
139
- theFile,
140
- imageOptions: {
141
- altText,
142
- isDecorativeImage,
143
- displayAs
144
- },
145
- usageRights: usageRightsState
146
- }, contentProps, source, onDismiss);
147
- },
148
- open: true,
149
- shouldCloseOnDocumentClick: false,
150
- liveRegion: trayProps.liveRegion
151
- }, /*#__PURE__*/React.createElement(Modal.Header, null, /*#__PURE__*/React.createElement(CloseButton, {
152
- onClick: onDismiss,
153
- offset: "small",
154
- placement: "end",
155
- screenReaderLabel: formatMessage('Close')
156
- }), /*#__PURE__*/React.createElement(Heading, null, label)), /*#__PURE__*/React.createElement(Modal.Body, {
157
- ref: ref
158
- }, /*#__PURE__*/React.createElement(Tabs, {
159
- onRequestTabChange: (event, _ref3) => {
160
- let {
161
- index
162
- } = _ref3;
163
- return setSelectedPanel(panels[index]);
164
- }
165
- }, panels.map(panel => {
166
- switch (panel) {
167
- case 'COMPUTER':
168
- return /*#__PURE__*/React.createElement(Tabs.Panel, {
169
- key: panel,
170
- renderTitle: function () {
171
- return formatMessage('Computer');
172
- },
173
- isSelected: selectedPanel === 'COMPUTER'
174
- }, /*#__PURE__*/React.createElement(Suspense, {
175
- fallback: /*#__PURE__*/React.createElement(Spinner, {
176
- renderTitle: formatMessage('Loading'),
177
- size: "large"
178
- })
179
- }, /*#__PURE__*/React.createElement(ComputerPanel, {
180
- editor: editor,
181
- theFile: theFile,
182
- setFile: setFile,
183
- setError: setError,
184
- label: label,
185
- accept: accept,
186
- bounds: {
187
- width: modalBodyWidth,
188
- height: modalBodyHeight
189
- }
190
- })));
191
-
192
- case 'URL':
193
- return /*#__PURE__*/React.createElement(Tabs.Panel, {
194
- key: panel,
195
- renderTitle: function () {
196
- return formatMessage('URL');
197
- },
198
- isSelected: selectedPanel === 'URL'
199
- }, /*#__PURE__*/React.createElement(Suspense, {
200
- fallback: /*#__PURE__*/React.createElement(Spinner, {
201
- renderTitle: formatMessage('Loading'),
202
- size: "large"
203
- })
204
- }, /*#__PURE__*/React.createElement(UrlPanel, {
205
- fileUrl: fileUrl,
206
- setFileUrl: setFileUrl
207
- })));
208
- }
209
-
210
- return null;
211
- })), // We shouldn't show the accordions until the session data is loaded.
212
- Object.keys(contentProps.session || {}).length > 0 && /*#__PURE__*/React.createElement(React.Fragment, null, selectedPanel === 'COMPUTER' && requiresUsageRights && /*#__PURE__*/React.createElement(View, {
213
- as: "div",
214
- role: "group",
215
- borderColor: "primary",
216
- borderWidth: "0 0 small 0",
217
- padding: "medium"
218
- }, /*#__PURE__*/React.createElement(ToggleDetails, {
219
- defaultExpanded: true,
220
- summary: /*#__PURE__*/React.createElement(Heading, {
221
- level: "h3"
222
- }, formatMessage('Usage Rights (required)'))
223
- }, /*#__PURE__*/React.createElement(UsageRightsSelectBox, {
224
- usageRightsState: usageRightsState,
225
- setUsageRightsState: setUsageRightsState,
226
- contextType: trayProps.contextType,
227
- contextId: trayProps.contextId,
228
- showMessage: false
229
- }))), /image/.test(accept) && requireA11yAttributes && /*#__PURE__*/React.createElement(View, {
230
- as: "div",
231
- role: "group",
232
- borderColor: "primary",
233
- borderWidth: "0 0 small 0",
234
- padding: "medium"
235
- }, /*#__PURE__*/React.createElement(ToggleDetails, {
236
- defaultExpanded: !requiresUsageRights,
237
- summary: /*#__PURE__*/React.createElement(Heading, {
238
- level: "h3"
239
- }, formatMessage('Attributes'))
240
- }, /*#__PURE__*/React.createElement(ImageOptionsForm, {
241
- id: "upload-file-form",
242
- altText: altText,
243
- isDecorativeImage: isDecorativeImage,
244
- displayAs: displayAs,
245
- handleAltTextChange: handleAltTextChange,
246
- handleIsDecorativeChange: handleIsDecorativeChange,
247
- handleDisplayAsChange: handleDisplayAsChange,
248
- hideDimensions: true
249
- }))))), /*#__PURE__*/React.createElement(Modal.Footer, null, /*#__PURE__*/React.createElement(Button, {
250
- onClick: onDismiss
251
- }, formatMessage('Close')), "\xA0", /*#__PURE__*/React.createElement(Button, {
252
- color: "primary",
253
- type: "submit",
254
- disabled: submitDisabled
255
- }, formatMessage('Submit'))));
256
- });
257
- UploadFileModal.propTypes = {
258
- editor: object.isRequired,
259
- contentProps: object,
260
- trayProps: object,
261
- canvasOrigin: string,
262
- onSubmit: func,
263
- onDismiss: func.isRequired,
264
- panels: arrayOf(oneOf(['COMPUTER', 'URL'])),
265
- label: string.isRequired,
266
- accept: oneOfType([arrayOf(string), string]),
267
- modalBodyWidth: number,
268
- modalBodyHeight: number,
269
- requireA11yAttributes: bool,
270
- preselectedFile: object // JS File
271
-
272
- };
273
- export default UploadFileModal;
@@ -1,38 +0,0 @@
1
- /*
2
- * Copyright (C) 2019 - present Instructure, Inc.
3
- *
4
- * This file is part of Canvas.
5
- *
6
- * Canvas is free software: you can redistribute it and/or modify it under
7
- * the terms of the GNU Affero General Public License as published by the Free
8
- * Software Foundation, version 3 of the License.
9
- *
10
- * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
11
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12
- * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
13
- * details.
14
- *
15
- * You should have received a copy of the GNU Affero General Public License along
16
- * with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
18
- import React from 'react';
19
- import { string, func } from 'prop-types';
20
- import { TextInput } from '@instructure/ui-text-input';
21
- import formatMessage from '../../../../format-message';
22
- export default function UrlPanel(_ref) {
23
- let {
24
- fileUrl,
25
- setFileUrl
26
- } = _ref;
27
- return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(TextInput, {
28
- name: "file-url",
29
- renderLabel: formatMessage('File URL'),
30
- type: "url",
31
- value: fileUrl,
32
- onChange: (e, val) => setFileUrl(val)
33
- }));
34
- }
35
- UrlPanel.propTypes = {
36
- fileUrl: string.isRequired,
37
- setFileUrl: func.isRequired
38
- };
@@ -1,172 +0,0 @@
1
- /*
2
- * Copyright (C) 2020 - present Instructure, Inc.
3
- *
4
- * This file is part of Canvas.
5
- *
6
- * Canvas is free software: you can redistribute it and/or modify it under
7
- * the terms of the GNU Affero General Public License as published by the Free
8
- * Software Foundation, version 3 of the License.
9
- *
10
- * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
11
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12
- * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
13
- * details.
14
- *
15
- * You should have received a copy of the GNU Affero General Public License along
16
- * with this program. If not, see <http://www.gnu.org/licenses/>.
17
- */
18
- import React from 'react';
19
- import PropTypes from 'prop-types';
20
- import formatMessage from '../../../../format-message';
21
- import { SimpleSelect } from '@instructure/ui-simple-select';
22
- import { View } from '@instructure/ui-view';
23
- import { TextInput } from '@instructure/ui-text-input';
24
- const CONTENT_OPTIONS = [{
25
- display: formatMessage('Choose usage rights...'),
26
- value: 'choose'
27
- }, {
28
- display: formatMessage('I hold the copyright'),
29
- value: 'own_copyright'
30
- }, {
31
- display: formatMessage('I have obtained permission to use this file.'),
32
- value: 'used_by_permission'
33
- }, {
34
- display: formatMessage('The material is in the public domain'),
35
- value: 'public_domain'
36
- }, {
37
- display: formatMessage('The material is subject to an exception - e.g. fair use, the right to quote, or others under applicable copyright laws'),
38
- value: 'fair_use'
39
- }, {
40
- display: formatMessage('The material is licensed under Creative Commons'),
41
- value: 'creative_commons'
42
- }];
43
-
44
- const ShowCreativeCommonsOptions = _ref => {
45
- let {
46
- ccLicense,
47
- setCCLicense,
48
- licenseOptions
49
- } = _ref;
50
- const onlyCC = licenseOptions.filter(license => license.id.indexOf('cc') === 0);
51
- return /*#__PURE__*/React.createElement(View, {
52
- as: "div",
53
- margin: "medium 0"
54
- }, /*#__PURE__*/React.createElement(SimpleSelect, {
55
- renderLabel: formatMessage('Creative Commons License:'),
56
- assistiveText: formatMessage('Use arrow keys to navigate options.'),
57
- value: ccLicense,
58
- onChange: (e, _ref2) => {
59
- let {
60
- id
61
- } = _ref2;
62
- return setCCLicense(id);
63
- }
64
- }, onlyCC.map(license => /*#__PURE__*/React.createElement(SimpleSelect.Option, {
65
- key: license.id,
66
- id: license.id,
67
- value: license.id
68
- }, license.name))));
69
- };
70
-
71
- const ShowMessage = () => {
72
- return /*#__PURE__*/React.createElement("div", {
73
- className: "alert"
74
- }, /*#__PURE__*/React.createElement("span", null, /*#__PURE__*/React.createElement("i", {
75
- className: "icon-warning"
76
- }), /*#__PURE__*/React.createElement("span", {
77
- style: {
78
- paddingLeft: '10px'
79
- }
80
- }, formatMessage("If you do not select usage rights now, this file will be unpublished after it's uploaded."))));
81
- };
82
-
83
- const UsageRightsSelectBox = _ref3 => {
84
- let {
85
- contextType,
86
- contextId,
87
- showMessage: showMessageProp,
88
- usageRightsState,
89
- setUsageRightsState
90
- } = _ref3;
91
- const {
92
- usageRight,
93
- ccLicense,
94
- copyrightHolder
95
- } = usageRightsState;
96
- const showCreativeCommonsOptions = usageRight === 'creative_commons';
97
- const [licenseOptions, setLicenseOptions] = React.useState([]);
98
- const [showMessage, setShowMessage] = React.useState(showMessageProp);
99
- React.useEffect(() => {
100
- function getUsageRightsOptions() {
101
- fetch(apiUrl()).then(res => res.text()).then(res => setLicenseOptions(JSON.parse(res))).catch(() => {});
102
- }
103
-
104
- function apiUrl() {
105
- const context = contextType.replace(/([^s])$/, '$1s'); // pluralize
106
-
107
- return `/api/v1/${context}/${contextId}/content_licenses`;
108
- }
109
-
110
- getUsageRightsOptions();
111
- }, [contextType, contextId]);
112
-
113
- function handleChange(value) {
114
- setUsageRightsState(state => ({ ...state,
115
- usageRight: value
116
- }));
117
- setShowMessage(showMessageProp && value === 'choose');
118
- }
119
-
120
- return /*#__PURE__*/React.createElement(View, {
121
- as: "div"
122
- }, /*#__PURE__*/React.createElement(View, {
123
- as: "div",
124
- margin: "medium 0"
125
- }, /*#__PURE__*/React.createElement(SimpleSelect, {
126
- renderLabel: formatMessage('Usage Right:'),
127
- assistiveText: formatMessage('Use arrow keys to navigate options.'),
128
- onChange: (e, _ref4) => {
129
- let {
130
- id
131
- } = _ref4;
132
- handleChange(id);
133
- },
134
- value: usageRight
135
- }, CONTENT_OPTIONS.map(contentOption => /*#__PURE__*/React.createElement(SimpleSelect.Option, {
136
- key: contentOption.value,
137
- id: contentOption.value,
138
- value: contentOption.value
139
- }, contentOption.display)))), showCreativeCommonsOptions && /*#__PURE__*/React.createElement(ShowCreativeCommonsOptions, {
140
- ccLicese: ccLicense,
141
- setCCLicense: license => setUsageRightsState(state => ({ ...state,
142
- ccLicense: license
143
- })),
144
- licenseOptions: licenseOptions
145
- }), /*#__PURE__*/React.createElement(View, {
146
- as: "div",
147
- margin: "medium 0"
148
- }, /*#__PURE__*/React.createElement(TextInput, {
149
- renderLabel: formatMessage('Copyright Holder:'),
150
- value: copyrightHolder,
151
- onChange: (e, value) => setUsageRightsState(state => ({ ...state,
152
- copyrightHolder: value
153
- })),
154
- placeholder: formatMessage('(c) 2001 Acme Inc.')
155
- })), /*#__PURE__*/React.createElement(View, {
156
- as: "div",
157
- margin: "medium 0"
158
- }, showMessage && /*#__PURE__*/React.createElement(ShowMessage, null)));
159
- };
160
-
161
- UsageRightsSelectBox.propTypes = {
162
- usageRightsState: PropTypes.shape({
163
- ccLicense: PropTypes.string,
164
- usageRight: PropTypes.oneOf(Object.values(CONTENT_OPTIONS).map(o => o.value)),
165
- copyrightHolder: PropTypes.string
166
- }),
167
- setUsageRightsState: PropTypes.func,
168
- showMessage: PropTypes.bool,
169
- contextType: PropTypes.string,
170
- contextId: PropTypes.oneOfType([PropTypes.string, PropTypes.number])
171
- };
172
- export default UsageRightsSelectBox;