@pie-lib/editable-html-tip-tap 2.1.2-next.31 → 2.1.2-next.36

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 (280) hide show
  1. package/CHANGELOG.json +32 -0
  2. package/CHANGELOG.md +2532 -0
  3. package/LICENSE.md +5 -0
  4. package/lib/components/CharacterPicker.js +201 -0
  5. package/lib/components/CharacterPicker.js.map +1 -0
  6. package/lib/components/EditableHtml.js +376 -0
  7. package/lib/components/EditableHtml.js.map +1 -0
  8. package/lib/components/MenuBar.js +697 -0
  9. package/lib/components/MenuBar.js.map +1 -0
  10. package/lib/components/TiptapContainer.js +234 -0
  11. package/lib/components/TiptapContainer.js.map +1 -0
  12. package/lib/components/characters/characterUtils.js +378 -0
  13. package/lib/components/characters/characterUtils.js.map +1 -0
  14. package/lib/components/characters/custom-popper.js +44 -0
  15. package/lib/components/characters/custom-popper.js.map +1 -0
  16. package/lib/components/common/done-button.js +34 -0
  17. package/lib/components/common/done-button.js.map +1 -0
  18. package/lib/components/common/toolbar-buttons.js +144 -0
  19. package/lib/components/common/toolbar-buttons.js.map +1 -0
  20. package/lib/components/icons/CssIcon.js +25 -0
  21. package/lib/components/icons/CssIcon.js.map +1 -0
  22. package/lib/components/icons/RespArea.js +72 -0
  23. package/lib/components/icons/RespArea.js.map +1 -0
  24. package/lib/components/icons/TableIcons.js +53 -0
  25. package/lib/components/icons/TableIcons.js.map +1 -0
  26. package/lib/components/icons/TextAlign.js +157 -0
  27. package/lib/components/icons/TextAlign.js.map +1 -0
  28. package/lib/components/image/AltDialog.js +98 -0
  29. package/lib/components/image/AltDialog.js.map +1 -0
  30. package/lib/components/image/ImageToolbar.js +137 -0
  31. package/lib/components/image/ImageToolbar.js.map +1 -0
  32. package/lib/components/image/InsertImageHandler.js +135 -0
  33. package/lib/components/image/InsertImageHandler.js.map +1 -0
  34. package/lib/components/media/MediaDialog.js +594 -0
  35. package/lib/components/media/MediaDialog.js.map +1 -0
  36. package/lib/components/media/MediaToolbar.js +74 -0
  37. package/lib/components/media/MediaToolbar.js.map +1 -0
  38. package/lib/components/media/MediaWrapper.js +67 -0
  39. package/lib/components/media/MediaWrapper.js.map +1 -0
  40. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +84 -0
  41. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +1 -0
  42. package/lib/components/respArea/DragInTheBlank/choice.js +250 -0
  43. package/lib/components/respArea/DragInTheBlank/choice.js.map +1 -0
  44. package/lib/components/respArea/ExplicitConstructedResponse.js +137 -0
  45. package/lib/components/respArea/ExplicitConstructedResponse.js.map +1 -0
  46. package/lib/components/respArea/InlineDropdown.js +210 -0
  47. package/lib/components/respArea/InlineDropdown.js.map +1 -0
  48. package/lib/components/respArea/MathTemplated.js +130 -0
  49. package/lib/components/respArea/MathTemplated.js.map +1 -0
  50. package/lib/components/respArea/ToolbarIcon.js +81 -0
  51. package/lib/components/respArea/ToolbarIcon.js.map +1 -0
  52. package/lib/components/respArea/inlineDropdownUtils.js +67 -0
  53. package/lib/components/respArea/inlineDropdownUtils.js.map +1 -0
  54. package/lib/constants.js +11 -0
  55. package/lib/constants.js.map +1 -0
  56. package/lib/extensions/css.js +217 -0
  57. package/lib/extensions/css.js.map +1 -0
  58. package/lib/extensions/custom-toolbar-wrapper.js +92 -0
  59. package/lib/extensions/custom-toolbar-wrapper.js.map +1 -0
  60. package/lib/extensions/div-node.js +83 -0
  61. package/lib/extensions/div-node.js.map +1 -0
  62. package/lib/extensions/ensure-empty-root-div.js +48 -0
  63. package/lib/extensions/ensure-empty-root-div.js.map +1 -0
  64. package/lib/extensions/ensure-list-item-content-is-div.js +64 -0
  65. package/lib/extensions/ensure-list-item-content-is-div.js.map +1 -0
  66. package/lib/extensions/extended-list-item.js +15 -0
  67. package/lib/extensions/extended-list-item.js.map +1 -0
  68. package/lib/extensions/extended-table-cell.js +22 -0
  69. package/lib/extensions/extended-table-cell.js.map +1 -0
  70. package/lib/extensions/extended-table.js +75 -0
  71. package/lib/extensions/extended-table.js.map +1 -0
  72. package/lib/extensions/heading-paragraph.js +61 -0
  73. package/lib/extensions/heading-paragraph.js.map +1 -0
  74. package/lib/extensions/image-component.js +348 -0
  75. package/lib/extensions/image-component.js.map +1 -0
  76. package/lib/extensions/image.js +134 -0
  77. package/lib/extensions/image.js.map +1 -0
  78. package/lib/extensions/index.js +46 -0
  79. package/lib/extensions/index.js.map +1 -0
  80. package/lib/extensions/math.js +342 -0
  81. package/lib/extensions/math.js.map +1 -0
  82. package/lib/extensions/media.js +243 -0
  83. package/lib/extensions/media.js.map +1 -0
  84. package/lib/extensions/responseArea.js +446 -0
  85. package/lib/extensions/responseArea.js.map +1 -0
  86. package/lib/index.js +37 -0
  87. package/lib/index.js.map +1 -0
  88. package/lib/styles/editorContainerStyles.js +137 -0
  89. package/lib/styles/editorContainerStyles.js.map +1 -0
  90. package/lib/theme.js +8 -0
  91. package/lib/theme.js.map +1 -0
  92. package/lib/utils/helper.js +73 -0
  93. package/lib/utils/helper.js.map +1 -0
  94. package/lib/utils/size.js +26 -0
  95. package/lib/utils/size.js.map +1 -0
  96. package/lib/utils/toolbar.js +19 -0
  97. package/lib/utils/toolbar.js.map +1 -0
  98. package/package.json +24 -40
  99. package/src/__tests__/EditableHtml.test.jsx +554 -0
  100. package/src/__tests__/constants.test.js +19 -0
  101. package/src/__tests__/div-to-paragraph-conversion.test.jsx +125 -0
  102. package/src/__tests__/extensions.test.js +208 -0
  103. package/src/__tests__/index.test.jsx +154 -0
  104. package/src/__tests__/size-utils.test.js +64 -0
  105. package/src/__tests__/theme.test.js +17 -0
  106. package/src/components/CharacterPicker.jsx +207 -0
  107. package/src/components/EditableHtml.jsx +440 -0
  108. package/src/components/MenuBar.jsx +556 -0
  109. package/src/components/TiptapContainer.jsx +219 -0
  110. package/src/components/__tests__/AltDialog.test.jsx +147 -0
  111. package/src/components/__tests__/CharacterPicker.test.jsx +261 -0
  112. package/src/components/__tests__/CssIcon.test.jsx +46 -0
  113. package/src/components/__tests__/DragInTheBlank.test.jsx +255 -0
  114. package/src/components/__tests__/ExplicitConstructedResponse.test.jsx +209 -0
  115. package/src/components/__tests__/ImageToolbar.test.jsx +128 -0
  116. package/src/components/__tests__/InlineDropdown.test.jsx +393 -0
  117. package/src/components/__tests__/InsertImageHandler.test.js +161 -0
  118. package/src/components/__tests__/MediaDialog.test.jsx +293 -0
  119. package/src/components/__tests__/MediaToolbar.test.jsx +74 -0
  120. package/src/components/__tests__/MediaWrapper.test.jsx +81 -0
  121. package/src/components/__tests__/MenuBar.test.jsx +250 -0
  122. package/src/components/__tests__/RespArea.test.jsx +122 -0
  123. package/src/components/__tests__/TableIcons.test.jsx +149 -0
  124. package/src/components/__tests__/TextAlign.test.jsx +167 -0
  125. package/src/components/__tests__/TiptapContainer.test.jsx +138 -0
  126. package/src/components/__tests__/characterUtils.test.js +166 -0
  127. package/src/components/__tests__/choice.test.jsx +171 -0
  128. package/src/components/__tests__/custom-popper.test.jsx +82 -0
  129. package/src/components/__tests__/done-button.test.jsx +54 -0
  130. package/src/components/__tests__/toolbar-buttons.test.jsx +234 -0
  131. package/src/components/characters/characterUtils.js +447 -0
  132. package/src/components/characters/custom-popper.js +38 -0
  133. package/src/components/common/done-button.jsx +27 -0
  134. package/src/components/common/toolbar-buttons.jsx +122 -0
  135. package/src/components/icons/CssIcon.jsx +15 -0
  136. package/src/components/icons/RespArea.jsx +71 -0
  137. package/src/components/icons/TableIcons.jsx +52 -0
  138. package/src/components/icons/TextAlign.jsx +114 -0
  139. package/src/components/image/AltDialog.jsx +82 -0
  140. package/src/components/image/ImageToolbar.jsx +99 -0
  141. package/src/components/image/InsertImageHandler.js +107 -0
  142. package/src/components/media/MediaDialog.jsx +596 -0
  143. package/src/components/media/MediaToolbar.jsx +49 -0
  144. package/src/components/media/MediaWrapper.jsx +39 -0
  145. package/src/components/respArea/DragInTheBlank/DragInTheBlank.jsx +76 -0
  146. package/src/components/respArea/DragInTheBlank/choice.jsx +256 -0
  147. package/src/components/respArea/ExplicitConstructedResponse.jsx +136 -0
  148. package/src/components/respArea/InlineDropdown.jsx +221 -0
  149. package/src/components/respArea/MathTemplated.jsx +124 -0
  150. package/src/components/respArea/ToolbarIcon.jsx +66 -0
  151. package/src/components/respArea/__tests__/MathTemplated.test.jsx +210 -0
  152. package/src/components/respArea/inlineDropdownUtils.js +79 -0
  153. package/src/constants.js +5 -0
  154. package/src/extensions/__tests__/css.test.js +196 -0
  155. package/src/extensions/__tests__/custom-toolbar-wrapper.test.jsx +180 -0
  156. package/src/extensions/__tests__/divNode.test.js +87 -0
  157. package/src/extensions/__tests__/ensure-empty-root-div.test.js +57 -0
  158. package/src/extensions/__tests__/ensure-list-item-content-is-div.test.js +44 -0
  159. package/src/extensions/__tests__/extended-list-item.test.js +13 -0
  160. package/src/extensions/__tests__/extended-table-cell.test.js +22 -0
  161. package/src/extensions/__tests__/extended-table.test.js +183 -0
  162. package/src/extensions/__tests__/image-component.test.jsx +345 -0
  163. package/src/extensions/__tests__/image.test.js +237 -0
  164. package/src/extensions/__tests__/math.test.js +604 -0
  165. package/src/extensions/__tests__/media-node-view.test.jsx +298 -0
  166. package/src/extensions/__tests__/media.test.js +271 -0
  167. package/src/extensions/__tests__/responseArea.test.js +601 -0
  168. package/src/extensions/css.js +220 -0
  169. package/src/extensions/custom-toolbar-wrapper.jsx +78 -0
  170. package/src/extensions/div-node.js +86 -0
  171. package/src/extensions/ensure-empty-root-div.js +47 -0
  172. package/src/extensions/ensure-list-item-content-is-div.js +62 -0
  173. package/src/extensions/extended-list-item.js +10 -0
  174. package/src/extensions/extended-table-cell.js +19 -0
  175. package/src/extensions/extended-table.js +60 -0
  176. package/src/extensions/heading-paragraph.js +53 -0
  177. package/src/extensions/image-component.jsx +338 -0
  178. package/src/extensions/image.js +109 -0
  179. package/src/extensions/index.js +81 -0
  180. package/src/extensions/math.js +325 -0
  181. package/src/extensions/media.js +188 -0
  182. package/src/extensions/responseArea.js +401 -0
  183. package/src/index.jsx +5 -0
  184. package/src/styles/editorContainerStyles.js +145 -0
  185. package/src/theme.js +1 -0
  186. package/src/utils/__tests__/helper.test.js +126 -0
  187. package/src/utils/__tests__/toolbar.test.js +43 -0
  188. package/src/utils/helper.js +69 -0
  189. package/src/utils/size.js +32 -0
  190. package/src/utils/toolbar.js +15 -0
  191. package/dist/components/CharacterPicker.d.ts +0 -31
  192. package/dist/components/CharacterPicker.js +0 -131
  193. package/dist/components/EditableHtml.d.ts +0 -11
  194. package/dist/components/EditableHtml.js +0 -291
  195. package/dist/components/MenuBar.d.ts +0 -11
  196. package/dist/components/MenuBar.js +0 -462
  197. package/dist/components/TiptapContainer.d.ts +0 -11
  198. package/dist/components/TiptapContainer.js +0 -154
  199. package/dist/components/characters/characterUtils.d.ts +0 -35
  200. package/dist/components/characters/characterUtils.js +0 -465
  201. package/dist/components/characters/custom-popper.d.ts +0 -14
  202. package/dist/components/characters/custom-popper.js +0 -32
  203. package/dist/components/common/done-button.d.ts +0 -30
  204. package/dist/components/common/done-button.js +0 -26
  205. package/dist/components/common/toolbar-buttons.d.ts +0 -38
  206. package/dist/components/common/toolbar-buttons.js +0 -91
  207. package/dist/components/icons/CssIcon.d.ts +0 -11
  208. package/dist/components/icons/CssIcon.js +0 -14
  209. package/dist/components/icons/RespArea.d.ts +0 -26
  210. package/dist/components/icons/RespArea.js +0 -42
  211. package/dist/components/icons/TableIcons.d.ts +0 -14
  212. package/dist/components/icons/TableIcons.js +0 -32
  213. package/dist/components/icons/TextAlign.d.ts +0 -18
  214. package/dist/components/icons/TextAlign.js +0 -134
  215. package/dist/components/image/AltDialog.d.ts +0 -22
  216. package/dist/components/image/AltDialog.js +0 -61
  217. package/dist/components/image/ImageToolbar.d.ts +0 -24
  218. package/dist/components/image/ImageToolbar.js +0 -80
  219. package/dist/components/image/InsertImageHandler.d.ts +0 -32
  220. package/dist/components/image/InsertImageHandler.js +0 -53
  221. package/dist/components/media/MediaDialog.d.ts +0 -43
  222. package/dist/components/media/MediaDialog.js +0 -389
  223. package/dist/components/media/MediaToolbar.d.ts +0 -19
  224. package/dist/components/media/MediaToolbar.js +0 -41
  225. package/dist/components/media/MediaWrapper.d.ts +0 -19
  226. package/dist/components/respArea/DragInTheBlank/DragInTheBlank.d.ts +0 -23
  227. package/dist/components/respArea/DragInTheBlank/DragInTheBlank.js +0 -58
  228. package/dist/components/respArea/DragInTheBlank/choice.d.ts +0 -56
  229. package/dist/components/respArea/DragInTheBlank/choice.js +0 -156
  230. package/dist/components/respArea/ExplicitConstructedResponse.d.ts +0 -20
  231. package/dist/components/respArea/ExplicitConstructedResponse.js +0 -83
  232. package/dist/components/respArea/InlineDropdown.d.ts +0 -18
  233. package/dist/components/respArea/InlineDropdown.js +0 -119
  234. package/dist/components/respArea/MathTemplated.d.ts +0 -19
  235. package/dist/components/respArea/MathTemplated.js +0 -97
  236. package/dist/components/respArea/ToolbarIcon.d.ts +0 -14
  237. package/dist/components/respArea/ToolbarIcon.js +0 -17
  238. package/dist/components/respArea/inlineDropdownUtils.d.ts +0 -15
  239. package/dist/components/respArea/inlineDropdownUtils.js +0 -15
  240. package/dist/constants.d.ts +0 -13
  241. package/dist/constants.js +0 -4
  242. package/dist/extensions/css.d.ts +0 -11
  243. package/dist/extensions/css.js +0 -115
  244. package/dist/extensions/custom-toolbar-wrapper.d.ts +0 -11
  245. package/dist/extensions/custom-toolbar-wrapper.js +0 -61
  246. package/dist/extensions/div-node.d.ts +0 -10
  247. package/dist/extensions/div-node.js +0 -42
  248. package/dist/extensions/ensure-empty-root-div.d.ts +0 -14
  249. package/dist/extensions/ensure-empty-root-div.js +0 -24
  250. package/dist/extensions/ensure-list-item-content-is-div.d.ts +0 -15
  251. package/dist/extensions/ensure-list-item-content-is-div.js +0 -31
  252. package/dist/extensions/extended-list-item.d.ts +0 -13
  253. package/dist/extensions/extended-list-item.js +0 -5
  254. package/dist/extensions/extended-table-cell.d.ts +0 -10
  255. package/dist/extensions/extended-table-cell.js +0 -6
  256. package/dist/extensions/extended-table.d.ts +0 -17
  257. package/dist/extensions/extended-table.js +0 -34
  258. package/dist/extensions/heading-paragraph.d.ts +0 -17
  259. package/dist/extensions/heading-paragraph.js +0 -30
  260. package/dist/extensions/image-component.d.ts +0 -22
  261. package/dist/extensions/image-component.js +0 -220
  262. package/dist/extensions/image.d.ts +0 -10
  263. package/dist/extensions/image.js +0 -68
  264. package/dist/extensions/index.d.ts +0 -16
  265. package/dist/extensions/index.js +0 -64
  266. package/dist/extensions/math.d.ts +0 -15
  267. package/dist/extensions/math.js +0 -158
  268. package/dist/extensions/media.d.ts +0 -19
  269. package/dist/extensions/media.js +0 -149
  270. package/dist/extensions/responseArea.d.ts +0 -27
  271. package/dist/extensions/responseArea.js +0 -259
  272. package/dist/index.d.ts +0 -13
  273. package/dist/index.js +0 -7
  274. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +0 -16
  275. package/dist/styles/editorContainerStyles.d.ts +0 -134
  276. package/dist/theme.d.ts +0 -9
  277. package/dist/utils/helper.d.ts +0 -9
  278. package/dist/utils/helper.js +0 -27
  279. package/dist/utils/size.d.ts +0 -9
  280. package/dist/utils/size.js +0 -14
