@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,141 +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, { useEffect, useState } from 'react';
19
- import { bool, func, oneOf, string } from 'prop-types';
20
- import { Alert } from '@instructure/ui-alerts';
21
- import { Button, CloseButton } from '@instructure/ui-buttons';
22
- import { Heading } from '@instructure/ui-heading';
23
- import { TextInput } from '@instructure/ui-text-input';
24
- import { Modal } from '@instructure/ui-modal';
25
- import { View } from '@instructure/ui-view';
26
- import formatMessage from '../../../../../format-message';
27
- import validateURL from '../../validateURL';
28
- import { instuiPopupMountNode } from '../../../../../util/fullscreenHelpers';
29
- const CREATE_LINK = 'create';
30
- const EDIT_LINK = 'edit';
31
- export default function LinkOptionsDialog(props) {
32
- const [text, setText] = useState(props.text || '');
33
- const [url, setUrl] = useState(props.url || '');
34
- const [err, setErr] = useState(null);
35
- const [isValidURL, setIsValidURL] = useState(false);
36
- useEffect(() => {
37
- try {
38
- const v = validateURL(url);
39
- setIsValidURL(v);
40
- setErr(null);
41
- } catch (ex) {
42
- setIsValidURL(false);
43
- setErr(ex.message);
44
- }
45
- }, [url]);
46
-
47
- function handleSave(event) {
48
- event.preventDefault();
49
- if (!url) return;
50
- const linkText = text.trim() || url;
51
- props.onSave({
52
- text: linkText,
53
- target: '_blank',
54
- href: url,
55
- userText: props.showText,
56
- class: 'inline_disabled',
57
- forceRename: true
58
- });
59
- }
60
-
61
- function handleTextChange(event) {
62
- setText(event.target.value);
63
- }
64
-
65
- function handleLinkChange(event) {
66
- setUrl(event.target.value);
67
- }
68
-
69
- const label = props.operation === CREATE_LINK ? formatMessage('Insert Link') : formatMessage('Edit Link');
70
- return /*#__PURE__*/React.createElement(Modal, {
71
- "data-testid": "RCELinkOptionsDialog",
72
- "data-mce-component": true,
73
- as: "form",
74
- label: label,
75
- mountNode: instuiPopupMountNode,
76
- onDismiss: props.onRequestClose,
77
- onEntered: props.onEntered,
78
- onExited: props.onExited,
79
- onSubmit: handleSave,
80
- open: props.open,
81
- shouldCloseOnDocumentClick: false,
82
- shouldReturnFocus: false,
83
- size: "medium"
84
- }, /*#__PURE__*/React.createElement(Modal.Header, null, /*#__PURE__*/React.createElement(CloseButton, {
85
- offset: "medium",
86
- placement: "end",
87
- screenReaderLabel: formatMessage('Close'),
88
- onClick: props.onRequestClose
89
- }), /*#__PURE__*/React.createElement(Heading, null, label)), /*#__PURE__*/React.createElement(Modal.Body, null, props.showText && /*#__PURE__*/React.createElement(View, {
90
- as: "div",
91
- margin: "small"
92
- }, /*#__PURE__*/React.createElement(TextInput, {
93
- renderLabel: formatMessage('Text'),
94
- name: "linktext",
95
- onChange: handleTextChange,
96
- value: text
97
- })), /*#__PURE__*/React.createElement(View, {
98
- as: "div",
99
- margin: "small"
100
- }, /*#__PURE__*/React.createElement(TextInput, {
101
- renderLabel: formatMessage('Link'),
102
- name: "linklink",
103
- onChange: handleLinkChange,
104
- value: url
105
- })), err && /*#__PURE__*/React.createElement(View, {
106
- as: "div",
107
- margin: "small",
108
- "data-testid": "url-error"
109
- }, /*#__PURE__*/React.createElement(Alert, {
110
- variant: "error"
111
- }, err))), /*#__PURE__*/React.createElement(Modal.Footer, null, /*#__PURE__*/React.createElement("input", {
112
- type: "submit",
113
- style: {
114
- display: 'none'
115
- }
116
- }), /*#__PURE__*/React.createElement(Button, {
117
- onClick: props.onRequestClose,
118
- margin: "0 small",
119
- color: "secondary"
120
- }, formatMessage('Close')), /*#__PURE__*/React.createElement(Button, {
121
- disabled: !(url && isValidURL),
122
- onClick: handleSave,
123
- color: "primary"
124
- }, formatMessage('Done'))));
125
- }
126
- LinkOptionsDialog.propTypes = {
127
- text: string,
128
- url: string,
129
- operation: oneOf([CREATE_LINK, EDIT_LINK]),
130
- onEntered: func,
131
- onExited: func,
132
- onRequestClose: func.isRequired,
133
- onSave: func.isRequired,
134
- open: bool.isRequired,
135
- showText: bool
136
- };
137
- LinkOptionsDialog.defaultProps = {
138
- onEntered: null,
139
- onExited: null,
140
- showText: true
141
- };
@@ -1,125 +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 { getLinkContentFromEditor } from '../../../shared/ContentSelection';
22
- import { getAnchorElement } from '../../../../contentInsertionUtils';
23
- import LinkOptionsTray from '.';
24
- export const CONTAINER_ID = 'instructure-link-options-tray-container';
25
- export default class LinkOptionsTrayController {
26
- constructor() {
27
- this._editor = null;
28
- this._isOpen = false;
29
- this._shouldOpen = false;
30
- this._renderId = 0;
31
- }
32
-
33
- get $container() {
34
- let $container = document.getElementById(CONTAINER_ID);
35
-
36
- if ($container == null) {
37
- $container = document.createElement('div');
38
- $container.id = CONTAINER_ID;
39
- document.body.appendChild($container);
40
- }
41
-
42
- return $container;
43
- }
44
-
45
- get isOpen() {
46
- return this._isOpen;
47
- }
48
-
49
- showTrayForEditor(editor) {
50
- this._editor = editor;
51
- this._shouldOpen = true;
52
- const selectedElm = editor.selection.getNode();
53
-
54
- if (editor.selection.isCollapsed() && selectedElm.nodeName === 'A') {
55
- // expand the selection to include the whole <a>
56
- editor.selection.select(editor.selection.getNode());
57
- } else {
58
- const anchorElm = getAnchorElement(editor, selectedElm);
59
- editor.selection.select(anchorElm);
60
- }
61
-
62
- if (bridge.focusedEditor) {
63
- // Dismiss any content trays that may already be open
64
- bridge.hideTrays();
65
- }
66
-
67
- this._renderTray();
68
- }
69
-
70
- hideTrayForEditor(editor) {
71
- if (this._editor === editor) {
72
- this._dismissTray();
73
- }
74
- }
75
-
76
- _applyLinkOptions(linkOptions) {
77
- this._dismissTray();
78
-
79
- bridge.insertLink({ ...linkOptions,
80
- userText: true
81
- });
82
- }
83
-
84
- _dismissTray() {
85
- this._shouldOpen = false;
86
-
87
- this._renderTray();
88
-
89
- this._editor = null;
90
- }
91
-
92
- _renderTray() {
93
- let content = {};
94
-
95
- if (this._shouldOpen) {
96
- content = getLinkContentFromEditor(this._editor);
97
- /*
98
- * When the tray is being opened again, it should be rendered fresh
99
- * (clearing the internal state) so that the currently-selected content
100
- * can be used for initial options.
101
- */
102
-
103
- this._renderId++;
104
- }
105
-
106
- const element = /*#__PURE__*/React.createElement(LinkOptionsTray, {
107
- content: content,
108
- key: this._renderId,
109
- onEntered: () => {
110
- this._isOpen = true;
111
- },
112
- onExited: () => {
113
- bridge.focusActiveEditor(false);
114
- this._isOpen = false;
115
- },
116
- onSave: linkOptions => {
117
- this._applyLinkOptions(linkOptions);
118
- },
119
- onRequestClose: () => this._dismissTray(),
120
- open: this._shouldOpen
121
- });
122
- ReactDOM.render(element, this.$container);
123
- }
124
-
125
- }
@@ -1,245 +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, { useEffect, useState } from 'react';
19
- import { checkPropTypes, bool, func, object, oneOf, shape, string } from 'prop-types';
20
- import { Button, CloseButton } from '@instructure/ui-buttons';
21
- import { Alert } from '@instructure/ui-alerts';
22
- import { Heading } from '@instructure/ui-heading';
23
- import { FormFieldGroup } from '@instructure/ui-form-field';
24
- import { Checkbox } from '@instructure/ui-checkbox';
25
- import { RadioInputGroup, RadioInput } from '@instructure/ui-radio-input';
26
- import { TextInput } from '@instructure/ui-text-input';
27
- import { Flex } from '@instructure/ui-flex';
28
- import { Tray } from '@instructure/ui-tray';
29
- import { View } from '@instructure/ui-view';
30
- import validateURL from '../../validateURL';
31
- import formatMessage from '../../../../../format-message';
32
- import { DISPLAY_AS_LINK, DISPLAY_AS_EMBED, DISPLAY_AS_EMBED_DISABLED, DISPLAY_AS_DOWNLOAD_LINK } from '../../../shared/ContentSelection';
33
- import { getTrayHeight } from '../../../shared/trayUtils';
34
- import { instuiPopupMountNode } from '../../../../../util/fullscreenHelpers';
35
- export default function LinkOptionsTray(props) {
36
- const content = props.content || {};
37
- const textToLink = content.text || '';
38
- const showText = content.onlyTextSelected;
39
- const [text, setText] = useState(textToLink || '');
40
- const [url, setUrl] = useState(content.url || '');
41
- const [err, setErr] = useState(null);
42
- const [isValidURL, setIsValidURL] = useState(false);
43
- const [autoOpenPreview, setAutoOpenPreview] = useState(content.displayAs === DISPLAY_AS_EMBED);
44
- const [disableInlinePreview, setDisableInlinePreview] = useState(content.displayAs === DISPLAY_AS_EMBED_DISABLED || content.displayAs === DISPLAY_AS_DOWNLOAD_LINK);
45
- const [displayOptionSelection, setDisplayOptionSelection] = useState(initialPreviewSelection(content));
46
- useEffect(() => {
47
- try {
48
- const v = validateURL(url);
49
- setIsValidURL(v);
50
- setErr(null);
51
- } catch (ex) {
52
- setIsValidURL(false);
53
- setErr(ex.message);
54
- }
55
- }, [url]);
56
-
57
- function handleSave(event) {
58
- event.preventDefault();
59
- const embedType = content.isPreviewable ? 'scribd' : null;
60
- const linkAttrs = {
61
- embed: embedType ? {
62
- type: embedType,
63
- autoOpenPreview: autoOpenPreview && !disableInlinePreview,
64
- disableInlinePreview,
65
- noPreview: displayOptionSelection === 'disable'
66
- } : null,
67
- text,
68
- href: url,
69
- id: content.id || null,
70
- forceRename: true // A change to "text" should always update the link's text
71
-
72
- };
73
- props.onSave(linkAttrs);
74
- }
75
-
76
- function initialPreviewSelection(previewContent) {
77
- if (previewContent.displayAs === DISPLAY_AS_DOWNLOAD_LINK) {
78
- return 'disable';
79
- } else if (previewContent.displayAs === DISPLAY_AS_EMBED || previewContent.displayAs === DISPLAY_AS_LINK) {
80
- return 'inline';
81
- } else {
82
- return 'overlay';
83
- }
84
- }
85
-
86
- function handleTextChange(event) {
87
- setText(event.target.value);
88
- }
89
-
90
- function handleLinkChange(event) {
91
- setUrl(event.target.value);
92
- }
93
-
94
- function handlePreviewChange(event) {
95
- setAutoOpenPreview(event.target.checked);
96
- }
97
-
98
- function handlePreviewOptionChange(_event, value) {
99
- setDisableInlinePreview(value === 'overlay' || value === 'disable');
100
- setDisplayOptionSelection(value);
101
- }
102
-
103
- function renderDisplayOptions() {
104
- return /*#__PURE__*/React.createElement(FormFieldGroup, {
105
- description: formatMessage('Display Options'),
106
- layout: "stacked",
107
- rowSpacing: "small"
108
- }, /*#__PURE__*/React.createElement(RadioInputGroup, {
109
- description: " "
110
- /* the FormFieldGroup is providing the label */
111
- ,
112
- name: "preview_option",
113
- onChange: handlePreviewOptionChange,
114
- value: displayOptionSelection
115
- }, /*#__PURE__*/React.createElement(RadioInput, {
116
- key: "disable",
117
- value: "disable",
118
- label: formatMessage('Disable Preview')
119
- }), /*#__PURE__*/React.createElement(RadioInput, {
120
- key: "overlay",
121
- value: "overlay",
122
- label: formatMessage('Preview in overlay')
123
- }), /*#__PURE__*/React.createElement(RadioInput, {
124
- key: "inline",
125
- value: "inline",
126
- label: formatMessage('Preview inline')
127
- })), !disableInlinePreview && /*#__PURE__*/React.createElement(View, {
128
- as: "div",
129
- margin: "0 0 0 small"
130
- }, /*#__PURE__*/React.createElement(Checkbox, {
131
- label: formatMessage('Expand preview by Default'),
132
- name: "auto-preview",
133
- onChange: handlePreviewChange,
134
- checked: autoOpenPreview
135
- })));
136
- }
137
-
138
- return /*#__PURE__*/React.createElement(Tray, {
139
- "data-testid": "RCELinkOptionsTray",
140
- "data-mce-component": true,
141
- label: formatMessage('Link Options'),
142
- mountNode: instuiPopupMountNode,
143
- onDismiss: props.onRequestClose,
144
- onEntered: props.onEntered,
145
- onExited: props.onExited,
146
- open: props.open,
147
- placement: "end",
148
- shouldCloseOnDocumentClick: true,
149
- shouldContainFocus: true,
150
- shouldReturnFocus: true
151
- }, /*#__PURE__*/React.createElement(Flex, {
152
- direction: "column",
153
- height: getTrayHeight()
154
- }, /*#__PURE__*/React.createElement(Flex.Item, {
155
- as: "header",
156
- padding: "medium"
157
- }, /*#__PURE__*/React.createElement(Flex, {
158
- direction: "row"
159
- }, /*#__PURE__*/React.createElement(Flex.Item, {
160
- shouldGrow: true,
161
- shouldShrink: true
162
- }, /*#__PURE__*/React.createElement(Heading, {
163
- as: "h2"
164
- }, formatMessage('Link Options'))), /*#__PURE__*/React.createElement(Flex.Item, null, /*#__PURE__*/React.createElement(CloseButton, {
165
- color: "primary",
166
- onClick: props.onRequestClose,
167
- screenReaderLabel: formatMessage('Close')
168
- })))), /*#__PURE__*/React.createElement(Flex.Item, {
169
- as: "form",
170
- shouldGrow: true,
171
- margin: "none",
172
- shouldShrink: true,
173
- onSubmit: handleSave
174
- }, /*#__PURE__*/React.createElement(Flex, {
175
- justifyItems: "space-between",
176
- direction: "column",
177
- height: "100%"
178
- }, /*#__PURE__*/React.createElement(Flex.Item, {
179
- shouldGrow: true,
180
- padding: "small",
181
- shouldShrink: true
182
- }, /*#__PURE__*/React.createElement("input", {
183
- type: "submit",
184
- style: {
185
- display: 'none'
186
- }
187
- }), /*#__PURE__*/React.createElement(Flex, {
188
- direction: "column"
189
- }, showText && /*#__PURE__*/React.createElement(Flex.Item, {
190
- padding: "small"
191
- }, /*#__PURE__*/React.createElement(TextInput, {
192
- renderLabel: () => formatMessage('Text'),
193
- onChange: handleTextChange,
194
- value: text
195
- })), /*#__PURE__*/React.createElement(Flex.Item, {
196
- padding: "small"
197
- }, /*#__PURE__*/React.createElement(TextInput, {
198
- renderLabel: () => formatMessage('Link'),
199
- onChange: handleLinkChange,
200
- value: url
201
- })), err && /*#__PURE__*/React.createElement(Flex.Item, {
202
- padding: "small",
203
- "data-testid": "url-error"
204
- }, /*#__PURE__*/React.createElement(Alert, {
205
- variant: "error"
206
- }, err)), content.isPreviewable && /*#__PURE__*/React.createElement(Flex.Item, {
207
- margin: "small none none none",
208
- padding: "small"
209
- }, renderDisplayOptions()))), /*#__PURE__*/React.createElement(Flex.Item, {
210
- background: "secondary",
211
- borderWidth: "small none none none",
212
- padding: "small medium",
213
- textAlign: "end"
214
- }, /*#__PURE__*/React.createElement(Button, {
215
- disabled: showText && text.trim().length === 0 || !(url && isValidURL),
216
- onClick: handleSave,
217
- color: "primary"
218
- }, formatMessage('Done')))))));
219
- }
220
- LinkOptionsTray.propTypes = {
221
- // content is required only if the tray is open
222
- content: (props, _propName, _componentName) => {
223
- if (props.open) {
224
- checkPropTypes({
225
- content: shape({
226
- $element: object,
227
- // the DOM's HTMLElement
228
- dispalyAs: oneOf([DISPLAY_AS_LINK, DISPLAY_AS_EMBED]),
229
- isPreviewable: bool,
230
- text: string,
231
- url: string
232
- }).isRequired
233
- }, props, 'content', 'LinkOptionsTray');
234
- }
235
- },
236
- onEntered: func,
237
- onExited: func,
238
- onRequestClose: func.isRequired,
239
- onSave: func.isRequired,
240
- open: bool.isRequired
241
- };
242
- LinkOptionsTray.defaultProps = {
243
- onEntered: null,
244
- onExited: null
245
- };
@@ -1,195 +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, { Component, useRef } from 'react';
19
- import { bool, func, string } from 'prop-types';
20
- import { linkShape, linksShape, linkType } from './propTypes';
21
- import formatMessage from '../../../../format-message';
22
- import { ScreenReaderContent } from '@instructure/ui-a11y-content';
23
- import { List } from '@instructure/ui-list';
24
- import { View } from '@instructure/ui-view';
25
- import uid from '@instructure/uid';
26
- import { LoadMoreButton, LoadingIndicator, LoadingStatus, useIncrementalLoading } from '../../../../common/incremental-loading';
27
- import Link from './Link';
28
- import RCEGlobals from '../../../RCEGlobals';
29
- import { NoResults } from './NoResults';
30
- /*
31
- * This is needed only as long as `LinkSet` is a class component.
32
- */
33
-
34
- function IncrementalLoader(props) {
35
- const {
36
- children,
37
- collection,
38
- fetchInitialPage,
39
- fetchNextPage,
40
- contextType,
41
- searchString
42
- } = props;
43
- const {
44
- hasMore,
45
- isLoading,
46
- links
47
- } = collection;
48
- const lastItemRef = useRef(null);
49
- const loader = useIncrementalLoading({
50
- hasMore: hasMore && fetchNextPage != null,
51
- isLoading,
52
- lastItemRef,
53
- contextType,
54
- sortBy: {
55
- sort: 'alphabetical',
56
- order: 'asc'
57
- },
58
- // not actually used in the query, but a required param
59
- searchString,
60
-
61
- onLoadInitial() {
62
- if (fetchInitialPage) {
63
- fetchInitialPage();
64
- }
65
- },
66
-
67
- onLoadMore() {
68
- fetchNextPage();
69
- },
70
-
71
- records: links
72
- });
73
- return children({
74
- loader,
75
- lastItemRef
76
- });
77
- }
78
-
79
- class LinkSet extends Component {
80
- constructor(props) {
81
- super(props);
82
- this.describedByID = `rce-LinkSet-describedBy-${uid()}`;
83
- this.loadMoreButtonRef = null;
84
- }
85
-
86
- hasLinks(props) {
87
- return props.collection.links.length > 0;
88
- }
89
-
90
- isEmpty(props) {
91
- return !this.hasLinks(props) && !props.collection.hasMore && !props.collection.isLoading;
92
- }
93
-
94
- compareURLs() {
95
- let url1 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
96
- let url2 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
97
- if (url1 === '' || url2 === '') return false;
98
- return url1.split('?')[0] === url2.split('?')[0];
99
- }
100
-
101
- renderLinks(lastItemRef) {
102
- function refFor(index, array) {
103
- if (!lastItemRef || index !== array.length - 1) {
104
- return null;
105
- } // Return a compatible callback ref for InstUI
106
-
107
-
108
- return ref => {
109
- lastItemRef.current = ref;
110
- };
111
- }
112
-
113
- return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(ScreenReaderContent, {
114
- id: this.describedByID
115
- }, formatMessage('Click to insert a link into the editor.')), /*#__PURE__*/React.createElement(List, {
116
- isUnstyled: true,
117
- as: "ul",
118
- margin: "0"
119
- }, this.props.collection.links.map((link, index, array) => {
120
- var _this$props$selectedL;
121
-
122
- return /*#__PURE__*/React.createElement(List.Item, {
123
- key: link.href,
124
- spacing: "none",
125
- padding: "0"
126
- }, /*#__PURE__*/React.createElement(Link, {
127
- link: link,
128
- type: this.props.type,
129
- onClick: this.props.onLinkClick,
130
- describedByID: this.describedByID,
131
- elementRef: refFor(index, array),
132
- editing: this.props.editing,
133
- onEditClick: this.props.onEditClick,
134
- isSelected: this.compareURLs((_this$props$selectedL = this.props.selectedLink) === null || _this$props$selectedL === void 0 ? void 0 : _this$props$selectedL.href, link.href)
135
- }));
136
- })));
137
- }
138
-
139
- renderEmptyIndicator() {
140
- var _this$props$searchStr;
141
-
142
- return /*#__PURE__*/React.createElement(NoResults, {
143
- contextType: this.props.contextType,
144
- contextId: this.props.contextId,
145
- collectionType: this.props.type,
146
- isSearchResult: ((_this$props$searchStr = this.props.searchString) === null || _this$props$searchStr === void 0 ? void 0 : _this$props$searchStr.length) >= 3
147
- });
148
- }
149
-
150
- renderLoadingError() {
151
- if (this.props.collection.lastError) {
152
- return /*#__PURE__*/React.createElement("span", {
153
- className: "rcs-LinkSet-LoadFailed",
154
- role: "alert"
155
- }, formatMessage('Loading failed...'));
156
- }
157
-
158
- return null;
159
- }
160
-
161
- render() {
162
- return /*#__PURE__*/React.createElement(IncrementalLoader, this.props, _ref => {
163
- let {
164
- loader,
165
- lastItemRef
166
- } = _ref;
167
- return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
168
- "data-testid": "instructure_links-LinkSet"
169
- }, this.hasLinks(this.props) && this.renderLinks(lastItemRef), this.renderLoadingError(), loader.isLoading && /*#__PURE__*/React.createElement(LoadingIndicator, {
170
- loader: loader
171
- }), !loader.isLoading && loader.hasMore && /*#__PURE__*/React.createElement(LoadMoreButton, {
172
- loader: loader
173
- }), this.isEmpty(this.props) && !this.props.suppressRenderEmpty && this.renderEmptyIndicator()), /*#__PURE__*/React.createElement(LoadingStatus, {
174
- loader: loader
175
- }));
176
- });
177
- }
178
-
179
- }
180
-
181
- LinkSet.propTypes = {
182
- type: linkType.isRequired,
183
- collection: linksShape.isRequired,
184
- onLinkClick: func.isRequired,
185
- contextType: string.isRequired,
186
- contextId: string.isRequired,
187
- fetchInitialPage: func,
188
- fetchNextPage: func,
189
- suppressRenderEmpty: bool,
190
- searchString: string,
191
- editing: bool,
192
- onEditClick: func,
193
- selectedLink: linkShape
194
- };
195
- export default LinkSet;