@mirrormedia/lilith-draft-editor 1.0.1 → 1.1.0-alpha.10

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.
@@ -9,6 +9,8 @@ var _react = _interopRequireDefault(require("react"));
9
9
 
10
10
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
11
11
 
12
+ var _theme = _interopRequireDefault(require("./theme"));
13
+
12
14
  var _draftJs = require("draft-js");
13
15
 
14
16
  var _blockRendererFn = require("./block-renderer-fn");
@@ -49,6 +51,10 @@ var _fontColor = require("../../draft-js/buttons/font-color");
49
51
 
50
52
  var _backgroundColor = require("../../draft-js/buttons/background-color");
51
53
 
54
+ var _video = require("../../draft-js/buttons/video");
55
+
56
+ var _audio = require("../../draft-js/buttons/audio");
57
+
52
58
  var _const = require("../../draft-js/const");
53
59
 
54
60
  var _imageSelector = require("./selector/image-selector");
@@ -57,6 +63,8 @@ var _videoSelector = require("./selector/video-selector");
57
63
 
58
64
  var _postSelector = require("./selector/post-selector");
59
65
 
66
+ var _audioSelector = require("./selector/audio-selector");
67
+
60
68
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
61
69
 
62
70
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -95,10 +103,12 @@ const buttonNames = {
95
103
  backgroundImage: 'background-image',
96
104
  backgroundVideo: 'background-video',
97
105
  relatedPost: 'related-post',
98
- sideIndex: 'side-index'
106
+ sideIndex: 'side-index',
107
+ video: 'video',
108
+ audio: 'audio'
99
109
  };
100
110
  exports.buttonNames = buttonNames;
101
- const disabledButtonsOnBasicEditor = [buttonNames.annotation, buttonNames.divider, buttonNames.embed, buttonNames.image, buttonNames.infoBox, buttonNames.slideshow, buttonNames.table, buttonNames.textAlign, buttonNames.colorBox, buttonNames.backgroundColor, buttonNames.backgroundImage, buttonNames.backgroundVideo, buttonNames.relatedPost, buttonNames.sideIndex];
111
+ const disabledButtonsOnBasicEditor = [buttonNames.annotation, buttonNames.divider, buttonNames.embed, buttonNames.image, buttonNames.infoBox, buttonNames.slideshow, buttonNames.table, buttonNames.textAlign, buttonNames.colorBox, buttonNames.backgroundColor, buttonNames.backgroundImage, buttonNames.backgroundVideo, buttonNames.relatedPost, buttonNames.sideIndex, buttonNames.video, buttonNames.audio];
102
112
  const buttonStyle = (0, _styledComponents.css)`
103
113
  border-radius: 6px;
104
114
  text-align: center;
@@ -238,6 +248,8 @@ const CustomRelatedPostButton = createButtonWithoutProps(_relatedPost.RelatedPos
238
248
  const CustomSideIndexButton = createButtonWithoutProps(_sideIndex.SideIndexButton, true);
239
249
  const CustomAlignCenterButton = createButtonWithoutProps(_textAlign.AlignCenterButton, true);
240
250
  const CustomAlignLeftButton = createButtonWithoutProps(_textAlign.AlignLeftButton, true);
251
+ const CustomVideoButton = createButtonWithoutProps(_video.VideoButton);
252
+ const CustomAudioButton = createButtonWithoutProps(_audio.AudioButton);
241
253
  const DraftEditorWrapper = _styledComponents.default.div`
242
254
  /* Rich-editor default setting (.RichEditor-root)*/
243
255
  background: #fff;
@@ -622,7 +634,9 @@ class RichTextEditor extends _react.default.Component {
622
634
  }));
623
635
  };
624
636
 
