@akemona-org/strapi-plugin-upload 3.7.0

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 (246) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +19 -0
  3. package/admin/src/assets/images/logo.svg +1 -0
  4. package/admin/src/components/BrowseAssets/Wrapper.js +8 -0
  5. package/admin/src/components/BrowseAssets/index.js +182 -0
  6. package/admin/src/components/Card/index.js +146 -0
  7. package/admin/src/components/CardBorder/index.js +28 -0
  8. package/admin/src/components/CardControl/Wrapper.js +89 -0
  9. package/admin/src/components/CardControl/index.js +61 -0
  10. package/admin/src/components/CardControlsWrapper/index.js +22 -0
  11. package/admin/src/components/CardEmpty/Bar.js +19 -0
  12. package/admin/src/components/CardEmpty/Wrapper.js +7 -0
  13. package/admin/src/components/CardEmpty/index.js +16 -0
  14. package/admin/src/components/CardErrorMessage/index.js +9 -0
  15. package/admin/src/components/CardImgWrapper/index.js +52 -0
  16. package/admin/src/components/CardPreview/Image.js +12 -0
  17. package/admin/src/components/CardPreview/Wrapper.js +25 -0
  18. package/admin/src/components/CardPreview/index.js +66 -0
  19. package/admin/src/components/CardTitle/index.js +14 -0
  20. package/admin/src/components/CardWrapper/index.js +23 -0
  21. package/admin/src/components/CheckControl/Button.js +49 -0
  22. package/admin/src/components/CheckControl/CustomDropdownSection.js +9 -0
  23. package/admin/src/components/CheckControl/Spacer.js +7 -0
  24. package/admin/src/components/CheckControl/index.js +74 -0
  25. package/admin/src/components/Container/index.js +7 -0
  26. package/admin/src/components/ContainerFluid/index.js +12 -0
  27. package/admin/src/components/ControlsWrapper/index.js +9 -0
  28. package/admin/src/components/DragLayer/Wrapper.js +13 -0
  29. package/admin/src/components/DragLayer/index.js +68 -0
  30. package/admin/src/components/DropdownButton/index.js +63 -0
  31. package/admin/src/components/DropdownSection/index.js +27 -0
  32. package/admin/src/components/Duration/index.js +25 -0
  33. package/admin/src/components/Duration/utils/formatDuration.js +13 -0
  34. package/admin/src/components/EditForm/CropWrapper.js +21 -0
  35. package/admin/src/components/EditForm/ErrorMessage.js +10 -0
  36. package/admin/src/components/EditForm/FileDetailsBox.js +95 -0
  37. package/admin/src/components/EditForm/FileDetailsBoxWrapper.js +14 -0
  38. package/admin/src/components/EditForm/FileWrapper.js +41 -0
  39. package/admin/src/components/EditForm/FormWrapper.js +7 -0
  40. package/admin/src/components/EditForm/SizeBox.js +13 -0
  41. package/admin/src/components/EditForm/Wrapper.js +8 -0
  42. package/admin/src/components/EditForm/index.js +425 -0
  43. package/admin/src/components/EditForm/utils/form.js +34 -0
  44. package/admin/src/components/EditForm/utils/isImageType.js +3 -0
  45. package/admin/src/components/EditForm/utils/isVideoType.js +3 -0
  46. package/admin/src/components/FileIcon/Wrapper.js +20 -0
  47. package/admin/src/components/FileIcon/index.js +33 -0
  48. package/admin/src/components/FileIcon/utils/extensions.json +4 -0
  49. package/admin/src/components/FileInfos/index.js +32 -0
  50. package/admin/src/components/Filters/index.js +30 -0
  51. package/admin/src/components/FiltersList/index.js +34 -0
  52. package/admin/src/components/FiltersList/utils/formatFilter.js +36 -0
  53. package/admin/src/components/FiltersPicker/FiltersCard/FilterButton.js +8 -0
  54. package/admin/src/components/FiltersPicker/FiltersCard/FilterInput.js +35 -0
  55. package/admin/src/components/FiltersPicker/FiltersCard/InputWrapper.js +10 -0
  56. package/admin/src/components/FiltersPicker/FiltersCard/SizeInput.js +57 -0
  57. package/admin/src/components/FiltersPicker/FiltersCard/Wrapper.js +8 -0
  58. package/admin/src/components/FiltersPicker/FiltersCard/index.js +97 -0
  59. package/admin/src/components/FiltersPicker/FiltersCard/init.js +21 -0
  60. package/admin/src/components/FiltersPicker/FiltersCard/reducer.js +47 -0
  61. package/admin/src/components/FiltersPicker/FiltersCard/utils/filtersForm.js +27 -0
  62. package/admin/src/components/FiltersPicker/index.js +43 -0
  63. package/admin/src/components/FiltersPicker/utils/formatFilter.js +18 -0
  64. package/admin/src/components/InfiniteLoadingIndicator/Button.js +20 -0
  65. package/admin/src/components/InfiniteLoadingIndicator/Container.js +12 -0
  66. package/admin/src/components/InfiniteLoadingIndicator/Wrapper.js +18 -0
  67. package/admin/src/components/InfiniteLoadingIndicator/index.js +39 -0
  68. package/admin/src/components/Input/index.js +7 -0
  69. package/admin/src/components/InputFileModal/Label.js +47 -0
  70. package/admin/src/components/InputFileModal/P.js +15 -0
  71. package/admin/src/components/InputFileModal/index.js +73 -0
  72. package/admin/src/components/InputMedia/CardControlWrapper.js +12 -0
  73. package/admin/src/components/InputMedia/CardPreviewWrapper.js +13 -0
  74. package/admin/src/components/InputMedia/Chevron/Wrapper.js +10 -0
  75. package/admin/src/components/InputMedia/Chevron/index.js +21 -0
  76. package/admin/src/components/InputMedia/EmptyInputMedia.js +60 -0
  77. package/admin/src/components/InputMedia/EmptyText.js +13 -0
  78. package/admin/src/components/InputMedia/ErrorMessage.js +12 -0
  79. package/admin/src/components/InputMedia/IconUpload.js +48 -0
  80. package/admin/src/components/InputMedia/InputFilePreview.js +37 -0
  81. package/admin/src/components/InputMedia/Name.js +10 -0
  82. package/admin/src/components/InputMedia/Wrapper.js +11 -0
  83. package/admin/src/components/InputMedia/index.js +238 -0
  84. package/admin/src/components/InputUploadURL/Wrapper.js +13 -0
  85. package/admin/src/components/InputUploadURL/index.js +46 -0
  86. package/admin/src/components/IntlText/index.js +26 -0
  87. package/admin/src/components/List/ListCell.js +19 -0
  88. package/admin/src/components/List/ListRow.js +8 -0
  89. package/admin/src/components/List/index.js +114 -0
  90. package/admin/src/components/ListEmpty/Wrapper.js +15 -0
  91. package/admin/src/components/ListEmpty/index.js +70 -0
  92. package/admin/src/components/ListEmpty/utils/generateRows.js +12 -0
  93. package/admin/src/components/ListModal/BaselineAlignmentWrapper.js +12 -0
  94. package/admin/src/components/ListModal/index.js +66 -0
  95. package/admin/src/components/ListWrapper/index.js +16 -0
  96. package/admin/src/components/LoadingIndicator/index.js +44 -0
  97. package/admin/src/components/ModalHeader/BackButton.js +33 -0
  98. package/admin/src/components/ModalHeader/Wrapper.js +24 -0
  99. package/admin/src/components/ModalHeader/index.js +47 -0
  100. package/admin/src/components/ModalNavWrapper/BaselineAlignment.js +12 -0
  101. package/admin/src/components/ModalNavWrapper/Hr.js +14 -0
  102. package/admin/src/components/ModalNavWrapper/Wrapper.js +8 -0
  103. package/admin/src/components/ModalNavWrapper/index.js +70 -0
  104. package/admin/src/components/ModalSection/index.js +20 -0
  105. package/admin/src/components/ModalTab/Count/Wrapper.js +16 -0
  106. package/admin/src/components/ModalTab/Count/index.js +30 -0
  107. package/admin/src/components/ModalTab/Wrapper.js +37 -0
  108. package/admin/src/components/ModalTab/index.js +60 -0
  109. package/admin/src/components/PlayIcon/Play.js +65 -0
  110. package/admin/src/components/PlayIcon/Wrapper.js +24 -0
  111. package/admin/src/components/PlayIcon/index.js +23 -0
  112. package/admin/src/components/SelectAll/Wrapper.js +19 -0
  113. package/admin/src/components/SelectAll/index.js +26 -0
  114. package/admin/src/components/SelectedAssets/DraggableCard.js +149 -0
  115. package/admin/src/components/SelectedAssets/ListTitleWrapper.js +7 -0
  116. package/admin/src/components/SelectedAssets/ListWrapper.js +7 -0
  117. package/admin/src/components/SelectedAssets/SortableList.js +102 -0
  118. package/admin/src/components/SelectedAssets/Wrapper.js +7 -0
  119. package/admin/src/components/SelectedAssets/index.js +56 -0
  120. package/admin/src/components/SortList/Wrapper.js +19 -0
  121. package/admin/src/components/SortList/index.js +37 -0
  122. package/admin/src/components/SortListItem/Wrapper.js +28 -0
  123. package/admin/src/components/SortListItem/index.js +35 -0
  124. package/admin/src/components/SortPicker/index.js +54 -0
  125. package/admin/src/components/Tag/Wrapper.js +16 -0
  126. package/admin/src/components/Tag/index.js +25 -0
  127. package/admin/src/components/UploadForm/index.js +61 -0
  128. package/admin/src/components/UploadList/ButtonWrapper.js +7 -0
  129. package/admin/src/components/UploadList/Container.js +10 -0
  130. package/admin/src/components/UploadList/CustomModalSection.js +9 -0
  131. package/admin/src/components/UploadList/ListTitle.js +10 -0
  132. package/admin/src/components/UploadList/ListTitleWrapper.js +7 -0
  133. package/admin/src/components/UploadList/RowItem.js +98 -0
  134. package/admin/src/components/UploadList/index.js +90 -0
  135. package/admin/src/components/VideoPlayer/Wrapper.js +24 -0
  136. package/admin/src/components/VideoPlayer/index.js +57 -0
  137. package/admin/src/components/VideoPreview/CanvasWrapper.js +22 -0
  138. package/admin/src/components/VideoPreview/Thumbnail.js +12 -0
  139. package/admin/src/components/VideoPreview/Wrapper.js +15 -0
  140. package/admin/src/components/VideoPreview/index.js +165 -0
  141. package/admin/src/components/VideoPreview/reducer.js +33 -0
  142. package/admin/src/containers/App/index.js +31 -0
  143. package/admin/src/containers/HomePage/HomePageContent/HomePageList.js +98 -0
  144. package/admin/src/containers/HomePage/HomePageContent/HomePageSettings.js +103 -0
  145. package/admin/src/containers/HomePage/HomePageContent/index.js +90 -0
  146. package/admin/src/containers/HomePage/components.js +18 -0
  147. package/admin/src/containers/HomePage/index.js +373 -0
  148. package/admin/src/containers/HomePage/init.js +5 -0
  149. package/admin/src/containers/HomePage/reducer.js +88 -0
  150. package/admin/src/containers/HomePage/utils/generateParamsFromQuery.js +14 -0
  151. package/admin/src/containers/HomePage/utils/generateStringFromParams.js +27 -0
  152. package/admin/src/containers/HomePage/utils/getHeaderLabel.js +13 -0
  153. package/admin/src/containers/HomePage/utils/index.js +2 -0
  154. package/admin/src/containers/Initializer/index.js +44 -0
  155. package/admin/src/containers/InputModalStepper/HeaderSearch.js +12 -0
  156. package/admin/src/containers/InputModalStepper/InputModalStepper.js +480 -0
  157. package/admin/src/containers/InputModalStepper/Search.js +48 -0
  158. package/admin/src/containers/InputModalStepper/index.js +86 -0
  159. package/admin/src/containers/InputModalStepper/stepper.js +52 -0
  160. package/admin/src/containers/InputModalStepperProvider/index.js +564 -0
  161. package/admin/src/containers/InputModalStepperProvider/init.js +5 -0
  162. package/admin/src/containers/InputModalStepperProvider/reducer.js +301 -0
  163. package/admin/src/containers/ModalStepper/index.js +629 -0
  164. package/admin/src/containers/ModalStepper/init.js +5 -0
  165. package/admin/src/containers/ModalStepper/reducer.js +132 -0
  166. package/admin/src/containers/ModalStepper/stepper.js +46 -0
  167. package/admin/src/containers/SettingsPage/Divider.js +11 -0
  168. package/admin/src/containers/SettingsPage/SectionTitleWrapper.js +7 -0
  169. package/admin/src/containers/SettingsPage/Wrapper.js +17 -0
  170. package/admin/src/containers/SettingsPage/index.js +198 -0
  171. package/admin/src/containers/SettingsPage/init.js +5 -0
  172. package/admin/src/containers/SettingsPage/reducer.js +38 -0
  173. package/admin/src/contexts/AppContext/index.js +5 -0
  174. package/admin/src/contexts/InputModal/InputModalDataManager.js +5 -0
  175. package/admin/src/contexts/index.js +2 -0
  176. package/admin/src/hooks/index.js +2 -0
  177. package/admin/src/hooks/useAppContext/index.js +6 -0
  178. package/admin/src/hooks/useModalContext.js +6 -0
  179. package/admin/src/icons/BrokenFile/index.js +91 -0
  180. package/admin/src/icons/Cloud/index.js +35 -0
  181. package/admin/src/icons/DoubleFile/index.js +35 -0
  182. package/admin/src/icons/Download/index.js +36 -0
  183. package/admin/src/icons/File/index.js +35 -0
  184. package/admin/src/index.js +85 -0
  185. package/admin/src/lifecycles.js +13 -0
  186. package/admin/src/permissions.js +40 -0
  187. package/admin/src/pluginId.js +5 -0
  188. package/admin/src/translations/de.json +81 -0
  189. package/admin/src/translations/dk.json +81 -0
  190. package/admin/src/translations/en.json +86 -0
  191. package/admin/src/translations/es.json +81 -0
  192. package/admin/src/translations/fr.json +85 -0
  193. package/admin/src/translations/he.json +81 -0
  194. package/admin/src/translations/index.js +39 -0
  195. package/admin/src/translations/it.json +82 -0
  196. package/admin/src/translations/ja.json +81 -0
  197. package/admin/src/translations/ms.json +73 -0
  198. package/admin/src/translations/pl.json +81 -0
  199. package/admin/src/translations/pt-BR.json +81 -0
  200. package/admin/src/translations/ru.json +81 -0
  201. package/admin/src/translations/sk.json +81 -0
  202. package/admin/src/translations/th.json +81 -0
  203. package/admin/src/translations/uk.json +78 -0
  204. package/admin/src/translations/zh-Hans.json +86 -0
  205. package/admin/src/translations/zh.json +81 -0
  206. package/admin/src/utils/ItemTypes.js +3 -0
  207. package/admin/src/utils/canDownloadFile.js +3 -0
  208. package/admin/src/utils/compactParams.js +13 -0
  209. package/admin/src/utils/createFileToDownloadName.js +9 -0
  210. package/admin/src/utils/createMatrix.js +32 -0
  211. package/admin/src/utils/createNewFilesToDownloadArray.js +57 -0
  212. package/admin/src/utils/createNewFilesToUploadArray.js +25 -0
  213. package/admin/src/utils/formatBytes.js +13 -0
  214. package/admin/src/utils/formatFileForEditing.js +20 -0
  215. package/admin/src/utils/formatFilters.js +23 -0
  216. package/admin/src/utils/generatePageFromStart.js +5 -0
  217. package/admin/src/utils/generateStartFromPage.js +5 -0
  218. package/admin/src/utils/getFileModelTimestamps.js +15 -0
  219. package/admin/src/utils/getFilesToDownload.js +5 -0
  220. package/admin/src/utils/getRequestUrl.js +5 -0
  221. package/admin/src/utils/getTrad.js +5 -0
  222. package/admin/src/utils/getType.js +15 -0
  223. package/admin/src/utils/getYupError.js +17 -0
  224. package/admin/src/utils/index.js +20 -0
  225. package/admin/src/utils/unformatBytes.js +16 -0
  226. package/admin/src/utils/urlYupSchema.js +49 -0
  227. package/config/config.json +8 -0
  228. package/config/functions/bootstrap.js +143 -0
  229. package/config/routes.json +98 -0
  230. package/config/schema.graphql.js +96 -0
  231. package/controllers/Upload.js +103 -0
  232. package/controllers/upload/admin.js +213 -0
  233. package/controllers/upload/api.js +125 -0
  234. package/controllers/validation/settings.js +22 -0
  235. package/controllers/validation/upload.js +27 -0
  236. package/documentation/1.0.0/overrides/upload-File.json +263 -0
  237. package/errors.js +48 -0
  238. package/index.js +7 -0
  239. package/middlewares/upload/defaults.json +5 -0
  240. package/middlewares/upload/index.js +35 -0
  241. package/models/File.js +7 -0
  242. package/models/File.settings.json +86 -0
  243. package/package.json +71 -0
  244. package/services/Upload.js +397 -0
  245. package/services/image-manipulation.js +167 -0
  246. package/utils/file.js +23 -0
