@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,321 +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, { useState } from 'react';
19
- import { arrayOf, bool, func, number, shape, string } from 'prop-types';
20
- import { Button, CloseButton, IconButton } from '@instructure/ui-buttons';
21
- import { Heading } from '@instructure/ui-heading';
22
- import { RadioInput, RadioInputGroup } from '@instructure/ui-radio-input';
23
- import { SimpleSelect } from '@instructure/ui-simple-select';
24
- import { TextArea } from '@instructure/ui-text-area';
25
- import { Text } from '@instructure/ui-text';
26
- import { IconQuestionLine } from '@instructure/ui-icons';
27
- import { Flex } from '@instructure/ui-flex';
28
- import { FormFieldGroup } from '@instructure/ui-form-field';
29
- import { View } from '@instructure/ui-view';
30
- import { Tooltip } from '@instructure/ui-tooltip';
31
- import { Tray } from '@instructure/ui-tray';
32
- import { StoreProvider } from '../../shared/StoreContext';
33
- import { ClosedCaptionPanel } from '@instructure/canvas-media';
34
- import { CUSTOM, MIN_WIDTH_VIDEO, MIN_PERCENTAGE, videoSizes, labelForImageSize, scaleToSize } from '../../instructure_image/ImageEmbedOptions';
35
- import Bridge from '../../../../bridge';
36
- import formatMessage from '../../../../format-message';
37
- import DimensionsInput, { useDimensionsState } from '../../shared/DimensionsInput';
38
- import { getTrayHeight } from '../../shared/trayUtils';
39
- import { instuiPopupMountNode } from '../../../../util/fullscreenHelpers';
40
- import { parsedStudioOptionsPropType } from '../../shared/StudioLtiSupportUtils';
41
-
42
- const getLiveRegion = () => document.getElementById('flash_screenreader_holder');
43
-
44
- export default function VideoOptionsTray(_ref) {
45
- let {
46
- videoOptions,
47
- onRequestClose,
48
- onSave,
49
- open,
50
- trayProps,
51
- onEntered = null,
52
- onExited = null,
53
- id = 'video-options-tray',
54
- studioOptions = null
55
- } = _ref;
56
- const {
57
- naturalHeight,
58
- naturalWidth
59
- } = videoOptions;
60
- const currentHeight = videoOptions.appliedHeight || naturalHeight;
61
- const currentWidth = videoOptions.appliedWidth || naturalWidth;
62
- const [titleText, setTitleText] = useState(videoOptions.titleText);
63
- const [displayAs, setDisplayAs] = useState('embed');
64
- const [videoSize, setVideoSize] = useState(videoOptions.videoSize);
65
- const [videoHeight, setVideoHeight] = useState(currentHeight);
66
- const [videoWidth, setVideoWidth] = useState(currentWidth);
67
- const [subtitles, setSubtitles] = useState(videoOptions.tracks || []);
68
- const [minWidth] = useState(MIN_WIDTH_VIDEO);
69
- const [minHeight] = useState(Math.round(videoHeight / videoWidth * MIN_WIDTH_VIDEO));
70
- const [minPercentage] = useState(MIN_PERCENTAGE);
71
- const isStudio = !!studioOptions;
72
- const showDisplayOptions = !isStudio || studioOptions.convertibleToLink;
73
- const showSizeControls = !isStudio || studioOptions.resizable;
74
- const dimensionsState = useDimensionsState(videoOptions, {
75
- minHeight,
76
- minWidth,
77
- minPercentage
78
- });
79
-
80
- function handleTitleTextChange(event) {
81
- setTitleText(event.target.value);
82
- }
83
-
84
- function handleDisplayAsChange(event) {
85
- event.target.focus();
86
- setDisplayAs(event.target.value);
87
- }
88
-
89
- function handleVideoSizeChange(event, selectedOption) {
90
- setVideoSize(selectedOption.value);
91
-
92
- if (selectedOption.value === CUSTOM) {
93
- setVideoHeight(currentHeight);
94
- setVideoWidth(currentWidth);
95
- } else {
96
- const {
97
- height,
98
- width
99
- } = scaleToSize(selectedOption.value, naturalWidth, naturalHeight);
100
- setVideoHeight(height);
101
- setVideoWidth(width);
102
- }
103
- }
104
-
105
- function handleUpdateSubtitles(new_subtitles) {
106
- setSubtitles(new_subtitles);
107
- }
108
-
109
- function handleSave(event, updateMediaObject) {
110
- event.preventDefault();
111
- let appliedHeight = videoHeight;
112
- let appliedWidth = videoWidth;
113
-
114
- if (videoSize === CUSTOM) {
115
- appliedHeight = dimensionsState.height;
116
- appliedWidth = dimensionsState.width;
117
- }
118
-
119
- onSave({
120
- media_object_id: videoOptions.id,
121
- attachment_id: videoOptions.attachmentId,
122
- titleText,
123
- appliedHeight,
124
- appliedWidth,
125
- displayAs,
126
- subtitles,
127
- updateMediaObject
128
- });
129
- }
130
-
131
- const tooltipText = formatMessage('Used by screen readers to describe the video');
132
- const textAreaLabel = /*#__PURE__*/React.createElement(Flex, {
133
- alignItems: "center"
134
- }, /*#__PURE__*/React.createElement(Flex.Item, null, formatMessage('Title')), /*#__PURE__*/React.createElement(Flex.Item, {
135
- margin: "0 0 0 xx-small"
136
- }, /*#__PURE__*/React.createElement(Tooltip, {
137
- on: ['hover', 'focus'],
138
- placement: "top",
139
- renderTip: /*#__PURE__*/React.createElement(View, {
140
- display: "block",
141
- id: "alt-text-label-tooltip",
142
- maxWidth: "14rem"
143
- }, tooltipText)
144
- }, /*#__PURE__*/React.createElement(IconButton, {
145
- renderIcon: IconQuestionLine,
146
- size: "small",
147
- screenReaderLabel: tooltipText,
148
- withBackground: false,
149
- withBorder: false
150
- }))));
151
- const messagesForSize = [];
152
-
153
- if (videoSize !== CUSTOM) {
154
- messagesForSize.push({
155
- text: formatMessage('{width} x {height}px', {
156
- height: videoHeight,
157
- width: videoWidth
158
- }),
159
- type: 'hint'
160
- });
161
- }
162
-
163
- const saveDisabled = displayAs === 'embed' && (titleText === '' || videoSize === CUSTOM && !dimensionsState.isValid);
164
- return /*#__PURE__*/React.createElement(StoreProvider, trayProps, contentProps => /*#__PURE__*/React.createElement(Tray, {
165
- key: "video-options-tray",
166
- "data-mce-component": true,
167
- label: isStudio ? formatMessage('Studio Media Options Tray') : formatMessage('Video Options Tray'),
168
- mountNode: instuiPopupMountNode,
169
- onDismiss: onRequestClose,
170
- onEntered: onEntered,
171
- onExited: onExited,
172
- open: open,
173
- placement: "end",
174
- shouldCloseOnDocumentClick: true,
175
- shouldContainFocus: true,
176
- shouldReturnFocus: true,
177
- size: "regular"
178
- }, /*#__PURE__*/React.createElement(Flex, {
179
- direction: "column",
180
- height: getTrayHeight()
181
- }, /*#__PURE__*/React.createElement(Flex.Item, {
182
- as: "header",
183
- padding: "medium"
184
- }, /*#__PURE__*/React.createElement(Flex, {
185
- direction: "row"
186
- }, /*#__PURE__*/React.createElement(Flex.Item, {
187
- shouldGrow: true,
188
- shouldShrink: true
189
- }, /*#__PURE__*/React.createElement(Heading, {
190
- as: "h2"
191
- }, isStudio ? formatMessage('Studio Media Options') : formatMessage('Video Options'))), /*#__PURE__*/React.createElement(Flex.Item, null, /*#__PURE__*/React.createElement(CloseButton, {
192
- color: "primary",
193
- onClick: onRequestClose,
194
- screenReaderLabel: formatMessage('Close')
195
- })))), /*#__PURE__*/React.createElement(Flex.Item, {
196
- as: "form",
197
- shouldGrow: true,
198
- margin: "none",
199
- shouldShrink: true
200
- }, /*#__PURE__*/React.createElement(Flex, {
201
- justifyItems: "space-between",
202
- direction: "column",
203
- height: "100%"
204
- }, /*#__PURE__*/React.createElement(Flex.Item, {
205
- shouldGrow: true,
206
- padding: "small",
207
- shouldShrink: true
208
- }, /*#__PURE__*/React.createElement(Flex, {
209
- direction: "column"
210
- }, /*#__PURE__*/React.createElement(Flex.Item, {
211
- padding: "small"
212
- }, isStudio ? /*#__PURE__*/React.createElement(Flex, {
213
- direction: "column"
214
- }, /*#__PURE__*/React.createElement(Flex.Item, null, /*#__PURE__*/React.createElement(Text, {
215
- weight: "bold"
216
- }, formatMessage('Media Title'))), /*#__PURE__*/React.createElement(Flex.Item, {
217
- padding: "small none none small"
218
- }, titleText)) : /*#__PURE__*/React.createElement(TextArea, {
219
- "aria-describedby": "alt-text-label-tooltip",
220
- disabled: displayAs === 'link',
221
- height: "4rem",
222
- label: textAreaLabel,
223
- onChange: handleTitleTextChange,
224
- placeholder: formatMessage('(Describe the video)'),
225
- resize: "vertical",
226
- value: titleText
227
- })), showDisplayOptions && /*#__PURE__*/React.createElement(Flex.Item, {
228
- margin: "small none none none",
229
- padding: "small"
230
- }, /*#__PURE__*/React.createElement(RadioInputGroup, {
231
- description: formatMessage('Display Options'),
232
- name: "display-video-as",
233
- onChange: handleDisplayAsChange,
234
- value: displayAs
235
- }, /*#__PURE__*/React.createElement(RadioInput, {
236
- label: formatMessage('Embed Video'),
237
- value: "embed"
238
- }), /*#__PURE__*/React.createElement(RadioInput, {
239
- label: formatMessage('Display Text Link (Opens in a new tab)'),
240
- value: "link"
241
- }))), showSizeControls && /*#__PURE__*/React.createElement(Flex.Item, {
242
- margin: "small none xx-small none"
243
- }, /*#__PURE__*/React.createElement(View, {
244
- as: "div",
245
- padding: "small small xx-small small"
246
- }, /*#__PURE__*/React.createElement(SimpleSelect, {
247
- id: `${id}-size`,
248
- mountNode: instuiPopupMountNode,
249
- disabled: displayAs !== 'embed',
250
- renderLabel: formatMessage('Size'),
251
- messages: messagesForSize,
252
- assistiveText: formatMessage('Use arrow keys to navigate options.'),
253
- onChange: handleVideoSizeChange,
254
- value: videoSize
255
- }, videoSizes.map(size => /*#__PURE__*/React.createElement(SimpleSelect.Option, {
256
- id: `${id}-size-${size}`,
257
- key: size,
258
- value: size
259
- }, labelForImageSize(size))))), videoSize === CUSTOM && /*#__PURE__*/React.createElement(View, {
260
- as: "div",
261
- padding: "xx-small small"
262
- }, /*#__PURE__*/React.createElement(DimensionsInput, {
263
- dimensionsState: dimensionsState,
264
- disabled: displayAs !== 'embed',
265
- minHeight: minHeight,
266
- minWidth: minWidth,
267
- minPercentage: minPercentage,
268
- hidePercentage: true
269
- }))), !isStudio && /*#__PURE__*/React.createElement(Flex.Item, {
270
- padding: "small"
271
- }, /*#__PURE__*/React.createElement(FormFieldGroup, {
272
- description: formatMessage('Closed Captions/Subtitles')
273
- }, /*#__PURE__*/React.createElement(ClosedCaptionPanel, {
274
- subtitles: subtitles.map(st => ({
275
- locale: st.locale,
276
- inherited: st.inherited,
277
- file: {
278
- name: st.language || st.locale
279
- } // this is an artifact of ClosedCaptionCreatorRow's inards
280
-
281
- })),
282
- uploadMediaTranslations: Bridge.uploadMediaTranslations,
283
- userLocale: Bridge.userLocale,
284
- updateSubtitles: handleUpdateSubtitles,
285
- liveRegion: getLiveRegion,
286
- mountNode: instuiPopupMountNode
287
- }))))), /*#__PURE__*/React.createElement(Flex.Item, {
288
- background: "secondary",
289
- borderWidth: "small none none none",
290
- padding: "small medium",
291
- textAlign: "end"
292
- }, /*#__PURE__*/React.createElement(Button, {
293
- disabled: saveDisabled,
294
- onClick: event => handleSave(event, contentProps.updateMediaObject),
295
- color: "primary"
296
- }, formatMessage('Done'))))))));
297
- }
298
- VideoOptionsTray.propTypes = {
299
- videoOptions: shape({
300
- titleText: string,
301
- appliedHeight: number,
302
- appliedWidth: number,
303
- naturalHeight: number.isRequired,
304
- naturalWidth: number.isRequired,
305
- tracks: arrayOf(shape({
306
- locale: string.isRequired,
307
- inherited: bool
308
- }))
309
- }).isRequired,
310
- onEntered: func,
311
- onExited: func,
312
- onRequestClose: func.isRequired,
313
- onSave: func.isRequired,
314
- open: bool.isRequired,
315
- trayProps: shape({
316
- host: string.isRequired,
317
- jwt: string.isRequired
318
- }),
319
- id: string,
320
- studioOptions: parsedStudioOptionsPropType
321
- };
@@ -1,105 +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 ReactDOM from 'react-dom';
20
- import Bridge from '../../../bridge';
21
- import { StoreProvider } from '../shared/StoreContext';
22
- import formatMessage from '../../../format-message';
23
- import { headerFor, originFromHost } from '../../../rcs/api';
24
- import { instuiPopupMountNode } from '../../../util/fullscreenHelpers';
25
- import RCEGlobals from '../../RCEGlobals';
26
- export const handleUpload = (error, uploadData, onUploadComplete, uploadBookmark) => {
27
- let err_msg = error && Bridge.uploadMediaTranslations.UploadMediaStrings.UPLOADING_ERROR;
28
-
29
- if ((error === null || error === void 0 ? void 0 : error.name) === 'FileSizeError') {
30
- err_msg = formatMessage('Size of caption file is greater than the maximum {max} kb allowed file size.', {
31
- max: error.maxBytes / 1000
32
- });
33
- }
34
-
35
- const editorComponent = Bridge.activeEditor();
36
- let newBookmark;
37
-
38
- if (uploadBookmark) {
39
- newBookmark = editorComponent.editor.selection.getBookmark(2, true);
40
- editorComponent.editor.selection.moveToBookmark(uploadBookmark);
41
- }
42
-
43
- onUploadComplete(err_msg, uploadData);
44
-
45
- if (newBookmark) {
46
- editorComponent.editor.selection.moveToBookmark(newBookmark);
47
- }
48
- };
49
- export default function (ed, document) {
50
- return import('@instructure/canvas-media').then(CanvasMedia => {
51
- const UploadMedia = CanvasMedia.default;
52
- let container = document.querySelector('.canvas-rce-media-upload');
53
-
54
- if (!container) {
55
- container = document.createElement('div');
56
- container.className = 'canvas-rce-media-upload';
57
- document.body.appendChild(container);
58
- }
59
-
60
- const handleDismiss = () => {
61
- ReactDOM.unmountComponentAtNode(container);
62
- ed.focus(false);
63
- }; // We need to have a place to store the bookmark location
64
- // while the upload happens.
65
-
66
-
67
- let uploadBookmark = null; // redux's activateMediaUpload action does the image placeholder,
68
- // but it also does the upload. We need to separate them if we
69
- // want to stay within the redux approach
70
-
71
- const handleStartUpload = fileProps => {
72
- var _editorComponent$edit;
73
-
74
- Bridge.focusEditor(ed.rceWrapper);
75
- const editorComponent = Bridge.activeEditor();
76
- uploadBookmark = editorComponent === null || editorComponent === void 0 ? void 0 : (_editorComponent$edit = editorComponent.editor) === null || _editorComponent$edit === void 0 ? void 0 : _editorComponent$edit.selection.getBookmark(2, true);
77
- Bridge.insertImagePlaceholder(fileProps);
78
- handleDismiss();
79
- };
80
-
81
- const trayProps = Bridge.trayProps.get(ed);
82
- ReactDOM.render( /*#__PURE__*/React.createElement(StoreProvider, trayProps, contentProps => /*#__PURE__*/React.createElement(UploadMedia, {
83
- "data-mce-component": true,
84
- rcsConfig: {
85
- contextType: ed.settings.canvas_rce_user_context.type,
86
- contextId: ed.settings.canvas_rce_user_context.id,
87
- origin: originFromHost(contentProps.host),
88
- headers: headerFor(contentProps.jwt)
89
- },
90
- userLocale: Bridge.userLocale,
91
- mountNode: instuiPopupMountNode,
92
- open: true,
93
- liveRegion: () => document.getElementById('flash_screenreader_holder'),
94
- onStartUpload: fileProps => handleStartUpload(fileProps),
95
- onUploadComplete: (err, data) => handleUpload(err, data, contentProps.mediaUploadComplete, uploadBookmark),
96
- onDismiss: handleDismiss,
97
- tabs: {
98
- record: true,
99
- upload: true
100
- },
101
- uploadMediaTranslations: Bridge.uploadMediaTranslations,
102
- media_links_use_attachment_id: RCEGlobals.getFeatures().media_links_use_attachment_id
103
- })), container);
104
- });
105
- }
@@ -1,94 +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
- // IMPORTANT!
19
- // Do not import this file directly, but get it via Bridge.uploadMediaTranslations
20
- // This is because the locale, which is lazy imported, has to be loaded and
21
- // format-message initialized before this file gets evaluated.
22
- import formatMessage from '../../../format-message';
23
- const uploadMediaTranslations = {
24
- UploadMediaStrings: {
25
- ADD_CLOSED_CAPTIONS_OR_SUBTITLES: formatMessage('Add CC/Subtitles'),
26
- CLEAR_FILE_TEXT: formatMessage('Clear selected file'),
27
- CLOSE_TEXT: formatMessage('Close'),
28
- CLOSED_CAPTIONS_CHOOSE_FILE: formatMessage('Choose caption file'),
29
- CLOSED_CAPTIONS_SELECT_LANGUAGE: formatMessage('Select Language'),
30
- COMPUTER_PANEL_TITLE: formatMessage('Computer'),
31
- DRAG_DROP_CLICK_TO_BROWSE: formatMessage('Drag and drop, or click to browse your computer'),
32
- DRAG_FILE_TEXT: formatMessage('Drag a file here'),
33
- EMBED_PANEL_TITLE: formatMessage('Embed'),
34
- EMBED_VIDEO_CODE_TEXT: formatMessage('Embed Code'),
35
- INVALID_FILE_TEXT: formatMessage('Invalid File'),
36
- LOADING_MEDIA: formatMessage('Loading...'),
37
- RECORD_PANEL_TITLE: formatMessage('Record'),
38
- SUBMIT_TEXT: formatMessage('Submit'),
39
- UPLOADING_ERROR: formatMessage('An error occurred uploading your media.'),
40
- UPLOAD_MEDIA_LABEL: formatMessage('Upload Media'),
41
- MEDIA_RECORD_NOT_AVAILABLE: formatMessage('Audio and video recording not supported; please use a different browser.'),
42
- SUPPORTED_FILE_TYPES: formatMessage('Supported file types: SRT or WebVTT'),
43
- NO_FILE_CHOSEN: formatMessage('No file chosen'),
44
- REMOVE_FILE: 'Remove {lang} closed captions',
45
- ADD_NEW_CAPTION_OR_SUBTITLE: formatMessage('Add another'),
46
- ADDED_CAPTION: 'Captions for {lang} added',
47
- DELETED_CAPTION: 'Deleted captions for {lang}',
48
- PROGRESS_LABEL: formatMessage('Uploading')
49
- },
50
- SelectStrings: {
51
- USE_ARROWS: 'Use arrow keys to navigate options.',
52
- LIST_COLLAPSED: 'List collapsed.',
53
- LIST_EXPANDED: 'List expanded.',
54
- OPTION_SELECTED: '{option} selected.'
55
- },
56
- // Structure copied from @instructure/media-capture translations file
57
- MediaCaptureStrings: {
58
- ARIA_TIMEBAR_LABEL: formatMessage('Timebar'),
59
- ARIA_VIDEO_LABEL: formatMessage('Video Player'),
60
- ARIA_VOLUME: formatMessage('Current Volume Level'),
61
- ARIA_RECORDING: formatMessage('Recording'),
62
- DEFAULT_ERROR: formatMessage('Something went wrong accessing your webcam.'),
63
- DEVICE_AUDIO: formatMessage('Mic'),
64
- DEVICE_VIDEO: formatMessage('Webcam'),
65
- FILE_PLACEHOLDER: formatMessage('Untitled'),
66
- FINISH: formatMessage('Finish'),
67
- WEBCAM_VIDEO_SELECTION_LABEL: formatMessage('Select video source'),
68
- WEBCAM_AUDIO_SELECTION_LABEL: formatMessage('Select audio source'),
69
- NO_WEBCAM: formatMessage('No Video'),
70
- // Modified string to match from ui/shared/media-recorder/react/components/MediaRecorder.js
71
- NOT_ALLOWED_ERROR: formatMessage('Please allow Canvas to access your microphone and webcam.'),
72
- NOT_READABLE_ERROR: formatMessage('Your webcam may already be in use.'),
73
- PLAYBACK_PAUSE: formatMessage('Pause'),
74
- PLAYBACK_PLAY: formatMessage('Play'),
75
- PREVIEW: formatMessage('PREVIEW'),
76
- SAVE_MEDIA: formatMessage('Save Media'),
77
- // Modified string to match from ui/shared/media-recorder/react/components/MediaRecorder.js
78
- SR_FILE_INPUT: formatMessage('File name'),
79
- START: formatMessage('Start Recording'),
80
- START_OVER: formatMessage('Start Over'),
81
- SCREEN_DEFAULT_ERROR: formatMessage('Something went wrong while sharing your screen.'),
82
- MIC_BLOCKED: formatMessage('Your microphone is blocked in the browser settings.'),
83
- WEBCAM_BLOCKED: formatMessage('Your webcam is blocked in the browser settings.'),
84
- MIC_AND_WEBCAM_BLOCKED: formatMessage('Your webcam and microphone are blocked in the browser settings.'),
85
- NO_MIC_EXIST: formatMessage('We couldn’t detect a working microphone connected to your device.'),
86
- NO_WEBCAM_EXIST: formatMessage('We couldn’t detect a working webcam connected to your device.'),
87
- NO_MIC_AND_WEBCAM_EXIST: formatMessage('We couldn’t detect a working webcam or microphone connected to your device.'),
88
- WEBCAM_DISABLED: formatMessage('Webcam Disabled'),
89
- MICROPHONE_DISABLED: formatMessage('Microphone Disabled'),
90
- SYSTEM_AUDIO_ALLOWED: formatMessage('System Audio Allowed'),
91
- SYSTEM_AUDIO_DISABLED: formatMessage('System Audio Disabled')
92
- }
93
- };
94
- export default uploadMediaTranslations;
@@ -1,173 +0,0 @@
1
- // @ts-nocheck
2
-
3
- /*
4
- * Copyright (C) 2018 - present Instructure, Inc.
5
- *
6
- * This file is part of Canvas.
7
- *
8
- * Canvas is free software: you can redistribute it and/or modify it under
9
- * the terms of the GNU Affero General Public License as published by the Free
10
- * Software Foundation, version 3 of the License.
11
- *
12
- * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
13
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14
- * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
15
- * details.
16
- *
17
- * You should have received a copy of the GNU Affero General Public License along
18
- * with this program. If not, see <http://www.gnu.org/licenses/>.
19
- */
20
- import clickCallback from './clickCallback';
21
- import bridge from '../../../bridge';
22
- import formatMessage from '../../../format-message';
23
- import VideoTrayController from './VideoOptionsTray/TrayController';
24
- import AudioTrayController from './AudioOptionsTray/TrayController';
25
- import { isAudioElement, isVideoElement } from '../shared/ContentSelection';
26
- import { isOKToLink } from '../../contentInsertionUtils';
27
- import tinymce from 'tinymce';
28
- const videoTrayController = new VideoTrayController();
29
- const audioTrayController = new AudioTrayController();
30
- const COURSE_PLUGIN_KEY = 'course_media';
31
- const USER_PLUGIN_KEY = 'user_media';
32
- const GROUP_PLUGIN_KEY = 'group_media';
33
-
34
- function getMenuItems(ed) {
35
- const contextType = ed.settings.canvas_rce_user_context.type;
36
- const items = [];
37
-
38
- if (ed.getParam('show_media_upload')) {
39
- // test if it's ok
40
- items.push({
41
- text: formatMessage('Upload/Record Media'),
42
- value: 'instructure_upload_media'
43
- });
44
- }
45
-
46
- if (contextType === 'course') {
47
- items.push({
48
- text: formatMessage('Course Media'),
49
- value: 'instructure_course_media'
50
- });
51
- } else if (contextType === 'group') {
52
- items.push({
53
- text: formatMessage('Group Media'),
54
- value: 'instructure_group_media'
55
- });
56
- }
57
-
58
- items.push({
59
- text: formatMessage('User Media'),
60
- value: 'instructure_user_media'
61
- });
62
- return items;
63
- }
64
-
65
- function doMenuItem(ed, value) {
66
- switch (value) {
67
- case 'instructure_upload_media':
68
- ed.execCommand('instructureRecord');
69
- break;
70
-
71
- case 'instructure_course_media':
72
- ed.focus(true);
73
- ed.execCommand('instructureTrayForMedia', false, COURSE_PLUGIN_KEY);
74
- break;
75
-
76
- case 'instructure_group_media':
77
- ed.focus(true);
78
- ed.execCommand('instructureTrayForMedia', false, GROUP_PLUGIN_KEY);
79
- break;
80
-
81
- case 'instructure_user_media':
82
- ed.focus(true);
83
- ed.execCommand('instructureTrayForMedia', false, USER_PLUGIN_KEY);
84
- break;
85
- }
86
- } // Register plugin
87
-
88
-
89
- tinymce.PluginManager.add('instructure_record', function (ed) {
90
- ed.addCommand('instructureRecord', () => clickCallback(ed, document));
91
- ed.addCommand('instructureTrayForMedia', (ui, plugin_key) => {
92
- bridge.showTrayForPlugin(plugin_key, ed.id);
93
- }); // Register menu items
94
-
95
- ed.ui.registry.addNestedMenuItem('instructure_media', {
96
- text: formatMessage('Media'),
97
- icon: 'video',
98
- getSubmenuItems: () => getMenuItems(ed).map(item => {
99
- return {
100
- type: 'menuitem',
101
- text: item.text,
102
- onAction: () => doMenuItem(ed, item.value),
103
- onSetup: api => {
104
- api.setDisabled(!isOKToLink(ed.selection.getContent()));
105
- return () => undefined;
106
- }
107
- };
108
- })
109
- }); // Register buttons
110
-
111
- ed.ui.registry.addMenuButton('instructure_record', {
112
- tooltip: formatMessage('Record/Upload Media'),
113
- icon: 'video',
114
- fetch: callback => callback(getMenuItems(ed).map(item => ({
115
- type: 'menuitem',
116
- text: item.text,
117
- value: item.value,
118
- onAction: () => doMenuItem(ed, item.value)
119
- }))),
120
-
121
- onSetup(api) {
122
- function handleNodeChange(_e) {
123
- api.setDisabled(!isOKToLink(ed.selection.getContent()));
124
- }
125
-
126
- setTimeout(handleNodeChange);
127
- ed.on('NodeChange', handleNodeChange);
128
- return () => {
129
- ed.off('NodeChange', handleNodeChange);
130
- };
131
- }
132
-
133
- });
134
- /*
135
- * Register the Video "Options" button that will open the Video Options
136
- * tray.
137
- */
138
-
139
- const buttonAriaLabel = formatMessage('Show video options');
140
- ed.ui.registry.addButton('instructure-video-options', {
141
- onAction() {
142
- // show the tray
143
- videoTrayController.showTrayForEditor(ed);
144
- },
145
-
146
- text: formatMessage('Video Options'),
147
- tooltip: buttonAriaLabel
148
- });
149
- ed.ui.registry.addContextToolbar('instructure-video-toolbar', {
150
- items: 'instructure-video-options',
151
- position: 'node',
152
- predicate: isVideoElement,
153
- scope: 'node'
154
- });
155
- ed.ui.registry.addButton('instructure-audio-options', {
156
- onAction() {
157
- audioTrayController.showTrayForEditor(ed);
158
- },
159
-
160
- text: formatMessage('Audio Options'),
161
- tooltip: formatMessage('Show audio options')
162
- });
163
- ed.ui.registry.addContextToolbar('instructure-audio-toolbar', {
164
- items: 'instructure-audio-options',
165
- position: 'node',
166
- predicate: isAudioElement,
167
- scope: 'node'
168
- });
169
- ed.on('remove', editor => {
170
- audioTrayController.hideTrayForEditor(editor);
171
- videoTrayController.hideTrayForEditor(editor);
172
- });
173
- });