@mirrormedia/lilith-draft-editor 1.1.0-alpha.1 → 1.1.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.AudioButton = AudioButton;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _draftJs = require("draft-js");
11
+
12
+ var _audioSelector = require("./selector/audio-selector");
13
+
14
+ 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); }
15
+
16
+ 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; }
17
+
18
+ function AudioButton(props) {
19
+ const {
20
+ editorState,
21
+ onChange,
22
+ className,
23
+ AudioSelector = _audioSelector.AudioSelector
24
+ } = props;
25
+ const [toShowAudioSelector, setToShowAudioSelector] = (0, _react.useState)(false);
26
+
27
+ const promptForAudioSelector = () => {
28
+ setToShowAudioSelector(true);
29
+ };
30
+
31
+ const onAudioSelectorChange = selectedAudiosWithMeta => {
32
+ var _selectedAudiosWithMe;
33
+
34
+ const audio = selectedAudiosWithMeta === null || selectedAudiosWithMeta === void 0 ? void 0 : (_selectedAudiosWithMe = selectedAudiosWithMeta[0]) === null || _selectedAudiosWithMe === void 0 ? void 0 : _selectedAudiosWithMe.audio;
35
+
36
+ if (!audio) {
37
+ setToShowAudioSelector(false);
38
+ return;
39
+ }
40
+
41
+ const contentState = editorState.getCurrentContent();
42
+ const contentStateWithEntity = contentState.createEntity('AUDIO', 'IMMUTABLE', {
43
+ audio
44
+ });
45
+ const entityKey = contentStateWithEntity.getLastCreatedEntityKey();
46
+
47
+ const newEditorState = _draftJs.EditorState.set(editorState, {
48
+ currentContent: contentStateWithEntity
49
+ }); // The third parameter here is a space string, not an empty string
50
+ // If you set an empty string, you will get an error: Unknown DraftEntity key: null
51
+
52
+
53
+ onChange(_draftJs.AtomicBlockUtils.insertAtomicBlock(newEditorState, entityKey, ' '));
54
+ setToShowAudioSelector(false);
55
+ };
56
+
57
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, toShowAudioSelector && /*#__PURE__*/_react.default.createElement(AudioSelector, {
58
+ onChange: onAudioSelectorChange
59
+ }), /*#__PURE__*/_react.default.createElement("div", {
60
+ className: className,
61
+ onClick: promptForAudioSelector
62
+ }, /*#__PURE__*/_react.default.createElement("i", {
63
+ className: "fa fa-file-audio"
64
+ }), /*#__PURE__*/_react.default.createElement("span", null, " Audio")));
65
+ }
@@ -0,0 +1,281 @@
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
+ console.log('audio', audio);
98
+ return /*#__PURE__*/_react.default.createElement(AudioGridWrapper, {
99
+ key: audio === null || audio === void 0 ? void 0 : audio.id,
100
+ onClick: () => onSelect(audio)
101
+ }, /*#__PURE__*/_react.default.createElement(AudioSelected, null, isSelected ? /*#__PURE__*/_react.default.createElement("i", {
102
+ className: "fas fa-check-circle"
103
+ }) : null), /*#__PURE__*/_react.default.createElement(Audio, {
104
+ controls: true
105
+ }, /*#__PURE__*/_react.default.createElement("source", {
106
+ src: audio === null || audio === void 0 ? void 0 : audio.urlOriginal
107
+ }), /*#__PURE__*/_react.default.createElement("source", {
108
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file = audio.file) === null || _audio$file === void 0 ? void 0 : _audio$file.url
109
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
110
+ }
111
+
112
+ function AudioMetaGrids(props) {
113
+ const {
114
+ audioMetas
115
+ } = props;
116
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridsWrapper, null, audioMetas.map(audioMeta => {
117
+ var _audioMeta$audio;
118
+
119
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGrid, {
120
+ key: audioMeta === null || audioMeta === void 0 ? void 0 : (_audioMeta$audio = audioMeta.audio) === null || _audioMeta$audio === void 0 ? void 0 : _audioMeta$audio.id,
121
+ audioMeta: audioMeta
122
+ });
123
+ }));
124
+ }
125
+
126
+ function AudioMetaGrid(props) {
127
+ var _audio$file2;
128
+
129
+ const {
130
+ audioMeta
131
+ } = props;
132
+ const {
133
+ audio
134
+ } = audioMeta;
135
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridWrapper, null, /*#__PURE__*/_react.default.createElement(Audio, {
136
+ controls: true
137
+ }, /*#__PURE__*/_react.default.createElement("source", {
138
+ src: audio === null || audio === void 0 ? void 0 : audio.urlOriginal
139
+ }), /*#__PURE__*/_react.default.createElement("source", {
140
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file2 = audio.file) === null || _audio$file2 === void 0 ? void 0 : _audio$file2.url
141
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
142
+ }
143
+
144
+ const AudiosQuery = (0, _apollo.gql)`
145
+ query Audios($searchText: String!, $take: Int, $skip: Int) {
146
+ audioFilesCount(where: { name: { contains: $searchText } })
147
+ audioFiles(
148
+ where: { name: { contains: $searchText } }
149
+ take: $take
150
+ skip: $skip
151
+ ) {
152
+ id
153
+ name
154
+ urlOriginal
155
+ file {
156
+ url
157
+ }
158
+ heroImage {
159
+ imageFile {
160
+ url
161
+ }
162
+ resized {
163
+ w480
164
+ w800
165
+ w1200
166
+ w1600
167
+ w2400
168
+ }
169
+ }
170
+ }
171
+ }
172
+ `;
173
+
174
+ function AudioSelector(props) {
175
+ const [queryAudios, {
176
+ loading,
177
+ error,
178
+ data: {
179
+ audioFiles = [],
180
+ audioFilesCount = 0
181
+ } = {}
182
+ }] = (0, _apollo.useLazyQuery)(AudiosQuery, {
183
+ fetchPolicy: 'no-cache'
184
+ });
185
+ const [currentPage, setCurrentPage] = (0, _react.useState)(0); // page starts with 1, 0 is used to detect initialization
186
+
187
+ const [searchText, setSearchText] = (0, _react.useState)('');
188
+ const [selected, setSelected] = (0, _react.useState)([]);
189
+ const pageSize = 6;
190
+ const {
191
+ onChange
192
+ } = props;
193
+
194
+ const onSave = () => {
195
+ onChange(selected);
196
+ };
197
+
198
+ const onCancel = () => {
199
+ onChange([]);
200
+ };
201
+
202
+ const onSearchBoxChange = async searchInput => {
203
+ setSearchText(searchInput);
204
+ setCurrentPage(1);
205
+ };
206
+
207
+ const onAudiosGridSelect = audioEntity => {
208
+ setSelected(selected => {
209
+ const filterdSelected = selected.filter(ele => {
210
+ var _ele$audio;
211
+
212
+ return ((_ele$audio = ele.audio) === null || _ele$audio === void 0 ? void 0 : _ele$audio.id) !== audioEntity.id;
213
+ }); // deselect the audio
214
+
215
+ if (filterdSelected.length !== selected.length) {
216
+ return filterdSelected;
217
+ } // single select
218
+
219
+
220
+ return [{
221
+ audio: audioEntity
222
+ }];
223
+ });
224
+ };
225
+
226
+ const selectedAudios = selected.map(ele => {
227
+ return ele.audio;
228
+ });
229
+ (0, _react.useEffect)(() => {
230
+ if (currentPage !== 0) {
231
+ queryAudios({
232
+ variables: {
233
+ searchText: searchText,
234
+ skip: (currentPage - 1) * pageSize,
235
+ take: pageSize
236
+ }
237
+ });
238
+ }
239
+ }, [currentPage, searchText]);
240
+
241
+ let searchResult = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(AudiosGrids, {
242
+ audios: audioFiles,
243
+ selected: selectedAudios,
244
+ onSelect: onAudiosGridSelect
245
+ }), /*#__PURE__*/_react.default.createElement(_pagination.Pagination, {
246
+ currentPage: currentPage,
247
+ total: audioFilesCount,
248
+ pageSize: pageSize,
249
+ onChange: pageIndex => {
250
+ setCurrentPage(pageIndex);
251
+ }
252
+ }));
253
+
254
+ if (loading) {
255
+ searchResult = /*#__PURE__*/_react.default.createElement("p", null, "searching...");
256
+ }
257
+
258
+ if (error) {
259
+ 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)));
260
+ }
261
+
262
+ return /*#__PURE__*/_react.default.createElement(_modals.DrawerController, {
263
+ isOpen: true
264
+ }, /*#__PURE__*/_react.default.createElement(_modals.Drawer, {
265
+ title: "Select audio",
266
+ actions: {
267
+ cancel: {
268
+ label: 'Cancel',
269
+ action: onCancel
270
+ },
271
+ confirm: {
272
+ label: 'Confirm',
273
+ action: onSave
274
+ }
275
+ }
276
+ }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(AudioSearchBox, {
277
+ onChange: onSearchBoxChange
278
+ }), /*#__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, {
279
+ audioMetas: selected
280
+ })))));
281
+ }
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.VideoButton = VideoButton;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _draftJs = require("draft-js");
11
+
12
+ var _videoSelector = require("./selector/video-selector");
13
+
14
+ 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); }
15
+
16
+ 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; }
17
+
18
+ function VideoButton(props) {
19
+ const {
20
+ editorState,
21
+ onChange,
22
+ className,
23
+ VideoSelector = _videoSelector.VideoSelector
24
+ } = props;
25
+ const [toShowVideoSelector, setToShowVideoSelector] = (0, _react.useState)(false);
26
+
27
+ const promptForVideoSelector = () => {
28
+ setToShowVideoSelector(true);
29
+ };
30
+
31
+ const onVideoSelectorChange = selectedVideosWithMeta => {
32
+ var _selectedVideosWithMe;
33
+
34
+ const video = selectedVideosWithMeta === null || selectedVideosWithMeta === void 0 ? void 0 : (_selectedVideosWithMe = selectedVideosWithMeta[0]) === null || _selectedVideosWithMe === void 0 ? void 0 : _selectedVideosWithMe.video;
35
+
36
+ if (!video) {
37
+ setToShowVideoSelector(false);
38
+ return;
39
+ }
40
+
41
+ const contentState = editorState.getCurrentContent();
42
+ const contentStateWithEntity = contentState.createEntity('VIDEO', 'IMMUTABLE', {
43
+ video
44
+ });
45
+ const entityKey = contentStateWithEntity.getLastCreatedEntityKey();
46
+
47
+ const newEditorState = _draftJs.EditorState.set(editorState, {
48
+ currentContent: contentStateWithEntity
49
+ }); // The third parameter here is a space string, not an empty string
50
+ // If you set an empty string, you will get an error: Unknown DraftEntity key: null
51
+
52
+
53
+ onChange(_draftJs.AtomicBlockUtils.insertAtomicBlock(newEditorState, entityKey, ' '));
54
+ setToShowVideoSelector(false);
55
+ };
56
+
57
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, toShowVideoSelector && /*#__PURE__*/_react.default.createElement(VideoSelector, {
58
+ onChange: onVideoSelectorChange
59
+ }), /*#__PURE__*/_react.default.createElement("div", {
60
+ className: className,
61
+ onClick: promptForVideoSelector
62
+ }, /*#__PURE__*/_react.default.createElement("i", {
63
+ className: "fa fa-video-camera"
64
+ }), /*#__PURE__*/_react.default.createElement("span", null, " Video")));
65
+ }
@@ -29,7 +29,9 @@ const {
29
29
  MediaBlock,
30
30
  ImageBlock,
31
31
  DividerBlock,
32
- RelatedPostBlock
32
+ RelatedPostBlock,
33
+ VideoBlock,
34
+ AudioBlock
33
35
  } = _mirrormedia.default.blockRenderers;
