@instructure/canvas-rce 5.12.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 (476) hide show
  1. package/CHANGELOG.md +8 -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/enhance-user-content/doc_previews.js +4 -0
  6. package/es/enhance-user-content/enhance_user_content.js +4 -59
  7. package/es/enhance-user-content/external_links.js +75 -0
  8. package/es/enhance-user-content/mathml.js +9 -7
  9. package/es/index.js +1 -1
  10. package/es/rce/RCEWrapper.js +3 -2322
  11. package/es/rce/plugins/instructure_equation/EquationEditorModal/index.js +1 -1
  12. package/es/rce/plugins/instructure_equation/EquationEditorModal/styles.js +3 -11
  13. package/es/rce/plugins/instructure_equation/mathlive/index.js +5 -13
  14. package/es/rce/tinymce.oxide.content.min.css.js +732 -0
  15. package/es/rce/tinymce.oxide.skin.min.css.js +7 -0
  16. package/jest.config.js +0 -7
  17. package/package.json +1 -5
  18. package/scripts/build.js +1 -7
  19. package/lib/bridge/Bridge.js +0 -287
  20. package/lib/bridge/index.js +0 -21
  21. package/lib/canvasFileBrowser/FileBrowser.js +0 -457
  22. package/lib/canvasFileBrowser/en-US.js +0 -234
  23. package/lib/common/FlashAlert.js +0 -263
  24. package/lib/common/browser.js +0 -40
  25. package/lib/common/components/FileTree/File.js +0 -64
  26. package/lib/common/components/FileTree/Folder.js +0 -110
  27. package/lib/common/components/FileTree/index.js +0 -84
  28. package/lib/common/components/FileTree/styles.js +0 -72
  29. package/lib/common/components/Loading.js +0 -83
  30. package/lib/common/fileUrl.js +0 -152
  31. package/lib/common/getCookie.js +0 -32
  32. package/lib/common/incremental-loading/LoadMoreButton.js +0 -40
  33. package/lib/common/incremental-loading/LoadingIndicator.js +0 -36
  34. package/lib/common/incremental-loading/LoadingStatus.js +0 -47
  35. package/lib/common/incremental-loading/index.js +0 -21
  36. package/lib/common/incremental-loading/useIncrementalLoading.js +0 -58
  37. package/lib/common/indicate.js +0 -75
  38. package/lib/common/mimeClass.js +0 -120
  39. package/lib/common/natcompare.js +0 -47
  40. package/lib/defaultTinymceConfig.js +0 -160
  41. package/lib/elementDenylist.js +0 -19
  42. package/lib/enhance-user-content/doc_previews.js +0 -233
  43. package/lib/enhance-user-content/enhance_user_content.js +0 -396
  44. package/lib/enhance-user-content/index.js +0 -21
  45. package/lib/enhance-user-content/instructure_helper.js +0 -207
  46. package/lib/enhance-user-content/jqueryish_funcs.js +0 -88
  47. package/lib/enhance-user-content/mathml.js +0 -397
  48. package/lib/enhance-user-content/media_comment_thumbnail.js +0 -130
  49. package/lib/format-message.js +0 -30
  50. package/lib/getThemeVars.js +0 -46
  51. package/lib/getTranslations.js +0 -340
  52. package/lib/index.js +0 -51
  53. package/lib/rce/AlertMessageArea.js +0 -47
  54. package/lib/rce/DraggingBlocker.js +0 -43
  55. package/lib/rce/KeyboardShortcutModal.js +0 -88
  56. package/lib/rce/RCE.js +0 -150
  57. package/lib/rce/RCEGlobals.js +0 -62
  58. package/lib/rce/RCEWrapper.js +0 -4274
  59. package/lib/rce/RCEWrapperProps.js +0 -130
  60. package/lib/rce/RceHtmlEditor.js +0 -142
  61. package/lib/rce/ResizeHandle.js +0 -102
  62. package/lib/rce/RestoreAutoSaveModal.js +0 -82
  63. package/lib/rce/ShowOnFocusButton/index.js +0 -93
  64. package/lib/rce/StatusBar.js +0 -386
  65. package/lib/rce/__mocks__/_mockCryptoEs.js +0 -124
  66. package/lib/rce/__mocks__/styleMock.js +0 -18
  67. package/lib/rce/__mocks__/tinymceReact.js +0 -55
  68. package/lib/rce/alertHandler.js +0 -46
  69. package/lib/rce/contentInsertion.js +0 -325
  70. package/lib/rce/contentInsertionUtils.js +0 -85
  71. package/lib/rce/contentRendering.js +0 -145
  72. package/lib/rce/customEvents.js +0 -18
  73. package/lib/rce/editorLanguage.js +0 -101
  74. package/lib/rce/indicatorRegion.js +0 -49
  75. package/lib/rce/normalizeLocale.js +0 -50
  76. package/lib/rce/normalizeProps.js +0 -29
  77. package/lib/rce/plugins/instructure-ui-icons/plugin.js +0 -122
  78. package/lib/rce/plugins/instructure_condensed_buttons/core/ListUtils.js +0 -24
  79. package/lib/rce/plugins/instructure_condensed_buttons/plugin.js +0 -27
  80. package/lib/rce/plugins/instructure_condensed_buttons/ui/alignment-button.js +0 -63
  81. package/lib/rce/plugins/instructure_condensed_buttons/ui/directionality-button.js +0 -48
  82. package/lib/rce/plugins/instructure_condensed_buttons/ui/indent-outdent-button.js +0 -41
  83. package/lib/rce/plugins/instructure_condensed_buttons/ui/list-button.js +0 -145
  84. package/lib/rce/plugins/instructure_condensed_buttons/ui/subscript-superscript-button.js +0 -56
  85. package/lib/rce/plugins/instructure_documents/clickCallback.js +0 -23
  86. package/lib/rce/plugins/instructure_documents/components/DocumentsPanel.js +0 -120
  87. package/lib/rce/plugins/instructure_documents/components/Link.js +0 -219
  88. package/lib/rce/plugins/instructure_documents/plugin.js +0 -123
  89. package/lib/rce/plugins/instructure_equation/EquationEditorModal/advancedOnlySyntax.js +0 -25
  90. package/lib/rce/plugins/instructure_equation/EquationEditorModal/advancedPreference.js +0 -51
  91. package/lib/rce/plugins/instructure_equation/EquationEditorModal/index.js +0 -321
  92. package/lib/rce/plugins/instructure_equation/EquationEditorModal/latexTextareaUtil.js +0 -116
  93. package/lib/rce/plugins/instructure_equation/EquationEditorModal/parseLatex.js +0 -91
  94. package/lib/rce/plugins/instructure_equation/EquationEditorModal/styles.js +0 -46
  95. package/lib/rce/plugins/instructure_equation/EquationEditorToolbar/buttons.js +0 -728
  96. package/lib/rce/plugins/instructure_equation/EquationEditorToolbar/index.js +0 -84
  97. package/lib/rce/plugins/instructure_equation/MathIcon/index.js +0 -41
  98. package/lib/rce/plugins/instructure_equation/MathIcon/svgs.js +0 -236
  99. package/lib/rce/plugins/instructure_equation/clickCallback.js +0 -53
  100. package/lib/rce/plugins/instructure_equation/mathlive/index.js +0 -36
  101. package/lib/rce/plugins/instructure_equation/plugin.js +0 -69
  102. package/lib/rce/plugins/instructure_fullscreen/plugin.js +0 -50
  103. package/lib/rce/plugins/instructure_html_view/clickCallback.js +0 -21
  104. package/lib/rce/plugins/instructure_html_view/plugin.js +0 -37
  105. package/lib/rce/plugins/instructure_icon_maker/clickCallback.js +0 -57
  106. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ColorSection.js +0 -82
  107. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/CreateIconMakerForm.js +0 -56
  108. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Footer.js +0 -78
  109. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Group.js +0 -36
  110. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Header.js +0 -110
  111. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/Course.js +0 -169
  112. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/ImageOptions.js +0 -186
  113. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/ImageSection.js +0 -243
  114. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/ModeSelect.js +0 -64
  115. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/MultiColor/index.js +0 -73
  116. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/MultiColor/svg.js +0 -298
  117. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SVGList.js +0 -86
  118. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SVGThumbnail.js +0 -55
  119. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SingleColor/index.js +0 -70
  120. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/SingleColor/svg.js +0 -317
  121. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/Upload.js +0 -149
  122. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/index.js +0 -18
  123. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/propTypes.js +0 -32
  124. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ImageSection/utils.js +0 -25
  125. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/Preview.js +0 -60
  126. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/ShapeSection.js +0 -87
  127. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/TextSection.js +0 -139
  128. package/lib/rce/plugins/instructure_icon_maker/components/CreateIconMakerForm/index.js +0 -18
  129. package/lib/rce/plugins/instructure_icon_maker/components/IconMakerTray.js +0 -323
  130. package/lib/rce/plugins/instructure_icon_maker/components/SavedIconMakerList.js +0 -91
  131. package/lib/rce/plugins/instructure_icon_maker/plugin.js +0 -110
  132. package/lib/rce/plugins/instructure_icon_maker/reducers/imageSection.js +0 -194
  133. package/lib/rce/plugins/instructure_icon_maker/reducers/svgSettings.js +0 -98
  134. package/lib/rce/plugins/instructure_icon_maker/registerEditToolbar.js +0 -56
  135. package/lib/rce/plugins/instructure_icon_maker/svg/clipPath.js +0 -25
  136. package/lib/rce/plugins/instructure_icon_maker/svg/constants.js +0 -100
  137. package/lib/rce/plugins/instructure_icon_maker/svg/font.js +0 -25
  138. package/lib/rce/plugins/instructure_icon_maker/svg/image.js +0 -354
  139. package/lib/rce/plugins/instructure_icon_maker/svg/index.js +0 -122
  140. package/lib/rce/plugins/instructure_icon_maker/svg/metadata.js +0 -48
  141. package/lib/rce/plugins/instructure_icon_maker/svg/settings.js +0 -179
  142. package/lib/rce/plugins/instructure_icon_maker/svg/shape.js +0 -316
  143. package/lib/rce/plugins/instructure_icon_maker/svg/text.js +0 -468
  144. package/lib/rce/plugins/instructure_icon_maker/svg/utils.js +0 -70
  145. package/lib/rce/plugins/instructure_icon_maker/utils/IconMakerClose.js +0 -45
  146. package/lib/rce/plugins/instructure_icon_maker/utils/IconMakerFormHasChanges.js +0 -83
  147. package/lib/rce/plugins/instructure_icon_maker/utils/addIconMakerAttributes.js +0 -28
  148. package/lib/rce/plugins/instructure_icon_maker/utils/iconValidation.js +0 -35
  149. package/lib/rce/plugins/instructure_icon_maker/utils/iconsLabels.js +0 -375
  150. package/lib/rce/plugins/instructure_icon_maker/utils/useDebouncedValue.js +0 -59
  151. package/lib/rce/plugins/instructure_image/ImageEmbedOptions.js +0 -202
  152. package/lib/rce/plugins/instructure_image/ImageList/Image.js +0 -106
  153. package/lib/rce/plugins/instructure_image/ImageList/index.js +0 -69
  154. package/lib/rce/plugins/instructure_image/ImageOptionsTray/TrayController.js +0 -166
  155. package/lib/rce/plugins/instructure_image/ImageOptionsTray/index.js +0 -246
  156. package/lib/rce/plugins/instructure_image/Images/index.js +0 -122
  157. package/lib/rce/plugins/instructure_image/clickCallback.js +0 -24
  158. package/lib/rce/plugins/instructure_image/plugin.js +0 -157
  159. package/lib/rce/plugins/instructure_links/clickCallback.js +0 -22
  160. package/lib/rce/plugins/instructure_links/components/AccordionSection.js +0 -60
  161. package/lib/rce/plugins/instructure_links/components/CollectionPanel.js +0 -84
  162. package/lib/rce/plugins/instructure_links/components/Link.js +0 -213
  163. package/lib/rce/plugins/instructure_links/components/LinkOptionsDialog/LinkOptionsDialogController.js +0 -127
  164. package/lib/rce/plugins/instructure_links/components/LinkOptionsDialog/index.js +0 -141
  165. package/lib/rce/plugins/instructure_links/components/LinkOptionsTray/LinkOptionsTrayController.js +0 -125
  166. package/lib/rce/plugins/instructure_links/components/LinkOptionsTray/index.js +0 -245
  167. package/lib/rce/plugins/instructure_links/components/LinkSet.js +0 -195
  168. package/lib/rce/plugins/instructure_links/components/LinksPanel.js +0 -100
  169. package/lib/rce/plugins/instructure_links/components/NavigationPanel.js +0 -141
  170. package/lib/rce/plugins/instructure_links/components/NoResults.js +0 -87
  171. package/lib/rce/plugins/instructure_links/components/propTypes.js +0 -41
  172. package/lib/rce/plugins/instructure_links/plugin.js +0 -294
  173. package/lib/rce/plugins/instructure_links/validateURL.js +0 -70
  174. package/lib/rce/plugins/instructure_media_embed/clickCallback.js +0 -48
  175. package/lib/rce/plugins/instructure_media_embed/components/Embed.js +0 -68
  176. package/lib/rce/plugins/instructure_media_embed/plugin.js +0 -36
  177. package/lib/rce/plugins/instructure_paste/pasteMenuCommand.js +0 -117
  178. package/lib/rce/plugins/instructure_paste/plugin.js +0 -174
  179. package/lib/rce/plugins/instructure_rce_external_tools/ExternalToolsEnv.js +0 -169
  180. package/lib/rce/plugins/instructure_rce_external_tools/RceToolWrapper.js +0 -225
  181. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialog.js +0 -297
  182. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialogModal.js +0 -46
  183. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolDialog/ExternalToolDialogTray.js +0 -79
  184. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolSelectionDialog/ExternalToolSelectionDialog.js +0 -153
  185. package/lib/rce/plugins/instructure_rce_external_tools/components/ExternalToolSelectionDialog/ExternalToolSelectionItem.js +0 -94
  186. package/lib/rce/plugins/instructure_rce_external_tools/components/util/ExpandoText.js +0 -90
  187. package/lib/rce/plugins/instructure_rce_external_tools/components/util/ToolLaunchIframe.js +0 -35
  188. package/lib/rce/plugins/instructure_rce_external_tools/dialog-helper.js +0 -29
  189. package/lib/rce/plugins/instructure_rce_external_tools/helpers/tags.js +0 -55
  190. package/lib/rce/plugins/instructure_rce_external_tools/jquery/jquery.dropdownList.js +0 -172
  191. package/lib/rce/plugins/instructure_rce_external_tools/lti11-content-items/RceLti11ContentItem.js +0 -203
  192. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/Lti13ContentItemJson.js +0 -23
  193. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/RceLti13ContentItem.js +0 -111
  194. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/BaseLinkContentItem.js +0 -79
  195. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/HtmlFragmentContentItem.js +0 -47
  196. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/ImageContentItem.js +0 -57
  197. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/LinkContentItem.js +0 -26
  198. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/models/ResourceLinkContentItem.js +0 -47
  199. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/processEditorContentItems.js +0 -67
  200. package/lib/rce/plugins/instructure_rce_external_tools/lti13-content-items/rceLti13ContentItemFromJson.js +0 -48
  201. package/lib/rce/plugins/instructure_rce_external_tools/plugin.js +0 -112
  202. package/lib/rce/plugins/instructure_rce_external_tools/util/addParentFrameContextToUrl.js +0 -27
  203. package/lib/rce/plugins/instructure_record/AudioOptionsTray/TrayController.js +0 -152
  204. package/lib/rce/plugins/instructure_record/AudioOptionsTray/index.js +0 -154
  205. package/lib/rce/plugins/instructure_record/MediaPanel/index.js +0 -123
  206. package/lib/rce/plugins/instructure_record/VideoOptionsTray/TrayController.js +0 -240
  207. package/lib/rce/plugins/instructure_record/VideoOptionsTray/index.js +0 -350
  208. package/lib/rce/plugins/instructure_record/clickCallback.js +0 -105
  209. package/lib/rce/plugins/instructure_record/mediaTranslations.js +0 -94
  210. package/lib/rce/plugins/instructure_record/plugin.js +0 -173
  211. package/lib/rce/plugins/instructure_studio_media_options/plugin.js +0 -42
  212. package/lib/rce/plugins/instructure_wordcount/clickCallback.js +0 -49
  213. package/lib/rce/plugins/instructure_wordcount/components/WordCountModal.js +0 -88
  214. package/lib/rce/plugins/instructure_wordcount/plugin.js +0 -30
  215. package/lib/rce/plugins/instructure_wordcount/utils/countContent.js +0 -78
  216. package/lib/rce/plugins/instructure_wordcount/utils/tableContent.js +0 -40
  217. package/lib/rce/plugins/shared/CanvasContentTray.js +0 -580
  218. package/lib/rce/plugins/shared/CheckerboardStyling.js +0 -25
  219. package/lib/rce/plugins/shared/ColorInput.js +0 -233
  220. package/lib/rce/plugins/shared/ConditionalTooltip.js +0 -32
  221. package/lib/rce/plugins/shared/ContentSelection.js +0 -269
  222. package/lib/rce/plugins/shared/DimensionUtils.js +0 -66
  223. package/lib/rce/plugins/shared/DimensionsInput/DimensionInput.js +0 -62
  224. package/lib/rce/plugins/shared/DimensionsInput/index.js +0 -161
  225. package/lib/rce/plugins/shared/DimensionsInput/useDimensionsState.js +0 -220
  226. package/lib/rce/plugins/shared/ErrorBoundary.js +0 -54
  227. package/lib/rce/plugins/shared/EventUtils.js +0 -39
  228. package/lib/rce/plugins/shared/Filter.js +0 -353
  229. package/lib/rce/plugins/shared/FixedContentTray.js +0 -115
  230. package/lib/rce/plugins/shared/ImageCropper/DirectionRegion.js +0 -67
  231. package/lib/rce/plugins/shared/ImageCropper/Modal.js +0 -153
  232. package/lib/rce/plugins/shared/ImageCropper/Preview.js +0 -148
  233. package/lib/rce/plugins/shared/ImageCropper/constants.js +0 -39
  234. package/lib/rce/plugins/shared/ImageCropper/controls/CustomNumberInput.js +0 -83
  235. package/lib/rce/plugins/shared/ImageCropper/controls/ResetControls.js +0 -38
  236. package/lib/rce/plugins/shared/ImageCropper/controls/RotationControls.js +0 -89
  237. package/lib/rce/plugins/shared/ImageCropper/controls/ShapeControls.js +0 -82
  238. package/lib/rce/plugins/shared/ImageCropper/controls/ZoomControls.js +0 -111
  239. package/lib/rce/plugins/shared/ImageCropper/controls/index.js +0 -61
  240. package/lib/rce/plugins/shared/ImageCropper/controls/useDebouncedNumericValue.js +0 -94
  241. package/lib/rce/plugins/shared/ImageCropper/controls/utils.js +0 -41
  242. package/lib/rce/plugins/shared/ImageCropper/imageCropUtils.js +0 -149
  243. package/lib/rce/plugins/shared/ImageCropper/index.js +0 -18
  244. package/lib/rce/plugins/shared/ImageCropper/propTypes.js +0 -26
  245. package/lib/rce/plugins/shared/ImageCropper/reducers/imageCropper.js +0 -72
  246. package/lib/rce/plugins/shared/ImageCropper/shape.js +0 -27
  247. package/lib/rce/plugins/shared/ImageCropper/svg/index.js +0 -89
  248. package/lib/rce/plugins/shared/ImageCropper/svg/shape.js +0 -125
  249. package/lib/rce/plugins/shared/ImageCropper/svg/utils.js +0 -26
  250. package/lib/rce/plugins/shared/ImageCropper/useKeyMouseEvents.js +0 -233
  251. package/lib/rce/plugins/shared/ImageCropper/useMouseWheel.js +0 -66
  252. package/lib/rce/plugins/shared/ImageOptionsForm.js +0 -140
  253. package/lib/rce/plugins/shared/LinkDisplay.js +0 -96
  254. package/lib/rce/plugins/shared/PreviewIcon.js +0 -112
  255. package/lib/rce/plugins/shared/Previewable.js +0 -22
  256. package/lib/rce/plugins/shared/RceFileBrowser.js +0 -106
  257. package/lib/rce/plugins/shared/StoreContext.js +0 -57
  258. package/lib/rce/plugins/shared/StudioLtiSupportUtils.js +0 -71
  259. package/lib/rce/plugins/shared/UnknownFileTypePanel.js +0 -29
  260. package/lib/rce/plugins/shared/Upload/CategoryProcessor.js +0 -27
  261. package/lib/rce/plugins/shared/Upload/ComputerPanel.js +0 -334
  262. package/lib/rce/plugins/shared/Upload/SvgCategoryProcessor.js +0 -35
  263. package/lib/rce/plugins/shared/Upload/UploadFile.js +0 -171
  264. package/lib/rce/plugins/shared/Upload/UploadFileModal.js +0 -273
  265. package/lib/rce/plugins/shared/Upload/UrlPanel.js +0 -38
  266. package/lib/rce/plugins/shared/Upload/UsageRightsSelectBox.js +0 -172
  267. package/lib/rce/plugins/shared/Upload/doFileUpload.js +0 -77
  268. package/lib/rce/plugins/shared/__mocks__/screenfull.js +0 -24
  269. package/lib/rce/plugins/shared/buildDownloadUrl.js +0 -31
  270. package/lib/rce/plugins/shared/compressionUtils.js +0 -98
  271. package/lib/rce/plugins/shared/dateUtils.js +0 -28
  272. package/lib/rce/plugins/shared/fileShape.js +0 -129
  273. package/lib/rce/plugins/shared/fileTypeUtils.js +0 -139
  274. package/lib/rce/plugins/shared/fileUtils.js +0 -25
  275. package/lib/rce/plugins/shared/linkUtils.js +0 -89
  276. package/lib/rce/plugins/shared/round.js +0 -25
  277. package/lib/rce/plugins/shared/trayUtils.js +0 -34
  278. package/lib/rce/plugins/shared/useDataUrl.js +0 -76
  279. package/lib/rce/plugins/tinymce-a11y-checker/components/ColorField.js +0 -86
  280. package/lib/rce/plugins/tinymce-a11y-checker/components/checker.js +0 -558
  281. package/lib/rce/plugins/tinymce-a11y-checker/components/color-picker.js +0 -59
  282. package/lib/rce/plugins/tinymce-a11y-checker/components/placeholder-svg.js +0 -90
  283. package/lib/rce/plugins/tinymce-a11y-checker/components/pointer.js +0 -32
  284. package/lib/rce/plugins/tinymce-a11y-checker/node-checker.js +0 -54
  285. package/lib/rce/plugins/tinymce-a11y-checker/plugin.js +0 -90
  286. package/lib/rce/plugins/tinymce-a11y-checker/rules/__mocks__/index.js +0 -53
  287. package/lib/rce/plugins/tinymce-a11y-checker/rules/adjacent-links.js +0 -129
  288. package/lib/rce/plugins/tinymce-a11y-checker/rules/headings-sequence.js +0 -200
  289. package/lib/rce/plugins/tinymce-a11y-checker/rules/headings-start-at-h2.js +0 -67
  290. package/lib/rce/plugins/tinymce-a11y-checker/rules/img-alt-filename.js +0 -63
  291. package/lib/rce/plugins/tinymce-a11y-checker/rules/img-alt-length.js +0 -49
  292. package/lib/rce/plugins/tinymce-a11y-checker/rules/img-alt.js +0 -61
  293. package/lib/rce/plugins/tinymce-a11y-checker/rules/index.js +0 -31
  294. package/lib/rce/plugins/tinymce-a11y-checker/rules/large-text-contrast.js +0 -51
  295. package/lib/rce/plugins/tinymce-a11y-checker/rules/list-structure.js +0 -144
  296. package/lib/rce/plugins/tinymce-a11y-checker/rules/paragraphs-for-headings.js +0 -61
  297. package/lib/rce/plugins/tinymce-a11y-checker/rules/small-text-contrast.js +0 -75
  298. package/lib/rce/plugins/tinymce-a11y-checker/rules/table-caption.js +0 -54
  299. package/lib/rce/plugins/tinymce-a11y-checker/rules/table-header-scope.js +0 -52
  300. package/lib/rce/plugins/tinymce-a11y-checker/rules/table-header.js +0 -81
  301. package/lib/rce/plugins/tinymce-a11y-checker/utils/colors.js +0 -43
  302. package/lib/rce/plugins/tinymce-a11y-checker/utils/describe.js +0 -66
  303. package/lib/rce/plugins/tinymce-a11y-checker/utils/dom.js +0 -160
  304. package/lib/rce/plugins/tinymce-a11y-checker/utils/indicate.js +0 -83
  305. package/lib/rce/plugins/tinymce-a11y-checker/utils/rgb-hex.js +0 -57
  306. package/lib/rce/plugins/tinymce-a11y-checker/utils/strings.js +0 -40
  307. package/lib/rce/root.js +0 -58
  308. package/lib/rce/sanitizePlugins.js +0 -32
  309. package/lib/rce/style.js +0 -843
  310. package/lib/rce/tinyRCE.js +0 -66
  311. package/lib/rce/transformContent.js +0 -73
  312. package/lib/rce/userOS.js +0 -31
  313. package/lib/rce/wrapInitCb.js +0 -78
  314. package/lib/rcs/api.js +0 -672
  315. package/lib/rcs/buildError.js +0 -98
  316. package/lib/rcs/fake.js +0 -621
  317. package/lib/sidebar/actions/all_files.js +0 -29
  318. package/lib/sidebar/actions/data.js +0 -105
  319. package/lib/sidebar/actions/documents.js +0 -107
  320. package/lib/sidebar/actions/files.js +0 -167
  321. package/lib/sidebar/actions/filter.js +0 -63
  322. package/lib/sidebar/actions/flickr.js +0 -60
  323. package/lib/sidebar/actions/images.js +0 -153
  324. package/lib/sidebar/actions/links.js +0 -23
  325. package/lib/sidebar/actions/media.js +0 -142
  326. package/lib/sidebar/actions/session.js +0 -34
  327. package/lib/sidebar/actions/ui.js +0 -49
  328. package/lib/sidebar/actions/upload.js +0 -550
  329. package/lib/sidebar/containers/Sidebar.js +0 -67
  330. package/lib/sidebar/containers/sidebarHandlers.js +0 -73
  331. package/lib/sidebar/dragHtml.js +0 -49
  332. package/lib/sidebar/reducers/all_files.js +0 -35
  333. package/lib/sidebar/reducers/collection.js +0 -72
  334. package/lib/sidebar/reducers/collections.js +0 -52
  335. package/lib/sidebar/reducers/documents.js +0 -89
  336. package/lib/sidebar/reducers/files.js +0 -38
  337. package/lib/sidebar/reducers/filter.js +0 -61
  338. package/lib/sidebar/reducers/flickr.js +0 -51
  339. package/lib/sidebar/reducers/folder.js +0 -92
  340. package/lib/sidebar/reducers/folders.js +0 -39
  341. package/lib/sidebar/reducers/images.js +0 -115
  342. package/lib/sidebar/reducers/index.js +0 -57
  343. package/lib/sidebar/reducers/media.js +0 -84
  344. package/lib/sidebar/reducers/newPageLinkExpanded.js +0 -30
  345. package/lib/sidebar/reducers/noop.js +0 -21
  346. package/lib/sidebar/reducers/rootFolderId.js +0 -30
  347. package/lib/sidebar/reducers/session.js +0 -33
  348. package/lib/sidebar/reducers/ui.js +0 -87
  349. package/lib/sidebar/reducers/upload.js +0 -206
  350. package/lib/sidebar/store/configureStore.js +0 -26
  351. package/lib/sidebar/store/initialState.js +0 -173
  352. package/lib/translations/locales/ab.js +0 -26
  353. package/lib/translations/locales/ar.js +0 -2427
  354. package/lib/translations/locales/ca.js +0 -2427
  355. package/lib/translations/locales/cs.js +0 -27
  356. package/lib/translations/locales/cs_CZ.js +0 -27
  357. package/lib/translations/locales/cy.js +0 -2427
  358. package/lib/translations/locales/da-x-k12.js +0 -2427
  359. package/lib/translations/locales/da.js +0 -2427
  360. package/lib/translations/locales/da_DK.js +0 -27
  361. package/lib/translations/locales/de.js +0 -2427
  362. package/lib/translations/locales/el.js +0 -459
  363. package/lib/translations/locales/en-AU-x-unimelb.js +0 -2427
  364. package/lib/translations/locales/en-GB-x-ukhe.js +0 -2427
  365. package/lib/translations/locales/en.js +0 -2427
  366. package/lib/translations/locales/en_AU.js +0 -2427
  367. package/lib/translations/locales/en_CA.js +0 -2426
  368. package/lib/translations/locales/en_CY.js +0 -2426
  369. package/lib/translations/locales/en_GB.js +0 -2427
  370. package/lib/translations/locales/en_NZ.js +0 -26
  371. package/lib/translations/locales/en_SE.js +0 -26
  372. package/lib/translations/locales/en_US.js +0 -26
  373. package/lib/translations/locales/es.js +0 -2427
  374. package/lib/translations/locales/es_ES.js +0 -2427
  375. package/lib/translations/locales/es_GT.js +0 -27
  376. package/lib/translations/locales/fa_IR.js +0 -615
  377. package/lib/translations/locales/fi.js +0 -2427
  378. package/lib/translations/locales/fr.js +0 -2427
  379. package/lib/translations/locales/fr_CA.js +0 -2427
  380. package/lib/translations/locales/he.js +0 -486
  381. package/lib/translations/locales/ht.js +0 -2426
  382. package/lib/translations/locales/hu.js +0 -2007
  383. package/lib/translations/locales/hu_HU.js +0 -27
  384. package/lib/translations/locales/hy.js +0 -444
  385. package/lib/translations/locales/id.js +0 -2426
  386. package/lib/translations/locales/id_ID.js +0 -26
  387. package/lib/translations/locales/is.js +0 -2426
  388. package/lib/translations/locales/it.js +0 -2427
  389. package/lib/translations/locales/ja.js +0 -2427
  390. package/lib/translations/locales/ko.js +0 -342
  391. package/lib/translations/locales/ko_KR.js +0 -27
  392. package/lib/translations/locales/lt.js +0 -26
  393. package/lib/translations/locales/lt_LT.js +0 -26
  394. package/lib/translations/locales/mi.js +0 -2426
  395. package/lib/translations/locales/mn_MN.js +0 -26
  396. package/lib/translations/locales/ms.js +0 -2426
  397. package/lib/translations/locales/nb-x-k12.js +0 -2427
  398. package/lib/translations/locales/nb.js +0 -2427
  399. package/lib/translations/locales/nl.js +0 -2427
  400. package/lib/translations/locales/nl_NL.js +0 -27
  401. package/lib/translations/locales/nn.js +0 -2247
  402. package/lib/translations/locales/pl.js +0 -2427
  403. package/lib/translations/locales/pt.js +0 -2427
  404. package/lib/translations/locales/pt_BR.js +0 -2427
  405. package/lib/translations/locales/ro.js +0 -27
  406. package/lib/translations/locales/ru.js +0 -2427
  407. package/lib/translations/locales/se.js +0 -26
  408. package/lib/translations/locales/sl.js +0 -2427
  409. package/lib/translations/locales/sv-x-k12.js +0 -2427
  410. package/lib/translations/locales/sv.js +0 -2427
  411. package/lib/translations/locales/sv_SE.js +0 -27
  412. package/lib/translations/locales/tg.js +0 -26
  413. package/lib/translations/locales/th.js +0 -2427
  414. package/lib/translations/locales/th_TH.js +0 -27
  415. package/lib/translations/locales/tl_PH.js +0 -26
  416. package/lib/translations/locales/tr.js +0 -687
  417. package/lib/translations/locales/uk_UA.js +0 -519
  418. package/lib/translations/locales/vi.js +0 -2427
  419. package/lib/translations/locales/vi_VN.js +0 -27
  420. package/lib/translations/locales/zh-Hans.js +0 -2427
  421. package/lib/translations/locales/zh-Hant.js +0 -2427
  422. package/lib/translations/locales/zh.js +0 -2427
  423. package/lib/translations/locales/zh_HK.js +0 -2427
  424. package/lib/translations/locales/zh_TW.Big5.js +0 -27
  425. package/lib/translations/locales/zh_TW.js +0 -27
  426. package/lib/translations/tinymce/ar_SA.js +0 -211
  427. package/lib/translations/tinymce/bg_BG.js +0 -419
  428. package/lib/translations/tinymce/ca.js +0 -419
  429. package/lib/translations/tinymce/cs.js +0 -419
  430. package/lib/translations/tinymce/cy.js +0 -418
  431. package/lib/translations/tinymce/da.js +0 -419
  432. package/lib/translations/tinymce/de.js +0 -419
  433. package/lib/translations/tinymce/el.js +0 -261
  434. package/lib/translations/tinymce/en_GB.js +0 -230
  435. package/lib/translations/tinymce/es.js +0 -419
  436. package/lib/translations/tinymce/fa_IR.js +0 -390
  437. package/lib/translations/tinymce/fi.js +0 -19
  438. package/lib/translations/tinymce/fr_FR.js +0 -419
  439. package/lib/translations/tinymce/he_IL.js +0 -420
  440. package/lib/translations/tinymce/hu_HU.js +0 -419
  441. package/lib/translations/tinymce/hy.js +0 -419
  442. package/lib/translations/tinymce/it.js +0 -419
  443. package/lib/translations/tinymce/ja.js +0 -419
  444. package/lib/translations/tinymce/ko_KR.js +0 -419
  445. package/lib/translations/tinymce/nb_NO.js +0 -419
  446. package/lib/translations/tinymce/nl.js +0 -419
  447. package/lib/translations/tinymce/pl.js +0 -419
  448. package/lib/translations/tinymce/pt_BR.js +0 -419
  449. package/lib/translations/tinymce/pt_PT.js +0 -419
  450. package/lib/translations/tinymce/ro.js +0 -418
  451. package/lib/translations/tinymce/ru.js +0 -436
  452. package/lib/translations/tinymce/ru_RU.js +0 -71
  453. package/lib/translations/tinymce/sl.js +0 -462
  454. package/lib/translations/tinymce/sr.js +0 -278
  455. package/lib/translations/tinymce/sv_SE.js +0 -419
  456. package/lib/translations/tinymce/th.js +0 -479
  457. package/lib/translations/tinymce/tr_TR.js +0 -389
  458. package/lib/translations/tinymce/uk_UA.js +0 -278
  459. package/lib/translations/tinymce/vi_VN.js +0 -277
  460. package/lib/translations/tinymce/zh_CN.js +0 -419
  461. package/lib/translations/tinymce/zh_TW.js +0 -419
  462. package/lib/util/DeepPartialNullable.js +0 -1
  463. package/lib/util/ExtractRequired.js +0 -1
  464. package/lib/util/TypedDict.js +0 -131
  465. package/lib/util/assertNever.js +0 -44
  466. package/lib/util/elem-util.js +0 -26
  467. package/lib/util/encrypted-storage.js +0 -84
  468. package/lib/util/file-url-util.js +0 -44
  469. package/lib/util/fullscreenHelpers.js +0 -27
  470. package/lib/util/instui-icon-helper.js +0 -31
  471. package/lib/util/loadingPlaceholder.js +0 -436
  472. package/lib/util/simpleCache.js +0 -41
  473. package/lib/util/string-util.js +0 -48
  474. package/lib/util/textarea-editing-util.js +0 -87
  475. package/lib/util/tinymce-plugin-util.js +0 -52
  476. package/lib/util/url-util.js +0 -138