625
- return /*#__PURE__*/_react.default.createElement(DraftEditorContainer, {
637
+ return /*#__PURE__*/_react.default.createElement(_styledComponents.ThemeProvider, {
638
+ theme: _theme.default
639
+ }, /*#__PURE__*/_react.default.createElement(DraftEditorContainer, {
626
640
  isEnlarged: isEnlarged
627
641
  }, /*#__PURE__*/_react.default.createElement(DraftEditorWrapper, null, /*#__PURE__*/_react.default.createElement("link", {
628
642
  href: "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css",
@@ -683,6 +697,18 @@ class RichTextEditor extends _react.default.Component {
683
697
  onChange: this.onChange,
684
698
  readOnly: this.state.readOnly,
685
699
  ImageSelector: _imageSelector.ImageSelector
700
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomVideoButton, {
701
+ isDisabled: disabledButtons.includes(buttonNames.video),
702
+ editorState: editorState,
703
+ onChange: this.onChange,
704
+ readOnly: this.state.readOnly,
705
+ VideoSelector: _videoSelector.VideoSelector
706
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomAudioButton, {
707
+ isDisabled: disabledButtons.includes(buttonNames.audio),
708
+ editorState: editorState,
709
+ onChange: this.onChange,
710
+ readOnly: this.state.readOnly,
711
+ AudioSelector: _audioSelector.AudioSelector
686
712
  })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomSlideshowButton, {
687
713
  isDisabled: disabledButtons.includes(buttonNames.slideshow),
688
714
  editorState: editorState,
@@ -779,7 +805,7 @@ class RichTextEditor extends _react.default.Component {
779
805
  ref: "editor",
780
806
  spellCheck: true,
781
807
  readOnly: readOnly
782
- }))));
808
+ })))));
783
809
  }
784
810
 
785
811
  }
