@drodil/backstage-plugin-qeta-react 3.12.5 → 3.13.1

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 (194) hide show
  1. package/dist/components/AIAnswerCard/AIAnswerCard.esm.js +46 -58
  2. package/dist/components/AIAnswerCard/AIAnswerCard.esm.js.map +1 -1
  3. package/dist/components/AnswerCard/AnswerCard.esm.js +45 -29
  4. package/dist/components/AnswerCard/AnswerCard.esm.js.map +1 -1
  5. package/dist/components/AnswerForm/AnswerForm.esm.js +2 -12
  6. package/dist/components/AnswerForm/AnswerForm.esm.js.map +1 -1
  7. package/dist/components/AnswersContainer/AnswerList.esm.js +1 -6
  8. package/dist/components/AnswersContainer/AnswerList.esm.js.map +1 -1
  9. package/dist/components/AnswersContainer/AnswerListItem.esm.js +2 -4
  10. package/dist/components/AnswersContainer/AnswerListItem.esm.js.map +1 -1
  11. package/dist/components/AnswersContainer/AnswersContainer.esm.js +2 -6
  12. package/dist/components/AnswersContainer/AnswersContainer.esm.js.map +1 -1
  13. package/dist/components/ArticleContent/ArticleButtons.esm.js +27 -28
  14. package/dist/components/ArticleContent/ArticleButtons.esm.js.map +1 -1
  15. package/dist/components/ArticleContent/ArticleContent.esm.js +44 -44
  16. package/dist/components/ArticleContent/ArticleContent.esm.js.map +1 -1
  17. package/dist/components/AuthorBox/AuthorBox.esm.js +51 -49
  18. package/dist/components/AuthorBox/AuthorBox.esm.js.map +1 -1
  19. package/dist/components/Buttons/AddToCollectionButton.esm.js +6 -12
  20. package/dist/components/Buttons/AddToCollectionButton.esm.js.map +1 -1
  21. package/dist/components/Buttons/AskQuestionButton.esm.js +3 -3
  22. package/dist/components/Buttons/AskQuestionButton.esm.js.map +1 -1
  23. package/dist/components/Buttons/ButtonContainer.esm.js +22 -0
  24. package/dist/components/Buttons/ButtonContainer.esm.js.map +1 -0
  25. package/dist/components/Buttons/CollectionFollowButton.esm.js +3 -5
  26. package/dist/components/Buttons/CollectionFollowButton.esm.js.map +1 -1
  27. package/dist/components/Buttons/CreateCollectionButton.esm.js +3 -4
  28. package/dist/components/Buttons/CreateCollectionButton.esm.js.map +1 -1
  29. package/dist/components/Buttons/EntityFollowButton.esm.js +4 -5
  30. package/dist/components/Buttons/EntityFollowButton.esm.js.map +1 -1
  31. package/dist/components/Buttons/FavoriteButton.esm.js +3 -4
  32. package/dist/components/Buttons/FavoriteButton.esm.js.map +1 -1
  33. package/dist/components/Buttons/LinkButton.esm.js +2 -3
  34. package/dist/components/Buttons/LinkButton.esm.js.map +1 -1
  35. package/dist/components/Buttons/TagFollowButton.esm.js +4 -5
  36. package/dist/components/Buttons/TagFollowButton.esm.js.map +1 -1
  37. package/dist/components/Buttons/UserFollowButton.esm.js +4 -5
  38. package/dist/components/Buttons/UserFollowButton.esm.js.map +1 -1
  39. package/dist/components/Buttons/VoteButtons.esm.js +21 -10
  40. package/dist/components/Buttons/VoteButtons.esm.js.map +1 -1
  41. package/dist/components/Buttons/WriteArticleButton.esm.js +2 -2
  42. package/dist/components/Buttons/WriteArticleButton.esm.js.map +1 -1
  43. package/dist/components/CollectionCard/CollectionCard.esm.js +5 -7
  44. package/dist/components/CollectionCard/CollectionCard.esm.js.map +1 -1
  45. package/dist/components/CollectionForm/CollectionForm.esm.js +4 -11
  46. package/dist/components/CollectionForm/CollectionForm.esm.js.map +1 -1
  47. package/dist/components/CollectionsGrid/CollectionsGrid.esm.js +11 -11
  48. package/dist/components/CollectionsGrid/CollectionsGrid.esm.js.map +1 -1
  49. package/dist/components/CollectionsGrid/CollectionsGridContent.esm.js +10 -4
  50. package/dist/components/CollectionsGrid/CollectionsGridContent.esm.js.map +1 -1
  51. package/dist/components/CollectionsGrid/CollectionsGridItem.esm.js +2 -9
  52. package/dist/components/CollectionsGrid/CollectionsGridItem.esm.js.map +1 -1
  53. package/dist/components/CollectionsGrid/NoCollectionsCard.esm.js +1 -4
  54. package/dist/components/CollectionsGrid/NoCollectionsCard.esm.js.map +1 -1
  55. package/dist/components/CommentSection/CommentList.esm.js +20 -14
  56. package/dist/components/CommentSection/CommentList.esm.js.map +1 -1
  57. package/dist/components/CommentSection/CommentSection.esm.js +78 -62
  58. package/dist/components/CommentSection/CommentSection.esm.js.map +1 -1
  59. package/dist/components/DeleteModal/DeleteModal.esm.js +8 -8
  60. package/dist/components/DeleteModal/DeleteModal.esm.js.map +1 -1
  61. package/dist/components/EntitiesGrid/EntitiesGrid.esm.js +12 -9
  62. package/dist/components/EntitiesGrid/EntitiesGrid.esm.js.map +1 -1
  63. package/dist/components/EntitiesGrid/EntitiesGridContent.esm.js +1 -1
  64. package/dist/components/EntitiesGrid/EntitiesGridContent.esm.js.map +1 -1
  65. package/dist/components/EntitiesGrid/EntitiesGridItem.esm.js +1 -10
  66. package/dist/components/EntitiesGrid/EntitiesGridItem.esm.js.map +1 -1
  67. package/dist/components/EntitiesGrid/NoEntitiesCard.esm.js +1 -4
  68. package/dist/components/EntitiesGrid/NoEntitiesCard.esm.js.map +1 -1
  69. package/dist/components/FilterPanel/DateRangeFilter.esm.js +1 -7
  70. package/dist/components/FilterPanel/DateRangeFilter.esm.js.map +1 -1
  71. package/dist/components/FilterPanel/FilterPanel.esm.js +173 -199
  72. package/dist/components/FilterPanel/FilterPanel.esm.js.map +1 -1
  73. package/dist/components/FollowedLists/FollowedCollectionsList.esm.js +2 -2
  74. package/dist/components/FollowedLists/FollowedCollectionsList.esm.js.map +1 -1
  75. package/dist/components/FollowedLists/FollowedEntitiesList.esm.js +2 -2
  76. package/dist/components/FollowedLists/FollowedEntitiesList.esm.js.map +1 -1
  77. package/dist/components/FollowedLists/FollowedTagsList.esm.js +2 -2
  78. package/dist/components/FollowedLists/FollowedTagsList.esm.js.map +1 -1
  79. package/dist/components/FollowedLists/FollowedUsersList.esm.js +2 -2
  80. package/dist/components/FollowedLists/FollowedUsersList.esm.js.map +1 -1
  81. package/dist/components/HeaderImageInput/HeaderImageInput.esm.js +7 -10
  82. package/dist/components/HeaderImageInput/HeaderImageInput.esm.js.map +1 -1
  83. package/dist/components/HomePageCards/ImpactCard.esm.js +4 -17
  84. package/dist/components/HomePageCards/ImpactCard.esm.js.map +1 -1
  85. package/dist/components/HomePageCards/PostsCard.esm.js +15 -42
  86. package/dist/components/HomePageCards/PostsCard.esm.js.map +1 -1
  87. package/dist/components/LeftMenu/LeftMenu.esm.js +64 -66
  88. package/dist/components/LeftMenu/LeftMenu.esm.js.map +1 -1
  89. package/dist/components/LeftMenu/LeftMenuButton.esm.js +12 -33
  90. package/dist/components/LeftMenu/LeftMenuButton.esm.js.map +1 -1
  91. package/dist/components/Links/Links.esm.js +1 -1
  92. package/dist/components/Links/Links.esm.js.map +1 -1
  93. package/dist/components/LoadingGrid/LoadingGrid.esm.js +3 -3
  94. package/dist/components/LoadingGrid/LoadingGrid.esm.js.map +1 -1
  95. package/dist/components/MarkdownEditor/MarkdownEditor.esm.js +92 -81
  96. package/dist/components/MarkdownEditor/MarkdownEditor.esm.js.map +1 -1
  97. package/dist/components/MarkdownRenderer/MarkdownRenderer.esm.js +106 -107
  98. package/dist/components/MarkdownRenderer/MarkdownRenderer.esm.js.map +1 -1
  99. package/dist/components/PostAnonymouslyCheckbox/PostAnonymouslyCheckbox.esm.js +1 -4
  100. package/dist/components/PostAnonymouslyCheckbox/PostAnonymouslyCheckbox.esm.js.map +1 -1
  101. package/dist/components/PostForm/EntitiesInput.esm.js +5 -6
  102. package/dist/components/PostForm/EntitiesInput.esm.js.map +1 -1
  103. package/dist/components/PostForm/PostForm.esm.js +4 -5
  104. package/dist/components/PostForm/PostForm.esm.js.map +1 -1
  105. package/dist/components/PostForm/TagInput.esm.js +5 -6
  106. package/dist/components/PostForm/TagInput.esm.js.map +1 -1
  107. package/dist/components/PostHighlightList/PostHighlightList.esm.js +6 -8
  108. package/dist/components/PostHighlightList/PostHighlightList.esm.js.map +1 -1
  109. package/dist/components/PostsContainer/NoPostsCard.esm.js +3 -6
  110. package/dist/components/PostsContainer/NoPostsCard.esm.js.map +1 -1
  111. package/dist/components/PostsContainer/PostList.esm.js +2 -5
  112. package/dist/components/PostsContainer/PostList.esm.js.map +1 -1
  113. package/dist/components/PostsContainer/PostListItem.esm.js +25 -25
  114. package/dist/components/PostsContainer/PostListItem.esm.js.map +1 -1
  115. package/dist/components/PostsContainer/PostsContainer.esm.js +8 -17
  116. package/dist/components/PostsContainer/PostsContainer.esm.js.map +1 -1
  117. package/dist/components/PostsGrid/PostsGrid.esm.js +8 -17
  118. package/dist/components/PostsGrid/PostsGrid.esm.js.map +1 -1
  119. package/dist/components/PostsGrid/PostsGridContent.esm.js +13 -5
  120. package/dist/components/PostsGrid/PostsGridContent.esm.js.map +1 -1
  121. package/dist/components/PostsGrid/PostsGridItem.esm.js +13 -30
  122. package/dist/components/PostsGrid/PostsGridItem.esm.js.map +1 -1
  123. package/dist/components/QetaPagination/QetaPagination.esm.js +19 -11
  124. package/dist/components/QetaPagination/QetaPagination.esm.js.map +1 -1
  125. package/dist/components/QuestionCard/QuestionCard.esm.js +30 -15
  126. package/dist/components/QuestionCard/QuestionCard.esm.js.map +1 -1
  127. package/dist/components/QuestionsTable/QuestionTableRow.esm.js +1 -2
  128. package/dist/components/QuestionsTable/QuestionTableRow.esm.js.map +1 -1
  129. package/dist/components/QuestionsTable/QuestionsTable.esm.js +2 -12
  130. package/dist/components/QuestionsTable/QuestionsTable.esm.js.map +1 -1
  131. package/dist/components/RelativeTimeWithTooltip/RelativeTimeWithTooltip.esm.js +1 -1
  132. package/dist/components/RelativeTimeWithTooltip/RelativeTimeWithTooltip.esm.js.map +1 -1
  133. package/dist/components/SearchBar/SearchBar.esm.js +57 -45
  134. package/dist/components/SearchBar/SearchBar.esm.js.map +1 -1
  135. package/dist/components/SelectTemplateList/SelectTemplateList.esm.js +1 -8
  136. package/dist/components/SelectTemplateList/SelectTemplateList.esm.js.map +1 -1
  137. package/dist/components/StatsChart/StatsChart.esm.js +150 -111
  138. package/dist/components/StatsChart/StatsChart.esm.js.map +1 -1
  139. package/dist/components/SuggestionsCard/SuggestionsCard.esm.js +6 -11
  140. package/dist/components/SuggestionsCard/SuggestionsCard.esm.js.map +1 -1
  141. package/dist/components/SummaryStatsGrid/SummaryStatsGrid.esm.js +1 -4
  142. package/dist/components/SummaryStatsGrid/SummaryStatsGrid.esm.js.map +1 -1
  143. package/dist/components/TagsAndEntities/CollectionChip.esm.js +1 -5
  144. package/dist/components/TagsAndEntities/CollectionChip.esm.js.map +1 -1
  145. package/dist/components/TagsAndEntities/EntityChip.esm.js +1 -5
  146. package/dist/components/TagsAndEntities/EntityChip.esm.js.map +1 -1
  147. package/dist/components/TagsAndEntities/TagChip.esm.js +1 -5
  148. package/dist/components/TagsAndEntities/TagChip.esm.js.map +1 -1
  149. package/dist/components/TagsAndEntities/UserChip.esm.js +1 -5
  150. package/dist/components/TagsAndEntities/UserChip.esm.js.map +1 -1
  151. package/dist/components/TagsGrid/EditTagModal.esm.js +7 -9
  152. package/dist/components/TagsGrid/EditTagModal.esm.js.map +1 -1
  153. package/dist/components/TagsGrid/NoTagsCard.esm.js +1 -4
  154. package/dist/components/TagsGrid/NoTagsCard.esm.js.map +1 -1
  155. package/dist/components/TagsGrid/TagGridItem.esm.js +1 -9
  156. package/dist/components/TagsGrid/TagGridItem.esm.js.map +1 -1
  157. package/dist/components/TagsGrid/TagsGrid.esm.js +1 -2
  158. package/dist/components/TagsGrid/TagsGrid.esm.js.map +1 -1
  159. package/dist/components/TagsGrid/TagsGridContent.esm.js +1 -1
  160. package/dist/components/TagsGrid/TagsGridContent.esm.js.map +1 -1
  161. package/dist/components/TemplateList/TemplateForm.esm.js +3 -5
  162. package/dist/components/TemplateList/TemplateForm.esm.js.map +1 -1
  163. package/dist/components/TemplateList/TemplateList.esm.js +5 -12
  164. package/dist/components/TemplateList/TemplateList.esm.js.map +1 -1
  165. package/dist/components/TopRankingUsersCard/TopRankingUsersCard.esm.js +29 -12
  166. package/dist/components/TopRankingUsersCard/TopRankingUsersCard.esm.js.map +1 -1
  167. package/dist/components/TopRankingUsersCard/TrophyIcon.esm.js +1 -1
  168. package/dist/components/TopRankingUsersCard/TrophyIcon.esm.js.map +1 -1
  169. package/dist/components/UsersGrid/NoUsersCard.esm.js +1 -4
  170. package/dist/components/UsersGrid/NoUsersCard.esm.js.map +1 -1
  171. package/dist/components/UsersGrid/UsersGrid.esm.js +1 -2
  172. package/dist/components/UsersGrid/UsersGrid.esm.js.map +1 -1
  173. package/dist/components/UsersGrid/UsersGridContent.esm.js +1 -1
  174. package/dist/components/UsersGrid/UsersGridContent.esm.js.map +1 -1
  175. package/dist/components/UsersGrid/UsersGridItem.esm.js +1 -10
  176. package/dist/components/UsersGrid/UsersGridItem.esm.js.map +1 -1
  177. package/dist/components/{Styled → Utility}/ModalContent.esm.js +10 -5
  178. package/dist/components/Utility/ModalContent.esm.js.map +1 -0
  179. package/dist/components/{Styled → Utility}/RightList.esm.js +10 -16
  180. package/dist/components/Utility/RightList.esm.js.map +1 -0
  181. package/dist/components/Utility/SmallAvatar.esm.js +19 -0
  182. package/dist/components/Utility/SmallAvatar.esm.js.map +1 -0
  183. package/dist/components/Utility/VoteButtonContainer.esm.js +22 -0
  184. package/dist/components/Utility/VoteButtonContainer.esm.js.map +1 -0
  185. package/dist/index.d.ts +47 -6
  186. package/dist/index.esm.js +1 -0
  187. package/dist/index.esm.js.map +1 -1
  188. package/package.json +5 -7
  189. package/dist/components/Styled/CardActionContainer.esm.js +0 -13
  190. package/dist/components/Styled/CardActionContainer.esm.js.map +0 -1
  191. package/dist/components/Styled/ModalContent.esm.js.map +0 -1
  192. package/dist/components/Styled/RightList.esm.js.map +0 -1
  193. package/dist/components/Styled/VoteButtonContainer.esm.js +0 -14
  194. package/dist/components/Styled/VoteButtonContainer.esm.js.map +0 -1
