@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.
Files changed (143) hide show
  1. package/CHANGELOG.md +255 -152
  2. package/lib/components.js +15 -39
  3. package/lib/components.js.map +1 -1
  4. package/lib/editor.js +200 -356
  5. package/lib/editor.js.map +1 -1
  6. package/lib/index.js +25 -49
  7. package/lib/index.js.map +1 -1
  8. package/lib/new-serialization.js +31 -71
  9. package/lib/new-serialization.js.map +1 -1
  10. package/lib/parse-html.js +7 -6
  11. package/lib/parse-html.js.map +1 -1
  12. package/lib/plugins/characters/custom-popper.js +3 -13
  13. package/lib/plugins/characters/custom-popper.js.map +1 -1
  14. package/lib/plugins/characters/index.js +20 -59
  15. package/lib/plugins/characters/index.js.map +1 -1
  16. package/lib/plugins/characters/utils.js +1 -1
  17. package/lib/plugins/characters/utils.js.map +1 -1
  18. package/lib/plugins/hotKeys/index.js +9 -16
  19. package/lib/plugins/hotKeys/index.js.map +1 -1
  20. package/lib/plugins/image/alt-dialog.js +6 -27
  21. package/lib/plugins/image/alt-dialog.js.map +1 -1
  22. package/lib/plugins/image/component.js +42 -99
  23. package/lib/plugins/image/component.js.map +1 -1
  24. package/lib/plugins/image/image-toolbar.js +14 -50
  25. package/lib/plugins/image/image-toolbar.js.map +1 -1
  26. package/lib/plugins/image/index.js +16 -59
  27. package/lib/plugins/image/index.js.map +1 -1
  28. package/lib/plugins/image/insert-image-handler.js +13 -25
  29. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  30. package/lib/plugins/index.js +6 -36
  31. package/lib/plugins/index.js.map +1 -1
  32. package/lib/plugins/list/index.js +11 -46
  33. package/lib/plugins/list/index.js.map +1 -1
  34. package/lib/plugins/math/index.js +89 -93
  35. package/lib/plugins/math/index.js.map +1 -1
  36. package/lib/plugins/media/index.js +32 -109
  37. package/lib/plugins/media/index.js.map +1 -1
  38. package/lib/plugins/media/media-dialog.js +107 -195
  39. package/lib/plugins/media/media-dialog.js.map +1 -1
  40. package/lib/plugins/media/media-toolbar.js +7 -27
  41. package/lib/plugins/media/media-toolbar.js.map +1 -1
  42. package/lib/plugins/media/media-wrapper.js +9 -14
  43. package/lib/plugins/media/media-wrapper.js.map +1 -1
  44. package/lib/plugins/respArea/drag-in-the-blank/choice.js +13 -53
  45. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  46. package/lib/plugins/respArea/drag-in-the-blank/index.js +6 -20
  47. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  48. package/lib/plugins/respArea/explicit-constructed-response/index.js +5 -10
  49. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  50. package/lib/plugins/respArea/icons/index.js +16 -31
  51. package/lib/plugins/respArea/icons/index.js.map +1 -1
  52. package/lib/plugins/respArea/index.js +7 -54
  53. package/lib/plugins/respArea/index.js.map +1 -1
  54. package/lib/plugins/respArea/inline-dropdown/index.js +3 -10
  55. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  56. package/lib/plugins/respArea/utils.js +6 -21
  57. package/lib/plugins/respArea/utils.js.map +1 -1
  58. package/lib/plugins/table/icons/index.js +1 -8
  59. package/lib/plugins/table/icons/index.js.map +1 -1
  60. package/lib/plugins/table/index.js +54 -187
  61. package/lib/plugins/table/index.js.map +1 -1
  62. package/lib/plugins/table/table-toolbar.js +12 -44
  63. package/lib/plugins/table/table-toolbar.js.map +1 -1
  64. package/lib/plugins/toolbar/default-toolbar.js +17 -46
  65. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  66. package/lib/plugins/toolbar/done-button.js +2 -10
  67. package/lib/plugins/toolbar/done-button.js.map +1 -1
  68. package/lib/plugins/toolbar/editor-and-toolbar.js +134 -144
  69. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  70. package/lib/plugins/toolbar/index.js +2 -6
  71. package/lib/plugins/toolbar/index.js.map +1 -1
  72. package/lib/plugins/toolbar/toolbar-buttons.js +9 -40
  73. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  74. package/lib/plugins/toolbar/toolbar.js +29 -83
  75. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  76. package/lib/plugins/utils.js +8 -30
  77. package/lib/plugins/utils.js.map +1 -1
  78. package/lib/serialization.js +11 -69
  79. package/lib/serialization.js.map +1 -1
  80. package/lib/test-serializer.js +5 -56
  81. package/lib/test-serializer.js.map +1 -1
  82. package/lib/theme.js +1 -1
  83. package/lib/theme.js.map +1 -1
  84. package/package.json +7 -7
  85. package/playground/image/data.js +20 -20
  86. package/playground/image/index.html +20 -22
  87. package/playground/image/index.jsx +10 -12
  88. package/playground/index.html +23 -25
  89. package/playground/mathquill/index.html +20 -23
  90. package/playground/mathquill/index.jsx +22 -18
  91. package/playground/prod-test/index.html +20 -24
  92. package/playground/prod-test/index.jsx +3 -5
  93. package/playground/schema-override/data.js +10 -10
  94. package/playground/schema-override/image-plugin.jsx +4 -3
  95. package/playground/schema-override/index.html +19 -21
  96. package/playground/schema-override/index.jsx +14 -13
  97. package/playground/serialization/data.js +10 -10
  98. package/playground/serialization/image-plugin.jsx +4 -3
  99. package/playground/serialization/index.html +20 -22
  100. package/playground/table-examples.html +8 -5
  101. package/playground/webpack.config.js +10 -10
  102. package/src/editor.jsx +108 -104
  103. package/src/index.jsx +20 -13
  104. package/src/new-serialization.jsx +30 -11
  105. package/src/parse-html.js +1 -1
  106. package/src/plugins/characters/custom-popper.js +7 -7
  107. package/src/plugins/characters/index.jsx +34 -23
  108. package/src/plugins/characters/utils.js +81 -81
  109. package/src/plugins/image/alt-dialog.jsx +5 -4
  110. package/src/plugins/image/component.jsx +47 -44
  111. package/src/plugins/image/image-toolbar.jsx +19 -27
  112. package/src/plugins/image/index.jsx +24 -18
  113. package/src/plugins/image/insert-image-handler.js +9 -0
  114. package/src/plugins/index.jsx +7 -9
  115. package/src/plugins/list/index.jsx +7 -7
  116. package/src/plugins/math/index.jsx +71 -28
  117. package/src/plugins/media/index.jsx +7 -7
  118. package/src/plugins/media/media-dialog.js +63 -89
  119. package/src/plugins/media/media-toolbar.jsx +8 -8
  120. package/src/plugins/media/media-wrapper.jsx +8 -5
  121. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +19 -21
  122. package/src/plugins/respArea/drag-in-the-blank/index.jsx +4 -4
  123. package/src/plugins/respArea/explicit-constructed-response/index.jsx +5 -4
  124. package/src/plugins/respArea/icons/index.jsx +14 -11
  125. package/src/plugins/respArea/index.jsx +9 -15
  126. package/src/plugins/respArea/inline-dropdown/index.jsx +6 -6
  127. package/src/plugins/respArea/utils.jsx +7 -3
  128. package/src/plugins/table/icons/index.jsx +11 -17
  129. package/src/plugins/table/index.jsx +14 -10
  130. package/src/plugins/table/table-toolbar.jsx +6 -6
  131. package/src/plugins/toolbar/default-toolbar.jsx +9 -9
  132. package/src/plugins/toolbar/done-button.jsx +4 -4
  133. package/src/plugins/toolbar/editor-and-toolbar.jsx +36 -33
  134. package/src/plugins/toolbar/index.jsx +3 -2
  135. package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
  136. package/src/plugins/toolbar/toolbar.jsx +6 -1
  137. package/src/plugins/utils.js +2 -2
  138. package/src/serialization.jsx +34 -32
  139. package/src/test-serializer.js +2 -9
  140. package/lib/old-serialization.js +0 -330
  141. package/lib/slate-editor.js +0 -302
  142. package/src/test-serializer.js.rej +0 -20
  143. 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