@@ -0,0 +1,280 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.AudioSelector = AudioSelector;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+
12
+ var _modals = require("@keystone-ui/modals");
13
+
14
+ var _apollo = require("@keystone-6/core/admin-ui/apollo");
15
+
16
+ var _searchBox = require("./search-box");
17
+
18
+ var _pagination = require("./pagination");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
22
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
23
+
24
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
+
26
+ const AudioSearchBox = (0, _styledComponents.default)(_searchBox.SearchBox)`
27
+ margin-top: 10px;
28
+ `;
29
+ const AudioSelectionWrapper = _styledComponents.default.div`
30
+ overflow: auto;
31
+ margin-top: 10px;
32
+ `;
33
+ const AudioGridsWrapper = _styledComponents.default.div`
34
+ display: flex;
35
+ flex-wrap: wrap;
36
+ overflow: auto;
37
+ `;
38
+ const AudioGridWrapper = _styledComponents.default.div`
39
+ flex: 0 0 50%;
40
+ cursor: pointer;
41
+ padding: 0 10px 10px;
42
+ `;
43
+ const AudioMetaGridsWrapper = _styledComponents.default.div`
44
+ display: flex;
45
+ flex-wrap: wrap;
46
+ overflow: auto;
47
+ `;
48
+ const AudioMetaGridWrapper = _styledComponents.default.div`
49
+ flex: 0 0 50%;
50
+ cursor: pointer;
51
+ padding: 0 10px 10px;
52
+ `;
53
+ const Audio = _styledComponents.default.audio`
54
+ width: 100%;
55
+ `;
56
+ const AudioName = _styledComponents.default.p`
57
+ text-align: center;
58
+ `;
59
+ const SeparationLine = _styledComponents.default.div`
60
+ border: #e1e5e9 1px solid;
61
+ margin-top: 10px;
62
+ margin-bottom: 10px;
63
+ `;
64
+ const AudioSelected = _styledComponents.default.div`
65
+ height: 1.4rem;
66
+ `;
67
+ const ErrorWrapper = _styledComponents.default.div`
68
+ & * {
69
+ margin: 0;
70
+ }
71
+ `;
72
+
73
+ function AudiosGrids(props) {
74
+ const {
75
+ audios,
76
+ selected,
77
+ onSelect
78
+ } = props;
79
+ return /*#__PURE__*/_react.default.createElement(AudioGridsWrapper, null, audios.map(audio => {
80
+ return /*#__PURE__*/_react.default.createElement(AudioGrid, {
81
+ key: audio.id,
82
+ isSelected: selected === null || selected === void 0 ? void 0 : selected.includes(audio),
83
+ onSelect: () => onSelect(audio),
84
+ audio: audio
85
+ });
86
+ }));
87
+ }
88
+
89
+ function AudioGrid(props) {
90
+ var _audio$file;
91
+
92
+ const {
93
+ audio,
94
+ onSelect,
95
+ isSelected
96
+ } = props;
97
+ return /*#__PURE__*/_react.default.createElement(AudioGridWrapper, {
98
+ key: audio === null || audio === void 0 ? void 0 : audio.id,
99
+ onClick: () => onSelect(audio)
100
+ }, /*#__PURE__*/_react.default.createElement(AudioSelected, null, isSelected ? /*#__PURE__*/_react.default.createElement("i", {
101
+ className: "fas fa-check-circle"
102
+ }) : null), /*#__PURE__*/_react.default.createElement(Audio, {
103
+ controls: true
104
+ }, /*#__PURE__*/_react.default.createElement("source", {
105
+ src: audio === null || audio === void 0 ? void 0 : audio.urlOriginal
106
+ }), /*#__PURE__*/_react.default.createElement("source", {
107
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file = audio.file) === null || _audio$file === void 0 ? void 0 : _audio$file.url
108
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
109
+ }
110
+
111
+ function AudioMetaGrids(props) {
112
+ const {
113
+ audioMetas
114
+ } = props;
115
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridsWrapper, null, audioMetas.map(audioMeta => {
116
+ var _audioMeta$audio;
117
+
118
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGrid, {
119
+ key: audioMeta === null || audioMeta === void 0 ? void 0 : (_audioMeta$audio = audioMeta.audio) === null || _audioMeta$audio === void 0 ? void 0 : _audioMeta$audio.id,
120
+ audioMeta: audioMeta
121
+ });
122
+ }));
123
+ }
124
+
125
+ function AudioMetaGrid(props) {
126
+ var _audio$file2;
127
+
128
+ const {
129
+ audioMeta
130
+ } = props;
131
+ const {
132
+ audio
133
+ } = audioMeta;
134
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridWrapper, null, /*#__PURE__*/_react.default.createElement(Audio, {
135
+ controls: true
136
+ }, /*#__PURE__*/_react.default.createElement("source", {
137
+ src: audio === null || audio === void 0 ? void 0 : audio.urlOriginal
138
+ }), /*#__PURE__*/_react.default.createElement("source", {
139
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file2 = audio.file) === null || _audio$file2 === void 0 ? void 0 : _audio$file2.url
140
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
141
+ }
142
+
143
+ const AudiosQuery = (0, _apollo.gql)`
144
+ query Audios($searchText: String!, $take: Int, $skip: Int) {
145
+ audioFilesCount(where: { name: { contains: $searchText } })
146
+ audioFiles(
147
+ where: { name: { contains: $searchText } }
148
+ take: $take
149
+ skip: $skip
150
+ ) {
151
+ id
152
+ name
153
+ urlOriginal
154
+ file {
155
+ url
156
+ }
157
+ heroImage {
158
+ imageFile {
159
+ url
160
+ }
161
+ resized {
162
+ w480
163
+ w800
164
+ w1200
165
+ w1600
166
+ w2400
167
+ }
168
+ }
169
+ }
170
+ }
171
+ `;
172
+
173
+ function AudioSelector(props) {
174
+ const [queryAudios, {
175
+ loading,
176
+ error,
177
+ data: {
178
+ audioFiles = [],
179
+ audioFilesCount = 0
180
+ } = {}
181
+ }] = (0, _apollo.useLazyQuery)(AudiosQuery, {
182
+ fetchPolicy: 'no-cache'
183
+ });
184
+ const [currentPage, setCurrentPage] = (0, _react.useState)(0); // page starts with 1, 0 is used to detect initialization
185
+
186
+ const [searchText, setSearchText] = (0, _react.useState)('');
187
+ const [selected, setSelected] = (0, _react.useState)([]);
188
+ const pageSize = 6;
189
+ const {
190
+ onChange
191
+ } = props;
192
+
193
+ const onSave = () => {
194
+ onChange(selected);
195
+ };
196
+
197
+ const onCancel = () => {
198
+ onChange([]);
199
+ };
200
+
201
+ const onSearchBoxChange = async searchInput => {
202
+ setSearchText(searchInput);
203
+ setCurrentPage(1);
204
+ };
205
+
206
+ const onAudiosGridSelect = audioEntity => {
207
+ setSelected(selected => {
208
+ const filterdSelected = selected.filter(ele => {
209
+ var _ele$audio;
210
+
211
+ return ((_ele$audio = ele.audio) === null || _ele$audio === void 0 ? void 0 : _ele$audio.id) !== audioEntity.id;
212
+ }); // deselect the audio
213
+
214
+ if (filterdSelected.length !== selected.length) {
215
+ return filterdSelected;
216
+ } // single select
217
+
218
+
219
+ return [{
220
+ audio: audioEntity
221
+ }];
222
+ });
223
+ };
224
+
225
+ const selectedAudios = selected.map(ele => {
226
+ return ele.audio;
227
+ });
228
+ (0, _react.useEffect)(() => {
229
+ if (currentPage !== 0) {
230
+ queryAudios({
231
+ variables: {
232
+ searchText: searchText,
233
+ skip: (currentPage - 1) * pageSize,
234
+ take: pageSize
235
+ }
236
+ });
237
+ }
238
+ }, [currentPage, searchText]);
239
+
240
+ let searchResult = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(AudiosGrids, {
241
+ audios: audioFiles,
242
+ selected: selectedAudios,
243
+ onSelect: onAudiosGridSelect
244
+ }), /*#__PURE__*/_react.default.createElement(_pagination.Pagination, {
245
+ currentPage: currentPage,
246
+ total: audioFilesCount,
247
+ pageSize: pageSize,
248
+ onChange: pageIndex => {
249
+ setCurrentPage(pageIndex);
250
+ }
251
+ }));
252
+
253
+ if (loading) {
254
+ searchResult = /*#__PURE__*/_react.default.createElement("p", null, "searching...");
255
+ }
256
+
257
+ if (error) {
258
+ searchResult = /*#__PURE__*/_react.default.createElement(ErrorWrapper, null, /*#__PURE__*/_react.default.createElement("h3", null, "Errors occurs in the `audios` query"), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("b", null, "Message:"), /*#__PURE__*/_react.default.createElement("div", null, error.message), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("b", null, "Stack:"), /*#__PURE__*/_react.default.createElement("div", null, error.stack), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("b", null, "Query:"), /*#__PURE__*/_react.default.createElement("pre", null, AudiosQuery.loc.source.body)));
259
+ }
260
+
261
+ return /*#__PURE__*/_react.default.createElement(_modals.DrawerController, {
262
+ isOpen: true
263
+ }, /*#__PURE__*/_react.default.createElement(_modals.Drawer, {
264
+ title: "Select audio",
265
+ actions: {
266
+ cancel: {
267
+ label: 'Cancel',
268
+ action: onCancel
269
+ },
270
+ confirm: {
271
+ label: 'Confirm',
272
+ action: onSave
273
+ }
274
+ }
275
+ }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(AudioSearchBox, {
276
+ onChange: onSearchBoxChange
277
+ }), /*#__PURE__*/_react.default.createElement(AudioSelectionWrapper, null, /*#__PURE__*/_react.default.createElement("div", null, searchResult), !!selected.length && /*#__PURE__*/_react.default.createElement(SeparationLine, null), /*#__PURE__*/_react.default.createElement(AudioMetaGrids, {
278
+ audioMetas: selected
279
+ })))));
280
+ }
@@ -109,6 +109,9 @@ const ErrorWrapper = _styledComponents.default.div`
109
109
  margin: 0;
110
110
  }
111
111
  `;