@@ -1,16 +1,4 @@
1
1
  import React__default from 'react';
2
- import IconButton from '@mui/material/IconButton';
3
- import Tooltip from '@mui/material/Tooltip';
4
- import Divider from '@mui/material/Divider';
5
- import Box from '@mui/material/Box';
6
- import Grid from '@mui/material/Grid';
7
- import FormControl from '@mui/material/FormControl';
8
- import FormControlLabel from '@mui/material/FormControlLabel';
9
- import Radio from '@mui/material/Radio';
10
- import RadioGroup from '@mui/material/RadioGroup';
11
- import FormGroup from '@mui/material/FormGroup';
12
- import FormLabel from '@mui/material/FormLabel';
13
- import Checkbox from '@mui/material/Checkbox';
14
2
  import { stringifyEntityRef } from '@backstage/catalog-model';
15
3
  import { DateRangeFilter } from './DateRangeFilter.esm.js';
16
4
  import { useApi, identityApiRef } from '@backstage/core-plugin-api';
@@ -21,8 +9,9 @@ import 'react-use/lib/useAsync';
21
9
  import { EntitiesInput } from '../PostForm/EntitiesInput.esm.js';
22
10
  import { TagInput } from '../PostForm/TagInput.esm.js';
23
11
  import { useStarredEntities, catalogApiRef } from '@backstage/plugin-catalog-react';
24
- import FiberManualRecordIcon from '@mui/icons-material/FiberManualRecord';
25
- import AdjustIcon from '@mui/icons-material/Adjust';
12
+ import { Box, Grid, FormGroup, FormLabel, FormControlLabel, Checkbox, FormControl, RadioGroup, Divider, Tooltip, IconButton, Radio } from '@material-ui/core';
13
+ import AdjustIcon from '@material-ui/icons/Adjust';
14
+ import FiberManualRecordIcon from '@material-ui/icons/FiberManualRecord';
26
15
 