34
36
 
35
37
  const AtomicBlock = props => {
@@ -103,6 +105,16 @@ const AtomicBlock = props => {
103
105
  {
104
106
  return (0, _sideIndexBlock.SideIndexEditorBlock)(props);
105
107
  }
108
+
109
+ case 'VIDEO':
110
+ {
111
+ return VideoBlock(entity);
112
+ }
113
+
114
+ case 'AUDIO':
115
+ {
116
+ return AudioBlock(entity);
117
+ }
106
118
  }
107
119
 
108
120
  return null;
@@ -49,6 +49,10 @@ var _fontColor = require("../../draft-js/buttons/font-color");
49
49
 
50
50
  var _backgroundColor = require("../../draft-js/buttons/background-color");
51
51
 
52
+ var _video = require("../../draft-js/buttons/video");
53
+
54
+ var _audio = require("../../draft-js/buttons/audio");
55
+
52
56
  var _const = require("../../draft-js/const");
53
57
 
54
58
  var _imageSelector = require("./selector/image-selector");
@@ -57,6 +61,8 @@ var _videoSelector = require("./selector/video-selector");
57
61
 
58
62
  var _postSelector = require("./selector/post-selector");
59
63
 
64
+ var _audioSelector = require("./selector/audio-selector");
65
+
60
66
  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
67
 
62
68
  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 +101,12 @@ const buttonNames = {
95
101
  backgroundImage: 'background-image',
96
102
  backgroundVideo: 'background-video',
97
103
  relatedPost: 'related-post',
98
- sideIndex: 'side-index'
104
+ sideIndex: 'side-index',
105
+ video: 'video',
106
+ audio: 'audio'
99
107
  };
100
108
  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];