112
+ const ImageName = _styledComponents.default.p`
113
+ text-align: center;
114
+ `;
112
115
 
113
116
  function ImageGrids(props) {
114
117
  const {
@@ -190,7 +193,7 @@ function ImageMetaGrid(props) {
190
193
 
191
194
  return e.currentTarget.src = image === null || image === void 0 ? void 0 : (_image$imageFile2 = image.imageFile) === null || _image$imageFile2 === void 0 ? void 0 : _image$imageFile2.url;
192
195
  }
193
- }), enableCaption && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Label, {
196
+ }), /*#__PURE__*/_react.default.createElement(ImageName, null, image === null || image === void 0 ? void 0 : image.name), enableCaption && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Label, {
194
197
  htmlFor: "caption"
195
198
  }, "Image Caption:"), /*#__PURE__*/_react.default.createElement(_fields.TextInput, {
196
199
  id: "caption",
@@ -98,6 +98,9 @@ const ErrorWrapper = _styledComponents.default.div`
98
98
  margin: 0;
99
99
  }
100
100
  `;
101
+ const VideoName = _styledComponents.default.p`
102
+ text-align: center;
103
+ `;
101
104
 
102
105
  function VideosGrids(props) {
103
106
  const {
@@ -169,7 +172,7 @@ function VideoMetaGrid(props) {
169
172
  src: video === null || video === void 0 ? void 0 : video.urlOriginal
170
173
  }), /*#__PURE__*/_react.default.createElement("source", {
171
174
  src: video === null || video === void 0 ? void 0 : (_video$file2 = video.file) === null || _video$file2 === void 0 ? void 0 : _video$file2.url
172
- })));
175
+ })), /*#__PURE__*/_react.default.createElement(VideoName, null, video === null || video === void 0 ? void 0 : video.name));
173
176
  }
