@pie-lib/editable-html 10.0.0-beta.4 → 10.0.0-beta.6
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.
- package/CHANGELOG.md +255 -152
- package/lib/components.js +15 -39
- package/lib/components.js.map +1 -1
- package/lib/editor.js +200 -356
- package/lib/editor.js.map +1 -1
- package/lib/index.js +25 -49
- package/lib/index.js.map +1 -1
- package/lib/new-serialization.js +31 -71
- package/lib/new-serialization.js.map +1 -1
- package/lib/parse-html.js +7 -6
- package/lib/parse-html.js.map +1 -1
- package/lib/plugins/characters/custom-popper.js +3 -13
- package/lib/plugins/characters/custom-popper.js.map +1 -1
- package/lib/plugins/characters/index.js +20 -59
- package/lib/plugins/characters/index.js.map +1 -1
- package/lib/plugins/characters/utils.js +1 -1
- package/lib/plugins/characters/utils.js.map +1 -1
- package/lib/plugins/hotKeys/index.js +9 -16
- package/lib/plugins/hotKeys/index.js.map +1 -1
- package/lib/plugins/image/alt-dialog.js +6 -27
- package/lib/plugins/image/alt-dialog.js.map +1 -1
- package/lib/plugins/image/component.js +42 -99
- package/lib/plugins/image/component.js.map +1 -1
- package/lib/plugins/image/image-toolbar.js +14 -50
- package/lib/plugins/image/image-toolbar.js.map +1 -1
- package/lib/plugins/image/index.js +16 -59
- package/lib/plugins/image/index.js.map +1 -1
- package/lib/plugins/image/insert-image-handler.js +13 -25
- package/lib/plugins/image/insert-image-handler.js.map +1 -1
- package/lib/plugins/index.js +6 -36
- package/lib/plugins/index.js.map +1 -1
- package/lib/plugins/list/index.js +11 -46
- package/lib/plugins/list/index.js.map +1 -1
- package/lib/plugins/math/index.js +89 -93
- package/lib/plugins/math/index.js.map +1 -1
- package/lib/plugins/media/index.js +32 -109
- package/lib/plugins/media/index.js.map +1 -1
- package/lib/plugins/media/media-dialog.js +107 -195
- package/lib/plugins/media/media-dialog.js.map +1 -1
- package/lib/plugins/media/media-toolbar.js +7 -27
- package/lib/plugins/media/media-toolbar.js.map +1 -1
- package/lib/plugins/media/media-wrapper.js +9 -14
- package/lib/plugins/media/media-wrapper.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +13 -53
- package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/index.js +6 -20
- package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
- package/lib/plugins/respArea/explicit-constructed-response/index.js +5 -10
- package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
- package/lib/plugins/respArea/icons/index.js +16 -31
- package/lib/plugins/respArea/icons/index.js.map +1 -1
- package/lib/plugins/respArea/index.js +7 -54
- package/lib/plugins/respArea/index.js.map +1 -1
- package/lib/plugins/respArea/inline-dropdown/index.js +3 -10
- package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
- package/lib/plugins/respArea/utils.js +6 -21
- package/lib/plugins/respArea/utils.js.map +1 -1
- package/lib/plugins/table/icons/index.js +1 -8
- package/lib/plugins/table/icons/index.js.map +1 -1
- package/lib/plugins/table/index.js +54 -187
- package/lib/plugins/table/index.js.map +1 -1
- package/lib/plugins/table/table-toolbar.js +12 -44
- package/lib/plugins/table/table-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/default-toolbar.js +17 -46
- package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/done-button.js +2 -10
- package/lib/plugins/toolbar/done-button.js.map +1 -1
- package/lib/plugins/toolbar/editor-and-toolbar.js +134 -144
- package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/index.js +2 -6
- package/lib/plugins/toolbar/index.js.map +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js +9 -40
- package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
- package/lib/plugins/toolbar/toolbar.js +29 -83
- package/lib/plugins/toolbar/toolbar.js.map +1 -1
- package/lib/plugins/utils.js +8 -30
- package/lib/plugins/utils.js.map +1 -1
- package/lib/serialization.js +11 -69
- package/lib/serialization.js.map +1 -1
- package/lib/test-serializer.js +5 -56
- package/lib/test-serializer.js.map +1 -1
- package/lib/theme.js +1 -1
- package/lib/theme.js.map +1 -1
- package/package.json +7 -7
- package/playground/image/data.js +20 -20
- package/playground/image/index.html +20 -22
- package/playground/image/index.jsx +10 -12
- package/playground/index.html +23 -25
- package/playground/mathquill/index.html +20 -23
- package/playground/mathquill/index.jsx +22 -18
- package/playground/prod-test/index.html +20 -24
- package/playground/prod-test/index.jsx +3 -5
- package/playground/schema-override/data.js +10 -10
- package/playground/schema-override/image-plugin.jsx +4 -3
- package/playground/schema-override/index.html +19 -21
- package/playground/schema-override/index.jsx +14 -13
- package/playground/serialization/data.js +10 -10
- package/playground/serialization/image-plugin.jsx +4 -3
- package/playground/serialization/index.html +20 -22
- package/playground/table-examples.html +8 -5
- package/playground/webpack.config.js +10 -10
- package/src/editor.jsx +108 -104
- package/src/index.jsx +20 -13
- package/src/new-serialization.jsx +30 -11
- package/src/parse-html.js +1 -1
- package/src/plugins/characters/custom-popper.js +7 -7
- package/src/plugins/characters/index.jsx +34 -23
- package/src/plugins/characters/utils.js +81 -81
- package/src/plugins/image/alt-dialog.jsx +5 -4
- package/src/plugins/image/component.jsx +47 -44
- package/src/plugins/image/image-toolbar.jsx +19 -27
- package/src/plugins/image/index.jsx +24 -18
- package/src/plugins/image/insert-image-handler.js +9 -0
- package/src/plugins/index.jsx +7 -9
- package/src/plugins/list/index.jsx +7 -7
- package/src/plugins/math/index.jsx +71 -28
- package/src/plugins/media/index.jsx +7 -7
- package/src/plugins/media/media-dialog.js +63 -89
- package/src/plugins/media/media-toolbar.jsx +8 -8
- package/src/plugins/media/media-wrapper.jsx +8 -5
- package/src/plugins/respArea/drag-in-the-blank/choice.jsx +19 -21
- package/src/plugins/respArea/drag-in-the-blank/index.jsx +4 -4
- package/src/plugins/respArea/explicit-constructed-response/index.jsx +5 -4
- package/src/plugins/respArea/icons/index.jsx +14 -11
- package/src/plugins/respArea/index.jsx +9 -15
- package/src/plugins/respArea/inline-dropdown/index.jsx +6 -6
- package/src/plugins/respArea/utils.jsx +7 -3
- package/src/plugins/table/icons/index.jsx +11 -17
- package/src/plugins/table/index.jsx +14 -10
- package/src/plugins/table/table-toolbar.jsx +6 -6
- package/src/plugins/toolbar/default-toolbar.jsx +9 -9
- package/src/plugins/toolbar/done-button.jsx +4 -4
- package/src/plugins/toolbar/editor-and-toolbar.jsx +36 -33
- package/src/plugins/toolbar/index.jsx +3 -2
- package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
- package/src/plugins/toolbar/toolbar.jsx +6 -1
- package/src/plugins/utils.js +2 -2
- package/src/serialization.jsx +34 -32
- package/src/test-serializer.js +2 -9
- package/lib/old-serialization.js +0 -330
- package/lib/slate-editor.js +0 -302
- package/src/test-serializer.js.rej +0 -20
- package/yarn-error.log +0 -18318
|
@@ -1,101 +1,61 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = exports.MediaDialog = void 0;
|
|
9
|
-
|
|
10
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
11
|
-
|
|
12
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
13
|
-
|
|
14
10
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
15
|
-
|
|
16
11
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
17
|
-
|
|
18
12
|
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
19
|
-
|
|
20
13
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
21
|
-
|
|
22
14
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
23
|
-
|
|
24
15
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
25
|
-
|
|
26
16
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
27
|
-
|
|
28
17
|
var _react = _interopRequireDefault(require("react"));
|
|
29
|
-
|
|
30
18
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
31
|
-
|
|
32
19
|
var _debug = _interopRequireDefault(require("debug"));
|
|
33
|
-
|
|
34
20
|
var _renderUi = require("@pie-lib/render-ui");
|
|
35
|
-
|
|
36
21
|
var _styles = require("@material-ui/core/styles");
|
|
37
|
-
|
|
38
22
|
var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
|
|
39
|
-
|
|
40
23
|
var _Dialog = _interopRequireDefault(require("@material-ui/core/Dialog"));
|
|
41
|
-
|
|
42
24
|
var _Tabs = _interopRequireDefault(require("@material-ui/core/Tabs"));
|
|
43
|
-
|
|
44
25
|
var _Tab = _interopRequireDefault(require("@material-ui/core/Tab"));
|
|
45
|
-
|
|
46
26
|
var _DialogTitle = _interopRequireDefault(require("@material-ui/core/DialogTitle"));
|
|
47
|
-
|
|
48
27
|
var _DialogContent = _interopRequireDefault(require("@material-ui/core/DialogContent"));
|
|
49
|
-
|
|
50
28
|
var _DialogContentText = _interopRequireDefault(require("@material-ui/core/DialogContentText"));
|
|
51
|
-
|
|
52
29
|
var _DialogActions = _interopRequireDefault(require("@material-ui/core/DialogActions"));
|
|
53
|
-
|
|
54
30
|
var _TextField = _interopRequireDefault(require("@material-ui/core/TextField"));
|
|
55
|
-
|
|
56
31
|
var _Typography = _interopRequireDefault(require("@material-ui/core/Typography"));
|
|
57
|
-
|
|
58
32
|
var _IconButton = _interopRequireDefault(require("@material-ui/core/IconButton"));
|
|
59
|
-
|
|
60
33
|
var _Delete = _interopRequireDefault(require("@material-ui/icons/Delete"));
|
|
61
|
-
|
|
62
34
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
63
|
-
|
|
64
35
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
65
|
-
|
|
66
36
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
67
|
-
|
|
68
37
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
69
|
-
|
|
70
38
|
var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:media:dialog');
|
|
71
|
-
|
|
72
39
|
var matchYoutubeUrl = function matchYoutubeUrl(url) {
|
|
73
40
|
if (!url) {
|
|
74
41
|
return false;
|
|
75
42
|
}
|
|
76
|
-
|
|
77
43
|
var p = /^(?:https?:\/\/)?(?:m\.|www\.)?(?:youtu\.be\/|youtube\.com\/(?:embed\/|v\/|watch\?v=|watch\?.+&v=))((\w|-){11})(?:\S+)?$/;
|
|
78
|
-
|
|
79
44
|
if (url.match(p)) {
|
|
80
45
|
return url.match(p)[1];
|
|
81
46
|
}
|
|
82
|
-
|
|
83
47
|
return false;
|
|
84
48
|
};
|
|
85
|
-
|
|
86
49
|
var matchVimeoUrl = function matchVimeoUrl(url) {
|
|
87
50
|
return url && /(http|https)?:\/\/(www\.)?(player\.)?vimeo.com\/(?:channels\/(?:\w+\/)?|groups\/([^/]*)\/videos\/|)(video\/)?(\d+)(?:|\/\?)/.test(url);
|
|
88
51
|
};
|
|
89
|
-
|
|
90
52
|
var matchSoundCloudUrl = function matchSoundCloudUrl(url) {
|
|
91
53
|
if (!url) {
|
|
92
54
|
return false;
|
|
93
55
|
}
|
|
94
|
-
|
|
95
56
|
var regexp = /^https?:\/\/(soundcloud\.com|snd\.sc)\/(.*)$/;
|
|
96
57
|
return url.match(regexp) && url.match(regexp)[2];
|
|
97
58
|
};
|
|
98
|
-
|
|
99
59
|
var makeApiRequest = function makeApiRequest(url) {
|
|
100
60
|
return new Promise(function (resolve) {
|
|
101
61
|
try {
|
|
@@ -115,71 +75,57 @@ var makeApiRequest = function makeApiRequest(url) {
|
|
|
115
75
|
}
|
|
116
76
|
});
|
|
117
77
|
};
|
|
118
|
-
|
|
119
78
|
var typeMap = {
|
|
120
79
|
video: 'Video',
|
|
121
80
|
audio: 'Audio'
|
|
122
81
|
};
|
|
123
|
-
|
|
124
82
|
var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
125
83
|
(0, _inherits2["default"])(MediaDialog, _React$Component);
|
|
126
|
-
|
|
127
84
|
var _super = _createSuper(MediaDialog);
|
|
128
|
-
|
|
129
85
|
function MediaDialog(props) {
|
|
130
86
|
var _this;
|
|
131
|
-
|
|
132
87
|
(0, _classCallCheck2["default"])(this, MediaDialog);
|
|
133
88
|
_this = _super.call(this, props);
|
|
134
89
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "formatUrl", function () {
|
|
135
90
|
var _this$state = _this.state,
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
91
|
+
url = _this$state.url,
|
|
92
|
+
urlToUse = _this$state.urlToUse,
|
|
93
|
+
starts = _this$state.starts,
|
|
94
|
+
ends = _this$state.ends;
|
|
140
95
|
var isYoutube = matchYoutubeUrl(url);
|
|
141
96
|
var isVimeo = matchVimeoUrl(url);
|
|
142
97
|
var formattedUrl = urlToUse || '';
|
|
143
|
-
|
|
144
98
|
if ((isYoutube || isVimeo) && urlToUse) {
|
|
145
99
|
var params = [];
|
|
146
100
|
var paramName;
|
|
147
101
|
var paramStart;
|
|
148
|
-
|
|
149
102
|
switch (true) {
|
|
150
103
|
case isVimeo:
|
|
151
104
|
paramName = 't';
|
|
152
105
|
paramStart = '#';
|
|
153
106
|
break;
|
|
154
|
-
|
|
155
107
|
case isYoutube:
|
|
156
108
|
paramName = 'start';
|
|
157
109
|
paramStart = '?';
|
|
158
110
|
break;
|
|
159
|
-
|
|
160
111
|
default:
|
|
161
112
|
paramName = 'start';
|
|
162
113
|
paramStart = '?';
|
|
163
114
|
}
|
|
164
|
-
|
|
165
115
|
if (starts) {
|
|
166
116
|
params.push("".concat(paramName, "=").concat(starts));
|
|
167
117
|
}
|
|
168
|
-
|
|
169
118
|
if (ends) {
|
|
170
119
|
params.push("end=".concat(ends));
|
|
171
120
|
}
|
|
172
|
-
|
|
173
121
|
formattedUrl = "".concat(urlToUse).concat(params.length ? paramStart : '').concat(params.join('&'));
|
|
174
122
|
}
|
|
175
|
-
|
|
176
123
|
var callback = function callback() {
|
|
177
124
|
return _this.setState({
|
|
178
125
|
formattedUrl: formattedUrl,
|
|
179
126
|
updating: false
|
|
180
127
|
});
|
|
181
128
|
};
|
|
182
|
-
|
|
183
129
|
_this.setState({
|
|
184
130
|
formattedUrl: null,
|
|
185
131
|
updating: true
|
|
@@ -190,10 +136,8 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
190
136
|
});
|
|
191
137
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "urlChange", function (e) {
|
|
192
138
|
var _ref = e.target || {},
|
|
193
|
-
|
|
194
|
-
|
|
139
|
+
value = _ref.value;
|
|
195
140
|
var type = _this.props.type;
|
|
196
|
-
|
|
197
141
|
if (type && type === 'audio') {
|
|
198
142
|
if (matchSoundCloudUrl(value)) {
|
|
199
143
|
makeApiRequest(value).then(function (urlToUse) {
|
|
@@ -212,34 +156,26 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
212
156
|
var id = match[2];
|
|
213
157
|
var urlToUse = "https://youtube.com/embed/".concat(id);
|
|
214
158
|
log('is youtube');
|
|
215
|
-
|
|
216
159
|
_this.handleStateChange({
|
|
217
160
|
urlToUse: urlToUse,
|
|
218
161
|
url: value || '',
|
|
219
162
|
invalid: false
|
|
220
163
|
});
|
|
221
|
-
|
|
222
164
|
return;
|
|
223
165
|
}
|
|
224
|
-
|
|
225
166
|
if (matchVimeoUrl(value)) {
|
|
226
167
|
var _id = value.replace(/.*vimeo.com\/(.*)/g, '$1');
|
|
227
|
-
|
|
228
168
|
var _urlToUse2 = "https://player.vimeo.com/video/".concat(_id);
|
|
229
|
-
|
|
230
169
|
log('is vimeo');
|
|
231
|
-
|
|
232
170
|
_this.handleStateChange({
|
|
233
171
|
urlToUse: _urlToUse2,
|
|
234
172
|
url: value || '',
|
|
235
173
|
ends: null,
|
|
236
174
|
invalid: false
|
|
237
175
|
});
|
|
238
|
-
|
|
239
176
|
return;
|
|
240
177
|
}
|
|
241
178
|
}
|
|
242
|
-
|
|
243
179
|
_this.handleStateChange({
|
|
244
180
|
urlToUse: '',
|
|
245
181
|
url: '',
|
|
@@ -254,25 +190,23 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
254
190
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleDone", function (val) {
|
|
255
191
|
var handleClose = _this.props.handleClose;
|
|
256
192
|
var _this$state2 = _this.state,
|
|
257
|
-
|
|
258
|
-
|
|
193
|
+
tabValue = _this$state2.tabValue,
|
|
194
|
+
fileUpload = _this$state2.fileUpload;
|
|
259
195
|
var isInsertURL = tabValue === 0;
|
|
260
|
-
|
|
261
196
|
if (!val) {
|
|
262
197
|
if (fileUpload.url) {
|
|
263
198
|
_this.handleRemoveFile();
|
|
264
199
|
}
|
|
265
|
-
|
|
266
200
|
handleClose(val);
|
|
267
201
|
} else if (isInsertURL) {
|
|
268
202
|
var _this$state3 = _this.state,
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
203
|
+
ends = _this$state3.ends,
|
|
204
|
+
height = _this$state3.height,
|
|
205
|
+
url = _this$state3.url,
|
|
206
|
+
urlToUse = _this$state3.urlToUse,
|
|
207
|
+
formattedUrl = _this$state3.formattedUrl,
|
|
208
|
+
starts = _this$state3.starts,
|
|
209
|
+
width = _this$state3.width;
|
|
276
210
|
handleClose(val, {
|
|
277
211
|
tag: 'iframe',
|
|
278
212
|
ends: ends,
|
|
@@ -294,111 +228,95 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
294
228
|
var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(e) {
|
|
295
229
|
var fileChosen, reader;
|
|
296
230
|
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
297
|
-
while (1) {
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
231
|
+
while (1) switch (_context.prev = _context.next) {
|
|
232
|
+
case 0:
|
|
233
|
+
e.preventDefault();
|
|
234
|
+
_this.setState({
|
|
235
|
+
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
236
|
+
error: null,
|
|
237
|
+
loading: true
|
|
238
|
+
})
|
|
239
|
+
});
|
|
240
|
+
fileChosen = e.target.files[0];
|
|
241
|
+
reader = new FileReader();
|
|
242
|
+
reader.onload = function () {
|
|
243
|
+
var dataURL = reader.result;
|
|
302
244
|
_this.setState({
|
|
303
245
|
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
304
|
-
|
|
305
|
-
loading: true
|
|
246
|
+
url: dataURL
|
|
306
247
|
})
|
|
307
248
|
});
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
//eslint-disable-next-line
|
|
331
|
-
console.log(err);
|
|
332
|
-
|
|
333
|
-
_this.setState({
|
|
334
|
-
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
335
|
-
loading: false,
|
|
336
|
-
error: err
|
|
337
|
-
})
|
|
338
|
-
});
|
|
339
|
-
} else {
|
|
340
|
-
_this.setState({
|
|
341
|
-
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
342
|
-
loading: false,
|
|
343
|
-
url: src
|
|
344
|
-
})
|
|
345
|
-
});
|
|
346
|
-
}
|
|
249
|
+
};
|
|
250
|
+
reader.readAsDataURL(fileChosen);
|
|
251
|
+
_this.props.uploadSoundSupport.add({
|
|
252
|
+
fileChosen: fileChosen,
|
|
253
|
+
done: function done(err, src) {
|
|
254
|
+
log('done: err:', err);
|
|
255
|
+
if (err) {
|
|
256
|
+
//eslint-disable-next-line
|
|
257
|
+
console.log(err);
|
|
258
|
+
_this.setState({
|
|
259
|
+
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
260
|
+
loading: false,
|
|
261
|
+
error: err
|
|
262
|
+
})
|
|
263
|
+
});
|
|
264
|
+
} else {
|
|
265
|
+
_this.setState({
|
|
266
|
+
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
267
|
+
loading: false,
|
|
268
|
+
url: src
|
|
269
|
+
})
|
|
270
|
+
});
|
|
347
271
|
}
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
}
|
|
272
|
+
}
|
|
273
|
+
});
|
|
274
|
+
case 7:
|
|
275
|
+
case "end":
|
|
276
|
+
return _context.stop();
|
|
354
277
|
}
|
|
355
278
|
}, _callee);
|
|
356
279
|
}));
|
|
357
|
-
|
|
358
280
|
return function (_x) {
|
|
359
281
|
return _ref2.apply(this, arguments);
|
|
360
282
|
};
|
|
361
283
|
}());
|
|
362
284
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleRemoveFile", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
363
285
|
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
364
|
-
while (1) {
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
}
|
|
378
|
-
}); // we should put it inside uploadSoundSupport.delete but we can leave it here for testing purposes
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
_this.setState({
|
|
382
|
-
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
383
|
-
loading: false,
|
|
384
|
-
url: ''
|
|
385
|
-
})
|
|
386
|
-
});
|
|
286
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
287
|
+
case 0:
|
|
288
|
+
_this.props.uploadSoundSupport["delete"](_this.state.fileUpload.url, function (err) {
|
|
289
|
+
if (err) {
|
|
290
|
+
//eslint-disable-next-line
|
|
291
|
+
console.log(err);
|
|
292
|
+
_this.setState({
|
|
293
|
+
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
294
|
+
error: err
|
|
295
|
+
})
|
|
296
|
+
});
|
|
297
|
+
}
|
|
298
|
+
});
|
|
387
299
|
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
300
|
+
// we should put it inside uploadSoundSupport.delete but we can leave it here for testing purposes
|
|
301
|
+
_this.setState({
|
|
302
|
+
fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
|
|
303
|
+
loading: false,
|
|
304
|
+
url: ''
|
|
305
|
+
})
|
|
306
|
+
});
|
|
307
|
+
case 2:
|
|
308
|
+
case "end":
|
|
309
|
+
return _context2.stop();
|
|
392
310
|
}
|
|
393
311
|
}, _callee2);
|
|
394
312
|
})));
|
|
395
313
|
var _src = props.src,
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
314
|
+
_starts = props.starts,
|
|
315
|
+
_ends = props.ends,
|
|
316
|
+
_height = props.height,
|
|
317
|
+
_url = props.url,
|
|
318
|
+
_urlToUse = props.urlToUse,
|
|
319
|
+
_width = props.width;
|
|
402
320
|
_this.state = {
|
|
403
321
|
ends: _ends || 0,
|
|
404
322
|
url: _url || '',
|
|
@@ -418,7 +336,6 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
418
336
|
};
|
|
419
337
|
return _this;
|
|
420
338
|
}
|
|
421
|
-
|
|
422
339
|
(0, _createClass2["default"])(MediaDialog, [{
|
|
423
340
|
key: "componentDidMount",
|
|
424
341
|
value: function componentDidMount() {
|
|
@@ -434,25 +351,24 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
434
351
|
key: "render",
|
|
435
352
|
value: function render() {
|
|
436
353
|
var _this2 = this;
|
|
437
|
-
|
|
438
354
|
var _this$props = this.props,
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
355
|
+
classes = _this$props.classes,
|
|
356
|
+
open = _this$props.open,
|
|
357
|
+
disablePortal = _this$props.disablePortal,
|
|
358
|
+
type = _this$props.type,
|
|
359
|
+
edit = _this$props.edit,
|
|
360
|
+
uploadSoundSupport = _this$props.uploadSoundSupport;
|
|
445
361
|
var _this$state4 = this.state,
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
362
|
+
ends = _this$state4.ends,
|
|
363
|
+
height = _this$state4.height,
|
|
364
|
+
invalid = _this$state4.invalid,
|
|
365
|
+
starts = _this$state4.starts,
|
|
366
|
+
width = _this$state4.width,
|
|
367
|
+
url = _this$state4.url,
|
|
368
|
+
formattedUrl = _this$state4.formattedUrl,
|
|
369
|
+
updating = _this$state4.updating,
|
|
370
|
+
tabValue = _this$state4.tabValue,
|
|
371
|
+
fileUpload = _this$state4.fileUpload;
|
|
456
372
|
var isYoutube = matchYoutubeUrl(url);
|
|
457
373
|
var isInsertURL = tabValue === 0;
|
|
458
374
|
var isUploadMedia = tabValue === 1;
|
|
@@ -585,7 +501,6 @@ var MediaDialog = /*#__PURE__*/function (_React$Component) {
|
|
|
585
501
|
}]);
|
|
586
502
|
return MediaDialog;
|
|
587
503
|
}(_react["default"].Component);
|
|
588
|
-
|
|
589
504
|
exports.MediaDialog = MediaDialog;
|
|
590
505
|
(0, _defineProperty2["default"])(MediaDialog, "propTypes", {
|
|
591
506
|
classes: _propTypes["default"].object.isRequired,
|
|
@@ -606,8 +521,7 @@ exports.MediaDialog = MediaDialog;
|
|
|
606
521
|
height: _propTypes["default"].number,
|
|
607
522
|
width: _propTypes["default"].number
|
|
608
523
|
});
|
|
609
|
-
|
|
610
|
-
var styles = function styles() {
|
|
524
|
+
var styles = function styles(theme) {
|
|
611
525
|
return {
|
|
612
526
|
paper: {
|
|
613
527
|
minWidth: '500px'
|
|
@@ -620,7 +534,7 @@ var styles = function styles() {
|
|
|
620
534
|
flexDirection: 'space-between'
|
|
621
535
|
},
|
|
622
536
|
rowItem: {
|
|
623
|
-
marginRight:
|
|
537
|
+
marginRight: theme.spacing.unit * 1.5,
|
|
624
538
|
cursor: 'pointer'
|
|
625
539
|
},
|
|
626
540
|
active: {
|
|
@@ -628,19 +542,17 @@ var styles = function styles() {
|
|
|
628
542
|
borderBottom: "2px solid ".concat(_renderUi.color.primary())
|
|
629
543
|
},
|
|
630
544
|
uploadInput: {
|
|
631
|
-
marginTop:
|
|
545
|
+
marginTop: theme.spacing.unit * 1.5
|
|
632
546
|
},
|
|
633
547
|
error: {
|
|
634
|
-
marginTop:
|
|
635
|
-
color:
|
|
548
|
+
marginTop: theme.spacing.unit * 1.5,
|
|
549
|
+
color: theme.palette.error.main
|
|
636
550
|
},
|
|
637
551
|
deleteIcon: {
|
|
638
|
-
marginLeft:
|
|
552
|
+
marginLeft: theme.spacing.unit * 1.5
|
|
639
553
|
}
|
|
640
554
|
};
|
|
641
555
|
};
|
|
642
|
-
|
|
643
556
|
var _default = (0, _styles.withStyles)(styles)(MediaDialog);
|
|
644
|
-
|
|
645
557
|
exports["default"] = _default;
|
|
646
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","matchYoutubeUrl","url","p","match","matchVimeoUrl","test","matchSoundCloudUrl","regexp","makeApiRequest","Promise","resolve","fetch","then","response","json","d","document","createElement","innerHTML","html","iframe","querySelector","src","err","typeMap","video","audio","MediaDialog","props","state","urlToUse","starts","ends","isYoutube","isVimeo","formattedUrl","params","paramName","paramStart","push","length","join","callback","setState","updating","newState","formatUrl","e","target","value","type","handleStateChange","invalid","regExp","id","replace","val","handleClose","tabValue","fileUpload","isInsertURL","handleRemoveFile","height","width","tag","preventDefault","error","loading","fileChosen","files","reader","FileReader","onload","dataURL","result","readAsDataURL","uploadSoundSupport","add","done","console","urlChange","classes","open","disablePortal","edit","isUploadMedia","submitIsDisabled","undefined","paper","handleDone","row","event","root","properties","changeHandler","uploadInput","deleteIcon","input","handleUploadFile","React","Component","PropTypes","object","isRequired","bool","func","shape","string","number","styles","minWidth","padding","display","flexDirection","rowItem","marginRight","cursor","active","color","primary","borderBottom","marginTop","marginLeft","withStyles"],"sources":["../../../src/plugins/media/media-dialog.js"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debug from 'debug';\nimport { color } from '@pie-lib/render-ui';\nimport { withStyles } from '@material-ui/core/styles';\nimport Button from '@material-ui/core/Button';\nimport Dialog from '@material-ui/core/Dialog';\nimport MuiTabs from '@material-ui/core/Tabs';\nimport MuiTab from '@material-ui/core/Tab';\nimport DialogTitle from '@material-ui/core/DialogTitle';\nimport DialogContent from '@material-ui/core/DialogContent';\nimport DialogContentText from '@material-ui/core/DialogContentText';\nimport DialogActions from '@material-ui/core/DialogActions';\nimport TextField from '@material-ui/core/TextField';\nimport Typography from '@material-ui/core/Typography';\nimport IconButton from '@material-ui/core/IconButton';\nimport ActionDelete from '@material-ui/icons/Delete';\n\nconst log = debug('@pie-lib:editable-html:plugins:media:dialog');\n\nconst matchYoutubeUrl = url => {\n  if (!url) {\n    return false;\n  }\n\n  const p = /^(?:https?:\\/\\/)?(?:m\\.|www\\.)?(?:youtu\\.be\\/|youtube\\.com\\/(?:embed\\/|v\\/|watch\\?v=|watch\\?.+&v=))((\\w|-){11})(?:\\S+)?$/;\n  if (url.match(p)) {\n    return url.match(p)[1];\n  }\n  return false;\n};\n\nconst matchVimeoUrl = url =>\n  url &&\n  /(http|https)?:\\/\\/(www\\.)?(player\\.)?vimeo.com\\/(?:channels\\/(?:\\w+\\/)?|groups\\/([^/]*)\\/videos\\/|)(video\\/)?(\\d+)(?:|\\/\\?)/.test(\n    url\n  );\n\nconst matchSoundCloudUrl = url => {\n  if (!url) {\n    return false;\n  }\n\n  const regexp = /^https?:\\/\\/(soundcloud\\.com|snd\\.sc)\\/(.*)$/;\n  return url.match(regexp) && url.match(regexp)[2];\n};\n\nconst makeApiRequest = url => {\n  return new Promise(resolve => {\n    try {\n      fetch(`https://soundcloud.com/oembed?format=json&url=${url}`)\n        .then(response => response.json())\n        .then(json => {\n          const d = document.createElement('div');\n\n          d.innerHTML = json.html;\n\n          const iframe = d.querySelector('iframe');\n\n          resolve(iframe.src);\n        })\n        .catch(err => {\n          resolve('');\n          log(err);\n        });\n    } catch (err) {\n      resolve('');\n    }\n  });\n};\n\nconst typeMap = {\n  video: 'Video',\n  audio: 'Audio'\n};\n\nexport class MediaDialog extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object.isRequired,\n    open: PropTypes.bool,\n    edit: PropTypes.bool,\n    disablePortal: PropTypes.bool,\n    handleClose: PropTypes.func,\n    uploadSoundSupport: PropTypes.shape({\n      add: PropTypes.func,\n      delete: PropTypes.func\n    }),\n    type: PropTypes.string,\n    src: PropTypes.string,\n    url: PropTypes.string,\n    urlToUse: PropTypes.string,\n    starts: PropTypes.number,\n    ends: PropTypes.number,\n    height: PropTypes.number,\n    width: PropTypes.number\n  };\n\n  constructor(props) {\n    super(props);\n\n    const { src, starts, ends, height, url, urlToUse, width } = props;\n\n    this.state = {\n      ends: ends || 0,\n      url: url || '',\n      urlToUse: urlToUse || '',\n      formattedUrl: src || '',\n      height: height || 315,\n      invalid: false,\n      starts: starts || 0,\n      width: width || 560,\n      tabValue: 0,\n      updating: false,\n      fileUpload: {\n        loading: false,\n        url: '',\n        error: null\n      }\n    };\n  }\n\n  componentDidMount() {\n    if (this.props.url) {\n      this.urlChange({\n        target: {\n          value: this.props.url\n        }\n      });\n    }\n  }\n\n  formatUrl = () => {\n    const { url, urlToUse, starts, ends } = this.state;\n    const isYoutube = matchYoutubeUrl(url);\n    const isVimeo = matchVimeoUrl(url);\n    let formattedUrl = urlToUse || '';\n\n    if ((isYoutube || isVimeo) && urlToUse) {\n      const params = [];\n\n      let paramName;\n      let paramStart;\n\n      switch (true) {\n        case isVimeo:\n          paramName = 't';\n          paramStart = '#';\n          break;\n        case isYoutube:\n          paramName = 'start';\n          paramStart = '?';\n          break;\n        default:\n          paramName = 'start';\n          paramStart = '?';\n      }\n\n      if (starts) {\n        params.push(`${paramName}=${starts}`);\n      }\n\n      if (ends) {\n        params.push(`end=${ends}`);\n      }\n\n      formattedUrl = `${urlToUse}${params.length ? paramStart : ''}${params.join('&')}`;\n    }\n\n    const callback = () => this.setState({ formattedUrl, updating: false });\n\n    this.setState({ formattedUrl: null, updating: true }, callback);\n  };\n\n  handleStateChange = newState => this.setState(newState, this.formatUrl);\n\n  urlChange = e => {\n    const { value } = e.target || {};\n    const { type } = this.props;\n\n    if (type && type === 'audio') {\n      if (matchSoundCloudUrl(value)) {\n        makeApiRequest(value)\n          .then(urlToUse => {\n            this.handleStateChange({\n              urlToUse,\n              invalid: !urlToUse,\n              url: value || ''\n            });\n          })\n          .catch(log);\n\n        return;\n      }\n    } else if (type && type === 'video') {\n      if (matchYoutubeUrl(value)) {\n        const regExp = /^.*(youtu\\.be\\/|v\\/|u\\/\\w\\/|embed\\/|watch\\?v=|&v=)([^#&?]*).*/;\n        const match = value.match(regExp);\n        const id = match[2];\n        const urlToUse = `https://youtube.com/embed/${id}`;\n\n        log('is youtube');\n\n        this.handleStateChange({\n          urlToUse,\n          url: value || '',\n          invalid: false\n        });\n\n        return;\n      }\n\n      if (matchVimeoUrl(value)) {\n        const id = value.replace(/.*vimeo.com\\/(.*)/g, '$1');\n        const urlToUse = `https://player.vimeo.com/video/${id}`;\n\n        log('is vimeo');\n\n        this.handleStateChange({\n          urlToUse,\n          url: value || '',\n          ends: null,\n          invalid: false\n        });\n\n        return;\n      }\n    }\n\n    this.handleStateChange({\n      urlToUse: '',\n      url: '',\n      invalid: true\n    });\n  };\n\n  changeHandler = type => e => this.handleStateChange({ [type]: e.target.value });\n\n  handleDone = val => {\n    const { handleClose } = this.props;\n    const { tabValue, fileUpload } = this.state;\n    const isInsertURL = tabValue === 0;\n\n    if (!val) {\n      if (fileUpload.url) {\n        this.handleRemoveFile();\n      }\n\n      handleClose(val);\n    } else if (isInsertURL) {\n      const { ends, height, url, urlToUse, formattedUrl, starts, width } = this.state;\n\n      handleClose(val, {\n        tag: 'iframe',\n        ends,\n        height,\n        starts,\n        width,\n        url,\n        urlToUse,\n        src: formattedUrl\n      });\n    } else {\n      handleClose(val, {\n        tag: 'audio',\n        src: fileUpload.url\n      });\n    }\n  };\n\n  handleUploadFile = async e => {\n    e.preventDefault();\n\n    this.setState({\n      fileUpload: {\n        ...this.state.fileUpload,\n        error: null,\n        loading: true\n      }\n    });\n\n    const fileChosen = e.target.files[0];\n\n    const reader = new FileReader();\n\n    reader.onload = () => {\n      const dataURL = reader.result;\n\n      this.setState({\n        fileUpload: {\n          ...this.state.fileUpload,\n          url: dataURL\n        }\n      });\n    };\n    reader.readAsDataURL(fileChosen);\n\n    this.props.uploadSoundSupport.add({\n      fileChosen,\n      done: (err, src) => {\n        log('done: err:', err);\n        if (err) {\n          //eslint-disable-next-line\n          console.log(err);\n          this.setState({\n            fileUpload: {\n              ...this.state.fileUpload,\n              loading: false,\n              error: err\n            }\n          });\n        } else {\n          this.setState({\n            fileUpload: {\n              ...this.state.fileUpload,\n              loading: false,\n              url: src\n            }\n          });\n        }\n      }\n    });\n  };\n\n  handleRemoveFile = async () => {\n    this.props.uploadSoundSupport.delete(this.state.fileUpload.url, err => {\n      if (err) {\n        //eslint-disable-next-line\n        console.log(err);\n        this.setState({\n          fileUpload: {\n            ...this.state.fileUpload,\n            error: err\n          }\n        });\n      }\n    });\n\n    // we should put it inside uploadSoundSupport.delete but we can leave it here for testing purposes\n    this.setState({\n      fileUpload: {\n        ...this.state.fileUpload,\n        loading: false,\n        url: ''\n      }\n    });\n  };\n\n  render() {\n    const { classes, open, disablePortal, type, edit, uploadSoundSupport } = this.props;\n    const {\n      ends,\n      height,\n      invalid,\n      starts,\n      width,\n      url,\n      formattedUrl,\n      updating,\n      tabValue,\n      fileUpload\n    } = this.state;\n    const isYoutube = matchYoutubeUrl(url);\n    const isInsertURL = tabValue === 0;\n    const isUploadMedia = tabValue === 1;\n    const submitIsDisabled = isInsertURL\n      ? invalid || url === null || url === undefined\n      : !fileUpload.url;\n\n    return (\n      <Dialog\n        classes={{\n          paper: classes.paper\n        }}\n        disablePortal={disablePortal}\n        open={open}\n        onClose={() => this.handleDone(false)}\n        aria-labelledby=\"form-dialog-title\"\n      >\n        <DialogTitle id=\"form-dialog-title\">Insert {typeMap[type]}</DialogTitle>\n        <DialogContent>\n          <div>\n            <div className={classes.row}>\n              <MuiTabs\n                indicatorColor=\"primary\"\n                value={tabValue}\n                onChange={(event, value) => {\n                  this.setState({ tabValue: value });\n                }}\n              >\n                <MuiTab\n                  label={type === 'video' ? 'Insert YouTube or Vimeo URL' : 'Insert SoundCloud URL'}\n                />\n                {uploadSoundSupport?.add && uploadSoundSupport?.delete && type !== 'video' ? (\n                  <MuiTab label=\"Upload file\" />\n                ) : null}\n              </MuiTabs>\n            </div>\n            {isInsertURL && (\n              <div>\n                <TextField\n                  autoFocus\n                  error={invalid}\n                  helperText={invalid ? 'Invalid URL' : ''}\n                  margin=\"dense\"\n                  id=\"name\"\n                  label=\"URL\"\n                  placeholder={`Paste URL of ${type}...`}\n                  type=\"text\"\n                  onChange={this.urlChange}\n                  value={url}\n                  fullWidth\n                />\n                {type === 'video' && (\n                  <DialogContent\n                    classes={{\n                      root: classes.properties\n                    }}\n                  >\n                    <DialogContentText>Video Properties</DialogContentText>\n                    <TextField\n                      autoFocus\n                      margin=\"dense\"\n                      id=\"width\"\n                      label=\"Width\"\n                      type=\"number\"\n                      placeholder=\"Width\"\n                      value={width}\n                      onChange={this.changeHandler('width')}\n                    />\n                    <TextField\n                      autoFocus\n                      margin=\"dense\"\n                      id=\"height\"\n                      label=\"Height\"\n                      type=\"number\"\n                      placeholder=\"Height\"\n                      value={height}\n                      onChange={this.changeHandler('height')}\n                    />\n                  </DialogContent>\n                )}\n                {formattedUrl && (\n                  <iframe\n                    width={width}\n                    height={height}\n                    src={formattedUrl}\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen\n                  />\n                )}\n                {type === 'video' && (formattedUrl || updating) && !invalid && (\n                  <React.Fragment>\n                    <DialogContent\n                      classes={{\n                        root: classes.properties\n                      }}\n                    >\n                      <TextField\n                        autoFocus\n                        margin=\"dense\"\n                        id=\"starts\"\n                        label=\"Starts\"\n                        type=\"number\"\n                        placeholder=\"Starts\"\n                        value={starts}\n                        onChange={this.changeHandler('starts')}\n                      />\n                      {isYoutube && (\n                        <TextField\n                          autoFocus\n                          margin=\"dense\"\n                          id=\"ends\"\n                          label=\"Ends\"\n                          type=\"number\"\n                          placeholder=\"Ends\"\n                          value={ends}\n                          onChange={this.changeHandler('ends')}\n                        />\n                      )}\n                    </DialogContent>\n                  </React.Fragment>\n                )}\n              </div>\n            )}\n            {isUploadMedia && (\n              <div className={classes.uploadInput}>\n                <div>\n                  {fileUpload.url ? (\n                    <>\n                      <div className={classes.row}>\n                        <audio controls=\"controls\">\n                          <source type=\"audio/mp3\" src={fileUpload.url} />\n                        </audio>\n                        <IconButton\n                          aria-label=\"delete\"\n                          className={classes.deleteIcon}\n                          onClick={this.handleRemoveFile}\n                        >\n                          <ActionDelete />\n                        </IconButton>\n                      </div>\n                      {fileUpload.loading ? (\n                        <Typography variant=\"subheading\">Loading...</Typography>\n                      ) : null}\n                    </>\n                  ) : !fileUpload.loading ? (\n                    <input\n                      accept=\"audio/*\"\n                      className={classes.input}\n                      onChange={this.handleUploadFile}\n                      type=\"file\"\n                    />\n                  ) : null}\n                  {!!fileUpload.error && (\n                    <Typography className={classes.error} variant=\"caption\">\n                      {fileUpload.error}\n                    </Typography>\n                  )}\n                </div>\n              </div>\n            )}\n          </div>\n        </DialogContent>\n        <DialogActions>\n          <Button onClick={() => this.handleDone(false)} color=\"primary\">\n            Cancel\n          </Button>\n          <Button disabled={submitIsDisabled} onClick={() => this.handleDone(true)} color=\"primary\">\n            {edit ? 'Update' : 'Insert'}\n          </Button>\n        </DialogActions>\n      </Dialog>\n    );\n  }\n}\n\nconst styles = () => ({\n  paper: {\n    minWidth: '500px'\n  },\n  properties: {\n    padding: 0\n  },\n  row: {\n    display: 'flex',\n    flexDirection: 'space-between'\n  },\n  rowItem: {\n    marginRight: '12px',\n    cursor: 'pointer'\n  },\n  active: {\n    color: color.primary(),\n    borderBottom: `2px solid ${color.primary()}`\n  },\n  uploadInput: {\n    marginTop: '12px'\n  },\n  error: {\n    marginTop: '12px',\n    color: 'red'\n  },\n  deleteIcon: {\n    marginLeft: '12px'\n  }\n});\n\nexport default withStyles(styles)(MediaDialog);\n"],"mappings":"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"}
|
|
558
|
+
//# sourceMappingURL=media-dialog.js.map
|