27
16
  const radioSelect = (value, label) => {
28
17
  return /* @__PURE__ */ React__default.createElement(
@@ -116,204 +105,189 @@ const FilterPanel = (props) => {
116
105
  const postFilters = isPostFilters(filters);
117
106
  const answerFilters = isAnswerFilters(filters);
118
107
  const collectionFilters = isCollectionFilters(filters);
119
- return /* @__PURE__ */ React__default.createElement(
120
- Box,
108
+ return /* @__PURE__ */ React__default.createElement(Box, null, /* @__PURE__ */ React__default.createElement(
109
+ Grid,
121
110
  {
122
- marginTop: 2,
123
- sx: (theme) => ({
124
- border: `1px solid ${theme.palette.action.selected}`,
125
- borderRadius: 1,
126
- padding: 3
127
- })
111
+ container: true,
112
+ spacing: 4,
113
+ alignItems: "stretch",
114
+ justifyContent: "space-evenly"
128
115
  },
129
- /* @__PURE__ */ React__default.createElement(
130
- Grid,
116
+ (postFilters || answerFilters) && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(FormGroup, null, /* @__PURE__ */ React__default.createElement(FormLabel, { id: "qeta-filter-quick" }, t("filterPanel.quickFilters.label")), postFilters && type !== "article" && /* @__PURE__ */ React__default.createElement(
117
+ FormControlLabel,
131
118
  {
132
- container: true,
133
- spacing: 4,
134
- alignItems: "stretch",
135
- justifyContent: "space-evenly"
136
- },
137
- (postFilters || answerFilters) && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(FormGroup, null, /* @__PURE__ */ React__default.createElement(FormLabel, { id: "qeta-filter-quick" }, t("filterPanel.quickFilters.label")), postFilters && type !== "article" && /* @__PURE__ */ React__default.createElement(
138
- FormControlLabel,
139
- {
140
- control: /* @__PURE__ */ React__default.createElement(
141
- Checkbox,
142
- {
143
- size: "small",
144
- name: "noAnswers",
145
- onChange: handleChange,
146
- checked: filters.noAnswers === "true"
147
- }
148
- ),
149
- label: t("filterPanel.noAnswers.label")
150
- }
151
- ), (postFilters || answerFilters) && type !== "article" && /* @__PURE__ */ React__default.createElement(
152
- FormControlLabel,
153
- {
154
- control: /* @__PURE__ */ React__default.createElement(
155
- Checkbox,
156
- {
157
- size: "small",
158
- name: "noCorrectAnswer",
159
- checked: filters.noCorrectAnswer === "true",
160
- onChange: handleChange
161
- }
162
- ),
163
- label: t("filterPanel.noCorrectAnswers.label")
164
- }
165
- ), (postFilters || answerFilters) && /* @__PURE__ */ React__default.createElement(
166
- FormControlLabel,
167
- {
168
- control: /* @__PURE__ */ React__default.createElement(
169
- Checkbox,
170
- {
171
- size: "small",
172
- name: "noVotes",
173
- checked: filters.noVotes === "true",
174
- onChange: handleChange
175
- }
176
- ),
177
- label: t("filterPanel.noVotes.label")
178
- }
179
- ), starredEntitiesApi.starredEntities.size > 0 && /* @__PURE__ */ React__default.createElement(
180
- FormControlLabel,
181
- {
182
- control: /* @__PURE__ */ React__default.createElement(
183
- Checkbox,
184
- {
185
- size: "small",
186
- name: "starredEntities",
187
- onChange: (e) => handleStarredEntities(e.target.checked),
188
- checked: starredEntities
189
- }
190
- ),
191
- label: t("filterPanel.starredEntities.label")
192
- }
193
- ), /* @__PURE__ */ React__default.createElement(
194
- FormControlLabel,
195
- {
196
- control: /* @__PURE__ */ React__default.createElement(
197
- Checkbox,
198
- {
199
- size: "small",
200
- name: "ownedEntities",
201
- onChange: (e) => handleOwnedEntities(e.target.checked),
202
- checked: ownedEntities
203
- }
204
- ),
205
- label: t("filterPanel.ownedEntities.label")
206
- }
207
- ))),
208
- /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(FormControl, null, /* @__PURE__ */ React__default.createElement(FormLabel, { id: "qeta-filter-order-by" }, t("filterPanel.orderBy.label")), /* @__PURE__ */ React__default.createElement(
209
- RadioGroup,
210
- {
211
- "aria-labelledby": "qeta-filter-order-by",
212
- name: "orderBy",
213
- value: filters.orderBy,
214
- onChange: handleChange,
215
- style: {
216
- display: "grid",
217
- gridTemplateColumns: "1fr 1fr",
218
- gap: "0 1em"
119
+ control: /* @__PURE__ */ React__default.createElement(
120
+ Checkbox,
121
+ {
122
+ size: "small",
123
+ name: "noAnswers",
124
+ onChange: handleChange,
125
+ checked: filters.noAnswers === "true"
219
126
  }
220
- },
221
- postFilters && filters.collectionId !== void 0 && radioSelect("rank", t("filterPanel.orderBy.rank")),
222
- radioSelect("created", t("filterPanel.orderBy.created")),
223
- (postFilters || collectionFilters) && radioSelect("title", t("filterPanel.orderBy.title")),
224
- postFilters && radioSelect("views", t("filterPanel.orderBy.views")),
225
- (postFilters || answerFilters) && radioSelect("score", t("filterPanel.orderBy.score")),
226
- postFilters && radioSelect("trend", t("filterPanel.orderBy.trend")),
227
- postFilters && type !== "article" && radioSelect("answersCount", t("filterPanel.orderBy.answers")),
228
- (postFilters || answerFilters) && radioSelect("updated", t("filterPanel.orderBy.updated"))
229
- ))),
230
- /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(FormControl, null, /* @__PURE__ */ React__default.createElement(FormLabel, { id: "qeta-filter-order" }, t("filterPanel.order.label")), /* @__PURE__ */ React__default.createElement(
231
- RadioGroup,
232
- {
233
- "aria-labelledby": "qeta-filter-order",
234
- name: "order",
235
- value: filters.order,
236
- onChange: handleChange
237
- },
238
- radioSelect("desc", t("filterPanel.order.desc")),
239
- radioSelect("asc", t("filterPanel.order.asc"))
240
- )))
241
- ),
242
- /* @__PURE__ */ React__default.createElement(Box, { marginY: "24px" }, /* @__PURE__ */ React__default.createElement(Divider, null)),
243
- /* @__PURE__ */ React__default.createElement(Grid, { container: true, alignItems: "stretch", justifyContent: "space-evenly" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
244
- DateRangeFilter,
127
+ ),
128
+ label: t("filterPanel.noAnswers.label")
129
+ }
130
+ ), (postFilters || answerFilters) && type !== "article" && /* @__PURE__ */ React__default.createElement(
131
+ FormControlLabel,
245
132
  {
246
- value: filters.dateRange,
247
- onChange: (val) => onChange({ key: "dateRange", value: val })
133
+ control: /* @__PURE__ */ React__default.createElement(
134
+ Checkbox,
135
+ {
136
+ size: "small",
137
+ name: "noCorrectAnswer",
138
+ checked: filters.noCorrectAnswer === "true",
139
+ onChange: handleChange
140
+ }
141
+ ),
142
+ label: t("filterPanel.noCorrectAnswers.label")
248
143
  }
249
- )), showEntityFilter && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(Grid, { container: true, alignItems: "center" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
250
- EntitiesInput,
144
+ ), (postFilters || answerFilters) && /* @__PURE__ */ React__default.createElement(
145
+ FormControlLabel,
251
146
  {
252
- disabled: starredEntities || ownedEntities,
253
- style: { minWidth: "200px" },
254
- onChange: (newEntities) => {
255
- const entityRefs = (newEntities ?? []).map(
256
- (e) => stringifyEntityRef(e)
257
- );
258
- handleChange({
259
- target: { name: "entities", value: entityRefs }
260
- });
261
- setEntities(newEntities);
262
- },
263
- value: entities,
264
- useOnlyUsedEntities: true,
265
- hideHelpText: true
147
+ control: /* @__PURE__ */ React__default.createElement(
148
+ Checkbox,
149
+ {
150
+ size: "small",
151
+ name: "noVotes",
152
+ checked: filters.noVotes === "true",
153
+ onChange: handleChange
154
+ }
155
+ ),
156
+ label: t("filterPanel.noVotes.label")
266
157
  }
267
- )), filters.entities && filters.entities?.length > 1 && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
268
- Tooltip,
158
+ ), starredEntitiesApi.starredEntities.size > 0 && /* @__PURE__ */ React__default.createElement(
159
+ FormControlLabel,
269
160
  {
270
- title: filters.entitiesRelation === "or" ? t("filterPanel.toggleEntityRelation.and") : t("filterPanel.toggleEntityRelation.or")
271
- },
272
- /* @__PURE__ */ React__default.createElement(
273
- IconButton,
274
- {
275
- disabled: starredEntities || ownedEntities,
276
- onClick: () => {
277
- if (filters.entitiesRelation === "or") {
278
- onChange({ key: "entitiesRelation", value: "and" });
279
- } else {
280
- onChange({ key: "entitiesRelation", value: "or" });
281
- }
282
- },
283
- size: "large"
284
- },
285
- filters.entitiesRelation === "or" ? /* @__PURE__ */ React__default.createElement(AdjustIcon, null) : /* @__PURE__ */ React__default.createElement(FiberManualRecordIcon, null)
286
- )
287
- )))), showTagFilter && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(Grid, { container: true, alignItems: "center" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
288
- TagInput,
161
+ control: /* @__PURE__ */ React__default.createElement(
162
+ Checkbox,
163
+ {
164
+ size: "small",
165
+ name: "starredEntities",
166
+ onChange: (e) => handleStarredEntities(e.target.checked),
167
+ checked: starredEntities
168
+ }
169
+ ),
170
+ label: t("filterPanel.starredEntities.label")
171
+ }
172
+ ), /* @__PURE__ */ React__default.createElement(
173
+ FormControlLabel,
289
174
  {
290
- style: { minWidth: "200px" },
291
- onChange: (newTags) => onChange({ key: "tags", value: newTags }),
292
- value: filters.tags,
293
- hideHelpText: true,
294
- allowCreate: false
175
+ control: /* @__PURE__ */ React__default.createElement(
176
+ Checkbox,
177
+ {
178
+ size: "small",
179
+ name: "ownedEntities",
180
+ onChange: (e) => handleOwnedEntities(e.target.checked),
181
+ checked: ownedEntities
182
+ }
183
+ ),
184
+ label: t("filterPanel.ownedEntities.label")
295
185
  }
296
- )), filters.tags && filters.tags?.length > 1 && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
297
- Tooltip,
186
+ ))),
187
+ /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(FormControl, null, /* @__PURE__ */ React__default.createElement(FormLabel, { id: "qeta-filter-order-by" }, t("filterPanel.orderBy.label")), /* @__PURE__ */ React__default.createElement(
188
+ RadioGroup,
298
189
  {
299
- title: filters.tagsRelation === "or" ? t("filterPanel.toggleTagRelation.and") : t("filterPanel.toggleTagRelation.or")
190
+ "aria-labelledby": "qeta-filter-order-by",
191
+ name: "orderBy",
192
+ value: filters.orderBy,
193
+ onChange: handleChange,
194
+ style: {
195
+ display: "grid",
196
+ gridTemplateColumns: "1fr 1fr",
197
+ gap: "0 1em"
198
+ }
300
199
  },
301
- /* @__PURE__ */ React__default.createElement(
302
- IconButton,
303
- {
304
- onClick: () => {
305
- if (filters.tagsRelation === "or") {
306
- onChange({ key: "tagsRelation", value: "and" });
307
- } else {
308
- onChange({ key: "tagsRelation", value: "or" });
309
- }
310
- },
311
- size: "large"
312
- },
313
- filters.tagsRelation === "or" ? /* @__PURE__ */ React__default.createElement(AdjustIcon, null) : /* @__PURE__ */ React__default.createElement(FiberManualRecordIcon, null)
314
- )
315
- )))))
316
- );
200
+ postFilters && filters.collectionId !== void 0 && radioSelect("rank", t("filterPanel.orderBy.rank")),
201
+ radioSelect("created", t("filterPanel.orderBy.created")),
202
+ (postFilters || collectionFilters) && radioSelect("title", t("filterPanel.orderBy.title")),
203
+ postFilters && radioSelect("views", t("filterPanel.orderBy.views")),
204
+ (postFilters || answerFilters) && radioSelect("score", t("filterPanel.orderBy.score")),
205
+ postFilters && radioSelect("trend", t("filterPanel.orderBy.trend")),
206
+ postFilters && type !== "article" && radioSelect("answersCount", t("filterPanel.orderBy.answers")),
207
+ (postFilters || answerFilters) && radioSelect("updated", t("filterPanel.orderBy.updated"))
208
+ ))),
209
+ /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(FormControl, null, /* @__PURE__ */ React__default.createElement(FormLabel, { id: "qeta-filter-order" }, t("filterPanel.order.label")), /* @__PURE__ */ React__default.createElement(
210
+ RadioGroup,
211
+ {
212
+ "aria-labelledby": "qeta-filter-order",
213
+ name: "order",
214
+ value: filters.order,
215
+ onChange: handleChange
216
+ },
217
+ radioSelect("desc", t("filterPanel.order.desc")),
218
+ radioSelect("asc", t("filterPanel.order.asc"))
219
+ )))
220
+ ), /* @__PURE__ */ React__default.createElement(Box, { marginY: "24px" }, /* @__PURE__ */ React__default.createElement(Divider, null)), /* @__PURE__ */ React__default.createElement(Grid, { container: true, alignItems: "stretch", justifyContent: "space-evenly" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
221
+ DateRangeFilter,
222
+ {
223
+ value: filters.dateRange,
224
+ onChange: (val) => onChange({ key: "dateRange", value: val })
225
+ }
226
+ )), showEntityFilter && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(Grid, { container: true, alignItems: "center" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
227
+ EntitiesInput,
228
+ {
229
+ disabled: starredEntities || ownedEntities,
230
+ style: { minWidth: "200px" },
231
+ onChange: (newEntities) => {
232
+ const entityRefs = (newEntities ?? []).map(
233
+ (e) => stringifyEntityRef(e)
234
+ );
235
+ handleChange({
236
+ target: { name: "entities", value: entityRefs }
237
+ });
238
+ setEntities(newEntities);
239
+ },
240
+ value: entities,
241
+ useOnlyUsedEntities: true,
242
+ hideHelpText: true
243
+ }
244
+ )), filters.entities && filters.entities?.length > 1 && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
245
+ Tooltip,
246
+ {
247
+ title: filters.entitiesRelation === "or" ? t("filterPanel.toggleEntityRelation.and") : t("filterPanel.toggleEntityRelation.or")
248
+ },
249
+ /* @__PURE__ */ React__default.createElement(
250
+ IconButton,
251
+ {
252
+ disabled: starredEntities || ownedEntities,
253
+ onClick: () => {
254
+ if (filters.entitiesRelation === "or") {
255
+ onChange({ key: "entitiesRelation", value: "and" });
256
+ } else {
257
+ onChange({ key: "entitiesRelation", value: "or" });
258
+ }
259
+ }
260
+ },
261
+ filters.entitiesRelation === "or" ? /* @__PURE__ */ React__default.createElement(AdjustIcon, null) : /* @__PURE__ */ React__default.createElement(FiberManualRecordIcon, null)
262
+ )
263
+ )))), showTagFilter && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(Grid, { container: true, alignItems: "center" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
264
+ TagInput,
265
+ {
266
+ style: { minWidth: "200px" },
267
+ onChange: (newTags) => onChange({ key: "tags", value: newTags }),
268
+ value: filters.tags,
269
+ hideHelpText: true,
270
+ allowCreate: false
271
+ }
272
+ )), filters.tags && filters.tags?.length > 1 && /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(
273
+ Tooltip,
274
+ {
275
+ title: filters.tagsRelation === "or" ? t("filterPanel.toggleTagRelation.and") : t("filterPanel.toggleTagRelation.or")
276
+ },
277
+ /* @__PURE__ */ React__default.createElement(
278
+ IconButton,
279
+ {
280
+ onClick: () => {
281
+ if (filters.tagsRelation === "or") {
282
+ onChange({ key: "tagsRelation", value: "and" });
283
+ } else {
284
+ onChange({ key: "tagsRelation", value: "or" });
285
+ }
286
+ }
287
+ },
288
+ filters.tagsRelation === "or" ? /* @__PURE__ */ React__default.createElement(AdjustIcon, null) : /* @__PURE__ */ React__default.createElement(FiberManualRecordIcon, null)
289
+ )
290
+ ))))));
317
291
  };