174
177
 
175
178
  function VideoSelector(props) {
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.theme = exports.mediaSize = exports.default = void 0;
7
+ const mediaSize = {
8
+ xs: 0,
9
+ sm: 576,
10
+ md: 768,
11
+ lg: 960,
12
+ xl: 1200,
13
+ xxl: 1400
14
+ };
15
+ exports.mediaSize = mediaSize;
16
+ const theme = {
17
+ breakpoint: {
18
+ xs: `@media (min-width: ${mediaSize.xs}px)`,
19
+ sm: `@media (min-width: ${mediaSize.sm}px)`,
20
+ md: `@media (min-width: ${mediaSize.md}px)`,
21
+ lg: `@media (min-width: ${mediaSize.lg}px)`,
22
+ xl: `@media (min-width: ${mediaSize.xl}px)`,
23
+ xxl: `@media (min-width: ${mediaSize.xxl}px)`
24
+ }
25
+ };
26
+ exports.theme = theme;
27
+ var _default = theme;
28
+ exports.default = _default;
@@ -28,7 +28,9 @@ const {
28
28
  SlideshowBlock,
29
29
  SlideshowBlockV2,
30
30
  DividerBlock,
31
- RelatedPostBlock
31
+ RelatedPostBlock,
32
+ VideoBlock,
33
+ AudioBlock
32
34
  } = _readr.default.blockRenderers;
33
35
 
34
36
  const AtomicBlock = props => {
@@ -102,6 +104,16 @@ const AtomicBlock = props => {
102
104
  {
103
105
  return (0, _sideIndexBlock.SideIndexEditorBlock)(props);
104
106
  }
107
+
108
+ case 'VIDEO':
109
+ {
110
+ return VideoBlock(entity);
111
+ }
112
+
113
+ case 'AUDIO':
114
+ {
115
+ return AudioBlock(entity);
116
+ }
105
117
  }
106
118
 
107
119
  return null;
@@ -9,6 +9,8 @@ var _react = _interopRequireDefault(require("react"));
9
9
 
10
10
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
11
11
 
12
+ var _theme = _interopRequireDefault(require("./theme"));
13
+
12
14
  var _draftJs = require("draft-js");
13
15
 
14
16
  var _blockRendererFn = require("./block-renderer-fn");
@@ -49,6 +51,10 @@ var _fontColor = require("../../draft-js/buttons/font-color");
49
51
 
50
52
  var _backgroundColor = require("../../draft-js/buttons/background-color");
51
53
 
54
+ var _video = require("../../draft-js/buttons/video");
55
+
56
+ var _audio = require("../../draft-js/buttons/audio");
57
+
52
58
  var _const = require("../../draft-js/const");
53
59
 
54
60
  var _imageSelector = require("./selector/image-selector");
@@ -57,6 +63,8 @@ var _videoSelector = require("./selector/video-selector");
57
63
 
58
64
  var _postSelector = require("./selector/post-selector");
59
65
 
66
+ var _audioSelector = require("./selector/audio-selector");
67
+
60
68
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
61
69
 
62
70
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -95,10 +103,12 @@ const buttonNames = {
95
103
  backgroundImage: 'background-image',
96
104
  backgroundVideo: 'background-video',
97
105
  relatedPost: 'related-post',
98
- sideIndex: 'side-index'
106
+ sideIndex: 'side-index',
107
+ video: 'video',
108
+ audio: 'audio'
99
109
  };
100
110
  exports.buttonNames = buttonNames;
101
- const disabledButtonsOnBasicEditor = [buttonNames.annotation, buttonNames.divider, buttonNames.embed, buttonNames.image, buttonNames.infoBox, buttonNames.slideshow, buttonNames.table, buttonNames.textAlign, buttonNames.colorBox, buttonNames.backgroundColor, buttonNames.backgroundImage, buttonNames.backgroundVideo, buttonNames.relatedPost, buttonNames.sideIndex];
111
+ const disabledButtonsOnBasicEditor = [buttonNames.annotation, buttonNames.divider, buttonNames.embed, buttonNames.image, buttonNames.infoBox, buttonNames.slideshow, buttonNames.table, buttonNames.textAlign, buttonNames.colorBox, buttonNames.backgroundColor, buttonNames.backgroundImage, buttonNames.backgroundVideo, buttonNames.relatedPost, buttonNames.sideIndex, buttonNames.video, buttonNames.audio];
102
112
  const buttonStyle = (0, _styledComponents.css)`
103
113
  border-radius: 6px;
104
114
  text-align: center;
@@ -238,6 +248,8 @@ const CustomRelatedPostButton = createButtonWithoutProps(_relatedPost.RelatedPos
238
248
  const CustomSideIndexButton = createButtonWithoutProps(_sideIndex.SideIndexButton, true);
239
249
  const CustomAlignCenterButton = createButtonWithoutProps(_textAlign.AlignCenterButton, true);
240
250
  const CustomAlignLeftButton = createButtonWithoutProps(_textAlign.AlignLeftButton, true);
251
+ const CustomVideoButton = createButtonWithoutProps(_video.VideoButton);
252
+ const CustomAudioButton = createButtonWithoutProps(_audio.AudioButton);
241
253
  const DraftEditorWrapper = _styledComponents.default.div`
242
254
  /* Rich-editor default setting (.RichEditor-root)*/
243
255
  background: #fff;
@@ -622,7 +634,9 @@ class RichTextEditor extends _react.default.Component {
622
634
  }));