109
+ 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
110
  const buttonStyle = (0, _styledComponents.css)`
103
111
  border-radius: 6px;
104
112
  text-align: center;
@@ -238,6 +246,8 @@ const CustomRelatedPostButton = createButtonWithoutProps(_relatedPost.RelatedPos
238
246
  const CustomSideIndexButton = createButtonWithoutProps(_sideIndex.SideIndexButton, true);
239
247
  const CustomAlignCenterButton = createButtonWithoutProps(_textAlign.AlignCenterButton, true);
240
248
  const CustomAlignLeftButton = createButtonWithoutProps(_textAlign.AlignLeftButton, true);
249
+ const CustomVideoButton = createButtonWithoutProps(_video.VideoButton);
250
+ const CustomAudioButton = createButtonWithoutProps(_audio.AudioButton);
241
251
  const DraftEditorWrapper = _styledComponents.default.div`
242
252
  /* Rich-editor default setting (.RichEditor-root)*/
243
253
  background: #fff;
@@ -683,6 +693,18 @@ class RichTextEditor extends _react.default.Component {
683
693
  onChange: this.onChange,
684
694
  readOnly: this.state.readOnly,
685
695
  ImageSelector: _imageSelector.ImageSelector
696
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomVideoButton, {
697
+ isDisabled: disabledButtons.includes(buttonNames.video),
698
+ editorState: editorState,
699
+ onChange: this.onChange,
700
+ readOnly: this.state.readOnly,
701
+ VideoSelector: _videoSelector.VideoSelector
702
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomAudioButton, {
703
+ isDisabled: disabledButtons.includes(buttonNames.audio),
704
+ editorState: editorState,
705
+ onChange: this.onChange,
706
+ readOnly: this.state.readOnly,
707
+ AudioSelector: _audioSelector.AudioSelector
686
708
  })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomSlideshowButton, {
687
709
  isDisabled: disabledButtons.includes(buttonNames.slideshow),
688
710
  editorState: editorState,
@@ -0,0 +1,281 @@
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
+ console.log('audio', audio);
98
+ return /*#__PURE__*/_react.default.createElement(AudioGridWrapper, {
99
+ key: audio === null || audio === void 0 ? void 0 : audio.id,
100
+ onClick: () => onSelect(audio)
101
+ }, /*#__PURE__*/_react.default.createElement(AudioSelected, null, isSelected ? /*#__PURE__*/_react.default.createElement("i", {
102
+ className: "fas fa-check-circle"
103
+ }) : null), /*#__PURE__*/_react.default.createElement(Audio, {
104
+ controls: true
105
+ }, /*#__PURE__*/_react.default.createElement("source", {
106
+ src: audio === null || audio === void 0 ? void 0 : audio.urlOriginal
107
+ }), /*#__PURE__*/_react.default.createElement("source", {
108
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file = audio.file) === null || _audio$file === void 0 ? void 0 : _audio$file.url
109
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
110
+ }
111
+
112
+ function AudioMetaGrids(props) {
113
+ const {
114
+ audioMetas
115
+ } = props;
116
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridsWrapper, null, audioMetas.map(audioMeta => {
117
+ var _audioMeta$audio;
118
+
119
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGrid, {
120
+ key: audioMeta === null || audioMeta === void 0 ? void 0 : (_audioMeta$audio = audioMeta.audio) === null || _audioMeta$audio === void 0 ? void 0 : _audioMeta$audio.id,
121
+ audioMeta: audioMeta
122
+ });
123
+ }));
124
+ }
125
+
126
+ function AudioMetaGrid(props) {
127
+ var _audio$file2;
128
+
129
+ const {
130
+ audioMeta
131
+ } = props;
132
+ const {
133
+ audio
134
+ } = audioMeta;
135
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridWrapper, null, /*#__PURE__*/_react.default.createElement(Audio, {
136
+ controls: true
137
+ }, /*#__PURE__*/_react.default.createElement("source", {
138
+ src: audio === null || audio === void 0 ? void 0 : audio.urlOriginal
139
+ }), /*#__PURE__*/_react.default.createElement("source", {
140
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file2 = audio.file) === null || _audio$file2 === void 0 ? void 0 : _audio$file2.url
141
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
142
+ }
143
+
144
+ const AudiosQuery = (0, _apollo.gql)`
145
+ query Audios($searchText: String!, $take: Int, $skip: Int) {
146
+ audioFilesCount(where: { name: { contains: $searchText } })
147
+ audioFiles(
148
+ where: { name: { contains: $searchText } }
149
+ take: $take
150
+ skip: $skip
151
+ ) {
152
+ id
153
+ name
154
+ urlOriginal
155
+ file {
156
+ url
157
+ }
158
+ heroImage {
159
+ imageFile {
160
+ url
161
+ }
162
+ resized {
163
+ w480
164
+ w800
165
+ w1200
166
+ w1600
167
+ w2400
168
+ }
169
+ }
170
+ }
171
+ }
172
+ `;
173
+
174
+ function AudioSelector(props) {
175
+ const [queryAudios, {
176
+ loading,
177
+ error,
178
+ data: {
179
+ audioFiles = [],
180
+ audioFilesCount = 0
181
+ } = {}
182
+ }] = (0, _apollo.useLazyQuery)(AudiosQuery, {
183
+ fetchPolicy: 'no-cache'
184
+ });
185
+ const [currentPage, setCurrentPage] = (0, _react.useState)(0); // page starts with 1, 0 is used to detect initialization
186
+
187
+ const [searchText, setSearchText] = (0, _react.useState)('');
188
+ const [selected, setSelected] = (0, _react.useState)([]);
189
+ const pageSize = 6;
190
+ const {
191
+ onChange
192
+ } = props;
193
+
194
+ const onSave = () => {
195
+ onChange(selected);
196
+ };
197
+
198
+ const onCancel = () => {
199
+ onChange([]);
200
+ };
201
+
202
+ const onSearchBoxChange = async searchInput => {
203
+ setSearchText(searchInput);
204
+ setCurrentPage(1);
205
+ };
206
+
207
+ const onAudiosGridSelect = audioEntity => {
208
+ setSelected(selected => {
209
+ const filterdSelected = selected.filter(ele => {
210
+ var _ele$audio;
211
+
212
+ return ((_ele$audio = ele.audio) === null || _ele$audio === void 0 ? void 0 : _ele$audio.id) !== audioEntity.id;
213
+ }); // deselect the audio
214
+
215
+ if (filterdSelected.length !== selected.length) {
216
+ return filterdSelected;
217
+ } // single select
218
+
219
+
220
+ return [{
221
+ audio: audioEntity
222
+ }];
223
+ });
224
+ };
225
+
226
+ const selectedAudios = selected.map(ele => {
227
+ return ele.audio;
228
+ });
229
+ (0, _react.useEffect)(() => {
230
+ if (currentPage !== 0) {
231
+ queryAudios({
232
+ variables: {
233
+ searchText: searchText,
234
+ skip: (currentPage - 1) * pageSize,
235
+ take: pageSize
236
+ }
237
+ });
238
+ }
239
+ }, [currentPage, searchText]);
240
+
241
+ let searchResult = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(AudiosGrids, {
242
+ audios: audioFiles,
243
+ selected: selectedAudios,
244
+ onSelect: onAudiosGridSelect
245
+ }), /*#__PURE__*/_react.default.createElement(_pagination.Pagination, {
246
+ currentPage: currentPage,
247
+ total: audioFilesCount,
248
+ pageSize: pageSize,
249
+ onChange: pageIndex => {
250
+ setCurrentPage(pageIndex);
251
+ }
252
+ }));
253
+
254
+ if (loading) {
255
+ searchResult = /*#__PURE__*/_react.default.createElement("p", null, "searching...");
256
+ }
257
+
258
+ if (error) {
259
+ 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)));
260
+ }
261
+
262
+ return /*#__PURE__*/_react.default.createElement(_modals.DrawerController, {
263
+ isOpen: true
264
+ }, /*#__PURE__*/_react.default.createElement(_modals.Drawer, {
265
+ title: "Select audio",
266
+ actions: {
267
+ cancel: {
268
+ label: 'Cancel',
269
+ action: onCancel
270
+ },
271
+ confirm: {
272
+ label: 'Confirm',
273
+ action: onSave
274
+ }
275
+ }
276
+ }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(AudioSearchBox, {
277
+ onChange: onSearchBoxChange
278
+ }), /*#__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, {
279
+ audioMetas: selected
280
+ })))));
281
+ }
@@ -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) {
@@ -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,11 @@ const AtomicBlock = props => {
102
104
  {
103
105
  return (0, _sideIndexBlock.SideIndexEditorBlock)(props);
104
106
  }
107
+
108
+ case 'VIDEO':
109
+ {
110
+ return VideoBlock(entity);
111
+ }
105
112
  }
106
113
 
107
114
  return null;
@@ -49,6 +49,10 @@ var _fontColor = require("../../draft-js/buttons/font-color");
49
49
 
50
50
  var _backgroundColor = require("../../draft-js/buttons/background-color");
51
51
 
52
+ var _video = require("../../draft-js/buttons/video");
53
+
54
+ var _audio = require("../../draft-js/buttons/audio");
55
+
52
56
  var _const = require("../../draft-js/const");
53
57
 
54
58
  var _imageSelector = require("./selector/image-selector");
@@ -57,6 +61,8 @@ var _videoSelector = require("./selector/video-selector");
57
61
 
58
62
  var _postSelector = require("./selector/post-selector");
59
63
 
64
+ var _audioSelector = require("./selector/audio-selector");
65
+
60
66
  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
67
 
62
68
  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 +101,12 @@ const buttonNames = {
95
101
  backgroundImage: 'background-image',
96
102
  backgroundVideo: 'background-video',
97
103
  relatedPost: 'related-post',
98
- sideIndex: 'side-index'
104
+ sideIndex: 'side-index',
105
+ video: 'video',
106
+ audio: 'audio'
99
107
  };
100
108
  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];
109
+ 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
110
  const buttonStyle = (0, _styledComponents.css)`
103
111
  border-radius: 6px;
104
112
  text-align: center;
@@ -238,6 +246,8 @@ const CustomRelatedPostButton = createButtonWithoutProps(_relatedPost.RelatedPos
238
246
  const CustomSideIndexButton = createButtonWithoutProps(_sideIndex.SideIndexButton, true);
239
247
  const CustomAlignCenterButton = createButtonWithoutProps(_textAlign.AlignCenterButton, true);
240
248
  const CustomAlignLeftButton = createButtonWithoutProps(_textAlign.AlignLeftButton, true);
249
+ const CustomVideoButton = createButtonWithoutProps(_video.VideoButton);
250
+ const CustomAudioButton = createButtonWithoutProps(_audio.AudioButton);
241
251
  const DraftEditorWrapper = _styledComponents.default.div`
242
252
  /* Rich-editor default setting (.RichEditor-root)*/
243
253
  background: #fff;
@@ -683,6 +693,18 @@ class RichTextEditor extends _react.default.Component {
683
693
  onChange: this.onChange,
684
694
  readOnly: this.state.readOnly,
685
695
  ImageSelector: _imageSelector.ImageSelector
696
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomVideoButton, {
697
+ isDisabled: disabledButtons.includes(buttonNames.video),
698
+ editorState: editorState,
699
+ onChange: this.onChange,
700
+ readOnly: this.state.readOnly,
701
+ VideoSelector: _videoSelector.VideoSelector
702
+ })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomAudioButton, {
703
+ isDisabled: disabledButtons.includes(buttonNames.audio),
704
+ editorState: editorState,
705
+ onChange: this.onChange,
706
+ readOnly: this.state.readOnly,
707
+ AudioSelector: _audioSelector.AudioSelector
686
708
  })), /*#__PURE__*/_react.default.createElement(ButtonGroup, null, /*#__PURE__*/_react.default.createElement(CustomSlideshowButton, {
687
709
  isDisabled: disabledButtons.includes(buttonNames.slideshow),
688
710
  editorState: editorState,
@@ -0,0 +1,281 @@
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
+ console.log('audio', audio);
98
+ return /*#__PURE__*/_react.default.createElement(AudioGridWrapper, {
99
+ key: audio === null || audio === void 0 ? void 0 : audio.id,
100
+ onClick: () => onSelect(audio)
101
+ }, /*#__PURE__*/_react.default.createElement(AudioSelected, null, isSelected ? /*#__PURE__*/_react.default.createElement("i", {
102
+ className: "fas fa-check-circle"
103
+ }) : null), /*#__PURE__*/_react.default.createElement(Audio, {
104
+ controls: true
105
+ }, /*#__PURE__*/_react.default.createElement("source", {
106
+ src: audio === null || audio === void 0 ? void 0 : audio.url
107
+ }), /*#__PURE__*/_react.default.createElement("source", {
108
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file = audio.file) === null || _audio$file === void 0 ? void 0 : _audio$file.url
109
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
110
+ }
111
+
112
+ function AudioMetaGrids(props) {
113
+ const {
114
+ audioMetas
115
+ } = props;
116
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridsWrapper, null, audioMetas.map(audioMeta => {
117
+ var _audioMeta$audio;
118
+
119
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGrid, {
120
+ key: audioMeta === null || audioMeta === void 0 ? void 0 : (_audioMeta$audio = audioMeta.audio) === null || _audioMeta$audio === void 0 ? void 0 : _audioMeta$audio.id,
121
+ audioMeta: audioMeta
122
+ });
123
+ }));
124
+ }
125
+
126
+ function AudioMetaGrid(props) {
127
+ var _audio$file2;
128
+
129
+ const {
130
+ audioMeta
131
+ } = props;
132
+ const {
133
+ audio
134
+ } = audioMeta;
135
+ return /*#__PURE__*/_react.default.createElement(AudioMetaGridWrapper, null, /*#__PURE__*/_react.default.createElement(Audio, {
136
+ controls: true
137
+ }, /*#__PURE__*/_react.default.createElement("source", {
138
+ src: audio === null || audio === void 0 ? void 0 : audio.url
139
+ }), /*#__PURE__*/_react.default.createElement("source", {
140
+ src: audio === null || audio === void 0 ? void 0 : (_audio$file2 = audio.file) === null || _audio$file2 === void 0 ? void 0 : _audio$file2.url
141
+ })), /*#__PURE__*/_react.default.createElement(AudioName, null, audio === null || audio === void 0 ? void 0 : audio.name));
142
+ }
143
+
144
+ const AudiosQuery = (0, _apollo.gql)`
145
+ query Audios($searchText: String!, $take: Int, $skip: Int) {
146
+ audioFilesCount(where: { name: { contains: $searchText } })
147
+ audioFiles(
148
+ where: { name: { contains: $searchText } }
149
+ take: $take
150
+ skip: $skip
151
+ ) {
152
+ id
153
+ name
154
+ url
155
+ file {
156
+ url
157
+ }
158
+ heroImage {
159
+ imageFile {
160
+ url
161
+ }
162
+ resized {
163
+ w480
164
+ w800
165
+ w1200
166
+ w1600
167
+ w2400
168
+ }
169
+ }
170
+ }
171
+ }
172
+ `;
173
+
174
+ function AudioSelector(props) {
175
+ const [queryAudios, {
176
+ loading,
177
+ error,
178
+ data: {
179
+ audioFiles = [],
180
+ audioFilesCount = 0
181
+ } = {}
182
+ }] = (0, _apollo.useLazyQuery)(AudiosQuery, {
183
+ fetchPolicy: 'no-cache'
184
+ });
185
+ const [currentPage, setCurrentPage] = (0, _react.useState)(0); // page starts with 1, 0 is used to detect initialization
186
+
187
+ const [searchText, setSearchText] = (0, _react.useState)('');
188
+ const [selected, setSelected] = (0, _react.useState)([]);
189
+ const pageSize = 6;
190
+ const {
191
+ onChange
192
+ } = props;
193
+
194
+ const onSave = () => {
195
+ onChange(selected);
196
+ };
197
+
198
+ const onCancel = () => {
199
+ onChange([]);
200
+ };
201
+
202
+ const onSearchBoxChange = async searchInput => {
203
+ setSearchText(searchInput);
204
+ setCurrentPage(1);
205
+ };
206
+
207
+ const onAudiosGridSelect = audioEntity => {
208
+ setSelected(selected => {
209
+ const filterdSelected = selected.filter(ele => {
210
+ var _ele$audio;
211
+
212
+ return ((_ele$audio = ele.audio) === null || _ele$audio === void 0 ? void 0 : _ele$audio.id) !== audioEntity.id;
213
+ }); // deselect the audio
214
+
215
+ if (filterdSelected.length !== selected.length) {
216
+ return filterdSelected;
217
+ } // single select
218
+
219
+
220
+ return [{
221
+ audio: audioEntity
222
+ }];
223
+ });
224
+ };
225
+
226
+ const selectedAudios = selected.map(ele => {
227
+ return ele.audio;
228
+ });
229
+ (0, _react.useEffect)(() => {
230
+ if (currentPage !== 0) {
231
+ queryAudios({
232
+ variables: {
233
+ searchText: searchText,
234
+ skip: (currentPage - 1) * pageSize,
235
+ take: pageSize
236
+ }
237
+ });
238
+ }
239
+ }, [currentPage, searchText]);
240
+
241
+ let searchResult = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(AudiosGrids, {
242
+ audios: audioFiles,
243
+ selected: selectedAudios,
244
+ onSelect: onAudiosGridSelect
245
+ }), /*#__PURE__*/_react.default.createElement(_pagination.Pagination, {
246
+ currentPage: currentPage,
247
+ total: audioFilesCount,
248
+ pageSize: pageSize,
249
+ onChange: pageIndex => {
250
+ setCurrentPage(pageIndex);
251
+ }
252
+ }));
253
+
254
+ if (loading) {
255
+ searchResult = /*#__PURE__*/_react.default.createElement("p", null, "searching...");
256
+ }
257
+
258
+ if (error) {
259
+ 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)));
260
+ }
261
+
262
+ return /*#__PURE__*/_react.default.createElement(_modals.DrawerController, {
263
+ isOpen: true
264
+ }, /*#__PURE__*/_react.default.createElement(_modals.Drawer, {
265
+ title: "Select audio",
266
+ actions: {
267
+ cancel: {
268
+ label: 'Cancel',
269
+ action: onCancel
270
+ },
271
+ confirm: {
272
+ label: 'Confirm',
273
+ action: onSave
274
+ }
275
+ }
276
+ }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(AudioSearchBox, {
277
+ onChange: onSearchBoxChange
278
+ }), /*#__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, {
279
+ audioMetas: selected
280
+ })))));
281
+ }
@@ -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.url
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) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mirrormedia/lilith-draft-editor",
3
- "version": "1.1.0-alpha.1",
3
+ "version": "1.1.0-alpha.2",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "scripts": {
@@ -23,7 +23,7 @@
23
23
  "license": "MIT",
24
24
  "dependencies": {
25
25
  "draft-js": "^0.11.7",
26
- "@mirrormedia/lilith-draft-renderer": "1.0.0"
26
+ "@mirrormedia/lilith-draft-renderer": "1.1.0-alpha.5"
27
27
  },
28
28
  "peerDependencies": {
29
29
  "react": "18.1.0",