@drodil/backstage-plugin-qeta 3.48.2 → 3.49.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.
- package/dist/components/ArticlePage/ArticlePage.esm.js +14 -6
- package/dist/components/ArticlePage/ArticlePage.esm.js.map +1 -1
- package/dist/components/ArticlesPage/ArticlesPage.esm.js +29 -24
- package/dist/components/ArticlesPage/ArticlesPage.esm.js.map +1 -1
- package/dist/components/AskPage/AskPage.esm.js +18 -3
- package/dist/components/AskPage/AskPage.esm.js.map +1 -1
- package/dist/components/CollectionPage/CollectionPage.esm.js +79 -15
- package/dist/components/CollectionPage/CollectionPage.esm.js.map +1 -1
- package/dist/components/CollectionsPage/CollectionsPage.esm.js +11 -14
- package/dist/components/CollectionsPage/CollectionsPage.esm.js.map +1 -1
- package/dist/components/CreateLinkPage/CreateLinkPage.esm.js +2 -2
- package/dist/components/CreateLinkPage/CreateLinkPage.esm.js.map +1 -1
- package/dist/components/EntityPage/EntityPage.esm.js +110 -123
- package/dist/components/EntityPage/EntityPage.esm.js.map +1 -1
- package/dist/components/EntityPostsContent/EntityPostsContent.esm.js +2 -2
- package/dist/components/EntityPostsContent/EntityPostsContent.esm.js.map +1 -1
- package/dist/components/FavoritePage/FavoritePage.esm.js +34 -31
- package/dist/components/FavoritePage/FavoritePage.esm.js.map +1 -1
- package/dist/components/HomePage/HomePage.esm.js +34 -35
- package/dist/components/HomePage/HomePage.esm.js.map +1 -1
- package/dist/components/LinkPage/LinkPage.esm.js +22 -25
- package/dist/components/LinkPage/LinkPage.esm.js.map +1 -1
- package/dist/components/LinksPage/LinksPage.esm.js +24 -25
- package/dist/components/LinksPage/LinksPage.esm.js.map +1 -1
- package/dist/components/ModeratorPage/ModeratorPage.esm.js +11 -5
- package/dist/components/ModeratorPage/ModeratorPage.esm.js.map +1 -1
- package/dist/components/PostsTableCard/Content.esm.js +2 -2
- package/dist/components/PostsTableCard/Content.esm.js.map +1 -1
- package/dist/components/QetaPage/QetaPage.esm.js +192 -164
- package/dist/components/QetaPage/QetaPage.esm.js.map +1 -1
- package/dist/components/QetaSearchResultListItem/QetaSearchResultListItem.esm.js +2 -2
- package/dist/components/QetaSearchResultListItem/QetaSearchResultListItem.esm.js.map +1 -1
- package/dist/components/QuestionPage/QuestionPage.esm.js +27 -9
- package/dist/components/QuestionPage/QuestionPage.esm.js.map +1 -1
- package/dist/components/QuestionsPage/QuestionsPage.esm.js +13 -54
- package/dist/components/QuestionsPage/QuestionsPage.esm.js.map +1 -1
- package/dist/components/RightContent/ArticlesRightContent.esm.js +31 -0
- package/dist/components/RightContent/ArticlesRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/AskRightContent.esm.js +16 -0
- package/dist/components/RightContent/AskRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/CollectionsRightContent.esm.js +12 -0
- package/dist/components/RightContent/CollectionsRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/DefaultRightContent.esm.js +27 -0
- package/dist/components/RightContent/DefaultRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/EntitiesRightContent.esm.js +12 -0
- package/dist/components/RightContent/EntitiesRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/EntityRightContent.esm.js +47 -0
- package/dist/components/RightContent/EntityRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/FavoriteRightContent.esm.js +9 -0
- package/dist/components/RightContent/FavoriteRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/HomeRightContent.esm.js +15 -0
- package/dist/components/RightContent/HomeRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/LinksRightContent.esm.js +31 -0
- package/dist/components/RightContent/LinksRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/QuestionsRightContent.esm.js +57 -0
- package/dist/components/RightContent/QuestionsRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/RightContent.esm.js +203 -0
- package/dist/components/RightContent/RightContent.esm.js.map +1 -0
- package/dist/components/RightContent/SimilarQuestions.esm.js +58 -0
- package/dist/components/RightContent/SimilarQuestions.esm.js.map +1 -0
- package/dist/components/RightContent/TagRightContent.esm.js +48 -0
- package/dist/components/RightContent/TagRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/TagsRightContent.esm.js +12 -0
- package/dist/components/RightContent/TagsRightContent.esm.js.map +1 -0
- package/dist/components/RightContent/UsersRightContent.esm.js +12 -0
- package/dist/components/RightContent/UsersRightContent.esm.js.map +1 -0
- package/dist/components/Statistics/GlobalStatsContent.esm.js +15 -9
- package/dist/components/Statistics/GlobalStatsContent.esm.js.map +1 -1
- package/dist/components/Statistics/StatisticsPage.esm.js +28 -11
- package/dist/components/Statistics/StatisticsPage.esm.js.map +1 -1
- package/dist/components/TagPage/TagPage.esm.js +75 -107
- package/dist/components/TagPage/TagPage.esm.js.map +1 -1
- package/dist/components/UserPage/UserPage.esm.js +34 -22
- package/dist/components/UserPage/UserPage.esm.js.map +1 -1
- package/dist/components/UserPage/UserStatsContent.esm.js +12 -9
- package/dist/components/UserPage/UserStatsContent.esm.js.map +1 -1
- package/dist/components/UsersPage/UsersPage.esm.js +12 -13
- package/dist/components/UsersPage/UsersPage.esm.js.map +1 -1
- package/dist/components/WritePage/WritePage.esm.js +2 -2
- package/dist/components/WritePage/WritePage.esm.js.map +1 -1
- package/dist/hooks/useSidebarSettings.esm.js +23 -0
- package/dist/hooks/useSidebarSettings.esm.js.map +1 -0
- package/dist/package.json.esm.js +1 -1
- package/package.json +3 -3
|
@@ -2,11 +2,12 @@ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
|
2
2
|
import { useParams } from 'react-router-dom';
|
|
3
3
|
import { useState, useEffect } from 'react';
|
|
4
4
|
import { useSignal } from '@backstage/plugin-signals-react';
|
|
5
|
-
import { WarningPanel
|
|
6
|
-
import { qetaTranslationRef, useQetaApi,
|
|
5
|
+
import { WarningPanel } from '@backstage/core-components';
|
|
6
|
+
import { qetaTranslationRef, useQetaApi, ContentHeader, WriteArticleButton, AddToCollectionButton, AIAnswerCard, ArticleContent } from '@drodil/backstage-plugin-qeta-react';
|
|
7
7
|
import { Container } from '@material-ui/core';
|
|
8
8
|
import { Skeleton } from '@material-ui/lab';
|
|
9
9
|
import { useTranslationRef } from '@backstage/core-plugin-api/alpha';
|
|
10
|
+
import LibraryBooksOutlined from '@material-ui/icons/LibraryBooksOutlined';
|
|
10
11
|
|
|
11
12
|
const ArticlePage = () => {
|
|
12
13
|
const { id } = useParams();
|
|
@@ -38,10 +39,17 @@ const ArticlePage = () => {
|
|
|
38
39
|
return /* @__PURE__ */ jsx(WarningPanel, { title: "Not found", message: t("articlePage.notFound") });
|
|
39
40
|
}
|
|
40
41
|
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
41
|
-
/* @__PURE__ */
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
42
|
+
/* @__PURE__ */ jsxs(
|
|
43
|
+
ContentHeader,
|
|
44
|
+
{
|
|
45
|
+
title: post.title,
|
|
46
|
+
titleIcon: /* @__PURE__ */ jsx(LibraryBooksOutlined, { fontSize: "large" }),
|
|
47
|
+
children: [
|
|
48
|
+
/* @__PURE__ */ jsx(WriteArticleButton, {}),
|
|
49
|
+
/* @__PURE__ */ jsx(AddToCollectionButton, { post })
|
|
50
|
+
]
|
|
51
|
+
}
|
|
52
|
+
),
|
|
45
53
|
/* @__PURE__ */ jsxs(Container, { maxWidth: false, children: [
|
|
46
54
|
/* @__PURE__ */ jsx(
|
|
47
55
|
AIAnswerCard,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArticlePage.esm.js","sources":["../../../src/components/ArticlePage/ArticlePage.tsx"],"sourcesContent":["import { useParams } from 'react-router-dom';\nimport { useEffect, useState } from 'react';\nimport { useSignal } from '@backstage/plugin-signals-react';\nimport {
|
|
1
|
+
{"version":3,"file":"ArticlePage.esm.js","sources":["../../../src/components/ArticlePage/ArticlePage.tsx"],"sourcesContent":["import { useParams } from 'react-router-dom';\nimport { useEffect, useState } from 'react';\nimport { useSignal } from '@backstage/plugin-signals-react';\nimport { WarningPanel } from '@backstage/core-components';\nimport { Article, QetaSignal } from '@drodil/backstage-plugin-qeta-common';\nimport {\n AddToCollectionButton,\n AIAnswerCard,\n ArticleContent,\n ContentHeader,\n qetaTranslationRef,\n useQetaApi,\n WriteArticleButton,\n} from '@drodil/backstage-plugin-qeta-react';\nimport { Container } from '@material-ui/core';\nimport { Skeleton } from '@material-ui/lab';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\nimport LibraryBooksOutlined from '@material-ui/icons/LibraryBooksOutlined';\n\nexport const ArticlePage = () => {\n const { id } = useParams();\n const { t } = useTranslationRef(qetaTranslationRef);\n\n const [views, setViews] = useState(0);\n\n const { lastSignal } = useSignal<QetaSignal>(`qeta:post_${id}`);\n\n const {\n value: post,\n loading,\n error,\n } = useQetaApi(api => api.getPost(id), [id]);\n\n useEffect(() => {\n if (post) {\n setViews(post.views);\n }\n }, [post]);\n\n useEffect(() => {\n if (lastSignal?.type === 'post_stats') {\n setViews(lastSignal.views);\n }\n }, [lastSignal]);\n\n if (loading) {\n return <Skeleton variant=\"rect\" height={200} />;\n }\n\n if (error || post === undefined) {\n return (\n <WarningPanel severity=\"error\" title={t('articlePage.errorLoading')}>\n {error?.message}\n </WarningPanel>\n );\n }\n\n if (post.type !== 'article') {\n return (\n <WarningPanel title=\"Not found\" message={t('articlePage.notFound')} />\n );\n }\n\n return (\n <>\n <ContentHeader\n title={post.title}\n titleIcon={<LibraryBooksOutlined fontSize=\"large\" />}\n >\n <WriteArticleButton />\n <AddToCollectionButton post={post} />\n </ContentHeader>\n <Container maxWidth={false}>\n <AIAnswerCard\n article={post as Article}\n style={{ marginBottom: '2em' }}\n />\n <ArticleContent post={post} views={views} />\n </Container>\n </>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;;;AAmBO,MAAM,cAAc,MAAM;AAC/B,EAAM,MAAA,EAAE,EAAG,EAAA,GAAI,SAAU,EAAA;AACzB,EAAA,MAAM,EAAE,CAAA,EAAM,GAAA,iBAAA,CAAkB,kBAAkB,CAAA;AAElD,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAI,SAAS,CAAC,CAAA;AAEpC,EAAA,MAAM,EAAE,UAAW,EAAA,GAAI,SAAsB,CAAA,CAAA,UAAA,EAAa,EAAE,CAAE,CAAA,CAAA;AAE9D,EAAM,MAAA;AAAA,IACJ,KAAO,EAAA,IAAA;AAAA,IACP,OAAA;AAAA,IACA;AAAA,GACF,GAAI,WAAW,CAAO,GAAA,KAAA,GAAA,CAAI,QAAQ,EAAE,CAAA,EAAG,CAAC,EAAE,CAAC,CAAA;AAE3C,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,IAAM,EAAA;AACR,MAAA,QAAA,CAAS,KAAK,KAAK,CAAA;AAAA;AACrB,GACF,EAAG,CAAC,IAAI,CAAC,CAAA;AAET,EAAA,SAAA,CAAU,MAAM;AACd,IAAI,IAAA,UAAA,EAAY,SAAS,YAAc,EAAA;AACrC,MAAA,QAAA,CAAS,WAAW,KAAK,CAAA;AAAA;AAC3B,GACF,EAAG,CAAC,UAAU,CAAC,CAAA;AAEf,EAAA,IAAI,OAAS,EAAA;AACX,IAAA,uBAAQ,GAAA,CAAA,QAAA,EAAA,EAAS,OAAQ,EAAA,MAAA,EAAO,QAAQ,GAAK,EAAA,CAAA;AAAA;AAG/C,EAAI,IAAA,KAAA,IAAS,SAAS,KAAW,CAAA,EAAA;AAC/B,IACE,uBAAA,GAAA,CAAC,gBAAa,QAAS,EAAA,OAAA,EAAQ,OAAO,CAAE,CAAA,0BAA0B,CAC/D,EAAA,QAAA,EAAA,KAAA,EAAO,OACV,EAAA,CAAA;AAAA;AAIJ,EAAI,IAAA,IAAA,CAAK,SAAS,SAAW,EAAA;AAC3B,IAAA,2BACG,YAAa,EAAA,EAAA,KAAA,EAAM,aAAY,OAAS,EAAA,CAAA,CAAE,sBAAsB,CAAG,EAAA,CAAA;AAAA;AAIxE,EAAA,uBAEI,IAAA,CAAA,QAAA,EAAA,EAAA,QAAA,EAAA;AAAA,oBAAA,IAAA;AAAA,MAAC,aAAA;AAAA,MAAA;AAAA,QACC,OAAO,IAAK,CAAA,KAAA;AAAA,QACZ,SAAW,kBAAA,GAAA,CAAC,oBAAqB,EAAA,EAAA,QAAA,EAAS,OAAQ,EAAA,CAAA;AAAA,QAElD,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,kBAAmB,EAAA,EAAA,CAAA;AAAA,0BACpB,GAAA,CAAC,yBAAsB,IAAY,EAAA;AAAA;AAAA;AAAA,KACrC;AAAA,oBACA,IAAA,CAAC,SAAU,EAAA,EAAA,QAAA,EAAU,KACnB,EAAA,QAAA,EAAA;AAAA,sBAAA,GAAA;AAAA,QAAC,YAAA;AAAA,QAAA;AAAA,UACC,OAAS,EAAA,IAAA;AAAA,UACT,KAAA,EAAO,EAAE,YAAA,EAAc,KAAM;AAAA;AAAA,OAC/B;AAAA,sBACA,GAAA,CAAC,cAAe,EAAA,EAAA,IAAA,EAAY,KAAc,EAAA;AAAA,KAC5C,EAAA;AAAA,GACF,EAAA,CAAA;AAEJ;;;;"}
|
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
1
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
2
2
|
import { useSearchParams } from 'react-router-dom';
|
|
3
3
|
import { useState, useEffect } from 'react';
|
|
4
|
-
import { ContentHeader } from '@backstage
|
|
5
|
-
import { qetaTranslationRef, ButtonContainer, WriteArticleButton, PostsGrid, PostsContainer, PostHighlightList, FollowedTagsList, FollowedEntitiesList } from '@drodil/backstage-plugin-qeta-react';
|
|
4
|
+
import { qetaTranslationRef, ContentHeader, WriteArticleButton, PostsGrid, PostsContainer } from '@drodil/backstage-plugin-qeta-react';
|
|
6
5
|
import { filterTags } from '@drodil/backstage-plugin-qeta-common';
|
|
7
|
-
import
|
|
8
|
-
import {
|
|
6
|
+
import LibraryBooksOutlined from '@material-ui/icons/LibraryBooksOutlined';
|
|
7
|
+
import { Typography } from '@material-ui/core';
|
|
9
8
|
import { useTranslationRef } from '@backstage/core-plugin-api/alpha';
|
|
10
9
|
|
|
11
10
|
const ArticlesPage = () => {
|
|
@@ -18,25 +17,31 @@ const ArticlesPage = () => {
|
|
|
18
17
|
setEntityRef(searchParams.get("entity") ?? void 0);
|
|
19
18
|
setTags(filterTags(searchParams.get("tags")));
|
|
20
19
|
}, [searchParams, setEntityRef]);
|
|
21
|
-
return /* @__PURE__ */ jsxs(
|
|
22
|
-
/* @__PURE__ */
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
20
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
21
|
+
/* @__PURE__ */ jsx(
|
|
22
|
+
ContentHeader,
|
|
23
|
+
{
|
|
24
|
+
titleComponent: /* @__PURE__ */ jsxs(
|
|
25
|
+
Typography,
|
|
26
|
+
{
|
|
27
|
+
variant: "h4",
|
|
28
|
+
style: { display: "flex", alignItems: "center" },
|
|
29
|
+
children: [
|
|
30
|
+
/* @__PURE__ */ jsx(
|
|
31
|
+
LibraryBooksOutlined,
|
|
32
|
+
{
|
|
33
|
+
fontSize: "large",
|
|
34
|
+
style: { marginRight: "8px" }
|
|
35
|
+
}
|
|
36
|
+
),
|
|
37
|
+
t("articlesPage.title")
|
|
38
|
+
]
|
|
39
|
+
}
|
|
40
|
+
),
|
|
41
|
+
children: /* @__PURE__ */ jsx(WriteArticleButton, { entity: entityRef, tags })
|
|
42
|
+
}
|
|
43
|
+
),
|
|
44
|
+
view === "grid" ? /* @__PURE__ */ jsx(PostsGrid, { type: "article", view, onViewChange: setView }) : /* @__PURE__ */ jsx(PostsContainer, { type: "article", view, onViewChange: setView })
|
|
40
45
|
] });
|
|
41
46
|
};
|
|
42
47
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArticlesPage.esm.js","sources":["../../../src/components/ArticlesPage/ArticlesPage.tsx"],"sourcesContent":["import { useSearchParams } from 'react-router-dom';\nimport { useEffect, useState } from 'react';\nimport {
|
|
1
|
+
{"version":3,"file":"ArticlesPage.esm.js","sources":["../../../src/components/ArticlesPage/ArticlesPage.tsx"],"sourcesContent":["import { useSearchParams } from 'react-router-dom';\nimport { useEffect, useState } from 'react';\nimport {\n ContentHeader,\n PostsGrid,\n PostsContainer,\n qetaTranslationRef,\n WriteArticleButton,\n ViewType,\n} from '@drodil/backstage-plugin-qeta-react';\nimport { filterTags } from '@drodil/backstage-plugin-qeta-common';\nimport LibraryBooksOutlined from '@material-ui/icons/LibraryBooksOutlined';\nimport { Typography } from '@material-ui/core';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nexport const ArticlesPage = () => {\n const [searchParams] = useSearchParams();\n const [view, setView] = useState<ViewType>('grid');\n\n const [entityRef, setEntityRef] = useState<string | undefined>(undefined);\n const [tags, setTags] = useState<string[] | undefined>(undefined);\n const { t } = useTranslationRef(qetaTranslationRef);\n useEffect(() => {\n setEntityRef(searchParams.get('entity') ?? undefined);\n setTags(filterTags(searchParams.get('tags')));\n }, [searchParams, setEntityRef]);\n\n return (\n <>\n <ContentHeader\n titleComponent={\n <Typography\n variant=\"h4\"\n style={{ display: 'flex', alignItems: 'center' }}\n >\n <LibraryBooksOutlined\n fontSize=\"large\"\n style={{ marginRight: '8px' }}\n />\n {t('articlesPage.title')}\n </Typography>\n }\n >\n <WriteArticleButton entity={entityRef} tags={tags} />\n </ContentHeader>\n {view === 'grid' ? (\n <PostsGrid type=\"article\" view={view} onViewChange={setView} />\n ) : (\n <PostsContainer type=\"article\" view={view} onViewChange={setView} />\n )}\n </>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;AAeO,MAAM,eAAe,MAAM;AAChC,EAAM,MAAA,CAAC,YAAY,CAAA,GAAI,eAAgB,EAAA;AACvC,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAI,SAAmB,MAAM,CAAA;AAEjD,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAI,SAA6B,KAAS,CAAA,CAAA;AACxE,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAI,SAA+B,KAAS,CAAA,CAAA;AAChE,EAAA,MAAM,EAAE,CAAA,EAAM,GAAA,iBAAA,CAAkB,kBAAkB,CAAA;AAClD,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,YAAA,CAAa,YAAa,CAAA,GAAA,CAAI,QAAQ,CAAA,IAAK,KAAS,CAAA,CAAA;AACpD,IAAA,OAAA,CAAQ,UAAW,CAAA,YAAA,CAAa,GAAI,CAAA,MAAM,CAAC,CAAC,CAAA;AAAA,GAC3C,EAAA,CAAC,YAAc,EAAA,YAAY,CAAC,CAAA;AAE/B,EAAA,uBAEI,IAAA,CAAA,QAAA,EAAA,EAAA,QAAA,EAAA;AAAA,oBAAA,GAAA;AAAA,MAAC,aAAA;AAAA,MAAA;AAAA,QACC,cACE,kBAAA,IAAA;AAAA,UAAC,UAAA;AAAA,UAAA;AAAA,YACC,OAAQ,EAAA,IAAA;AAAA,YACR,KAAO,EAAA,EAAE,OAAS,EAAA,MAAA,EAAQ,YAAY,QAAS,EAAA;AAAA,YAE/C,QAAA,EAAA;AAAA,8BAAA,GAAA;AAAA,gBAAC,oBAAA;AAAA,gBAAA;AAAA,kBACC,QAAS,EAAA,OAAA;AAAA,kBACT,KAAA,EAAO,EAAE,WAAA,EAAa,KAAM;AAAA;AAAA,eAC9B;AAAA,cACC,EAAE,oBAAoB;AAAA;AAAA;AAAA,SACzB;AAAA,QAGF,QAAC,kBAAA,GAAA,CAAA,kBAAA,EAAA,EAAmB,MAAQ,EAAA,SAAA,EAAW,IAAY,EAAA;AAAA;AAAA,KACrD;AAAA,IACC,SAAS,MACR,mBAAA,GAAA,CAAC,SAAU,EAAA,EAAA,IAAA,EAAK,WAAU,IAAY,EAAA,YAAA,EAAc,OAAS,EAAA,CAAA,uBAE5D,cAAe,EAAA,EAAA,IAAA,EAAK,SAAU,EAAA,IAAA,EAAY,cAAc,OAAS,EAAA;AAAA,GAEtE,EAAA,CAAA;AAEJ;;;;"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
|
-
import { Progress,
|
|
3
|
-
import { useState } from 'react';
|
|
4
|
-
import {
|
|
2
|
+
import { Progress, InfoCard } from '@backstage/core-components';
|
|
3
|
+
import { useState, useEffect } from 'react';
|
|
4
|
+
import { stringifyEntityRef } from '@backstage/catalog-model';
|
|
5
|
+
import { useAI, useQetaApi, useQetaContext, qetaTranslationRef, SelectTemplateList, ContentHeader, PostForm, AIAnswerCard } from '@drodil/backstage-plugin-qeta-react';
|
|
5
6
|
import { useParams, useSearchParams } from 'react-router-dom';
|
|
6
7
|
import { useEntityPresentation } from '@backstage/plugin-catalog-react';
|
|
7
8
|
import { filterTags } from '@drodil/backstage-plugin-qeta-common';
|
|
@@ -14,6 +15,12 @@ const AskPage = () => {
|
|
|
14
15
|
const { isNewQuestionsEnabled } = useAI();
|
|
15
16
|
const { value, loading } = useQetaApi((api) => api.getTemplates());
|
|
16
17
|
const [draft, setDraft] = useState(void 0);
|
|
18
|
+
const { setDraftQuestion } = useQetaContext();
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
return () => {
|
|
21
|
+
setDraftQuestion?.(void 0);
|
|
22
|
+
};
|
|
23
|
+
}, [setDraftQuestion]);
|
|
17
24
|
const [template, setTemplate] = useState(
|
|
18
25
|
void 0
|
|
19
26
|
);
|
|
@@ -48,6 +55,14 @@ const AskPage = () => {
|
|
|
48
55
|
) });
|
|
49
56
|
}
|
|
50
57
|
const handleFormChange = (data) => {
|
|
58
|
+
if (setDraftQuestion) {
|
|
59
|
+
setDraftQuestion({
|
|
60
|
+
title: data.title,
|
|
61
|
+
content: data.content,
|
|
62
|
+
tags: data.tags,
|
|
63
|
+
entities: data.entities?.map(stringifyEntityRef)
|
|
64
|
+
});
|
|
65
|
+
}
|
|
51
66
|
if (!isNewQuestionsEnabled) {
|
|
52
67
|
return;
|
|
53
68
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AskPage.esm.js","sources":["../../../src/components/AskPage/AskPage.tsx"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"AskPage.esm.js","sources":["../../../src/components/AskPage/AskPage.tsx"],"sourcesContent":["import { InfoCard, Progress } from '@backstage/core-components';\nimport { useEffect, useState } from 'react';\nimport { stringifyEntityRef } from '@backstage/catalog-model';\nimport {\n AIAnswerCard,\n ContentHeader,\n PostForm,\n qetaTranslationRef,\n QuestionFormValues,\n SelectTemplateList,\n useAI,\n useQetaApi,\n useQetaContext,\n} from '@drodil/backstage-plugin-qeta-react';\nimport { useParams, useSearchParams } from 'react-router-dom';\nimport { useEntityPresentation } from '@backstage/plugin-catalog-react';\nimport { filterTags, Template } from '@drodil/backstage-plugin-qeta-common';\nimport { Box, Grid } from '@material-ui/core';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nexport const AskPage = () => {\n const { id } = useParams();\n const [searchParams] = useSearchParams();\n const { isNewQuestionsEnabled } = useAI();\n const { value, loading } = useQetaApi(api => api.getTemplates());\n const [draft, setDraft] = useState<\n { title: string; content: string } | undefined\n >(undefined);\n const { setDraftQuestion } = useQetaContext();\n\n useEffect(() => {\n return () => {\n setDraftQuestion?.(undefined);\n };\n }, [setDraftQuestion]);\n\n const [template, setTemplate] = useState<Template | null | undefined>(\n undefined,\n );\n\n const entity = searchParams.get('entity') ?? undefined;\n const entityPage = searchParams.get('entityPage') === 'true';\n const questionTitle = searchParams.get('title') ?? undefined;\n const content = searchParams.get('content') ?? undefined;\n const tags = filterTags(searchParams.get('tags'));\n const { t } = useTranslationRef(qetaTranslationRef);\n let title;\n if (id) {\n title = t('askPage.title.existingQuestion');\n } else if (entity) {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const representation = useEntityPresentation(entity);\n title = t('askPage.title.entityQuestion', {\n entity: representation.primaryTitle,\n });\n } else {\n title = t('askPage.title.newQuestion');\n }\n\n if (loading) {\n return (\n <Box role=\"status\" aria-label={t('common.loading')}>\n <Progress />\n </Box>\n );\n }\n\n if (\n !id &&\n value &&\n value.templates &&\n value.total > 0 &&\n template === undefined\n ) {\n return (\n <Box role=\"region\" aria-label={t('askPage.templateSelection')}>\n <SelectTemplateList\n templates={value}\n onTemplateSelect={temp => setTemplate(temp)}\n aria-label={t('askPage.selectTemplate')}\n />\n </Box>\n );\n }\n\n const handleFormChange = (data: QuestionFormValues) => {\n if (setDraftQuestion) {\n setDraftQuestion({\n title: data.title,\n content: data.content,\n tags: data.tags,\n entities: data.entities?.map(stringifyEntityRef),\n });\n }\n if (!isNewQuestionsEnabled) {\n return;\n }\n setDraft({\n title: data.title,\n content: data.content,\n });\n };\n\n return (\n <>\n <ContentHeader title={title} />\n <Grid container spacing={3} direction=\"column\">\n <Grid item style={{ width: '100%' }}>\n <InfoCard>\n <PostForm\n id={id}\n entity={entity}\n entityPage={entityPage}\n tags={tags}\n type=\"question\"\n template={template}\n onFormChange={handleFormChange}\n aria-label={t('askPage.questionForm')}\n title={questionTitle}\n content={content}\n />\n <AIAnswerCard draft={draft} />\n </InfoCard>\n </Grid>\n </Grid>\n </>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,26 @@
|
|
|
1
1
|
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
|
-
import { useParams } from 'react-router-dom';
|
|
3
|
-
import { qetaTranslationRef, useQetaApi, CollectionFollowButton,
|
|
2
|
+
import { useParams, useNavigate } from 'react-router-dom';
|
|
3
|
+
import { qetaTranslationRef, collectionEditRouteRef, useQetaApi, CollectionFollowButton, ContentHeader, ContentHeaderCard, PostsGrid, DeleteModal } from '@drodil/backstage-plugin-qeta-react';
|
|
4
4
|
import { Skeleton } from '@material-ui/lab';
|
|
5
|
-
import { WarningPanel
|
|
6
|
-
import { Typography, Grid } from '@material-ui/core';
|
|
5
|
+
import { WarningPanel } from '@backstage/core-components';
|
|
6
|
+
import { Typography, Button, Grid } from '@material-ui/core';
|
|
7
7
|
import { useTranslationRef } from '@backstage/core-plugin-api/alpha';
|
|
8
|
+
import { useState } from 'react';
|
|
9
|
+
import EditIcon from '@material-ui/icons/Edit';
|
|
10
|
+
import DeleteIcon from '@material-ui/icons/Delete';
|
|
11
|
+
import PlaylistPlayIcon from '@material-ui/icons/PlaylistPlay';
|
|
12
|
+
import QuestionAnswerIcon from '@material-ui/icons/QuestionAnswer';
|
|
13
|
+
import PeopleIcon from '@material-ui/icons/People';
|
|
14
|
+
import { useRouteRef } from '@backstage/core-plugin-api';
|
|
8
15
|
|
|
9
16
|
const CollectionPage = () => {
|
|
10
17
|
const { id } = useParams();
|
|
11
18
|
const { t } = useTranslationRef(qetaTranslationRef);
|
|
19
|
+
const navigate = useNavigate();
|
|
20
|
+
const editCollectionRoute = useRouteRef(collectionEditRouteRef);
|
|
21
|
+
const [deleteModalOpen, setDeleteModalOpen] = useState(false);
|
|
22
|
+
const handleDeleteModalOpen = () => setDeleteModalOpen(true);
|
|
23
|
+
const handleDeleteModalClose = () => setDeleteModalOpen(false);
|
|
12
24
|
const {
|
|
13
25
|
value: collection,
|
|
14
26
|
loading,
|
|
@@ -20,7 +32,8 @@ const CollectionPage = () => {
|
|
|
20
32
|
if (error || collection === void 0) {
|
|
21
33
|
return /* @__PURE__ */ jsx(WarningPanel, { severity: "error", title: t("questionPage.errorLoading"), children: error?.message });
|
|
22
34
|
}
|
|
23
|
-
const title = /* @__PURE__ */ jsxs(Typography, { variant: "h5", component: "h2", children: [
|
|
35
|
+
const title = /* @__PURE__ */ jsxs(Typography, { variant: "h5", component: "h2", style: { display: "flex" }, children: [
|
|
36
|
+
/* @__PURE__ */ jsx(PlaylistPlayIcon, { fontSize: "large", style: { marginRight: "8px" } }),
|
|
24
37
|
collection.title,
|
|
25
38
|
/* @__PURE__ */ jsx(
|
|
26
39
|
CollectionFollowButton,
|
|
@@ -31,16 +44,59 @@ const CollectionPage = () => {
|
|
|
31
44
|
)
|
|
32
45
|
] });
|
|
33
46
|
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
34
|
-
/* @__PURE__ */
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
47
|
+
/* @__PURE__ */ jsxs(ContentHeader, { titleComponent: title, children: [
|
|
48
|
+
collection.canEdit && /* @__PURE__ */ jsx(
|
|
49
|
+
Button,
|
|
50
|
+
{
|
|
51
|
+
variant: "contained",
|
|
52
|
+
color: "primary",
|
|
53
|
+
startIcon: /* @__PURE__ */ jsx(EditIcon, {}),
|
|
54
|
+
onClick: () => editCollectionRoute && navigate(
|
|
55
|
+
editCollectionRoute({
|
|
56
|
+
id: collection.id.toString(10)
|
|
57
|
+
})
|
|
58
|
+
),
|
|
59
|
+
children: t("templateList.editButton")
|
|
60
|
+
}
|
|
61
|
+
),
|
|
62
|
+
collection.canDelete && /* @__PURE__ */ jsx(
|
|
63
|
+
Button,
|
|
64
|
+
{
|
|
65
|
+
variant: "outlined",
|
|
66
|
+
color: "secondary",
|
|
67
|
+
startIcon: /* @__PURE__ */ jsx(DeleteIcon, {}),
|
|
68
|
+
onClick: handleDeleteModalOpen,
|
|
69
|
+
children: t("templateList.deleteButton")
|
|
70
|
+
}
|
|
71
|
+
)
|
|
72
|
+
] }),
|
|
42
73
|
/* @__PURE__ */ jsxs(Grid, { container: true, children: [
|
|
43
|
-
/* @__PURE__ */ jsx(Grid, { item: true, xs: 12, children: /* @__PURE__ */ jsx(
|
|
74
|
+
/* @__PURE__ */ jsx(Grid, { item: true, xs: 12, children: /* @__PURE__ */ jsx(
|
|
75
|
+
ContentHeaderCard,
|
|
76
|
+
{
|
|
77
|
+
description: collection.description,
|
|
78
|
+
image: collection.headerImage,
|
|
79
|
+
imageIcon: /* @__PURE__ */ jsx(PlaylistPlayIcon, { style: { fontSize: 80 } }),
|
|
80
|
+
tagsAndEntities: { entity: collection },
|
|
81
|
+
stats: [
|
|
82
|
+
{
|
|
83
|
+
label: t("common.postsLabel", {
|
|
84
|
+
count: collection.postsCount,
|
|
85
|
+
itemType: "post"
|
|
86
|
+
}),
|
|
87
|
+
value: collection.postsCount,
|
|
88
|
+
icon: /* @__PURE__ */ jsx(QuestionAnswerIcon, { fontSize: "small" })
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
label: t("common.followersLabel", {
|
|
92
|
+
count: collection.followers
|
|
93
|
+
}),
|
|
94
|
+
value: collection.followers,
|
|
95
|
+
icon: /* @__PURE__ */ jsx(PeopleIcon, { fontSize: "small" })
|
|
96
|
+
}
|
|
97
|
+
]
|
|
98
|
+
}
|
|
99
|
+
) }),
|
|
44
100
|
/* @__PURE__ */ jsx(Grid, { item: true, xs: 12, children: /* @__PURE__ */ jsx(
|
|
45
101
|
PostsGrid,
|
|
46
102
|
{
|
|
@@ -49,7 +105,15 @@ const CollectionPage = () => {
|
|
|
49
105
|
allowRanking: collection.canEdit
|
|
50
106
|
}
|
|
51
107
|
) })
|
|
52
|
-
] })
|
|
108
|
+
] }),
|
|
109
|
+
collection.canDelete && /* @__PURE__ */ jsx(
|
|
110
|
+
DeleteModal,
|
|
111
|
+
{
|
|
112
|
+
open: deleteModalOpen,
|
|
113
|
+
onClose: handleDeleteModalClose,
|
|
114
|
+
entity: collection
|
|
115
|
+
}
|
|
116
|
+
)
|
|
53
117
|
] });
|
|
54
118
|
};
|
|
55
119
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CollectionPage.esm.js","sources":["../../../src/components/CollectionPage/CollectionPage.tsx"],"sourcesContent":["import { useParams } from 'react-router-dom';\nimport {\n
|
|
1
|
+
{"version":3,"file":"CollectionPage.esm.js","sources":["../../../src/components/CollectionPage/CollectionPage.tsx"],"sourcesContent":["import { useParams } from 'react-router-dom';\nimport {\n CollectionFollowButton,\n ContentHeader,\n DeleteModal,\n PostsGrid,\n collectionEditRouteRef,\n qetaTranslationRef,\n useQetaApi,\n} from '@drodil/backstage-plugin-qeta-react';\nimport { Skeleton } from '@material-ui/lab';\nimport { WarningPanel } from '@backstage/core-components';\nimport { Button, Grid, Typography } from '@material-ui/core';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\nimport { useState } from 'react';\nimport EditIcon from '@material-ui/icons/Edit';\nimport DeleteIcon from '@material-ui/icons/Delete';\nimport PlaylistPlayIcon from '@material-ui/icons/PlaylistPlay';\nimport QuestionAnswerIcon from '@material-ui/icons/QuestionAnswer';\nimport PeopleIcon from '@material-ui/icons/People';\nimport { useNavigate } from 'react-router-dom';\nimport { ContentHeaderCard } from '@drodil/backstage-plugin-qeta-react';\nimport { useRouteRef } from '@backstage/core-plugin-api';\n\nexport const CollectionPage = () => {\n const { id } = useParams();\n const { t } = useTranslationRef(qetaTranslationRef);\n const navigate = useNavigate();\n const editCollectionRoute = useRouteRef(collectionEditRouteRef);\n const [deleteModalOpen, setDeleteModalOpen] = useState(false);\n const handleDeleteModalOpen = () => setDeleteModalOpen(true);\n const handleDeleteModalClose = () => setDeleteModalOpen(false);\n\n const {\n value: collection,\n loading,\n error,\n } = useQetaApi(api => api.getCollection(id), [id]);\n\n if (loading) {\n return <Skeleton variant=\"rect\" height={200} />;\n }\n\n if (error || collection === undefined) {\n return (\n <WarningPanel severity=\"error\" title={t('questionPage.errorLoading')}>\n {error?.message}\n </WarningPanel>\n );\n }\n\n const title = (\n <Typography variant=\"h5\" component=\"h2\" style={{ display: 'flex' }}>\n <PlaylistPlayIcon fontSize=\"large\" style={{ marginRight: '8px' }} />\n {collection.title}\n <CollectionFollowButton\n collection={collection}\n style={{ marginLeft: '0.5em' }}\n />\n </Typography>\n );\n\n return (\n <>\n <ContentHeader titleComponent={title}>\n {collection.canEdit && (\n <Button\n variant=\"contained\"\n color=\"primary\"\n startIcon={<EditIcon />}\n onClick={() =>\n editCollectionRoute &&\n navigate(\n editCollectionRoute({\n id: collection.id.toString(10),\n }),\n )\n }\n >\n {t('templateList.editButton')}\n </Button>\n )}\n {collection.canDelete && (\n <Button\n variant=\"outlined\"\n color=\"secondary\"\n startIcon={<DeleteIcon />}\n onClick={handleDeleteModalOpen}\n >\n {t('templateList.deleteButton')}\n </Button>\n )}\n </ContentHeader>\n <Grid container>\n <Grid item xs={12}>\n <ContentHeaderCard\n description={collection.description}\n image={collection.headerImage}\n imageIcon={<PlaylistPlayIcon style={{ fontSize: 80 }} />}\n tagsAndEntities={{ entity: collection }}\n stats={[\n {\n label: t('common.postsLabel', {\n count: collection.postsCount,\n itemType: 'post',\n }),\n value: collection.postsCount,\n icon: <QuestionAnswerIcon fontSize=\"small\" />,\n },\n {\n label: t('common.followersLabel', {\n count: collection.followers,\n }),\n value: collection.followers,\n icon: <PeopleIcon fontSize=\"small\" />,\n },\n ]}\n />\n </Grid>\n <Grid item xs={12}>\n <PostsGrid\n collectionId={collection.id}\n orderBy=\"rank\"\n allowRanking={collection.canEdit}\n />\n </Grid>\n </Grid>\n {collection.canDelete && (\n <DeleteModal\n open={deleteModalOpen}\n onClose={handleDeleteModalClose}\n entity={collection}\n />\n )}\n </>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1,27 +1,24 @@
|
|
|
1
|
-
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
-
import { ContentHeader } from '@backstage
|
|
3
|
-
import
|
|
4
|
-
import { Grid } from '@material-ui/core';
|
|
1
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { qetaTranslationRef, ContentHeader, AskQuestionButton, WriteArticleButton, CreateLinkButton, CollectionsGrid } from '@drodil/backstage-plugin-qeta-react';
|
|
3
|
+
import PlaylistPlayOutlined from '@material-ui/icons/PlaylistPlayOutlined';
|
|
5
4
|
import { useTranslationRef } from '@backstage/core-plugin-api/alpha';
|
|
6
5
|
|
|
7
6
|
const CollectionsPage = () => {
|
|
8
7
|
const { t } = useTranslationRef(qetaTranslationRef);
|
|
9
|
-
|
|
10
|
-
return /* @__PURE__ */ jsxs(Grid, { container: true, spacing: 4, children: [
|
|
8
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
11
9
|
/* @__PURE__ */ jsxs(
|
|
12
|
-
|
|
10
|
+
ContentHeader,
|
|
13
11
|
{
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
lg: collections.collections.length > 0 ? 9 : 12,
|
|
17
|
-
xl: collections.collections.length > 0 ? 10 : 12,
|
|
12
|
+
title: t("collectionsPage.title"),
|
|
13
|
+
titleIcon: /* @__PURE__ */ jsx(PlaylistPlayOutlined, { fontSize: "large" }),
|
|
18
14
|
children: [
|
|
19
|
-
/* @__PURE__ */ jsx(
|
|
20
|
-
/* @__PURE__ */ jsx(
|
|
15
|
+
/* @__PURE__ */ jsx(AskQuestionButton, {}),
|
|
16
|
+
/* @__PURE__ */ jsx(WriteArticleButton, {}),
|
|
17
|
+
/* @__PURE__ */ jsx(CreateLinkButton, {})
|
|
21
18
|
]
|
|
22
19
|
}
|
|
23
20
|
),
|
|
24
|
-
/* @__PURE__ */ jsx(
|
|
21
|
+
/* @__PURE__ */ jsx(CollectionsGrid, {})
|
|
25
22
|
] });
|
|
26
23
|
};
|
|
27
24
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CollectionsPage.esm.js","sources":["../../../src/components/CollectionsPage/CollectionsPage.tsx"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"CollectionsPage.esm.js","sources":["../../../src/components/CollectionsPage/CollectionsPage.tsx"],"sourcesContent":["import {\n AskQuestionButton,\n ContentHeader,\n CreateLinkButton,\n CollectionsGrid,\n qetaTranslationRef,\n WriteArticleButton,\n} from '@drodil/backstage-plugin-qeta-react';\nimport PlaylistPlayOutlined from '@material-ui/icons/PlaylistPlayOutlined';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nexport const CollectionsPage = () => {\n const { t } = useTranslationRef(qetaTranslationRef);\n\n return (\n <>\n <ContentHeader\n title={t('collectionsPage.title')}\n titleIcon={<PlaylistPlayOutlined fontSize=\"large\" />}\n >\n <AskQuestionButton />\n <WriteArticleButton />\n <CreateLinkButton />\n </ContentHeader>\n <CollectionsGrid />\n </>\n );\n};\n"],"names":[],"mappings":";;;;;AAWO,MAAM,kBAAkB,MAAM;AACnC,EAAA,MAAM,EAAE,CAAA,EAAM,GAAA,iBAAA,CAAkB,kBAAkB,CAAA;AAElD,EAAA,uBAEI,IAAA,CAAA,QAAA,EAAA,EAAA,QAAA,EAAA;AAAA,oBAAA,IAAA;AAAA,MAAC,aAAA;AAAA,MAAA;AAAA,QACC,KAAA,EAAO,EAAE,uBAAuB,CAAA;AAAA,QAChC,SAAW,kBAAA,GAAA,CAAC,oBAAqB,EAAA,EAAA,QAAA,EAAS,OAAQ,EAAA,CAAA;AAAA,QAElD,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,iBAAkB,EAAA,EAAA,CAAA;AAAA,8BAClB,kBAAmB,EAAA,EAAA,CAAA;AAAA,8BACnB,gBAAiB,EAAA,EAAA;AAAA;AAAA;AAAA,KACpB;AAAA,wBACC,eAAgB,EAAA,EAAA;AAAA,GACnB,EAAA,CAAA;AAEJ;;;;"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
2
2
|
import { useParams, useSearchParams } from 'react-router-dom';
|
|
3
3
|
import { filterTags } from '@drodil/backstage-plugin-qeta-common';
|
|
4
|
-
import { qetaTranslationRef, PostForm } from '@drodil/backstage-plugin-qeta-react';
|
|
4
|
+
import { qetaTranslationRef, ContentHeader, PostForm } from '@drodil/backstage-plugin-qeta-react';
|
|
5
5
|
import { useEntityPresentation } from '@backstage/plugin-catalog-react';
|
|
6
|
-
import {
|
|
6
|
+
import { InfoCard } from '@backstage/core-components';
|
|
7
7
|
import { Grid } from '@material-ui/core';
|
|
8
8
|
import { useTranslationRef } from '@backstage/core-plugin-api/alpha';
|
|
9
9
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CreateLinkPage.esm.js","sources":["../../../src/components/CreateLinkPage/CreateLinkPage.tsx"],"sourcesContent":["import { useParams, useSearchParams } from 'react-router-dom';\nimport { filterTags } from '@drodil/backstage-plugin-qeta-common';\nimport {\n PostForm,\n qetaTranslationRef,\n} from '@drodil/backstage-plugin-qeta-react';\nimport { useEntityPresentation } from '@backstage/plugin-catalog-react';\nimport {
|
|
1
|
+
{"version":3,"file":"CreateLinkPage.esm.js","sources":["../../../src/components/CreateLinkPage/CreateLinkPage.tsx"],"sourcesContent":["import { useParams, useSearchParams } from 'react-router-dom';\nimport { filterTags } from '@drodil/backstage-plugin-qeta-common';\nimport {\n ContentHeader,\n PostForm,\n qetaTranslationRef,\n} from '@drodil/backstage-plugin-qeta-react';\nimport { useEntityPresentation } from '@backstage/plugin-catalog-react';\nimport { InfoCard } from '@backstage/core-components';\nimport { Grid } from '@material-ui/core';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nexport const CreateLinkPage = () => {\n const { id } = useParams();\n const [searchParams] = useSearchParams();\n const entity = searchParams.get('entity') ?? undefined;\n const entityPage = searchParams.get('entityPage') === 'true';\n const tags = filterTags(searchParams.get('tags'));\n const { t } = useTranslationRef(qetaTranslationRef);\n let title;\n if (id) {\n title = t('createLinkPage.title.existingLink');\n } else if (entity) {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const representation = useEntityPresentation(entity);\n title = t('createLinkPage.title.entityLink', {\n entity: representation.primaryTitle,\n });\n } else {\n title = t('createLinkPage.title.newLink');\n }\n\n return (\n <>\n <ContentHeader title={title} />\n <Grid container spacing={3} direction=\"column\">\n <Grid item>\n <InfoCard>\n <PostForm\n id={id}\n entity={entity}\n entityPage={entityPage}\n tags={tags}\n type=\"link\"\n />\n </InfoCard>\n </Grid>\n </Grid>\n </>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;AAYO,MAAM,iBAAiB,MAAM;AAClC,EAAM,MAAA,EAAE,EAAG,EAAA,GAAI,SAAU,EAAA;AACzB,EAAM,MAAA,CAAC,YAAY,CAAA,GAAI,eAAgB,EAAA;AACvC,EAAA,MAAM,MAAS,GAAA,YAAA,CAAa,GAAI,CAAA,QAAQ,CAAK,IAAA,KAAA,CAAA;AAC7C,EAAA,MAAM,UAAa,GAAA,YAAA,CAAa,GAAI,CAAA,YAAY,CAAM,KAAA,MAAA;AACtD,EAAA,MAAM,IAAO,GAAA,UAAA,CAAW,YAAa,CAAA,GAAA,CAAI,MAAM,CAAC,CAAA;AAChD,EAAA,MAAM,EAAE,CAAA,EAAM,GAAA,iBAAA,CAAkB,kBAAkB,CAAA;AAClD,EAAI,IAAA,KAAA;AACJ,EAAA,IAAI,EAAI,EAAA;AACN,IAAA,KAAA,GAAQ,EAAE,mCAAmC,CAAA;AAAA,aACpC,MAAQ,EAAA;AAEjB,IAAM,MAAA,cAAA,GAAiB,sBAAsB,MAAM,CAAA;AACnD,IAAA,KAAA,GAAQ,EAAE,iCAAmC,EAAA;AAAA,MAC3C,QAAQ,cAAe,CAAA;AAAA,KACxB,CAAA;AAAA,GACI,MAAA;AACL,IAAA,KAAA,GAAQ,EAAE,8BAA8B,CAAA;AAAA;AAG1C,EAAA,uBAEI,IAAA,CAAA,QAAA,EAAA,EAAA,QAAA,EAAA;AAAA,oBAAA,GAAA,CAAC,iBAAc,KAAc,EAAA,CAAA;AAAA,oBAC5B,GAAA,CAAA,IAAA,EAAA,EAAK,SAAS,EAAA,IAAA,EAAC,OAAS,EAAA,CAAA,EAAG,SAAU,EAAA,QAAA,EACpC,QAAC,kBAAA,GAAA,CAAA,IAAA,EAAA,EAAK,IAAI,EAAA,IAAA,EACR,8BAAC,QACC,EAAA,EAAA,QAAA,kBAAA,GAAA;AAAA,MAAC,QAAA;AAAA,MAAA;AAAA,QACC,EAAA;AAAA,QACA,MAAA;AAAA,QACA,UAAA;AAAA,QACA,IAAA;AAAA,QACA,IAAK,EAAA;AAAA;AAAA,KACP,EACF,GACF,CACF,EAAA;AAAA,GACF,EAAA,CAAA;AAEJ;;;;"}
|