623
635
  };
624
636
 
625
- return /*#__PURE__*/_react.default.createElement(DraftEditorContainer, {
637
+ return /*#__PURE__*/_react.default.createElement(_styledComponents.ThemeProvider, {
638
+ theme: _theme.default
639
+ }, /*#__PURE__*/_react.default.createElement(DraftEditorContainer, {
626
640
  isEnlarged: isEnlarged
627
641
  }, /*#__PURE__*/_react.default.createElement(DraftEditorWrapper, null, /*#__PURE__*/_react.default.createElement("link", {
628
642
  href: "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css",
@@ -683,6 +697,18 @@ class RichTextEditor extends _react.default.Component {
683
697
  onChange: this.onChange,
684
698
  readOnly: this.state.readOnly,
685
699
  ImageSelector: _imageSelector.ImageSelector
700
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomVideoButton, {
701
+ isDisabled: disabledButtons.includes(buttonNames.video),
702
+ editorState: editorState,
703
+ onChange: this.onChange,
704
+ readOnly: this.state.readOnly,
705
+ VideoSelector: _videoSelector.VideoSelector
706
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomAudioButton, {
707
+ isDisabled: disabledButtons.includes(buttonNames.audio),
708
+ editorState: editorState,
709
+ onChange: this.onChange,
710
+ readOnly: this.state.readOnly,
711
+ AudioSelector: _audioSelector.AudioSelector
686
712
  })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomSlideshowButton, {
687
713
  isDisabled: disabledButtons.includes(buttonNames.slideshow),
688
714
  editorState: editorState,
@@ -779,7 +805,7 @@ class RichTextEditor extends _react.default.Component {
779
805
  ref: "editor",
780
806
  spellCheck: true,
781
807
  readOnly: readOnly
782
- }))));
808
+ })))));
783
809
  }
784
810
 
785
811
  }