@@ -1,389 +0,0 @@
1
- import e from "react";
2
- import { styled as t } from "@mui/material/styles";
3
- import n from "prop-types";
4
- import r from "@mui/material/IconButton";
5
- import i from "@mui/icons-material/Delete";
6
- import { Fragment as a, jsx as o, jsxs as s } from "react/jsx-runtime";
7
- import c from "debug";
8
- import l from "@mui/material/DialogContent";
9
- import u from "@mui/material/TextField";
10
- import d from "@mui/material/DialogActions";
11
- import f from "@mui/material/Button";
12
- import p from "@mui/material/Dialog";
13
- import m from "@mui/material/Tabs";
14
- import h from "@mui/material/Tab";
15
- import g from "@mui/material/DialogTitle";
16
- import _ from "@mui/material/DialogContentText";
17
- import v from "@mui/material/Typography";
18
- //#region src/components/media/MediaDialog.tsx
19
- var y = c("@pie-lib:editable-html:plugins:media:dialog"), b = (e) => {
20
- if (!e) return !1;
21
- let t = /^(?:https?:\/\/)?(?:m\.|www\.)?(?:youtu\.be\/|youtube\.com\/(?:embed\/|v\/|watch\?v=|watch\?.+&v=))((\w|-){11})(?:\S+)?$/;
22
- return e.match(t) ? e.match(t)[1] : !1;
23
- }, x = (e) => e && /(http|https)?:\/\/(www\.)?(player\.)?vimeo.com\/(?:channels\/(?:\w+\/)?|groups\/([^/]*)\/videos\/|)(video\/)?(\d+)(?:|\/\?)/.test(e), S = (e) => e && /^https:\/\/drive\.google\.com\/(?:file\/d\/|drive\/(?:u\/\d+\/)?folders\/|uc\?id=)([a-zA-Z0-9_-]+)/.test(e), C = (e) => {
24
- if (!e) return !1;
25
- let t = /^https?:\/\/(soundcloud\.com|snd\.sc)\/(.*)$/;
26
- return e.match(t) && e.match(t)[2];
27
- }, w = (e) => new Promise((t) => {
28
- try {
29
- fetch(`https://soundcloud.com/oembed?format=json&url=${e}`).then((e) => e.json()).then((e) => {
30
- let n = document.createElement("div");
31
- n.innerHTML = e.html, t(n.querySelector("iframe").src);
32
- }).catch((e) => {
33
- t(""), y(e);
34
- });
35
- } catch {
36
- t("");
37
- }
38
- }), T = {
39
- video: "Video",
40
- audio: "Audio"
41
- }, E = {
42
- uploadFile: "upload-file",
43
- insertUrl: "insert-url"
44
- }, D = t(p)(({ theme: e }) => ({ "& .MuiDialog-paper": { minWidth: "500px" } })), O = t(l)(({ theme: e }) => ({ padding: 0 })), k = t("div")(({ theme: e }) => ({
45
- display: "flex",
46
- flexDirection: "space-between"
47
- })), A = t("div")(({ theme: e }) => ({ marginTop: e.spacing(1.5) })), j = t("input")(({ theme: e }) => ({})), M = t(v)(({ theme: e }) => ({
48
- marginTop: e.spacing(1.5),
49
- color: e.palette.error.main
50
- })), N = t(r)(({ theme: e }) => ({ marginLeft: e.spacing(1.5) })), P = class extends e.Component {
51
- static propTypes = {
52
- open: n.bool,
53
- edit: n.bool,
54
- disablePortal: n.bool,
55
- handleClose: n.func,
56
- uploadSoundSupport: n.shape({
57
- add: n.func,
58
- delete: n.func
59
- }),
60
- type: n.string,
61
- src: n.string,
62
- url: n.string,
63
- urlToUse: n.string,
64
- starts: n.number,
65
- ends: n.number,
66
- height: n.number,
67
- width: n.number
68
- };
69
- constructor(e) {
70
- super(e);
71
- let { ends: t, height: n, src: r, starts: i, type: a, uploadSoundSupport: o, url: s, urlToUse: c, width: l } = e, u = o?.add && o?.delete && a !== "video" && !r;
72
- this.state = {
73
- ends: t || 0,
74
- url: s,
75
- urlToUse: c,
76
- formattedUrl: r,
77
- height: n || 315,
78
- invalid: !1,
79
- starts: i || 0,
80
- width: l || 560,
81
- tabValue: u ? E.uploadFile : E.insertUrl,
82
- fileUpload: {
83
- error: null,
84
- loading: !1,
85
- scheduled: !1,
86
- url: "",
87
- mimeType: ""
88
- }
89
- };
90
- }
91
- componentDidMount() {
92
- this.props.url && this.urlChange({ target: { value: this.props.url } });
93
- }
94
- formatUrl = () => {
95
- let { url: e, urlToUse: t, starts: n, ends: r } = this.state, i = b(e), a = x(e), o = t;
96
- if ((i || a) && t) {
97
- let e = [], s, c;
98
- switch (!0) {
99
- case a:
100
- s = "t", c = "#";
101
- break;
102
- case i:
103
- s = "start", c = "?";
104
- break;
105
- default: s = "start", c = "?";
106
- }
107
- n && e.push(`${s}=${n}`), r && e.push(`end=${r}`), o = `${t}${e.length ? c : ""}${e.join("&")}`;
108
- }
109
- this.setState({
110
- formattedUrl: null,
111
- updating: !0
112
- }, () => this.setState({
113
- formattedUrl: o,
114
- updating: !1
115
- }));
116
- };
117
- handleStateChange = (e) => this.setState(e, this.formatUrl);
118
- checkAudio = (e) => {
119
- C(e) && w(e).then((t) => {
120
- this.handleStateChange({
121
- urlToUse: t,
122
- invalid: !t,
123
- url: e
124
- });
125
- }).catch(y);
126
- };
127
- checkVideo = (e) => {
128
- if (b(e)) {
129
- let t = `https://youtube.com/embed/${e.match(/^.*(youtu\.be\/|v\/|u\/\w\/|embed\/|watch\?v=|&v=)([^#&?]*).*/)[2]}`;
130
- y("is youtube"), this.handleStateChange({
131
- urlToUse: t,
132
- url: e,
133
- invalid: !1
134
- });
135
- }
136
- if (x(e)) {
137
- let t = `https://player.vimeo.com/video/${e.replace(/.*vimeo.com\/(.*)/g, "$1")}`;
138
- y("is vimeo"), this.handleStateChange({
139
- urlToUse: t,
140
- url: e,
141
- ends: null,
142
- invalid: !1
143
- });
144
- }
145
- if (S(e)) {
146
- let t = `https://drive.google.com/file/d/${e.replace(/^https:\/\/drive\.google\.com\/(?:file\/d\/|drive\/(?:u\/\d+\/)?folders\/|uc\?id=)([a-zA-Z0-9_-]+)\/.*/, "$1")}/preview`;
147
- y("is google drive"), this.handleStateChange({
148
- urlToUse: t,
149
- url: e,
150
- ends: null,
151
- invalid: !1
152
- });
153
- }
154
- };
155
- urlChange = (e) => {
156
- let { value: t } = e.target || {}, { type: n } = this.props;
157
- if (n && n === "audio") {
158
- this.checkAudio(t);
159
- return;
160
- } else if (n && n === "video") {
161
- this.checkVideo(t);
162
- return;
163
- }
164
- this.handleStateChange({
165
- urlToUse: null,
166
- url: null,
167
- invalid: !0
168
- });
169
- };
170
- changeHandler = (e) => (t) => this.handleStateChange({ [e]: t.target.value });
171
- handleDone = (e) => {
172
- let { handleClose: t } = this.props, { tabValue: n, fileUpload: r } = this.state, i = n === E.insertUrl;
173
- if (!e) {
174
- r.url && this.handleRemoveFile(), t(e);
175
- return;
176
- }
177
- if (i) {
178
- let { ends: n, height: r, url: i, urlToUse: a, formattedUrl: o, starts: s, width: c } = this.state;
179
- t(e, {
180
- tag: "iframe",
181
- ends: n,
182
- height: r,
183
- starts: s,
184
- width: c,
185
- url: i,
186
- urlToUse: a,
187
- src: o
188
- });
189
- return;
190
- }
191
- if (!r.loading) {
192
- t(e, {
193
- tag: "audio",
194
- src: r.url
195
- });
196
- return;
197
- }
198
- this.setState({ fileUpload: {
199
- ...r,
200
- scheduled: !0
201
- } });
202
- };
203
- handleUploadFile = async (e) => {
204
- e.preventDefault(), this.setState({ fileUpload: {
205
- ...this.state.fileUpload,
206
- error: null,
207
- loading: !0
208
- } });
209
- let t = e.target.files[0], n = new FileReader();
210
- n.onload = () => {
211
- let e = n.result;
212
- this.setState({ fileUpload: {
213
- ...this.state.fileUpload,
214
- url: e,
215
- mimeType: t.type
216
- } });
217
- }, n.readAsDataURL(t), this.props.uploadSoundSupport.add({
218
- fileChosen: t,
219
- done: (e, t) => {
220
- if (y("done: err:", e), e) {
221
- console.log(e), this.setState({ fileUpload: {
222
- ...this.state.fileUpload,
223
- scheduled: !1,
224
- loading: !1,
225
- error: e
226
- } });
227
- return;
228
- }
229
- let { fileUpload: n } = this.state, r = n && n.scheduled ? this.handleDone.bind(this, !0) : void 0;
230
- this.setState({ fileUpload: {
231
- ...n,
232
- scheduled: !1,
233
- loading: !1,
234
- url: t
235
- } }, r);
236
- }
237
- });
238
- };
239
- handleRemoveFile = async () => {
240
- this.props.uploadSoundSupport.delete(this.state.fileUpload.url, (e) => {
241
- e && (console.log(e), this.setState({ fileUpload: {
242
- ...this.state.fileUpload,
243
- error: e
244
- } }));
245
- }), this.setState({ fileUpload: {
246
- ...this.state.fileUpload,
247
- loading: !1,
248
- url: "",
249
- mimeType: ""
250
- } });
251
- };
252
- render() {
253
- let { open: t, disablePortal: n, type: r, edit: c, uploadSoundSupport: p } = this.props, { ends: y, height: x, invalid: S, starts: C, width: w, url: P, mimeType: F, formattedUrl: I, updating: L, tabValue: R, fileUpload: z } = this.state, B = b(P), V = R === E.insertUrl, H = R === E.uploadFile, U = V ? S || P == null : !z.url || z.scheduled, W = p?.add && p?.delete && r !== "video";
254
- return /* @__PURE__ */ s(D, {
255
- disablePortal: n,
256
- open: t,
257
- onClose: () => this.handleDone(!1),
258
- "aria-labelledby": "form-dialog-title",
259
- children: [
260
- /* @__PURE__ */ s(g, {
261
- id: "form-dialog-title",
262
- children: ["Insert ", T[r]]
263
- }),
264
- /* @__PURE__ */ o(l, { children: /* @__PURE__ */ s("div", { children: [
265
- /* @__PURE__ */ o(k, { children: /* @__PURE__ */ s(m, {
266
- indicatorColor: "primary",
267
- value: R,
268
- onChange: (e, t) => {
269
- this.setState({ tabValue: t });
270
- },
271
- children: [W ? /* @__PURE__ */ o(h, {
272
- value: E.uploadFile,
273
- label: "Upload file"
274
- }) : null, /* @__PURE__ */ o(h, {
275
- value: E.insertUrl,
276
- label: r === "video" ? "Insert YouTube, Vimeo, or Google Drive URL" : "Insert SoundCloud URL"
277
- })]
278
- }) }),
279
- V && /* @__PURE__ */ s("div", { children: [
280
- /* @__PURE__ */ o(u, {
281
- autoFocus: !0,
282
- error: S,
283
- helperText: S ? "Invalid URL" : "",
284
- margin: "dense",
285
- id: "name",
286
- label: "URL",
287
- placeholder: `Paste URL of ${r}...`,
288
- type: "text",
289
- onChange: this.urlChange,
290
- value: P,
291
- fullWidth: !0
292
- }),
293
- r === "video" && /* @__PURE__ */ s(O, { children: [
294
- /* @__PURE__ */ o(_, { children: "Video Properties" }),
295
- /* @__PURE__ */ o(u, {
296
- autoFocus: !0,
297
- margin: "dense",
298
- id: "width",
299
- label: "Width",
300
- type: "number",
301
- placeholder: "Width",
302
- value: w,
303
- onChange: this.changeHandler("width")
304
- }),
305
- /* @__PURE__ */ o(u, {
306
- autoFocus: !0,
307
- margin: "dense",
308
- id: "height",
309
- label: "Height",
310
- type: "number",
311
- placeholder: "Height",
312
- value: x,
313
- onChange: this.changeHandler("height")
314
- })
315
- ] }),
316
- I && /* @__PURE__ */ o("iframe", {
317
- width: w,
318
- height: x,
319
- src: I,
320
- frameBorder: "0",
321
- allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",
322
- allowFullScreen: !0
323
- }),
324
- r === "video" && (I || L) && !S && /* @__PURE__ */ o(e.Fragment, { children: /* @__PURE__ */ s(O, { children: [/* @__PURE__ */ o(u, {
325
- autoFocus: !0,
326
- margin: "dense",
327
- id: "starts",
328
- label: "Starts",
329
- type: "number",
330
- placeholder: "Starts",
331
- value: C,
332
- onChange: this.changeHandler("starts")
333
- }), B && /* @__PURE__ */ o(u, {
334
- autoFocus: !0,
335
- margin: "dense",
336
- id: "ends",
337
- label: "Ends",
338
- type: "number",
339
- placeholder: "Ends",
340
- value: y,
341
- onChange: this.changeHandler("ends")
342
- })] }) })
343
- ] }),
344
- H && /* @__PURE__ */ o(A, { children: /* @__PURE__ */ s("div", { children: [z.url ? /* @__PURE__ */ s(a, { children: [
345
- /* @__PURE__ */ s(k, { children: [/* @__PURE__ */ o("audio", {
346
- controls: "controls",
347
- controlsList: "nodownload",
348
- children: /* @__PURE__ */ o("source", {
349
- type: F,
350
- src: z.url
351
- })
352
- }), /* @__PURE__ */ o(N, {
353
- "aria-label": "delete",
354
- onClick: this.handleRemoveFile,
355
- children: /* @__PURE__ */ o(i, {})
356
- })] }),
357
- !z.scheduled && z.loading ? /* @__PURE__ */ o(v, {
358
- variant: "subheading",
359
- children: "Loading..."
360
- }) : null,
361
- z.scheduled ? /* @__PURE__ */ o(v, {
362
- variant: "subheading",
363
- children: "Waiting for Upload to finish, then inserting item..."
364
- }) : null
365
- ] }) : z.loading ? null : /* @__PURE__ */ o(j, {
366
- accept: "audio/*",
367
- onChange: this.handleUploadFile,
368
- type: "file"
369
- }), !!z.error && /* @__PURE__ */ o(M, {
370
- variant: "caption",
371
- children: z.error
372
- })] }) })
373
- ] }) }),
374
- /* @__PURE__ */ s(d, { children: [/* @__PURE__ */ o(f, {
375
- onClick: () => this.handleDone(!1),
376
- color: "primary",
377
- children: "Cancel"
378
- }), /* @__PURE__ */ o(f, {
379
- disabled: U,
380
- onClick: () => this.handleDone(!0),
381
- color: "primary",
382
- children: c ? "Update" : "Insert"
383
- })] })
384
- ]
385
- });
386
- }
387
- };
388
- //#endregion
389
- export { P as default };
@@ -1,19 +0,0 @@
1
- /**
2
- * @synced-from pie-lib/packages/editable-html-tip-tap/src/components/media/MediaToolbar.jsx
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- import React from 'react';
10
- import PropTypes from 'prop-types';
11
- declare class MediaToolbar extends React.Component {
12
- static propTypes: {
13
- onEdit: PropTypes.Requireable<(...args: any[]) => any>;
14
- hideEdit: PropTypes.Requireable<boolean>;
15
- onRemove: PropTypes.Requireable<(...args: any[]) => any>;
16
- };
17
- render(): React.JSX.Element;
18
- }
19
- export default MediaToolbar;
@@ -1,41 +0,0 @@
1
- import e from "react";
2
- import { styled as t } from "@mui/material/styles";
3
- import n from "prop-types";
4
- import { jsx as r, jsxs as i } from "react/jsx-runtime";
5
- //#region src/components/media/MediaToolbar.tsx
6
- var a = t("span")(({ theme: e }) => ({
7
- position: "relative",
8
- bottom: "5px",
9
- left: 0,
10
- width: "100%",
11
- background: e.palette.common.white,
12
- display: "inline-flex",
13
- padding: "5px",
14
- boxShadow: "0px 4px 4px rgba(0, 0, 0, 0.25)"
15
- })), o = t("span")(({ theme: e }) => ({
16
- cursor: "pointer",
17
- flex: 3,
18
- border: `solid ${e.palette.common.black}`,
19
- textAlign: "right",
20
- borderWidth: "0 2px 0 0",
21
- marginRight: "5px",
22
- paddingRight: "5px"
23
- })), s = t("span")({ cursor: "pointer" }), c = class extends e.Component {
24
- static propTypes = {
25
- onEdit: n.func,
26
- hideEdit: n.bool,
27
- onRemove: n.func
28
- };
29
- render() {
30
- let { hideEdit: e, onEdit: t, onRemove: n } = this.props;
31
- return /* @__PURE__ */ i(a, { children: [e ? null : /* @__PURE__ */ r(o, {
32
- onClick: t,
33
- children: "Edit Settings"
34
- }), /* @__PURE__ */ r(s, {
35
- onClick: n,
36
- children: "Remove"
37
- })] });
38
- }
39
- };
40
- //#endregion
41
- export { c as default };
@@ -1,19 +0,0 @@
1
- /**
2
- * @synced-from pie-lib/packages/editable-html-tip-tap/src/components/media/MediaWrapper.jsx
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- import React from 'react';
10
- import PropTypes from 'prop-types';
11
- declare class MediaWrapper extends React.Component {
12
- static propTypes: {
13
- children: PropTypes.Requireable<any[]>;
14
- editor: PropTypes.Requireable<boolean>;
15
- width: PropTypes.Requireable<NonNullable<string | number | null | undefined>>;
16
- };
17
- render(): React.JSX.Element;
18
- }
19
- export default MediaWrapper;
@@ -1,23 +0,0 @@
1
- /**
2
- * @synced-from pie-lib/packages/editable-html-tip-tap/src/components/respArea/DragInTheBlank/DragInTheBlank.jsx
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- import React from 'react';
10
- import PropTypes from 'prop-types';
11
- export declare const onValueChange: (editor: any, node: any, pos: any, choice: any) => void;
12
- export declare const onRemoveResponse: (editor: any, node: any, choice: any) => void;
13
- declare const DragDrop: {
14
- (props: any): React.JSX.Element;
15
- propTypes: {
16
- attributes: PropTypes.Requireable<object>;
17
- data: PropTypes.Requireable<object>;
18
- n: PropTypes.Requireable<object>;
19
- nodeProps: PropTypes.Requireable<object>;
20
- opts: PropTypes.Requireable<object>;
21
- };
22
- };
23
- export default DragDrop;
@@ -1,58 +0,0 @@
1
- import e from "./choice.js";
2
- import "react";
3
- import { omit as t } from "@pie-element/shared-lodash";
4
- import { NodeViewWrapper as n } from "@tiptap/react";
5
- import r from "prop-types";
6
- import { jsx as i } from "react/jsx-runtime";
7
- //#region src/components/respArea/DragInTheBlank/DragInTheBlank.tsx
8
- var a = (e, t, n, r) => {
9
- let { tr: i } = e.state;
10
- i.setNodeMarkup(n, void 0, {
11
- ...t.attrs,
12
- ...r.value
13
- }), i.isDone = !0, e.view.dispatch(i);
14
- }, o = (e, n, r) => {
15
- let { tr: i } = e.state;
16
- i.setNodeMarkup(r.pos, void 0, t(n.attrs, ["value", "id"])), i.isDone = !0, e.view.dispatch(i);
17
- }, s = (t) => {
18
- let { editor: r, node: s, getPos: c, options: l, selected: u } = t, { attrs: d } = s, { inTable: f } = d, p = c();
19
- return /* @__PURE__ */ i(n, {
20
- className: "drag-in-the-blank",
21
- "data-selected": u,
22
- style: {
23
- display: "inline",
24
- whiteSpace: "normal"
25
- },
26
- children: /* @__PURE__ */ i("span", {
27
- ...d,
28
- style: {
29
- display: "inline-flex",
30
- minHeight: "50px",
31
- minWidth: "178px",
32
- position: "relative",
33
- margin: f ? "10px" : "0 10px",
34
- cursor: "pointer"
35
- },
36
- children: /* @__PURE__ */ i(e, {
37
- n: d,
38
- dragKey: d.id,
39
- targetId: "0",
40
- pos: p,
41
- value: d,
42
- duplicates: l.duplicates,
43
- selected: u,
44
- onChange: (e) => a(r, s, p, e),
45
- removeResponse: (e) => o(r, s, e)
46
- })
47
- })
48
- });
49
- };
50
- s.propTypes = {
51
- attributes: r.object,
52
- data: r.object,
53
- n: r.object,
54
- nodeProps: r.object,
55
- opts: r.object
56
- };
57
- //#endregion
58
- export { s as default };
@@ -1,56 +0,0 @@
1
- /**
2
- * @synced-from pie-lib/packages/editable-html-tip-tap/src/components/respArea/DragInTheBlank/choice.jsx
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- import React from 'react';
10
- import PropTypes from 'prop-types';
11
- export declare function BlankContent({ n, children, isDragging, isOver, dragItem, value, selected }: {
12
- n: any;
13
- children: any;
14
- isDragging: any;
15
- isOver: any;
16
- dragItem: any;
17
- value: any;
18
- selected: any;
19
- }): React.JSX.Element;
20
- export declare namespace BlankContent {
21
- var propTypes: {
22
- n: PropTypes.Requireable<object>;
23
- children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
24
- isDragging: PropTypes.Requireable<boolean>;
25
- isOver: PropTypes.Requireable<boolean>;
26
- dragItem: PropTypes.Requireable<object>;
27
- value: PropTypes.Requireable<object>;
28
- selected: PropTypes.Requireable<boolean>;
29
- };
30
- }
31
- declare function DragDropChoice({ value, disabled, instanceId, children, n, onChange, removeResponse, duplicates, pos, selected, }: {
32
- value: any;
33
- disabled: any;
34
- instanceId: any;
35
- children: any;
36
- n: any;
37
- onChange: any;
38
- removeResponse: any;
39
- duplicates: any;
40
- pos: any;
41
- selected: any;
42
- }): React.JSX.Element;
43
- declare namespace DragDropChoice {
44
- var propTypes: {
45
- value: PropTypes.Requireable<object>;
46
- disabled: PropTypes.Requireable<boolean>;
47
- instanceId: PropTypes.Requireable<string>;
48
- children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
49
- n: PropTypes.Validator<object>;
50
- onChange: PropTypes.Validator<(...args: any[]) => any>;
51
- removeResponse: PropTypes.Validator<(...args: any[]) => any>;
52
- duplicates: PropTypes.Requireable<boolean>;
53
- selected: PropTypes.Requireable<boolean>;
54
- };
55
- }
56
- export default DragDropChoice;