@@ -0,0 +1,33 @@
1
+ import { fromJS } from 'immutable';
2
+
3
+ const initialState = fromJS({
4
+ dataLoaded: false,
5
+ duration: 0,
6
+ isHover: false,
7
+ metadataLoaded: false,
8
+ seeked: false,
9
+ snapshot: false,
10
+ isError: false,
11
+ });
12
+
13
+ const videoReducer = (state, action) => {
14
+ switch (action.type) {
15
+ case 'DATA_LOADED':
16
+ return state.update('dataLoaded', () => true).update('duration', () => action.duration);
17
+ case 'METADATA_LOADED':
18
+ return state.update('metadataLoaded', () => true);
19
+ case 'SEEKED':
20
+ return state.update('seeked', () => true);
21
+ case 'SET_IS_HOVER':
22
+ return state.update('isHover', () => action.isHover);
23
+ case 'SET_SNAPSHOT':
24
+ return state.update('snapshot', () => action.snapshot);
25
+ case 'SET_ERROR':
26
+ return state.update('isError', () => action.isError);
27
+ default:
28
+ return state;
29
+ }
30
+ };
31
+
32
+ export default videoReducer;
33
+ export { initialState };
@@ -0,0 +1,31 @@
1
+ import React from 'react';
2
+ import { Switch, Route, Redirect } from 'react-router-dom';
3
+ import { LoadingIndicatorPage, useUserPermissions } from 'strapi-helper-plugin';
4
+ import pluginId from '../../pluginId';
5
+ import pluginPermissions from '../../permissions';
6
+ import { AppContext } from '../../contexts';
7
+
8
+ import HomePage from '../HomePage';
9
+
10
+ const App = () => {
11
+ const state = useUserPermissions(pluginPermissions);
12
+
13
+ // Show a loader while all permissions are being checked
14
+ if (state.isLoading) {
15
+ return <LoadingIndicatorPage />;
16
+ }
17
+
18
+ if (state.allowedActions.canMain) {
19
+ return (
20
+ <AppContext.Provider value={state}>
21
+ <Switch>
22
+ <Route path={`/plugins/${pluginId}`} component={HomePage} />
23
+ </Switch>
24
+ </AppContext.Provider>
25
+ );
26
+ }
27
+
28
+ return <Redirect to="/" />;
29
+ };
30
+
31
+ export default App;
@@ -0,0 +1,98 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { Padded } from '@buffetjs/core';
4
+ import { PageFooter, useQuery } from 'strapi-helper-plugin';
5
+ import { generatePageFromStart, generateStartFromPage } from '../../../utils';
6
+ import { useAppContext } from '../../../hooks';
7
+ import List from '../../../components/List';
8
+ import ListEmpty from '../../../components/ListEmpty';
9
+
10
+ const HomePageList = ({
11
+ areResultsEmptyWithSettings,
12
+ data,
13
+ dataCount,
14
+ dataToDelete,
15
+ onCardCheck,
16
+ onCardClick,
17
+ onChange,
18
+ onClick,
19
+ }) => {
20
+ const query = useQuery();
21
+ const {
22
+ allowedActions: { canCreate, canUpdate },
23
+ } = useAppContext();
24
+
25
+ const limit = parseInt(query.get('_limit'), 10) || 10;
26
+ const start = parseInt(query.get('_start'), 10) || 0;
27
+
28
+ const params = {
29
+ _limit: limit,
30
+ _page: generatePageFromStart(start, limit),
31
+ };
32
+
33
+ const handleChangeListParams = ({ target: { name, value } }) => {
34
+ if (name.includes('_page')) {
35
+ onChange({
36
+ target: { name: '_start', value: generateStartFromPage(value, limit) },
37
+ });
38
+ } else {
39
+ onChange({ target: { name: '_limit', value } });
40
+ }
41
+ };
42
+
43
+ if (dataCount > 0 && !areResultsEmptyWithSettings) {
44
+ return (
45
+ <>
46
+ <List
47
+ data={data}
48
+ onChange={onCardCheck}
49
+ onCardClick={onCardClick}
50
+ selectedItems={dataToDelete}
51
+ showCheckbox={canUpdate}
52
+ />
53
+ <Padded left right size="sm">
54
+ <Padded left right size="xs">
55
+ <PageFooter
56
+ context={{ emitEvent: () => {} }}
57
+ count={dataCount}
58
+ onChangeParams={handleChangeListParams}
59
+ params={params}
60
+ />
61
+ </Padded>
62
+ </Padded>
63
+ </>
64
+ );
65
+ }
66
+
67
+ return (
68
+ <ListEmpty
69
+ canCreate={canCreate}
70
+ onClick={onClick}
71
+ hasSearchApplied={areResultsEmptyWithSettings}
72
+ />
73
+ );
74
+ };
75
+
76
+ HomePageList.defaultProps = {
77
+ areResultsEmptyWithSettings: false,
78
+ data: [],
79
+ dataCount: 0,
80
+ dataToDelete: [],
81
+ onCardCheck: () => {},
82
+ onCardClick: () => {},
83
+ onChange: () => {},
84
+ onClick: () => {},
85
+ };
86
+
87
+ HomePageList.propTypes = {
88
+ areResultsEmptyWithSettings: PropTypes.bool,
89
+ data: PropTypes.array,
90
+ dataCount: PropTypes.number,
91
+ dataToDelete: PropTypes.array,
92
+ onCardCheck: PropTypes.func,
93
+ onCardClick: PropTypes.func,
94
+ onChange: PropTypes.func,
95
+ onClick: PropTypes.func,
96
+ };
97
+
98
+ export default HomePageList;
@@ -0,0 +1,103 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { useDebounce } from '@buffetjs/hooks';
4
+ import { Padded } from '@buffetjs/core';
5
+ import { HeaderSearch, useGlobalContext, useQuery, LoadingIndicator } from 'strapi-helper-plugin';
6
+
7
+ import { useAppContext } from '../../../hooks';
8
+ import { getTrad, getFileModelTimestamps } from '../../../utils';
9
+ import ControlsWrapper from '../../../components/ControlsWrapper';
10
+ import Filters from '../../../components/Filters';
11
+ import SelectAll from '../../../components/SelectAll';
12
+ import SortPicker from '../../../components/SortPicker';
13
+
14
+ const HomePageSettings = ({
15
+ areAllCheckboxesSelected,
16
+ filters,
17
+ hasSomeCheckboxSelected,
18
+ isLoading,
19
+ onChange,
20
+ onFilterDelete,
21
+ onSelectAll,
22
+ }) => {
23
+ const {
24
+ allowedActions: { canUpdate },
25
+ } = useAppContext();
26
+ const { formatMessage, plugins } = useGlobalContext();
27
+ const [, updated_at] = getFileModelTimestamps(plugins);
28
+ const query = useQuery();
29
+ const [searchValue, setSearchValue] = useState(query.get('_q') || '');
30
+ const debouncedSearch = useDebounce(searchValue, 300);
31
+ const pluginName = formatMessage({ id: getTrad('plugin.name') });
32
+
33
+ useEffect(() => {
34
+ onChange({ target: { name: '_q', value: debouncedSearch } });
35
+
36
+ // eslint-disable-next-line react-hooks/exhaustive-deps
37
+ }, [debouncedSearch]);
38
+
39
+ const handleChangeSearchValue = ({ target: { value } }) => {
40
+ setSearchValue(value);
41
+ };
42
+
43
+ const handleClearSearch = () => {
44
+ setSearchValue('');
45
+ };
46
+
47
+ return (
48
+ <>
49
+ <HeaderSearch
50
+ label={pluginName}
51
+ onChange={handleChangeSearchValue}
52
+ onClear={handleClearSearch}
53
+ placeholder={formatMessage({ id: getTrad('search.placeholder') })}
54
+ name="_q"
55
+ value={searchValue}
56
+ autoFocus
57
+ />
58
+ {isLoading ? (
59
+ <>
60
+ <Padded top bottom size="lg" />
61
+ <LoadingIndicator />
62
+ </>
63
+ ) : (
64
+ <ControlsWrapper>
65
+ {canUpdate && (
66
+ <>
67
+ <SelectAll
68
+ onChange={onSelectAll}
69
+ checked={areAllCheckboxesSelected}
70
+ someChecked={hasSomeCheckboxSelected && !areAllCheckboxesSelected}
71
+ />
72
+ <Padded right />
73
+ </>
74
+ )}
75
+ <SortPicker onChange={onChange} value={query.get('_sort') || `${updated_at}:DESC`} />
76
+ <Padded right />
77
+ <Filters onChange={onChange} filters={filters} onClick={onFilterDelete} />
78
+ </ControlsWrapper>
79
+ )}
80
+ </>
81
+ );
82
+ };
83
+
84
+ HomePageSettings.defaultProps = {
85
+ areAllCheckboxesSelected: false,
86
+ filters: [],
87
+ hasSomeCheckboxSelected: false,
88
+ onChange: () => {},
89
+ onFilterDelete: () => {},
90
+ onSelectAll: () => {},
91
+ };
92
+
93
+ HomePageSettings.propTypes = {
94
+ areAllCheckboxesSelected: PropTypes.bool,
95
+ filters: PropTypes.array,
96
+ hasSomeCheckboxSelected: PropTypes.bool,
97
+ isLoading: PropTypes.bool.isRequired,
98
+ onChange: PropTypes.func,
99
+ onFilterDelete: PropTypes.func,
100
+ onSelectAll: PropTypes.func,
101
+ };
102
+
103
+ export default HomePageSettings;
@@ -0,0 +1,90 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { isEmpty } from 'lodash';
4
+ import { useLocation } from 'react-router-dom';
5
+ import { generateFiltersFromSearch, useQuery } from 'strapi-helper-plugin';
6
+
7
+ import HomePageSettings from './HomePageSettings';
8
+ import HomePageList from './HomePageList';
9
+
10
+ const HomePageContent = ({
11
+ data,
12
+ dataCount,
13
+ dataToDelete,
14
+ isLoading,
15
+ onCardCheck,
16
+ onCardClick,
17
+ onClick,
18
+ onFilterDelete,
19
+ onParamsChange,
20
+ onSelectAll,
21
+ }) => {
22
+ const query = useQuery();
23
+ const { search } = useLocation();
24
+ const filters = generateFiltersFromSearch(search);
25
+
26
+ const hasSomeCheckboxSelected = data.some(item =>
27
+ dataToDelete.find(itemToDelete => item.id.toString() === itemToDelete.id.toString())
28
+ );
29
+
30
+ const areAllCheckboxesSelected =
31
+ data.every(item =>
32
+ dataToDelete.find(itemToDelete => item.id.toString() === itemToDelete.id.toString())
33
+ ) && hasSomeCheckboxSelected;
34
+
35
+ const hasFilters = !isEmpty(filters);
36
+ const hasSearch = !isEmpty(query.get('_q'));
37
+ const areResultsEmptyWithSearchOrFilters = isEmpty(data) && (hasSearch || hasFilters);
38
+
39
+ return (
40
+ <>
41
+ <HomePageSettings
42
+ areAllCheckboxesSelected={areAllCheckboxesSelected}
43
+ filters={filters}
44
+ hasSomeCheckboxSelected={hasSomeCheckboxSelected}
45
+ isLoading={isLoading}
46
+ onChange={onParamsChange}
47
+ onFilterDelete={onFilterDelete}
48
+ onSelectAll={onSelectAll}
49
+ />
50
+ <HomePageList
51
+ areResultsEmptyWithSettings={areResultsEmptyWithSearchOrFilters}
52
+ data={data}
53
+ dataCount={dataCount}
54
+ dataToDelete={dataToDelete}
55
+ onCardCheck={onCardCheck}
56
+ onCardClick={onCardClick}
57
+ onClick={onClick}
58
+ onChange={onParamsChange}
59
+ />
60
+ </>
61
+ );
62
+ };
63
+
64
+ HomePageContent.defaultProps = {
65
+ data: [],
66
+ dataCount: 0,
67
+ dataToDelete: [],
68
+ isLoading: false,
69
+ onCardCheck: () => {},
70
+ onCardClick: () => {},
71
+ onClick: () => {},
72
+ onFilterDelete: () => {},
73
+ onParamsChange: () => {},
74
+ onSelectAll: () => {},
75
+ };
76
+
77
+ HomePageContent.propTypes = {
78
+ data: PropTypes.array,
79
+ dataCount: PropTypes.number,
80
+ dataToDelete: PropTypes.array,
81
+ isLoading: PropTypes.bool,
82
+ onCardCheck: PropTypes.func,
83
+ onCardClick: PropTypes.func,
84
+ onClick: PropTypes.func,
85
+ onFilterDelete: PropTypes.func,
86
+ onParamsChange: PropTypes.func,
87
+ onSelectAll: PropTypes.func,
88
+ };
89
+
90
+ export default HomePageContent;
@@ -0,0 +1,18 @@
1
+ import styled from 'styled-components';
2
+
3
+ const EntriesWrapper = styled.div`
4
+ display: flex;
5
+ height: 43px;
6
+ width: 100%;
7
+ padding-top: 16px;
8
+ margin-bottom: 10px;
9
+ justify-content: space-between;
10
+ `;
11
+
12
+ const Wrapper = styled.div`
13
+ padding-right: 20px;
14
+ padding-bottom: 2px;
15
+ font-family: Lato !important;
16
+ `;
17
+
18
+ export { EntriesWrapper, Wrapper };