- url = _this$state.url,
137
- urlToUse = _this$state.urlToUse,
138
- starts = _this$state.starts,
139
- ends = _this$state.ends;
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
- value = _ref.value;
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
- tabValue = _this$state2.tabValue,
258
- fileUpload = _this$state2.fileUpload;
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
- ends = _this$state3.ends,
270
- height = _this$state3.height,
271
- url = _this$state3.url,
272
- urlToUse = _this$state3.urlToUse,
273
- formattedUrl = _this$state3.formattedUrl,
274
- starts = _this$state3.starts,
275
- width = _this$state3.width;
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
- switch (_context.prev = _context.next) {
299
- case 0:
300
- e.preventDefault();
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
- error: null,
305
- loading: true
246
+ url: dataURL
306
247
  })
307
248
  });
308
-
309
- fileChosen = e.target.files[0];
310
- reader = new FileReader();
311
-
312
- reader.onload = function () {
313
- var dataURL = reader.result;
314
-
315
- _this.setState({
316
- fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
317
- url: dataURL
318
- })
319
- });
320
- };
321
-
322
- reader.readAsDataURL(fileChosen);
323
-
324
- _this.props.uploadSoundSupport.add({
325
- fileChosen: fileChosen,
326
- done: function done(err, src) {
327
- log('done: err:', err);
328
-
329
- if (err) {
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
- case 7:
351
- case "end":
352
- return _context.stop();
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
- switch (_context2.prev = _context2.next) {
366
- case 0:
367
- _this.props.uploadSoundSupport["delete"](_this.state.fileUpload.url, function (err) {
368
- if (err) {
369
- //eslint-disable-next-line
370
- console.log(err);
371
-
372
- _this.setState({
373
- fileUpload: _objectSpread(_objectSpread({}, _this.state.fileUpload), {}, {
374
- error: err
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
- case 2:
389
- case "end":
390
- return _context2.stop();
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
- _starts = props.starts,
397
- _ends = props.ends,
398
- _height = props.height,
399
- _url = props.url,
400
- _urlToUse = props.urlToUse,
401
- _width = props.width;
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
- classes = _this$props.classes,
440
- open = _this$props.open,
441
- disablePortal = _this$props.disablePortal,
442
- type = _this$props.type,
443
- edit = _this$props.edit,
444
- uploadSoundSupport = _this$props.uploadSoundSupport;
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
- ends = _this$state4.ends,
447
- height = _this$state4.height,
448
- invalid = _this$state4.invalid,
449
- starts = _this$state4.starts,
450
- width = _this$state4.width,
451
- url = _this$state4.url,
452
- formattedUrl = _this$state4.formattedUrl,
453
- updating = _this$state4.updating,
454
- tabValue = _this$state4.tabValue,
455
- fileUpload = _this$state4.fileUpload;
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: '12px',
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: '12px'
545
+ marginTop: theme.spacing.unit * 1.5
632
546
  },
633
547
  error: {
634
- marginTop: '12px',
635
- color: 'red'
548
+ marginTop: theme.spacing.unit * 1.5,
549
+ color: theme.palette.error.main
636
550
  },
637
551
  deleteIcon: {
638
- marginLeft: '12px'
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAEA,IAAMA,GAAG,GAAG,IAAAC,iBAAA,EAAM,6CAAN,CAAZ;;AAEA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAAAC,GAAG,EAAI;EAC7B,IAAI,CAACA,GAAL,EAAU;IACR,OAAO,KAAP;EACD;;EAED,IAAMC,CAAC,GAAG,0HAAV;;EACA,IAAID,GAAG,CAACE,KAAJ,CAAUD,CAAV,CAAJ,EAAkB;IAChB,OAAOD,GAAG,CAACE,KAAJ,CAAUD,CAAV,EAAa,CAAb,CAAP;EACD;;EACD,OAAO,KAAP;AACD,CAVD;;AAYA,IAAME,aAAa,GAAG,SAAhBA,aAAgB,CAAAH,GAAG;EAAA,OACvBA,GAAG,IACH,8HAA8HI,IAA9H,CACEJ,GADF,CAFuB;AAAA,CAAzB;;AAMA,IAAMK,kBAAkB,GAAG,SAArBA,kBAAqB,CAAAL,GAAG,EAAI;EAChC,IAAI,CAACA,GAAL,EAAU;IACR,OAAO,KAAP;EACD;;EAED,IAAMM,MAAM,GAAG,8CAAf;EACA,OAAON,GAAG,CAACE,KAAJ,CAAUI,MAAV,KAAqBN,GAAG,CAACE,KAAJ,CAAUI,MAAV,EAAkB,CAAlB,CAA5B;AACD,CAPD;;AASA,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAAAP,GAAG,EAAI;EAC5B,OAAO,IAAIQ,OAAJ,CAAY,UAAAC,OAAO,EAAI;IAC5B,IAAI;MACFC,KAAK,yDAAkDV,GAAlD,EAAL,CACGW,IADH,CACQ,UAAAC,QAAQ;QAAA,OAAIA,QAAQ,CAACC,IAAT,EAAJ;MAAA,CADhB,EAEGF,IAFH,CAEQ,UAAAE,IAAI,EAAI;QACZ,IAAMC,CAAC,GAAGC,QAAQ,CAACC,aAAT,CAAuB,KAAvB,CAAV;QAEAF,CAAC,CAACG,SAAF,GAAcJ,IAAI,CAACK,IAAnB;QAEA,IAAMC,MAAM,GAAGL,CAAC,CAACM,aAAF,CAAgB,QAAhB,CAAf;QAEAX,OAAO,CAACU,MAAM,CAACE,GAAR,CAAP;MACD,CAVH,WAWS,UAAAC,GAAG,EAAI;QACZb,OAAO,CAAC,EAAD,CAAP;QACAZ,GAAG,CAACyB,GAAD,CAAH;MACD,CAdH;IAeD,CAhBD,CAgBE,OAAOA,GAAP,EAAY;MACZb,OAAO,CAAC,EAAD,CAAP;IACD;EACF,CApBM,CAAP;AAqBD,CAtBD;;AAwBA,IAAMc,OAAO,GAAG;EACdC,KAAK,EAAE,OADO;EAEdC,KAAK,EAAE;AAFO,CAAhB;;IAKaC,W;;;;;EAqBX,qBAAYC,KAAZ,EAAmB;IAAA;;IAAA;IACjB,0BAAMA,KAAN;IADiB,8FAkCP,YAAM;MAChB,kBAAwC,MAAKC,KAA7C;MAAA,IAAQ5B,GAAR,eAAQA,GAAR;MAAA,IAAa6B,QAAb,eAAaA,QAAb;MAAA,IAAuBC,MAAvB,eAAuBA,MAAvB;MAAA,IAA+BC,IAA/B,eAA+BA,IAA/B;MACA,IAAMC,SAAS,GAAGjC,eAAe,CAACC,GAAD,CAAjC;MACA,IAAMiC,OAAO,GAAG9B,aAAa,CAACH,GAAD,CAA7B;MACA,IAAIkC,YAAY,GAAGL,QAAQ,IAAI,EAA/B;;MAEA,IAAI,CAACG,SAAS,IAAIC,OAAd,KAA0BJ,QAA9B,EAAwC;QACtC,IAAMM,MAAM,GAAG,EAAf;QAEA,IAAIC,SAAJ;QACA,IAAIC,UAAJ;;QAEA,QAAQ,IAAR;UACE,KAAKJ,OAAL;YACEG,SAAS,GAAG,GAAZ;YACAC,UAAU,GAAG,GAAb;YACA;;UACF,KAAKL,SAAL;YACEI,SAAS,GAAG,OAAZ;YACAC,UAAU,GAAG,GAAb;YACA;;UACF;YACED,SAAS,GAAG,OAAZ;YACAC,UAAU,GAAG,GAAb;QAXJ;;QAcA,IAAIP,MAAJ,EAAY;UACVK,MAAM,CAACG,IAAP,WAAeF,SAAf,cAA4BN,MAA5B;QACD;;QAED,IAAIC,IAAJ,EAAU;UACRI,MAAM,CAACG,IAAP,eAAmBP,IAAnB;QACD;;QAEDG,YAAY,aAAML,QAAN,SAAiBM,MAAM,CAACI,MAAP,GAAgBF,UAAhB,GAA6B,EAA9C,SAAmDF,MAAM,CAACK,IAAP,CAAY,GAAZ,CAAnD,CAAZ;MACD;;MAED,IAAMC,QAAQ,GAAG,SAAXA,QAAW;QAAA,OAAM,MAAKC,QAAL,CAAc;UAAER,YAAY,EAAZA,YAAF;UAAgBS,QAAQ,EAAE;QAA1B,CAAd,CAAN;MAAA,CAAjB;;MAEA,MAAKD,QAAL,CAAc;QAAER,YAAY,EAAE,IAAhB;QAAsBS,QAAQ,EAAE;MAAhC,CAAd,EAAsDF,QAAtD;IACD,CA1EkB;IAAA,sGA4EC,UAAAG,QAAQ;MAAA,OAAI,MAAKF,QAAL,CAAcE,QAAd,EAAwB,MAAKC,SAA7B,CAAJ;IAAA,CA5ET;IAAA,8FA8EP,UAAAC,CAAC,EAAI;MACf,WAAkBA,CAAC,CAACC,MAAF,IAAY,EAA9B;MAAA,IAAQC,KAAR,QAAQA,KAAR;;MACA,IAAQC,IAAR,GAAiB,MAAKtB,KAAtB,CAAQsB,IAAR;;MAEA,IAAIA,IAAI,IAAIA,IAAI,KAAK,OAArB,EAA8B;QAC5B,IAAI5C,kBAAkB,CAAC2C,KAAD,CAAtB,EAA+B;UAC7BzC,cAAc,CAACyC,KAAD,CAAd,CACGrC,IADH,CACQ,UAAAkB,QAAQ,EAAI;YAChB,MAAKqB,iBAAL,CAAuB;cACrBrB,QAAQ,EAARA,QADqB;cAErBsB,OAAO,EAAE,CAACtB,QAFW;cAGrB7B,GAAG,EAAEgD,KAAK,IAAI;YAHO,CAAvB;UAKD,CAPH,WAQSnD,GART;UAUA;QACD;MACF,CAdD,MAcO,IAAIoD,IAAI,IAAIA,IAAI,KAAK,OAArB,EAA8B;QACnC,IAAIlD,eAAe,CAACiD,KAAD,CAAnB,EAA4B;UAC1B,IAAMI,MAAM,GAAG,+DAAf;UACA,IAAMlD,KAAK,GAAG8C,KAAK,CAAC9C,KAAN,CAAYkD,MAAZ,CAAd;UACA,IAAMC,EAAE,GAAGnD,KAAK,CAAC,CAAD,CAAhB;UACA,IAAM2B,QAAQ,uCAAgCwB,EAAhC,CAAd;UAEAxD,GAAG,CAAC,YAAD,CAAH;;UAEA,MAAKqD,iBAAL,CAAuB;YACrBrB,QAAQ,EAARA,QADqB;YAErB7B,GAAG,EAAEgD,KAAK,IAAI,EAFO;YAGrBG,OAAO,EAAE;UAHY,CAAvB;;UAMA;QACD;;QAED,IAAIhD,aAAa,CAAC6C,KAAD,CAAjB,EAA0B;UACxB,IAAMK,GAAE,GAAGL,KAAK,CAACM,OAAN,CAAc,oBAAd,EAAoC,IAApC,CAAX;;UACA,IAAMzB,UAAQ,4CAAqCwB,GAArC,CAAd;;UAEAxD,GAAG,CAAC,UAAD,CAAH;;UAEA,MAAKqD,iBAAL,CAAuB;YACrBrB,QAAQ,EAARA,UADqB;YAErB7B,GAAG,EAAEgD,KAAK,IAAI,EAFO;YAGrBjB,IAAI,EAAE,IAHe;YAIrBoB,OAAO,EAAE;UAJY,CAAvB;;UAOA;QACD;MACF;;MAED,MAAKD,iBAAL,CAAuB;QACrBrB,QAAQ,EAAE,EADW;QAErB7B,GAAG,EAAE,EAFgB;QAGrBmD,OAAO,EAAE;MAHY,CAAvB;IAKD,CAxIkB;IAAA,kGA0IH,UAAAF,IAAI;MAAA,OAAI,UAAAH,CAAC;QAAA,OAAI,MAAKI,iBAAL,sCAA0BD,IAA1B,EAAiCH,CAAC,CAACC,MAAF,CAASC,KAA1C,EAAJ;MAAA,CAAL;IAAA,CA1ID;IAAA,+FA4IN,UAAAO,GAAG,EAAI;MAClB,IAAQC,WAAR,GAAwB,MAAK7B,KAA7B,CAAQ6B,WAAR;MACA,mBAAiC,MAAK5B,KAAtC;MAAA,IAAQ6B,QAAR,gBAAQA,QAAR;MAAA,IAAkBC,UAAlB,gBAAkBA,UAAlB;MACA,IAAMC,WAAW,GAAGF,QAAQ,KAAK,CAAjC;;MAEA,IAAI,CAACF,GAAL,EAAU;QACR,IAAIG,UAAU,CAAC1D,GAAf,EAAoB;UAClB,MAAK4D,gBAAL;QACD;;QAEDJ,WAAW,CAACD,GAAD,CAAX;MACD,CAND,MAMO,IAAII,WAAJ,EAAiB;QACtB,mBAAqE,MAAK/B,KAA1E;QAAA,IAAQG,IAAR,gBAAQA,IAAR;QAAA,IAAc8B,MAAd,gBAAcA,MAAd;QAAA,IAAsB7D,GAAtB,gBAAsBA,GAAtB;QAAA,IAA2B6B,QAA3B,gBAA2BA,QAA3B;QAAA,IAAqCK,YAArC,gBAAqCA,YAArC;QAAA,IAAmDJ,MAAnD,gBAAmDA,MAAnD;QAAA,IAA2DgC,KAA3D,gBAA2DA,KAA3D;QAEAN,WAAW,CAACD,GAAD,EAAM;UACfQ,GAAG,EAAE,QADU;UAEfhC,IAAI,EAAJA,IAFe;UAGf8B,MAAM,EAANA,MAHe;UAIf/B,MAAM,EAANA,MAJe;UAKfgC,KAAK,EAALA,KALe;UAMf9D,GAAG,EAAHA,GANe;UAOf6B,QAAQ,EAARA,QAPe;UAQfR,GAAG,EAAEa;QARU,CAAN,CAAX;MAUD,CAbM,MAaA;QACLsB,WAAW,CAACD,GAAD,EAAM;UACfQ,GAAG,EAAE,OADU;UAEf1C,GAAG,EAAEqC,UAAU,CAAC1D;QAFD,CAAN,CAAX;MAID;IACF,CA1KkB;IAAA;MAAA,0FA4KA,iBAAM8C,CAAN;QAAA;QAAA;UAAA;YAAA;cAAA;gBACjBA,CAAC,CAACkB,cAAF;;gBAEA,MAAKtB,QAAL,CAAc;kBACZgB,UAAU,kCACL,MAAK9B,KAAL,CAAW8B,UADN;oBAERO,KAAK,EAAE,IAFC;oBAGRC,OAAO,EAAE;kBAHD;gBADE,CAAd;;gBAQMC,UAXW,GAWErB,CAAC,CAACC,MAAF,CAASqB,KAAT,CAAe,CAAf,CAXF;gBAaXC,MAbW,GAaF,IAAIC,UAAJ,EAbE;;gBAejBD,MAAM,CAACE,MAAP,GAAgB,YAAM;kBACpB,IAAMC,OAAO,GAAGH,MAAM,CAACI,MAAvB;;kBAEA,MAAK/B,QAAL,CAAc;oBACZgB,UAAU,kCACL,MAAK9B,KAAL,CAAW8B,UADN;sBAER1D,GAAG,EAAEwE;oBAFG;kBADE,CAAd;gBAMD,CATD;;gBAUAH,MAAM,CAACK,aAAP,CAAqBP,UAArB;;gBAEA,MAAKxC,KAAL,CAAWgD,kBAAX,CAA8BC,GAA9B,CAAkC;kBAChCT,UAAU,EAAVA,UADgC;kBAEhCU,IAAI,EAAE,cAACvD,GAAD,EAAMD,GAAN,EAAc;oBAClBxB,GAAG,CAAC,YAAD,EAAeyB,GAAf,CAAH;;oBACA,IAAIA,GAAJ,EAAS;sBACP;sBACAwD,OAAO,CAACjF,GAAR,CAAYyB,GAAZ;;sBACA,MAAKoB,QAAL,CAAc;wBACZgB,UAAU,kCACL,MAAK9B,KAAL,CAAW8B,UADN;0BAERQ,OAAO,EAAE,KAFD;0BAGRD,KAAK,EAAE3C;wBAHC;sBADE,CAAd;oBAOD,CAVD,MAUO;sBACL,MAAKoB,QAAL,CAAc;wBACZgB,UAAU,kCACL,MAAK9B,KAAL,CAAW8B,UADN;0BAERQ,OAAO,EAAE,KAFD;0BAGRlE,GAAG,EAAEqB;wBAHG;sBADE,CAAd;oBAOD;kBACF;gBAvB+B,CAAlC;;cA3BiB;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CA5KA;;MAAA;QAAA;MAAA;IAAA;IAAA,gMAkOA;MAAA;QAAA;UAAA;YAAA;cACjB,MAAKM,KAAL,CAAWgD,kBAAX,WAAqC,MAAK/C,KAAL,CAAW8B,UAAX,CAAsB1D,GAA3D,EAAgE,UAAAsB,GAAG,EAAI;gBACrE,IAAIA,GAAJ,EAAS;kBACP;kBACAwD,OAAO,CAACjF,GAAR,CAAYyB,GAAZ;;kBACA,MAAKoB,QAAL,CAAc;oBACZgB,UAAU,kCACL,MAAK9B,KAAL,CAAW8B,UADN;sBAERO,KAAK,EAAE3C;oBAFC;kBADE,CAAd;gBAMD;cACF,CAXD,EADiB,CAcjB;;;cACA,MAAKoB,QAAL,CAAc;gBACZgB,UAAU,kCACL,MAAK9B,KAAL,CAAW8B,UADN;kBAERQ,OAAO,EAAE,KAFD;kBAGRlE,GAAG,EAAE;gBAHG;cADE,CAAd;;YAfiB;YAAA;cAAA;UAAA;QAAA;MAAA;IAAA,CAlOA;IAGjB,IAAQqB,IAAR,GAA4DM,KAA5D,CAAQN,GAAR;IAAA,IAAaS,OAAb,GAA4DH,KAA5D,CAAaG,MAAb;IAAA,IAAqBC,KAArB,GAA4DJ,KAA5D,CAAqBI,IAArB;IAAA,IAA2B8B,OAA3B,GAA4DlC,KAA5D,CAA2BkC,MAA3B;IAAA,IAAmC7D,IAAnC,GAA4D2B,KAA5D,CAAmC3B,GAAnC;IAAA,IAAwC6B,SAAxC,GAA4DF,KAA5D,CAAwCE,QAAxC;IAAA,IAAkDiC,MAAlD,GAA4DnC,KAA5D,CAAkDmC,KAAlD;IAEA,MAAKlC,KAAL,GAAa;MACXG,IAAI,EAAEA,KAAI,IAAI,CADH;MAEX/B,GAAG,EAAEA,IAAG,IAAI,EAFD;MAGX6B,QAAQ,EAAEA,SAAQ,IAAI,EAHX;MAIXK,YAAY,EAAEb,IAAG,IAAI,EAJV;MAKXwC,MAAM,EAAEA,OAAM,IAAI,GALP;MAMXV,OAAO,EAAE,KANE;MAOXrB,MAAM,EAAEA,OAAM,IAAI,CAPP;MAQXgC,KAAK,EAAEA,MAAK,IAAI,GARL;MASXL,QAAQ,EAAE,CATC;MAUXd,QAAQ,EAAE,KAVC;MAWXe,UAAU,EAAE;QACVQ,OAAO,EAAE,KADC;QAEVlE,GAAG,EAAE,EAFK;QAGViE,KAAK,EAAE;MAHG;IAXD,CAAb;IALiB;EAsBlB;;;;WAED,6BAAoB;MAClB,IAAI,KAAKtC,KAAL,CAAW3B,GAAf,EAAoB;QAClB,KAAK+E,SAAL,CAAe;UACbhC,MAAM,EAAE;YACNC,KAAK,EAAE,KAAKrB,KAAL,CAAW3B;UADZ;QADK,CAAf;MAKD;IACF;;;WA0ND,kBAAS;MAAA;;MACP,kBAAyE,KAAK2B,KAA9E;MAAA,IAAQqD,OAAR,eAAQA,OAAR;MAAA,IAAiBC,IAAjB,eAAiBA,IAAjB;MAAA,IAAuBC,aAAvB,eAAuBA,aAAvB;MAAA,IAAsCjC,IAAtC,eAAsCA,IAAtC;MAAA,IAA4CkC,IAA5C,eAA4CA,IAA5C;MAAA,IAAkDR,kBAAlD,eAAkDA,kBAAlD;MACA,mBAWI,KAAK/C,KAXT;MAAA,IACEG,IADF,gBACEA,IADF;MAAA,IAEE8B,MAFF,gBAEEA,MAFF;MAAA,IAGEV,OAHF,gBAGEA,OAHF;MAAA,IAIErB,MAJF,gBAIEA,MAJF;MAAA,IAKEgC,KALF,gBAKEA,KALF;MAAA,IAME9D,GANF,gBAMEA,GANF;MAAA,IAOEkC,YAPF,gBAOEA,YAPF;MAAA,IAQES,QARF,gBAQEA,QARF;MAAA,IASEc,QATF,gBASEA,QATF;MAAA,IAUEC,UAVF,gBAUEA,UAVF;MAYA,IAAM1B,SAAS,GAAGjC,eAAe,CAACC,GAAD,CAAjC;MACA,IAAM2D,WAAW,GAAGF,QAAQ,KAAK,CAAjC;MACA,IAAM2B,aAAa,GAAG3B,QAAQ,KAAK,CAAnC;MACA,IAAM4B,gBAAgB,GAAG1B,WAAW,GAChCR,OAAO,IAAInD,GAAG,KAAK,IAAnB,IAA2BA,GAAG,KAAKsF,SADH,GAEhC,CAAC5B,UAAU,CAAC1D,GAFhB;MAIA,oBACE,gCAAC,kBAAD;QACE,OAAO,EAAE;UACPuF,KAAK,EAAEP,OAAO,CAACO;QADR,CADX;QAIE,aAAa,EAAEL,aAJjB;QAKE,IAAI,EAAED,IALR;QAME,OAAO,EAAE;UAAA,OAAM,MAAI,CAACO,UAAL,CAAgB,KAAhB,CAAN;QAAA,CANX;QAOE,mBAAgB;MAPlB,gBASE,gCAAC,uBAAD;QAAa,EAAE,EAAC;MAAhB,cAA4CjE,OAAO,CAAC0B,IAAD,CAAnD,CATF,eAUE,gCAAC,yBAAD,qBACE,0DACE;QAAK,SAAS,EAAE+B,OAAO,CAACS;MAAxB,gBACE,gCAAC,gBAAD;QACE,cAAc,EAAC,SADjB;QAEE,KAAK,EAAEhC,QAFT;QAGE,QAAQ,EAAE,kBAACiC,KAAD,EAAQ1C,KAAR,EAAkB;UAC1B,MAAI,CAACN,QAAL,CAAc;YAAEe,QAAQ,EAAET;UAAZ,CAAd;QACD;MALH,gBAOE,gCAAC,eAAD;QACE,KAAK,EAAEC,IAAI,KAAK,OAAT,GAAmB,6BAAnB,GAAmD;MAD5D,EAPF,EAUG0B,kBAAkB,SAAlB,IAAAA,kBAAkB,WAAlB,IAAAA,kBAAkB,CAAEC,GAApB,IAA2BD,kBAA3B,aAA2BA,kBAA3B,eAA2BA,kBAAkB,UAA7C,IAAyD1B,IAAI,KAAK,OAAlE,gBACC,gCAAC,eAAD;QAAQ,KAAK,EAAC;MAAd,EADD,GAEG,IAZN,CADF,CADF,EAiBGU,WAAW,iBACV,0DACE,gCAAC,qBAAD;QACE,SAAS,MADX;QAEE,KAAK,EAAER,OAFT;QAGE,UAAU,EAAEA,OAAO,GAAG,aAAH,GAAmB,EAHxC;QAIE,MAAM,EAAC,OAJT;QAKE,EAAE,EAAC,MALL;QAME,KAAK,EAAC,KANR;QAOE,WAAW,yBAAkBF,IAAlB,QAPb;QAQE,IAAI,EAAC,MARP;QASE,QAAQ,EAAE,KAAK8B,SATjB;QAUE,KAAK,EAAE/E,GAVT;QAWE,SAAS;MAXX,EADF,EAcGiD,IAAI,KAAK,OAAT,iBACC,gCAAC,yBAAD;QACE,OAAO,EAAE;UACP0C,IAAI,EAAEX,OAAO,CAACY;QADP;MADX,gBAKE,gCAAC,6BAAD,2BALF,eAME,gCAAC,qBAAD;QACE,SAAS,MADX;QAEE,MAAM,EAAC,OAFT;QAGE,EAAE,EAAC,OAHL;QAIE,KAAK,EAAC,OAJR;QAKE,IAAI,EAAC,QALP;QAME,WAAW,EAAC,OANd;QAOE,KAAK,EAAE9B,KAPT;QAQE,QAAQ,EAAE,KAAK+B,aAAL,CAAmB,OAAnB;MARZ,EANF,eAgBE,gCAAC,qBAAD;QACE,SAAS,MADX;QAEE,MAAM,EAAC,OAFT;QAGE,EAAE,EAAC,QAHL;QAIE,KAAK,EAAC,QAJR;QAKE,IAAI,EAAC,QALP;QAME,WAAW,EAAC,QANd;QAOE,KAAK,EAAEhC,MAPT;QAQE,QAAQ,EAAE,KAAKgC,aAAL,CAAmB,QAAnB;MARZ,EAhBF,CAfJ,EA2CG3D,YAAY,iBACX;QACE,KAAK,EAAE4B,KADT;QAEE,MAAM,EAAED,MAFV;QAGE,GAAG,EAAE3B,YAHP;QAIE,WAAW,EAAC,GAJd;QAKE,KAAK,EAAC,0FALR;QAME,eAAe;MANjB,EA5CJ,EAqDGe,IAAI,KAAK,OAAT,KAAqBf,YAAY,IAAIS,QAArC,KAAkD,CAACQ,OAAnD,iBACC,gCAAC,iBAAD,CAAO,QAAP,qBACE,gCAAC,yBAAD;QACE,OAAO,EAAE;UACPwC,IAAI,EAAEX,OAAO,CAACY;QADP;MADX,gBAKE,gCAAC,qBAAD;QACE,SAAS,MADX;QAEE,MAAM,EAAC,OAFT;QAGE,EAAE,EAAC,QAHL;QAIE,KAAK,EAAC,QAJR;QAKE,IAAI,EAAC,QALP;QAME,WAAW,EAAC,QANd;QAOE,KAAK,EAAE9D,MAPT;QAQE,QAAQ,EAAE,KAAK+D,aAAL,CAAmB,QAAnB;MARZ,EALF,EAeG7D,SAAS,iBACR,gCAAC,qBAAD;QACE,SAAS,MADX;QAEE,MAAM,EAAC,OAFT;QAGE,EAAE,EAAC,MAHL;QAIE,KAAK,EAAC,MAJR;QAKE,IAAI,EAAC,QALP;QAME,WAAW,EAAC,MANd;QAOE,KAAK,EAAED,IAPT;QAQE,QAAQ,EAAE,KAAK8D,aAAL,CAAmB,MAAnB;MARZ,EAhBJ,CADF,CAtDJ,CAlBJ,EAyGGT,aAAa,iBACZ;QAAK,SAAS,EAAEJ,OAAO,CAACc;MAAxB,gBACE,6CACGpC,UAAU,CAAC1D,GAAX,gBACC,+EACE;QAAK,SAAS,EAAEgF,OAAO,CAACS;MAAxB,gBACE;QAAO,QAAQ,EAAC;MAAhB,gBACE;QAAQ,IAAI,EAAC,WAAb;QAAyB,GAAG,EAAE/B,UAAU,CAAC1D;MAAzC,EADF,CADF,eAIE,gCAAC,sBAAD;QACE,cAAW,QADb;QAEE,SAAS,EAAEgF,OAAO,CAACe,UAFrB;QAGE,OAAO,EAAE,KAAKnC;MAHhB,gBAKE,gCAAC,kBAAD,OALF,CAJF,CADF,EAaGF,UAAU,CAACQ,OAAX,gBACC,gCAAC,sBAAD;QAAY,OAAO,EAAC;MAApB,gBADD,GAEG,IAfN,CADD,GAkBG,CAACR,UAAU,CAACQ,OAAZ,gBACF;QACE,MAAM,EAAC,SADT;QAEE,SAAS,EAAEc,OAAO,CAACgB,KAFrB;QAGE,QAAQ,EAAE,KAAKC,gBAHjB;QAIE,IAAI,EAAC;MAJP,EADE,GAOA,IA1BN,EA2BG,CAAC,CAACvC,UAAU,CAACO,KAAb,iBACC,gCAAC,sBAAD;QAAY,SAAS,EAAEe,OAAO,CAACf,KAA/B;QAAsC,OAAO,EAAC;MAA9C,GACGP,UAAU,CAACO,KADd,CA5BJ,CADF,CA1GJ,CADF,CAVF,eA2JE,gCAAC,yBAAD,qBACE,gCAAC,kBAAD;QAAQ,OAAO,EAAE;UAAA,OAAM,MAAI,CAACuB,UAAL,CAAgB,KAAhB,CAAN;QAAA,CAAjB;QAA+C,KAAK,EAAC;MAArD,YADF,eAIE,gCAAC,kBAAD;QAAQ,QAAQ,EAAEH,gBAAlB;QAAoC,OAAO,EAAE;UAAA,OAAM,MAAI,CAACG,UAAL,CAAgB,IAAhB,CAAN;QAAA,CAA7C;QAA0E,KAAK,EAAC;MAAhF,GACGL,IAAI,GAAG,QAAH,GAAc,QADrB,CAJF,CA3JF,CADF;IAsKD;;;EA1c8Be,iBAAA,CAAMC,S;;;iCAA1BzE,W,eACQ;EACjBsD,OAAO,EAAEoB,qBAAA,CAAUC,MAAV,CAAiBC,UADT;EAEjBrB,IAAI,EAAEmB,qBAAA,CAAUG,IAFC;EAGjBpB,IAAI,EAAEiB,qBAAA,CAAUG,IAHC;EAIjBrB,aAAa,EAAEkB,qBAAA,CAAUG,IAJR;EAKjB/C,WAAW,EAAE4C,qBAAA,CAAUI,IALN;EAMjB7B,kBAAkB,EAAEyB,qBAAA,CAAUK,KAAV,CAAgB;IAClC7B,GAAG,EAAEwB,qBAAA,CAAUI,IADmB;IAElC,UAAQJ,qBAAA,CAAUI;EAFgB,CAAhB,CANH;EAUjBvD,IAAI,EAAEmD,qBAAA,CAAUM,MAVC;EAWjBrF,GAAG,EAAE+E,qBAAA,CAAUM,MAXE;EAYjB1G,GAAG,EAAEoG,qBAAA,CAAUM,MAZE;EAajB7E,QAAQ,EAAEuE,qBAAA,CAAUM,MAbH;EAcjB5E,MAAM,EAAEsE,qBAAA,CAAUO,MAdD;EAejB5E,IAAI,EAAEqE,qBAAA,CAAUO,MAfC;EAgBjB9C,MAAM,EAAEuC,qBAAA,CAAUO,MAhBD;EAiBjB7C,KAAK,EAAEsC,qBAAA,CAAUO;AAjBA,C;;AA4crB,IAAMC,MAAM,GAAG,SAATA,MAAS;EAAA,OAAO;IACpBrB,KAAK,EAAE;MACLsB,QAAQ,EAAE;IADL,CADa;IAIpBjB,UAAU,EAAE;MACVkB,OAAO,EAAE;IADC,CAJQ;IAOpBrB,GAAG,EAAE;MACHsB,OAAO,EAAE,MADN;MAEHC,aAAa,EAAE;IAFZ,CAPe;IAWpBC,OAAO,EAAE;MACPC,WAAW,EAAE,MADN;MAEPC,MAAM,EAAE;IAFD,CAXW;IAepBC,MAAM,EAAE;MACNC,KAAK,EAAEA,eAAA,CAAMC,OAAN,EADD;MAENC,YAAY,sBAAeF,eAAA,CAAMC,OAAN,EAAf;IAFN,CAfY;IAmBpBxB,WAAW,EAAE;MACX0B,SAAS,EAAE;IADA,CAnBO;IAsBpBvD,KAAK,EAAE;MACLuD,SAAS,EAAE,MADN;MAELH,KAAK,EAAE;IAFF,CAtBa;IA0BpBtB,UAAU,EAAE;MACV0B,UAAU,EAAE;IADF;EA1BQ,CAAP;AAAA,CAAf;;eA+Be,IAAAC,kBAAA,EAAWd,MAAX,EAAmBlF,WAAnB,C"}
558
+ //# sourceMappingURL=media-dialog.js.map