318
292
 
319
293
  export { FilterPanel, filterKeys };
@@ -1 +1 @@
1
- {"version":3,"file":"FilterPanel.esm.js","sources":["../../../src/components/FilterPanel/FilterPanel.tsx"],"sourcesContent":["import React from 'react';\nimport IconButton from '@mui/material/IconButton';\nimport Tooltip from '@mui/material/Tooltip';\nimport Divider from '@mui/material/Divider';\nimport Box from '@mui/material/Box';\nimport Grid from '@mui/material/Grid';\nimport FormControl from '@mui/material/FormControl';\nimport FormControlLabel from '@mui/material/FormControlLabel';\nimport Radio from '@mui/material/Radio';\nimport RadioGroup from '@mui/material/RadioGroup';\nimport FormGroup from '@mui/material/FormGroup';\nimport FormLabel from '@mui/material/FormLabel';\nimport Checkbox from '@mui/material/Checkbox';\nimport { Entity, stringifyEntityRef } from '@backstage/catalog-model';\nimport { DateRangeFilter } from './DateRangeFilter';\nimport { PostType } from '@drodil/backstage-plugin-qeta-common';\nimport { useTranslation } from '../../hooks';\nimport { EntitiesInput } from '../PostForm/EntitiesInput';\nimport { TagInput } from '../PostForm/TagInput';\nimport {\n catalogApiRef,\n useStarredEntities,\n} from '@backstage/plugin-catalog-react';\nimport { identityApiRef, useApi } from '@backstage/core-plugin-api';\nimport FiberManualRecordIcon from '@mui/icons-material/FiberManualRecord';\nimport AdjustIcon from '@mui/icons-material/Adjust';\n\nconst radioSelect = (value: string, label: string) => {\n return (\n <FormControlLabel\n value={value}\n control={<Radio size=\"small\" />}\n label={label}\n />\n );\n};\n\nexport const filterKeys = [\n 'orderBy',\n 'order',\n 'noAnswers',\n 'noCorrectAnswer',\n 'noVotes',\n 'tags',\n 'dateRange',\n] as const;\nexport type FilterKey = (typeof filterKeys)[number];\n\nexport type Filters = {\n order?: 'asc' | 'desc';\n orderBy?: string;\n searchQuery?: string;\n entities?: string[];\n entitiesRelation?: 'and' | 'or';\n entity?: string;\n tags?: string[];\n tagsRelation?: 'and' | 'or';\n dateRange?: string;\n};\n\nexport type PostFilters = Filters & {\n orderBy?:\n | 'rank'\n | 'created'\n | 'title'\n | 'views'\n | 'score'\n | 'trend'\n | 'answersCount'\n | 'updated';\n noAnswers?: 'true' | 'false';\n noCorrectAnswer?: 'true' | 'false';\n noVotes?: 'true' | 'false';\n collectionId?: number;\n type?: PostType;\n};\n\nexport type AnswerFilters = Filters & {\n orderBy?: 'created' | 'score' | 'updated';\n noVotes?: 'true' | 'false';\n noCorrectAnswer?: 'true' | 'false';\n};\n\nexport type CollectionFilters = Filters & {\n orderBy?: 'created' | 'title';\n};\n\nfunction isPostFilters(filters: Filters): filters is PostFilters {\n return (filters as PostFilters).noAnswers !== undefined;\n}\n\nfunction isAnswerFilters(filters: Filters): filters is AnswerFilters {\n return (\n (filters as AnswerFilters).noVotes !== undefined &&\n (filters as PostFilters).noAnswers === undefined\n );\n}\n\nfunction isCollectionFilters(filters: Filters): filters is CollectionFilters {\n return (filters as PostFilters).noAnswers === undefined;\n}\n\nexport type Change<T extends Filters> = {\n key: keyof T;\n value: string | string[];\n};\n\nexport interface FilterPanelProps<T extends Filters> {\n onChange: (changes: Change<T> | Change<T>[]) => void;\n filters: T;\n showEntityFilter?: boolean;\n showTagFilter?: boolean;\n answerFilters?: boolean;\n type?: PostType;\n}\n\nexport const FilterPanel = <T extends Filters>(props: FilterPanelProps<T>) => {\n const {\n onChange,\n filters,\n showEntityFilter = true,\n showTagFilter = true,\n type,\n } = props;\n const { t } = useTranslation();\n const [entities, setEntities] = React.useState<Entity[] | undefined>(\n undefined,\n );\n const [starredEntities, setStarredEntities] = React.useState(false);\n const [ownedEntities, setOwnedEntities] = React.useState(false);\n const starredEntitiesApi = useStarredEntities();\n const catalogApi = useApi(catalogApiRef);\n const identityApi = useApi(identityApiRef);\n\n const handleChange = (event: {\n target: {\n value: string | string[];\n type?: string;\n name: string;\n checked?: boolean;\n };\n }) => {\n let value = event.target.value;\n if (event.target.type === 'checkbox') {\n value = event.target.checked ? 'true' : 'false';\n }\n onChange({ key: event.target.name as keyof T, value });\n };\n\n const handleStarredEntities = (checked: boolean) => {\n setStarredEntities(checked);\n setEntities([]);\n if (checked) {\n onChange({\n key: 'entities',\n value: [...starredEntitiesApi.starredEntities],\n });\n } else {\n onChange({ key: 'entities', value: [] });\n }\n };\n\n const handleOwnedEntities = (checked: boolean) => {\n setOwnedEntities(checked);\n setEntities([]);\n if (checked) {\n identityApi.getBackstageIdentity().then(identity => {\n catalogApi\n .getEntities({\n filter: {\n 'spec.owner': identity.ownershipEntityRefs,\n },\n fields: ['kind', 'metadata.name', 'metadata.namespace'],\n })\n .then(data => {\n const entityRefs = data.items.map(e => stringifyEntityRef(e));\n onChange([\n { key: 'entities', value: entityRefs },\n { key: 'entitiesRelation', value: 'or' },\n ]);\n });\n });\n } else {\n onChange([\n { key: 'entities', value: [] },\n { key: 'entitiesRelation', value: 'and' },\n ]);\n }\n };\n\n const postFilters = isPostFilters(filters);\n const answerFilters = isAnswerFilters(filters);\n const collectionFilters = isCollectionFilters(filters);\n\n return (\n <Box\n marginTop={2}\n sx={theme => ({\n border: `1px solid ${theme.palette.action.selected}`,\n borderRadius: 1,\n padding: 3,\n })}\n >\n <Grid\n container\n spacing={4}\n alignItems=\"stretch\"\n justifyContent=\"space-evenly\"\n >\n {(postFilters || answerFilters) && (\n <Grid item>\n <FormGroup>\n <FormLabel id=\"qeta-filter-quick\">\n {t('filterPanel.quickFilters.label')}\n </FormLabel>\n {postFilters && type !== 'article' && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"noAnswers\"\n onChange={handleChange}\n checked={filters.noAnswers === 'true'}\n />\n }\n label={t('filterPanel.noAnswers.label')}\n />\n )}\n {(postFilters || answerFilters) && type !== 'article' && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"noCorrectAnswer\"\n checked={filters.noCorrectAnswer === 'true'}\n onChange={handleChange}\n />\n }\n label={t('filterPanel.noCorrectAnswers.label')}\n />\n )}\n {(postFilters || answerFilters) && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"noVotes\"\n checked={filters.noVotes === 'true'}\n onChange={handleChange}\n />\n }\n label={t('filterPanel.noVotes.label')}\n />\n )}\n {starredEntitiesApi.starredEntities.size > 0 && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"starredEntities\"\n onChange={e => handleStarredEntities(e.target.checked)}\n checked={starredEntities}\n />\n }\n label={t('filterPanel.starredEntities.label')}\n />\n )}\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"ownedEntities\"\n onChange={e => handleOwnedEntities(e.target.checked)}\n checked={ownedEntities}\n />\n }\n label={t('filterPanel.ownedEntities.label')}\n />\n </FormGroup>\n </Grid>\n )}\n <Grid item>\n <FormControl>\n <FormLabel id=\"qeta-filter-order-by\">\n {t('filterPanel.orderBy.label')}\n </FormLabel>\n <RadioGroup\n aria-labelledby=\"qeta-filter-order-by\"\n name=\"orderBy\"\n value={filters.orderBy}\n onChange={handleChange}\n style={{\n display: 'grid',\n gridTemplateColumns: '1fr 1fr',\n gap: '0 1em',\n }}\n >\n {postFilters &&\n filters.collectionId !== undefined &&\n radioSelect('rank', t('filterPanel.orderBy.rank'))}\n {radioSelect('created', t('filterPanel.orderBy.created'))}\n {(postFilters || collectionFilters) &&\n radioSelect('title', t('filterPanel.orderBy.title'))}\n {postFilters &&\n radioSelect('views', t('filterPanel.orderBy.views'))}\n {(postFilters || answerFilters) &&\n radioSelect('score', t('filterPanel.orderBy.score'))}\n {postFilters &&\n radioSelect('trend', t('filterPanel.orderBy.trend'))}\n {postFilters &&\n type !== 'article' &&\n radioSelect('answersCount', t('filterPanel.orderBy.answers'))}\n {(postFilters || answerFilters) &&\n radioSelect('updated', t('filterPanel.orderBy.updated'))}\n </RadioGroup>\n </FormControl>\n </Grid>\n <Grid item>\n <FormControl>\n <FormLabel id=\"qeta-filter-order\">\n {t('filterPanel.order.label')}\n </FormLabel>\n <RadioGroup\n aria-labelledby=\"qeta-filter-order\"\n name=\"order\"\n value={filters.order}\n onChange={handleChange}\n >\n {radioSelect('desc', t('filterPanel.order.desc'))}\n {radioSelect('asc', t('filterPanel.order.asc'))}\n </RadioGroup>\n </FormControl>\n </Grid>\n </Grid>\n <Box marginY=\"24px\">\n <Divider />\n </Box>\n <Grid container alignItems=\"stretch\" justifyContent=\"space-evenly\">\n <Grid item>\n <DateRangeFilter\n value={filters.dateRange}\n onChange={val => onChange({ key: 'dateRange', value: val })}\n />\n </Grid>\n {showEntityFilter && (\n <Grid item>\n <Grid container alignItems=\"center\">\n <Grid item>\n <EntitiesInput\n disabled={starredEntities || ownedEntities}\n style={{ minWidth: '200px' }}\n onChange={(newEntities?: Entity[]) => {\n const entityRefs = (newEntities ?? []).map(e =>\n stringifyEntityRef(e),\n );\n handleChange({\n target: { name: 'entities', value: entityRefs },\n });\n setEntities(newEntities);\n }}\n value={entities}\n useOnlyUsedEntities\n hideHelpText\n />\n </Grid>\n {filters.entities && filters.entities?.length > 1 && (\n <Grid item>\n <Tooltip\n title={\n filters.entitiesRelation === 'or'\n ? t('filterPanel.toggleEntityRelation.and')\n : t('filterPanel.toggleEntityRelation.or')\n }\n >\n <IconButton\n disabled={starredEntities || ownedEntities}\n onClick={() => {\n if (filters.entitiesRelation === 'or') {\n onChange({ key: 'entitiesRelation', value: 'and' });\n } else {\n onChange({ key: 'entitiesRelation', value: 'or' });\n }\n }}\n size=\"large\"\n >\n {filters.entitiesRelation === 'or' ? (\n <AdjustIcon />\n ) : (\n <FiberManualRecordIcon />\n )}\n </IconButton>\n </Tooltip>\n </Grid>\n )}\n </Grid>\n </Grid>\n )}\n {showTagFilter && (\n <Grid item>\n <Grid container alignItems=\"center\">\n <Grid item>\n <TagInput\n style={{ minWidth: '200px' }}\n onChange={(newTags: string[]) =>\n onChange({ key: 'tags', value: newTags })\n }\n value={filters.tags}\n hideHelpText\n allowCreate={false}\n />\n </Grid>\n {filters.tags && filters.tags?.length > 1 && (\n <Grid item>\n <Tooltip\n title={\n filters.tagsRelation === 'or'\n ? t('filterPanel.toggleTagRelation.and')\n : t('filterPanel.toggleTagRelation.or')\n }\n >\n <IconButton\n onClick={() => {\n if (filters.tagsRelation === 'or') {\n onChange({ key: 'tagsRelation', value: 'and' });\n } else {\n onChange({ key: 'tagsRelation', value: 'or' });\n }\n }}\n size=\"large\"\n >\n {filters.tagsRelation === 'or' ? (\n <AdjustIcon />\n ) : (\n <FiberManualRecordIcon />\n )}\n </IconButton>\n </Tooltip>\n </Grid>\n )}\n </Grid>\n </Grid>\n )}\n </Grid>\n </Box>\n );\n};\n"],"names":["React"],"mappings":"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"}
1
+ {"version":3,"file":"FilterPanel.esm.js","sources":["../../../src/components/FilterPanel/FilterPanel.tsx"],"sourcesContent":["import React from 'react';\nimport { Entity, stringifyEntityRef } from '@backstage/catalog-model';\nimport { DateRangeFilter } from './DateRangeFilter';\nimport { PostType } from '@drodil/backstage-plugin-qeta-common';\nimport { useTranslation } from '../../hooks';\nimport { EntitiesInput } from '../PostForm/EntitiesInput';\nimport { TagInput } from '../PostForm/TagInput';\nimport {\n catalogApiRef,\n useStarredEntities,\n} from '@backstage/plugin-catalog-react';\nimport { identityApiRef, useApi } from '@backstage/core-plugin-api';\nimport {\n Box,\n Checkbox,\n Divider,\n FormControl,\n FormControlLabel,\n FormGroup,\n FormLabel,\n Grid,\n IconButton,\n Radio,\n RadioGroup,\n Tooltip,\n} from '@material-ui/core';\nimport AdjustIcon from '@material-ui/icons/Adjust';\nimport FiberManualRecordIcon from '@material-ui/icons/FiberManualRecord';\n\nconst radioSelect = (value: string, label: string) => {\n return (\n <FormControlLabel\n value={value}\n control={<Radio size=\"small\" />}\n label={label}\n />\n );\n};\n\nexport const filterKeys = [\n 'orderBy',\n 'order',\n 'noAnswers',\n 'noCorrectAnswer',\n 'noVotes',\n 'tags',\n 'dateRange',\n] as const;\nexport type FilterKey = (typeof filterKeys)[number];\n\nexport type Filters = {\n order?: 'asc' | 'desc';\n orderBy?: string;\n searchQuery?: string;\n entities?: string[];\n entitiesRelation?: 'and' | 'or';\n entity?: string;\n tags?: string[];\n tagsRelation?: 'and' | 'or';\n dateRange?: string;\n};\n\nexport type PostFilters = Filters & {\n orderBy?:\n | 'rank'\n | 'created'\n | 'title'\n | 'views'\n | 'score'\n | 'trend'\n | 'answersCount'\n | 'updated';\n noAnswers?: 'true' | 'false';\n noCorrectAnswer?: 'true' | 'false';\n noVotes?: 'true' | 'false';\n collectionId?: number;\n type?: PostType;\n};\n\nexport type AnswerFilters = Filters & {\n orderBy?: 'created' | 'score' | 'updated';\n noVotes?: 'true' | 'false';\n noCorrectAnswer?: 'true' | 'false';\n};\n\nexport type CollectionFilters = Filters & {\n orderBy?: 'created' | 'title';\n};\n\nfunction isPostFilters(filters: Filters): filters is PostFilters {\n return (filters as PostFilters).noAnswers !== undefined;\n}\n\nfunction isAnswerFilters(filters: Filters): filters is AnswerFilters {\n return (\n (filters as AnswerFilters).noVotes !== undefined &&\n (filters as PostFilters).noAnswers === undefined\n );\n}\n\nfunction isCollectionFilters(filters: Filters): filters is CollectionFilters {\n return (filters as PostFilters).noAnswers === undefined;\n}\n\nexport type Change<T extends Filters> = {\n key: keyof T;\n value: string | string[];\n};\n\nexport interface FilterPanelProps<T extends Filters> {\n onChange: (changes: Change<T> | Change<T>[]) => void;\n filters: T;\n showEntityFilter?: boolean;\n showTagFilter?: boolean;\n answerFilters?: boolean;\n type?: PostType;\n}\n\nexport const FilterPanel = <T extends Filters>(props: FilterPanelProps<T>) => {\n const {\n onChange,\n filters,\n showEntityFilter = true,\n showTagFilter = true,\n type,\n } = props;\n const { t } = useTranslation();\n const [entities, setEntities] = React.useState<Entity[] | undefined>(\n undefined,\n );\n const [starredEntities, setStarredEntities] = React.useState(false);\n const [ownedEntities, setOwnedEntities] = React.useState(false);\n const starredEntitiesApi = useStarredEntities();\n const catalogApi = useApi(catalogApiRef);\n const identityApi = useApi(identityApiRef);\n\n const handleChange = (event: {\n target: {\n value: string | string[];\n type?: string;\n name: string;\n checked?: boolean;\n };\n }) => {\n let value = event.target.value;\n if (event.target.type === 'checkbox') {\n value = event.target.checked ? 'true' : 'false';\n }\n onChange({ key: event.target.name as keyof T, value });\n };\n\n const handleStarredEntities = (checked: boolean) => {\n setStarredEntities(checked);\n setEntities([]);\n if (checked) {\n onChange({\n key: 'entities',\n value: [...starredEntitiesApi.starredEntities],\n });\n } else {\n onChange({ key: 'entities', value: [] });\n }\n };\n\n const handleOwnedEntities = (checked: boolean) => {\n setOwnedEntities(checked);\n setEntities([]);\n if (checked) {\n identityApi.getBackstageIdentity().then(identity => {\n catalogApi\n .getEntities({\n filter: {\n 'spec.owner': identity.ownershipEntityRefs,\n },\n fields: ['kind', 'metadata.name', 'metadata.namespace'],\n })\n .then(data => {\n const entityRefs = data.items.map(e => stringifyEntityRef(e));\n onChange([\n { key: 'entities', value: entityRefs },\n { key: 'entitiesRelation', value: 'or' },\n ]);\n });\n });\n } else {\n onChange([\n { key: 'entities', value: [] },\n { key: 'entitiesRelation', value: 'and' },\n ]);\n }\n };\n\n const postFilters = isPostFilters(filters);\n const answerFilters = isAnswerFilters(filters);\n const collectionFilters = isCollectionFilters(filters);\n\n return (\n <Box>\n <Grid\n container\n spacing={4}\n alignItems=\"stretch\"\n justifyContent=\"space-evenly\"\n >\n {(postFilters || answerFilters) && (\n <Grid item>\n <FormGroup>\n <FormLabel id=\"qeta-filter-quick\">\n {t('filterPanel.quickFilters.label')}\n </FormLabel>\n {postFilters && type !== 'article' && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"noAnswers\"\n onChange={handleChange}\n checked={filters.noAnswers === 'true'}\n />\n }\n label={t('filterPanel.noAnswers.label')}\n />\n )}\n {(postFilters || answerFilters) && type !== 'article' && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"noCorrectAnswer\"\n checked={filters.noCorrectAnswer === 'true'}\n onChange={handleChange}\n />\n }\n label={t('filterPanel.noCorrectAnswers.label')}\n />\n )}\n {(postFilters || answerFilters) && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"noVotes\"\n checked={filters.noVotes === 'true'}\n onChange={handleChange}\n />\n }\n label={t('filterPanel.noVotes.label')}\n />\n )}\n {starredEntitiesApi.starredEntities.size > 0 && (\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"starredEntities\"\n onChange={e => handleStarredEntities(e.target.checked)}\n checked={starredEntities}\n />\n }\n label={t('filterPanel.starredEntities.label')}\n />\n )}\n <FormControlLabel\n control={\n <Checkbox\n size=\"small\"\n name=\"ownedEntities\"\n onChange={e => handleOwnedEntities(e.target.checked)}\n checked={ownedEntities}\n />\n }\n label={t('filterPanel.ownedEntities.label')}\n />\n </FormGroup>\n </Grid>\n )}\n <Grid item>\n <FormControl>\n <FormLabel id=\"qeta-filter-order-by\">\n {t('filterPanel.orderBy.label')}\n </FormLabel>\n <RadioGroup\n aria-labelledby=\"qeta-filter-order-by\"\n name=\"orderBy\"\n value={filters.orderBy}\n onChange={handleChange}\n style={{\n display: 'grid',\n gridTemplateColumns: '1fr 1fr',\n gap: '0 1em',\n }}\n >\n {postFilters &&\n filters.collectionId !== undefined &&\n radioSelect('rank', t('filterPanel.orderBy.rank'))}\n {radioSelect('created', t('filterPanel.orderBy.created'))}\n {(postFilters || collectionFilters) &&\n radioSelect('title', t('filterPanel.orderBy.title'))}\n {postFilters &&\n radioSelect('views', t('filterPanel.orderBy.views'))}\n {(postFilters || answerFilters) &&\n radioSelect('score', t('filterPanel.orderBy.score'))}\n {postFilters &&\n radioSelect('trend', t('filterPanel.orderBy.trend'))}\n {postFilters &&\n type !== 'article' &&\n radioSelect('answersCount', t('filterPanel.orderBy.answers'))}\n {(postFilters || answerFilters) &&\n radioSelect('updated', t('filterPanel.orderBy.updated'))}\n </RadioGroup>\n </FormControl>\n </Grid>\n <Grid item>\n <FormControl>\n <FormLabel id=\"qeta-filter-order\">\n {t('filterPanel.order.label')}\n </FormLabel>\n <RadioGroup\n aria-labelledby=\"qeta-filter-order\"\n name=\"order\"\n value={filters.order}\n onChange={handleChange}\n >\n {radioSelect('desc', t('filterPanel.order.desc'))}\n {radioSelect('asc', t('filterPanel.order.asc'))}\n </RadioGroup>\n </FormControl>\n </Grid>\n </Grid>\n <Box marginY=\"24px\">\n <Divider />\n </Box>\n <Grid container alignItems=\"stretch\" justifyContent=\"space-evenly\">\n <Grid item>\n <DateRangeFilter\n value={filters.dateRange}\n onChange={val => onChange({ key: 'dateRange', value: val })}\n />\n </Grid>\n {showEntityFilter && (\n <Grid item>\n <Grid container alignItems=\"center\">\n <Grid item>\n <EntitiesInput\n disabled={starredEntities || ownedEntities}\n style={{ minWidth: '200px' }}\n onChange={(newEntities?: Entity[]) => {\n const entityRefs = (newEntities ?? []).map(e =>\n stringifyEntityRef(e),\n );\n handleChange({\n target: { name: 'entities', value: entityRefs },\n });\n setEntities(newEntities);\n }}\n value={entities}\n useOnlyUsedEntities\n hideHelpText\n />\n </Grid>\n {filters.entities && filters.entities?.length > 1 && (\n <Grid item>\n <Tooltip\n title={\n filters.entitiesRelation === 'or'\n ? t('filterPanel.toggleEntityRelation.and')\n : t('filterPanel.toggleEntityRelation.or')\n }\n >\n <IconButton\n disabled={starredEntities || ownedEntities}\n onClick={() => {\n if (filters.entitiesRelation === 'or') {\n onChange({ key: 'entitiesRelation', value: 'and' });\n } else {\n onChange({ key: 'entitiesRelation', value: 'or' });\n }\n }}\n >\n {filters.entitiesRelation === 'or' ? (\n <AdjustIcon />\n ) : (\n <FiberManualRecordIcon />\n )}\n </IconButton>\n </Tooltip>\n </Grid>\n )}\n </Grid>\n </Grid>\n )}\n {showTagFilter && (\n <Grid item>\n <Grid container alignItems=\"center\">\n <Grid item>\n <TagInput\n style={{ minWidth: '200px' }}\n onChange={(newTags: string[]) =>\n onChange({ key: 'tags', value: newTags })\n }\n value={filters.tags}\n hideHelpText\n allowCreate={false}\n />\n </Grid>\n {filters.tags && filters.tags?.length > 1 && (\n <Grid item>\n <Tooltip\n title={\n filters.tagsRelation === 'or'\n ? t('filterPanel.toggleTagRelation.and')\n : t('filterPanel.toggleTagRelation.or')\n }\n >\n <IconButton\n onClick={() => {\n if (filters.tagsRelation === 'or') {\n onChange({ key: 'tagsRelation', value: 'and' });\n } else {\n onChange({ key: 'tagsRelation', value: 'or' });\n }\n }}\n >\n {filters.tagsRelation === 'or' ? (\n <AdjustIcon />\n ) : (\n <FiberManualRecordIcon />\n )}\n </IconButton>\n </Tooltip>\n </Grid>\n )}\n </Grid>\n </Grid>\n )}\n </Grid>\n </Box>\n );\n};\n"],"names":["React"],"mappings":"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"}
@@ -1,4 +1,3 @@
1
- import ListItem from '@mui/material/ListItem';
2
1
  import React__default from 'react';