@@ -1,106 +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 { func, instanceOf, number, oneOfType, shape, string, bool } from 'prop-types';
20
- import { Img } from '@instructure/ui-img';
21
- import { Link } from '@instructure/ui-link';
22
- import { Text } from '@instructure/ui-text';
23
- import { TruncateText } from '@instructure/ui-truncate-text';
24
- import { View } from '@instructure/ui-view';
25
- import dragHtml from '../../../../sidebar/dragHtml';
26
- import formatMessage from '../../../../format-message';
27
- import { renderImage } from '../../../contentRendering';
28
- export default function Image(_ref) {
29
- let {
30
- focusRef,
31
- image,
32
- onClick,
33
- isIconMaker,
34
- canvasOrigin
35
- } = _ref;
36
- const imgTitle = formatMessage('Click to embed {imageName}', {
37
- imageName: image.display_name
38
- });
39
-
40
- function handleDragStart(event) {
41
- dragHtml(event, renderImage(image, canvasOrigin));
42
- }
43
-
44
- function handleDragEnd() {
45
- document.body.click();
46
- }
47
-
48
- function handleImageClick(event) {
49
- event.preventDefault();
50
- onClick(image);
51
- }
52
-
53
- let elementRef = null;
54
-
55
- if (focusRef) {
56
- elementRef = ref => {
57
- focusRef.current = ref;
58
- };
59
- }
60
-
61
- return /*#__PURE__*/React.createElement(Link, {
62
- draggable: false,
63
- elementRef: elementRef,
64
- onClick: handleImageClick,
65
- onDragStart: handleDragStart
66
- }, /*#__PURE__*/React.createElement(View, {
67
- as: "div",
68
- borderRadius: "medium",
69
- margin: "none none small none",
70
- overflowX: "hidden",
71
- overflowY: "hidden"
72
- }, /*#__PURE__*/React.createElement(Img, {
73
- alt: image.display_name,
74
- constrain: isIconMaker ? 'contain' : 'cover',
75
- draggable: true,
76
- height: "6rem",
77
- display: "block",
78
- onDragStart: handleDragStart,
79
- onDragEnd: handleDragEnd,
80
- src: image.thumbnail_url,
81
- title: imgTitle,
82
- width: "6rem"
83
- })), /*#__PURE__*/React.createElement(TruncateText, null, /*#__PURE__*/React.createElement(Text, {
84
- size: "small"
85
- }, image.display_name)));
86
- }
87
- Image.propTypes = {
88
- focusRef: shape({
89
- current: instanceOf(Element)
90
- }),
91
- image: shape({
92
- display_name: string.isRequired,
93
- filename: string,
94
- href: string.isRequired,
95
- id: oneOfType([number, string]),
96
- preview_url: string,
97
- thumbnail_url: string.isRequired
98
- }).isRequired,
99
- onClick: func.isRequired,
100
- isIconMaker: bool,
101
- canvasOrigin: string.isRequired
102
- };
103
- Image.defaultProps = {
104
- focusRef: null,
105
- isIconMaker: false
106
- };
@@ -1,69 +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 { arrayOf, func, instanceOf, shape, bool, string } from 'prop-types';
20
- import { Flex } from '@instructure/ui-flex';
21
- import Image from './Image';
22
- export default function ImageList(_ref) {
23
- let {
24
- images,
25
- lastItemRef,
26
- onImageClick,
27
- isIconMaker,
28
- canvasOrigin
29
- } = _ref;
30
- return /*#__PURE__*/React.createElement(Flex, {
31
- justifyItems: "start",
32
- height: "100%",
33
- margin: "xx-small",
34
- padding: "small",
35
- wrap: "wrap"
36
- }, images.map((image, index) => {
37
- let focusRef = null;
38
-
39
- if (index === images.length - 1) {
40
- focusRef = lastItemRef;
41
- }
42
-
43
- return /*#__PURE__*/React.createElement(Flex.Item, {
44
- as: "div",
45
- key: 'image-' + image.id,
46
- margin: "xx-small xx-small small xx-small",
47
- size: "6rem"
48
- }, /*#__PURE__*/React.createElement(Image, {
49
- focusRef: focusRef,
50
- image: image,
51
- onClick: onImageClick,
52
- isIconMaker: isIconMaker,
53
- canvasOrigin: canvasOrigin
54
- }));
55
- }));
56
- }
57
- ImageList.propTypes = {
58
- images: arrayOf(Image.propTypes.image),
59
- lastItemRef: shape({
60
- current: instanceOf(Element)
61
- }).isRequired,
62
- onImageClick: func.isRequired,
63
- isIconMaker: bool,
64
- canvasOrigin: string.isRequired
65
- };
66
- ImageList.defaultProps = {
67
- images: [],
68
- isIconMaker: false
69
- };
@@ -1,166 +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 { asImageEmbed } from '../../shared/ContentSelection';
22
- import { renderLink, updateImage } from '../../../contentRendering';
23
- import ImageOptionsTray from '.';
24
- export const CONTAINER_ID = 'instructure-image-options-tray-container';
25
- export default class TrayController {
26
- constructor() {
27
- this._editor = null;
28
- this._isOpen = false;
29
- this._shouldOpen = false;
30
- this._renderId = 0;
31
- this._isIconMaker = false;
32
- }
33
-
34
- get $container() {
35
- let $container = document.getElementById(CONTAINER_ID);
36
-
37
- if ($container == null) {
38
- $container = document.createElement('div');
39
- $container.id = CONTAINER_ID;
40
- document.body.appendChild($container);
41
- }
42
-
43
- return $container;
44
- }
45
-
46
- get isOpen() {
47
- return this._isOpen;
48
- } // Tray may be called to edit an Icon Maker icon alt text
49
-
50
-
51
- showTrayForEditor(editor) {
52
- let isIconMaker = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
53
- this._editor = editor;
54
- this.$img = editor.selection.getNode();
55
- this._shouldOpen = true;
56
- this._isIconMaker = isIconMaker;
57
-
58
- if (bridge.focusedEditor) {
59
- // Dismiss any content trays that may already be open
60
- bridge.hideTrays();
61
- }
62
-
63
- this._renderTray();
64
- }
65
-
66
- hideTrayForEditor(editor) {
67
- if (this._editor === editor) {
68
- this._dismissTray();
69
- }
70
- }
71
-
72
- _applyImageOptions(imageOptions) {
73
- const editor = this._editor;
74
- const {
75
- $img
76
- } = this;
77
-
78
- if (this._isIconMaker) {
79
- this._applyIconAltTextChanges($img, editor, imageOptions);
80
-
81
- this._dismissTray();
82
-
83
- editor.focus();
84
- return;
85
- }
86
-
87
- if (imageOptions.displayAs === 'embed') {
88
- updateImage(editor, $img, imageOptions); // tell tinymce so the context toolbar resets
89
-
90
- editor.fire('ObjectResized', {
91
- target: $img,
92
- width: imageOptions.appliedWidth,
93
- height: imageOptions.appliedHeight
94
- });
95
- } else {
96
- const link = renderLink({
97
- href: $img.src,
98
- text: imageOptions.altText || $img.src,
99
- target: '_blank'
100
- });
101
- editor.selection.setContent(link);
102
- }
103
-
104
- this._dismissTray();
105
-
106
- editor.focus();
107
- }
108
-
109
- _applyIconAltTextChanges($img, editor, imageOptions) {
110
- // Workaround: When passing empty string to editor.dom.setAttribs it removes the attribute
111
- $img.setAttribute('alt', imageOptions.altText);
112
- editor.dom.setAttribs($img, {
113
- role: imageOptions.isDecorativeImage ? 'presentation' : null
114
- }); // tell tinymce so the context toolbar resets
115
-
116
- editor.fire('ObjectResized', {
117
- target: $img,
118
- width: imageOptions.appliedWidth,
119
- height: imageOptions.appliedHeight
120
- });
121
- }
122
-
123
- _dismissTray() {
124
- this._shouldOpen = false;
125
-
126
- this._renderTray();
127
-
128
- this.$img = null;
129
- this._editor = null;
130
- }
131
-
132
- _renderTray() {
133
- var _this$_editor, _this$_editor$selecti;
134
-
135
- if (this._shouldOpen) {
136
- /*
137
- * When the tray is being opened again, it should be rendered fresh
138
- * (clearing the internal state) so that the currently-selected image can
139
- * be used for initial image options.
140
- */
141
- this._renderId++;
142
- }
143
-
144
- const io = asImageEmbed(this.$img);
145
- io.isLinked = ((_this$_editor = this._editor) === null || _this$_editor === void 0 ? void 0 : (_this$_editor$selecti = _this$_editor.selection) === null || _this$_editor$selecti === void 0 ? void 0 : _this$_editor$selecti.getSel().anchorNode.tagName) === 'A';
146
- const element = /*#__PURE__*/React.createElement(ImageOptionsTray, {
147
- key: this._renderId,
148
- imageOptions: io,
149
- onEntered: () => {
150
- this._isOpen = true;
151
- },
152
- onExited: () => {
153
- bridge.focusActiveEditor(false);
154
- this._isOpen = false;
155
- },
156
- onSave: imageOptions => {
157
- this._applyImageOptions(imageOptions);
158
- },
159
- onRequestClose: () => this._dismissTray(),
160
- open: this._shouldOpen,
161
- isIconMaker: this._isIconMaker
162
- });
163
- ReactDOM.render(element, this.$container);
164
- }
165
-
166
- }
@@ -1,246 +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, useEffect } from 'react';
19
- import { bool, func, number, shape, string } from 'prop-types';
20
- import { Button, CloseButton } from '@instructure/ui-buttons';
21
- import { Heading } from '@instructure/ui-heading';
22
- import { Flex } from '@instructure/ui-flex';
23
- import { Tray } from '@instructure/ui-tray';
24
- import { CUSTOM, MIN_HEIGHT, MIN_WIDTH, MIN_PERCENTAGE, scaleToSize } from '../ImageEmbedOptions';
25
- import formatMessage from '../../../../format-message';
26
- import { useDimensionsState } from '../../shared/DimensionsInput';
27
- import ImageOptionsForm from '../../shared/ImageOptionsForm';
28
- import { getTrayHeight, isExternalUrl } from '../../shared/trayUtils';
29
- import validateURL from '../../instructure_links/validateURL';
30
- import UrlPanel from '../../shared/Upload/UrlPanel';
31
- import { instuiPopupMountNode } from '../../../../util/fullscreenHelpers';
32
- export default function ImageOptionsTray(props) {
33
- const {
34
- imageOptions,
35
- onEntered,
36
- onExited,
37
- onRequestClose,
38
- onSave,
39
- open,
40
- isIconMaker
41
- } = props;
42
- const {
43
- naturalHeight,
44
- naturalWidth,
45
- isLinked
46
- } = imageOptions;
47
- const currentHeight = imageOptions.appliedHeight || naturalHeight;
48
- const currentWidth = imageOptions.appliedWidth || naturalWidth;
49
- const [url, setUrl] = useState(imageOptions.url);
50
- const [showUrlField, setShowUrlField] = useState(false);
51
- const [altText, setAltText] = useState(imageOptions.altText);
52
- const [isDecorativeImage, setIsDecorativeImage] = useState(imageOptions.isDecorativeImage);
53
- const [displayAs, setDisplayAs] = useState('embed');
54
- const [imageSize, setImageSize] = useState(imageOptions.imageSize);
55
- const [imageHeight, setImageHeight] = useState(currentHeight);
56
- const [imageWidth, setImageWidth] = useState(currentWidth);
57
- const dimensionsState = useDimensionsState(imageOptions, {
58
- minHeight: MIN_HEIGHT,
59
- minWidth: MIN_WIDTH,
60
- minPercentage: MIN_PERCENTAGE
61
- });
62
-
63
- function handleUrlChange(newUrl) {
64
- setUrl(newUrl);
65
- }
66
-
67
- function handleAltTextChange(event) {
68
- setAltText(event.target.value);
69
- }
70
-
71
- function handleIsDecorativeChange(event) {
72
- setIsDecorativeImage(event.target.checked);
73
- }
74
-
75
- function handleDisplayAsChange(event) {
76
- setDisplayAs(event.target.value);
77
- }
78
-
79
- function handleImageSizeChange(event, selectedOption) {
80
- setImageSize(selectedOption.value);
81
-
82
- if (selectedOption.value === CUSTOM) {
83
- setImageHeight(currentHeight);
84
- setImageWidth(currentWidth);
85
- } else {
86
- const {
87
- height,
88
- width
89
- } = scaleToSize(selectedOption.value, naturalWidth, naturalHeight);
90
- setImageHeight(height);
91
- setImageWidth(width);
92
- }
93
- }
94
-
95
- function handleSave(event) {
96
- event.preventDefault();
97
- const savedAltText = isDecorativeImage ? '' : altText;
98
- let appliedHeight = imageHeight;
99
- let appliedWidth = imageWidth;
100
-
101
- if (imageSize === CUSTOM) {
102
- if (dimensionsState.usePercentageUnits) {
103
- appliedHeight = `${dimensionsState.percentage}%`;
104
- appliedWidth = `${dimensionsState.percentage}%`;
105
- } else {
106
- appliedHeight = dimensionsState.height;
107
- appliedWidth = dimensionsState.width;
108
- }
109
- }
110
-
111
- onSave({
112
- url,
113
- altText: savedAltText,
114
- appliedHeight,
115
- appliedWidth,
116
- displayAs,
117
- isDecorativeImage
118
- });
119
- }
120
-
121
- useEffect(() => {
122
- if (isIconMaker) {
123
- setShowUrlField(false);
124
- return;
125
- }
126
-
127
- let isValidURL;
128
-
129
- try {
130
- isValidURL = validateURL(url);
131
- } catch (error) {
132
- isValidURL = false;
133
- } finally {
134
- setShowUrlField(isValidURL ? isExternalUrl(url) : true);
135
- } // eslint-disable-next-line react-hooks/exhaustive-deps
136
-
137
- }, [url]);
138
- const messagesForSize = [];
139
-
140
- if (imageSize !== CUSTOM) {
141
- messagesForSize.push({
142
- text: formatMessage('{width} x {height}px', {
143
- height: imageHeight,
144
- width: imageWidth
145
- }),
146
- type: 'hint'
147
- });
148
- }
149
-
150
- const disableForIcons = isIconMaker && !isDecorativeImage && altText === '';
151
- const disableForImages = url === '' || displayAs === 'embed' && (!isDecorativeImage && altText === '' || imageSize === CUSTOM && !(dimensionsState !== null && dimensionsState !== void 0 && dimensionsState.isValid));
152
- const saveDisabled = isIconMaker ? disableForIcons : disableForImages;
153
- const trayLabel = isIconMaker ? formatMessage('Icon Options Tray') : formatMessage('Image Options Tray');
154
- const trayHeading = isIconMaker ? formatMessage('Icon Options') : formatMessage('Image Options');
155
- return /*#__PURE__*/React.createElement(Tray, {
156
- "data-mce-component": true,
157
- label: trayLabel,
158
- mountNode: instuiPopupMountNode,
159
- onDismiss: onRequestClose,
160
- onEntered: onEntered,
161
- onExited: onExited,
162
- open: open,
163
- placement: "end",
164
- shouldCloseOnDocumentClick: true,
165
- shouldContainFocus: true,
166
- shouldReturnFocus: true
167
- }, /*#__PURE__*/React.createElement(Flex, {
168
- direction: "column",
169
- height: getTrayHeight()
170
- }, /*#__PURE__*/React.createElement(Flex.Item, {
171
- as: "header",
172
- padding: "medium"
173
- }, /*#__PURE__*/React.createElement(Flex, {
174
- direction: "row"
175
- }, /*#__PURE__*/React.createElement(Flex.Item, {
176
- shouldGrow: true,
177
- shouldShrink: true
178
- }, /*#__PURE__*/React.createElement(Heading, {
179
- as: "h2"
180
- }, trayHeading)), /*#__PURE__*/React.createElement(Flex.Item, null, /*#__PURE__*/React.createElement(CloseButton, {
181
- color: "primary",
182
- onClick: onRequestClose,
183
- screenReaderLabel: formatMessage('Close')
184
- })))), /*#__PURE__*/React.createElement(Flex.Item, {
185
- as: "form",
186
- shouldGrow: true,
187
- margin: "none",
188
- shouldShrink: true
189
- }, /*#__PURE__*/React.createElement(Flex, {
190
- justifyItems: "space-between",
191
- direction: "column",
192
- height: "100%"
193
- }, /*#__PURE__*/React.createElement(Flex, {
194
- direction: "column"
195
- }, showUrlField && /*#__PURE__*/React.createElement(Flex.Item, {
196
- padding: "small"
197
- }, /*#__PURE__*/React.createElement(UrlPanel, {
198
- fileUrl: url,
199
- setFileUrl: handleUrlChange
200
- })), /*#__PURE__*/React.createElement(ImageOptionsForm, {
201
- id: "image-options-form",
202
- imageSize: imageSize,
203
- displayAs: displayAs,
204
- isDecorativeImage: isDecorativeImage,
205
- altText: altText,
206
- isLinked: isLinked,
207
- dimensionsState: dimensionsState,
208
- handleAltTextChange: handleAltTextChange,
209
- handleIsDecorativeChange: handleIsDecorativeChange,
210
- handleDisplayAsChange: handleDisplayAsChange,
211
- handleImageSizeChange: handleImageSizeChange,
212
- messagesForSize: messagesForSize,
213
- isIconMaker: isIconMaker
214
- })), /*#__PURE__*/React.createElement(Flex.Item, {
215
- background: "secondary",
216
- borderWidth: "small none none none",
217
- padding: "small medium",
218
- textAlign: "end"
219
- }, /*#__PURE__*/React.createElement(Button, {
220
- disabled: saveDisabled,
221
- onClick: handleSave,
222
- color: "primary"
223
- }, formatMessage('Done')))))));
224
- }
225
- ImageOptionsTray.propTypes = {
226
- imageOptions: shape({
227
- altText: string.isRequired,
228
- appliedHeight: number,
229
- appliedWidth: number,
230
- isDecorativeImage: bool.isRequired,
231
- isLinked: bool,
232
- naturalHeight: number.isRequired,
233
- naturalWidth: number.isRequired
234
- }).isRequired,
235
- onEntered: func,
236
- onExited: func,
237
- onRequestClose: func.isRequired,
238
- onSave: func.isRequired,
239
- open: bool.isRequired,
240
- isIconMaker: bool
241
- };
242
- ImageOptionsTray.defaultProps = {
243
- onEntered: null,
244
- onExited: null,
245
- isIconMaker: false
246
- };
@@ -1,122 +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, { useRef } from 'react';
19
- import { bool, func, oneOf, shape, string } from 'prop-types';
20
- import { contentTrayDocumentShape } from '../../shared/fileShape';
21
- import { Flex } from '@instructure/ui-flex';
22
- import { View } from '@instructure/ui-view';
23
- import { Text } from '@instructure/ui-text';
24
- import { LoadMoreButton, LoadingIndicator, LoadingStatus, useIncrementalLoading } from '../../../../common/incremental-loading';
25
- import ImageList from '../ImageList';
26
- import formatMessage from '../../../../format-message';
27
-
28
- function hasFiles(images) {
29
- return images.files.length > 0;
30
- }
31
-
32
- function isEmpty(images) {
33
- return !hasFiles(images) && !images.hasMore && !images.isLoading;
34
- }
35
-
36
- export default function Images(props) {
37
- const {
38
- fetchInitialImages,
39
- fetchNextImages,
40
- contextType,
41
- sortBy,
42
- searchString,
43
- isIconMaker,
44
- canvasOrigin
45
- } = props;
46
- const images = props.images[contextType];
47
- const {
48
- hasMore,
49
- isLoading,
50
- error,
51
- files
52
- } = images;
53
- const lastItemRef = useRef(null);
54
- const loader = useIncrementalLoading({
55
- hasMore,
56
- isLoading,
57
- lastItemRef,
58
- onLoadInitial: fetchInitialImages,
59
- onLoadMore: fetchNextImages,
60
- records: files,
61
- contextType,
62
- sortBy,
63
- searchString
64
- });
65
- return /*#__PURE__*/React.createElement(View, {
66
- as: "div",
67
- "data-testid": "instructure_links-ImagesPanel"
68
- }, /*#__PURE__*/React.createElement(Flex, {
69
- alignItems: "center",
70
- direction: "column",
71
- justifyItems: "space-between",
72
- height: "100%"
73
- }, /*#__PURE__*/React.createElement(Flex.Item, {
74
- overflowY: "visible",
75
- width: "100%"
76
- }, /*#__PURE__*/React.createElement(ImageList, {
77
- images: files,
78
- lastItemRef: lastItemRef,
79
- onImageClick: props.onImageEmbed,
80
- isIconMaker: isIconMaker,
81
- canvasOrigin: canvasOrigin
82
- })), loader.isLoading && /*#__PURE__*/React.createElement(Flex.Item, {
83
- as: "div",
84
- shouldGrow: true
85
- }, /*#__PURE__*/React.createElement(LoadingIndicator, {
86
- loader: loader
87
- })), !loader.isLoading && loader.hasMore && /*#__PURE__*/React.createElement(Flex.Item, {
88
- as: "div",
89
- margin: "small"
90
- }, /*#__PURE__*/React.createElement(LoadMoreButton, {
91
- loader: loader
92
- }))), /*#__PURE__*/React.createElement(LoadingStatus, {
93
- loader: loader
94
- }), error && /*#__PURE__*/React.createElement(View, {
95
- as: "div",
96
- role: "alert",
97
- margin: "medium"
98
- }, /*#__PURE__*/React.createElement(Text, {
99
- color: "danger"
100
- }, formatMessage('Loading failed.'))), isEmpty(images) && /*#__PURE__*/React.createElement(View, {
101
- as: "div",
102
- role: "alert",
103
- padding: "medium"
104
- }, formatMessage('No results.')));
105
- }
106
- Images.propTypes = {
107
- fetchInitialImages: func.isRequired,
108
- fetchNextImages: func.isRequired,
109
- contextType: string.isRequired,
110
- images: contentTrayDocumentShape.isRequired,
111
- sortBy: shape({
112
- sort: oneOf(['date_added', 'alphabetical']).isRequired,
113
- order: oneOf(['asc', 'desc']).isRequired
114
- }),
115
- searchString: string,
116
- onImageEmbed: func.isRequired,
117
- isIconMaker: bool,
118
- canvasOrigin: string.isRequired
119
- };
120
- Images.defaultProps = {
121
- isIconMaker: false
122
- };