3
2
  import '@backstage/core-plugin-api';
4
3
  import '../../api.esm.js';
@@ -7,7 +6,8 @@ import { useTranslation } from '../../hooks/useTranslation.esm.js';
7
6
  import 'react-use/lib/useAsync';
8
7
  import { useCollectionsFollow } from '../../hooks/useCollectionsFollow.esm.js';
9
8
  import { CollectionChip } from '../TagsAndEntities/CollectionChip.esm.js';
10
- import { RightListContainer, RightList } from '../Styled/RightList.esm.js';
9
+ import { RightListContainer, RightList } from '../Utility/RightList.esm.js';
10
+ import { ListItem } from '@material-ui/core';
11
11
 
12
12
  const FollowedCollectionsList = () => {
13
13
  const collections = useCollectionsFollow();
@@ -1 +1 @@
1
- {"version":3,"file":"FollowedCollectionsList.esm.js","sources":["../../../src/components/FollowedLists/FollowedCollectionsList.tsx"],"sourcesContent":["import ListItem from '@mui/material/ListItem';\nimport React from 'react';\nimport { useTranslation } from '../../hooks';\nimport { useCollectionsFollow } from '../../hooks/useCollectionsFollow';\nimport { CollectionChip } from '../TagsAndEntities/CollectionChip';\nimport { RightList, RightListContainer } from '../Styled/RightList';\n\nexport const FollowedCollectionsList = () => {\n const collections = useCollectionsFollow();\n const { t } = useTranslation();\n\n if (collections.collections.length === 0 || collections.loading) {\n return null;\n }\n\n return (\n <RightListContainer>\n <RightList title={t('rightMenu.followedCollections')}>\n <ListItem style={{ display: 'block' }} dense>\n {collections.collections.map(collection => (\n <CollectionChip key={collection.id} collection={collection} />\n ))}\n </ListItem>\n </RightList>\n </RightListContainer>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;AAOO,MAAM,0BAA0B,MAAM;AAC3C,EAAA,MAAM,cAAc,oBAAqB,EAAA;AACzC,EAAM,MAAA,EAAE,CAAE,EAAA,GAAI,cAAe,EAAA;AAE7B,EAAA,IAAI,WAAY,CAAA,WAAA,CAAY,MAAW,KAAA,CAAA,IAAK,YAAY,OAAS,EAAA;AAC/D,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACGA,cAAA,CAAA,aAAA,CAAA,kBAAA,EAAA,IAAA,kBACEA,cAAA,CAAA,aAAA,CAAA,SAAA,EAAA,EAAU,KAAO,EAAA,CAAA,CAAE,+BAA+B,CAAA,EAAA,kBAChDA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAS,KAAO,EAAA,EAAE,SAAS,OAAQ,EAAA,EAAG,KAAK,EAAA,IAAA,EAAA,EACzC,WAAY,CAAA,WAAA,CAAY,GAAI,CAAA,CAAA,UAAA,qBAC1BA,cAAA,CAAA,aAAA,CAAA,cAAA,EAAA,EAAe,GAAK,EAAA,UAAA,CAAW,EAAI,EAAA,UAAA,EAAwB,CAC7D,CACH,CACF,CACF,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"FollowedCollectionsList.esm.js","sources":["../../../src/components/FollowedLists/FollowedCollectionsList.tsx"],"sourcesContent":["import React from 'react';\nimport { useTranslation } from '../../hooks';\nimport { useCollectionsFollow } from '../../hooks/useCollectionsFollow';\nimport { CollectionChip } from '../TagsAndEntities/CollectionChip';\nimport { RightList, RightListContainer } from '../Utility/RightList';\nimport { ListItem } from '@material-ui/core';\n\nexport const FollowedCollectionsList = () => {\n const collections = useCollectionsFollow();\n const { t } = useTranslation();\n\n if (collections.collections.length === 0 || collections.loading) {\n return null;\n }\n\n return (\n <RightListContainer>\n <RightList title={t('rightMenu.followedCollections')}>\n <ListItem style={{ display: 'block' }} dense>\n {collections.collections.map(collection => (\n <CollectionChip key={collection.id} collection={collection} />\n ))}\n </ListItem>\n </RightList>\n </RightListContainer>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;AAOO,MAAM,0BAA0B,MAAM;AAC3C,EAAA,MAAM,cAAc,oBAAqB,EAAA;AACzC,EAAM,MAAA,EAAE,CAAE,EAAA,GAAI,cAAe,EAAA;AAE7B,EAAA,IAAI,WAAY,CAAA,WAAA,CAAY,MAAW,KAAA,CAAA,IAAK,YAAY,OAAS,EAAA;AAC/D,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACGA,cAAA,CAAA,aAAA,CAAA,kBAAA,EAAA,IAAA,kBACEA,cAAA,CAAA,aAAA,CAAA,SAAA,EAAA,EAAU,KAAO,EAAA,CAAA,CAAE,+BAA+B,CAAA,EAAA,kBAChDA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAS,KAAO,EAAA,EAAE,SAAS,OAAQ,EAAA,EAAG,KAAK,EAAA,IAAA,EAAA,EACzC,WAAY,CAAA,WAAA,CAAY,GAAI,CAAA,CAAA,UAAA,qBAC1BA,cAAA,CAAA,aAAA,CAAA,cAAA,EAAA,EAAe,GAAK,EAAA,UAAA,CAAW,EAAI,EAAA,UAAA,EAAwB,CAC7D,CACH,CACF,CACF,CAAA;AAEJ;;;;"}
@@ -1,4 +1,3 @@
1
- import ListItem from '@mui/material/ListItem';
2
1
  import React__default from 'react';
3
2
  import { EntityChip } from '../TagsAndEntities/EntityChip.esm.js';
4
3
  import '@backstage/core-plugin-api';
@@ -7,7 +6,8 @@ import 'react-use';
7
6
  import { useTranslation } from '../../hooks/useTranslation.esm.js';
8
7
  import { useEntityFollow } from '../../hooks/useEntityFollow.esm.js';
9
8
  import 'react-use/lib/useAsync';
10
- import { RightListContainer, RightList } from '../Styled/RightList.esm.js';
9
+ import { RightListContainer, RightList } from '../Utility/RightList.esm.js';
10
+ import { ListItem } from '@material-ui/core';
11
11
 
12
12
  const FollowedEntitiesList = () => {
13
13
  const entities = useEntityFollow();
@@ -1 +1 @@
1
- {"version":3,"file":"FollowedEntitiesList.esm.js","sources":["../../../src/components/FollowedLists/FollowedEntitiesList.tsx"],"sourcesContent":["import ListItem from '@mui/material/ListItem';\nimport React from 'react';\nimport { EntityChip } from '../TagsAndEntities/EntityChip';\nimport { useEntityFollow, useTranslation } from '../../hooks';\nimport { RightList, RightListContainer } from '../Styled/RightList';\n\nexport const FollowedEntitiesList = () => {\n const entities = useEntityFollow();\n const { t } = useTranslation();\n\n if (entities.entities.length === 0 || entities.loading) {\n return null;\n }\n\n return (\n <RightListContainer>\n <RightList title={t('rightMenu.followedEntities')}>\n <ListItem style={{ display: 'block' }} dense>\n {entities.entities.map(entity => (\n <EntityChip key={entity} entity={entity} />\n ))}\n </ListItem>\n </RightList>\n </RightListContainer>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;AAMO,MAAM,uBAAuB,MAAM;AACxC,EAAA,MAAM,WAAW,eAAgB,EAAA;AACjC,EAAM,MAAA,EAAE,CAAE,EAAA,GAAI,cAAe,EAAA;AAE7B,EAAA,IAAI,QAAS,CAAA,QAAA,CAAS,MAAW,KAAA,CAAA,IAAK,SAAS,OAAS,EAAA;AACtD,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACGA,cAAA,CAAA,aAAA,CAAA,kBAAA,EAAA,IAAA,kBACEA,cAAA,CAAA,aAAA,CAAA,SAAA,EAAA,EAAU,KAAO,EAAA,CAAA,CAAE,4BAA4B,CAAA,EAAA,kBAC7CA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAS,KAAO,EAAA,EAAE,OAAS,EAAA,OAAA,EAAW,EAAA,KAAA,EAAK,IACzC,EAAA,EAAA,QAAA,CAAS,QAAS,CAAA,GAAA,CAAI,CACrB,MAAA,qBAAAA,cAAA,CAAA,aAAA,CAAC,UAAW,EAAA,EAAA,GAAA,EAAK,MAAQ,EAAA,MAAA,EAAgB,CAC1C,CACH,CACF,CACF,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"FollowedEntitiesList.esm.js","sources":["../../../src/components/FollowedLists/FollowedEntitiesList.tsx"],"sourcesContent":["import React from 'react';\nimport { EntityChip } from '../TagsAndEntities/EntityChip';\nimport { useEntityFollow, useTranslation } from '../../hooks';\nimport { RightList, RightListContainer } from '../Utility/RightList';\nimport { ListItem } from '@material-ui/core';\n\nexport const FollowedEntitiesList = () => {\n const entities = useEntityFollow();\n const { t } = useTranslation();\n\n if (entities.entities.length === 0 || entities.loading) {\n return null;\n }\n\n return (\n <RightListContainer>\n <RightList title={t('rightMenu.followedEntities')}>\n <ListItem style={{ display: 'block' }} dense>\n {entities.entities.map(entity => (\n <EntityChip key={entity} entity={entity} />\n ))}\n </ListItem>\n </RightList>\n </RightListContainer>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;AAMO,MAAM,uBAAuB,MAAM;AACxC,EAAA,MAAM,WAAW,eAAgB,EAAA;AACjC,EAAM,MAAA,EAAE,CAAE,EAAA,GAAI,cAAe,EAAA;AAE7B,EAAA,IAAI,QAAS,CAAA,QAAA,CAAS,MAAW,KAAA,CAAA,IAAK,SAAS,OAAS,EAAA;AACtD,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACGA,cAAA,CAAA,aAAA,CAAA,kBAAA,EAAA,IAAA,kBACEA,cAAA,CAAA,aAAA,CAAA,SAAA,EAAA,EAAU,KAAO,EAAA,CAAA,CAAE,4BAA4B,CAAA,EAAA,kBAC7CA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAS,KAAO,EAAA,EAAE,OAAS,EAAA,OAAA,EAAW,EAAA,KAAA,EAAK,IACzC,EAAA,EAAA,QAAA,CAAS,QAAS,CAAA,GAAA,CAAI,CACrB,MAAA,qBAAAA,cAAA,CAAA,aAAA,CAAC,UAAW,EAAA,EAAA,GAAA,EAAK,MAAQ,EAAA,MAAA,EAAgB,CAC1C,CACH,CACF,CACF,CAAA;AAEJ;;;;"}
@@ -1,4 +1,3 @@
1
- import ListItem from '@mui/material/ListItem';
2
1
  import React__default from 'react';
3
2
  import { TagChip } from '../TagsAndEntities/TagChip.esm.js';
4
3
  import '@backstage/core-plugin-api';
@@ -7,7 +6,8 @@ import 'react-use';
7
6
  import { useTagsFollow } from '../../hooks/useTagsFollow.esm.js';
8
7
  import { useTranslation } from '../../hooks/useTranslation.esm.js';
9
8
  import 'react-use/lib/useAsync';
10
- import { RightListContainer, RightList } from '../Styled/RightList.esm.js';
9
+ import { RightListContainer, RightList } from '../Utility/RightList.esm.js';
10
+ import { ListItem } from '@material-ui/core';
11
11
 
12
12
  const FollowedTagsList = () => {
13
13
  const tags = useTagsFollow();
@@ -1 +1 @@
1
- {"version":3,"file":"FollowedTagsList.esm.js","sources":["../../../src/components/FollowedLists/FollowedTagsList.tsx"],"sourcesContent":["import ListItem from '@mui/material/ListItem';\nimport React from 'react';\nimport { TagChip } from '../TagsAndEntities/TagChip';\nimport { useTagsFollow, useTranslation } from '../../hooks';\nimport { RightList, RightListContainer } from '../Styled/RightList';\n\nexport const FollowedTagsList = () => {\n const tags = useTagsFollow();\n const { t } = useTranslation();\n\n if (tags.tags.length === 0 || tags.loading) {\n return null;\n }\n\n return (\n <RightListContainer>\n <RightList title={t('rightMenu.followedTags')}>\n <ListItem style={{ display: 'block' }} dense>\n {tags.tags.map(tag => (\n <TagChip key={tag} tag={tag} />\n ))}\n </ListItem>\n </RightList>\n </RightListContainer>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;AAMO,MAAM,mBAAmB,MAAM;AACpC,EAAA,MAAM,OAAO,aAAc,EAAA;AAC3B,EAAM,MAAA,EAAE,CAAE,EAAA,GAAI,cAAe,EAAA;AAE7B,EAAA,IAAI,IAAK,CAAA,IAAA,CAAK,MAAW,KAAA,CAAA,IAAK,KAAK,OAAS,EAAA;AAC1C,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACGA,cAAA,CAAA,aAAA,CAAA,kBAAA,EAAA,IAAA,kBACEA,cAAA,CAAA,aAAA,CAAA,SAAA,EAAA,EAAU,KAAO,EAAA,CAAA,CAAE,wBAAwB,CAAA,EAAA,kBACzCA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAS,KAAO,EAAA,EAAE,OAAS,EAAA,OAAA,EAAW,EAAA,KAAA,EAAK,IACzC,EAAA,EAAA,IAAA,CAAK,IAAK,CAAA,GAAA,CAAI,CACb,GAAA,qBAAAA,cAAA,CAAA,aAAA,CAAC,OAAQ,EAAA,EAAA,GAAA,EAAK,GAAK,EAAA,GAAA,EAAU,CAC9B,CACH,CACF,CACF,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"FollowedTagsList.esm.js","sources":["../../../src/components/FollowedLists/FollowedTagsList.tsx"],"sourcesContent":["import React from 'react';\nimport { TagChip } from '../TagsAndEntities/TagChip';\nimport { useTagsFollow, useTranslation } from '../../hooks';\nimport { RightList, RightListContainer } from '../Utility/RightList';\nimport { ListItem } from '@material-ui/core';\n\nexport const FollowedTagsList = () => {\n const tags = useTagsFollow();\n const { t } = useTranslation();\n\n if (tags.tags.length === 0 || tags.loading) {\n return null;\n }\n\n return (\n <RightListContainer>\n <RightList title={t('rightMenu.followedTags')}>\n <ListItem style={{ display: 'block' }} dense>\n {tags.tags.map(tag => (\n <TagChip key={tag} tag={tag} />\n ))}\n </ListItem>\n </RightList>\n </RightListContainer>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;;;AAMO,MAAM,mBAAmB,MAAM;AACpC,EAAA,MAAM,OAAO,aAAc,EAAA;AAC3B,EAAM,MAAA,EAAE,CAAE,EAAA,GAAI,cAAe,EAAA;AAE7B,EAAA,IAAI,IAAK,CAAA,IAAA,CAAK,MAAW,KAAA,CAAA,IAAK,KAAK,OAAS,EAAA;AAC1C,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACGA,cAAA,CAAA,aAAA,CAAA,kBAAA,EAAA,IAAA,kBACEA,cAAA,CAAA,aAAA,CAAA,SAAA,EAAA,EAAU,KAAO,EAAA,CAAA,CAAE,wBAAwB,CAAA,EAAA,kBACzCA,cAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAS,KAAO,EAAA,EAAE,OAAS,EAAA,OAAA,EAAW,EAAA,KAAA,EAAK,IACzC,EAAA,EAAA,IAAA,CAAK,IAAK,CAAA,GAAA,CAAI,CACb,GAAA,qBAAAA,cAAA,CAAA,aAAA,CAAC,OAAQ,EAAA,EAAA,GAAA,EAAK,GAAK,EAAA,GAAA,EAAU,CAC9B,CACH,CACF,CACF,CAAA;AAEJ;;;;"}