@telia-ace/knowledge-widget-components-guide 1.0.23 → 1.0.24-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE.txt CHANGED
@@ -1,6 +1,6 @@
1
- Copyright © 2021, Telia Company AB. All rights reserved.
2
-
3
- THIS PACKAGE AND CONTAINING SOFTWARE IS PART OF
4
- THE HUMANY SERVICE. BY USING THIS SOFTWARE YOU
5
- AGREE TO THE FOLLOWING TERMS AND CONDITIONS:
1
+ Copyright © 2021, Telia Company AB. All rights reserved.
2
+
3
+ THIS PACKAGE AND CONTAINING SOFTWARE IS PART OF
4
+ THE HUMANY SERVICE. BY USING THIS SOFTWARE YOU
5
+ AGREE TO THE FOLLOWING TERMS AND CONDITIONS:
6
6
  http://www.humany.com/legal
package/README.md CHANGED
@@ -1,3 +1,3 @@
1
- # `@telia-ace/knowledge-widget-components-guide`
2
-
3
- Guide component for ACE Knowledge Widgets.
1
+ # `@telia-ace/knowledge-widget-components-guide`
2
+
3
+ Guide component for ACE Knowledge Widgets.
@@ -1,10 +1,10 @@
1
- import React from 'react';
2
- import { AvailablePerspectives, GuideProps } from './guide-component';
3
- declare type Props = {
4
- className?: string;
5
- defaultAnswerVersionLabel: string;
6
- availablePerspectives?: AvailablePerspectives[];
7
- guide: GuideProps;
8
- };
9
- declare const AnswerVersionPicker: React.FC<Props>;
10
- export default AnswerVersionPicker;
1
+ import React from 'react';
2
+ import { AvailablePerspectives, GuideProps } from './guide-component';
3
+ declare type Props = {
4
+ className?: string;
5
+ defaultAnswerVersionLabel: string;
6
+ availablePerspectives?: AvailablePerspectives[];
7
+ guide: GuideProps;
8
+ };
9
+ declare const AnswerVersionPicker: React.FC<Props>;
10
+ export default AnswerVersionPicker;
@@ -1,8 +1,8 @@
1
- import React from 'react';
2
- import { GuideProps, ToolbarProps } from './guide-component';
3
- declare type Props = {
4
- guide: GuideProps;
5
- toolbar: ToolbarProps;
6
- };
7
- declare const Categories: React.FC<Props>;
8
- export default Categories;
1
+ import React from 'react';
2
+ import { GuideProps, ToolbarProps } from './guide-component';
3
+ declare type Props = {
4
+ guide: GuideProps;
5
+ toolbar: ToolbarProps;
6
+ };
7
+ declare const Categories: React.FC<Props>;
8
+ export default Categories;
@@ -1,7 +1,7 @@
1
- import React from 'react';
2
- declare type Props = {
3
- backButtonShown?: boolean;
4
- accordion?: boolean;
5
- };
6
- declare const Feedback: React.SFC<Props>;
7
- export default Feedback;
1
+ import React from 'react';
2
+ declare type Props = {
3
+ backButtonShown?: boolean;
4
+ accordion?: boolean;
5
+ };
6
+ declare const Feedback: React.FC<Props>;
7
+ export default Feedback;
@@ -1,29 +1,29 @@
1
- import { PickerTypes } from '@telia-ace/knowledge-widget-core';
2
- import { DispatchAction } from '@telia-ace/knowledge-widget-ui';
3
- import React from 'react';
4
- import { GuideProps } from './guide-component';
5
- export declare type FunctionListItem = {
6
- type: string;
7
- child: React.ReactNode;
8
- };
9
- declare type Props = {
10
- header?: string;
11
- tooltip?: string;
12
- printActionLabel?: string;
13
- copyActionLabel?: string;
14
- addFavoriteTooltip?: string;
15
- removeFavoriteCancelLabel?: string;
16
- removeFavoriteConfirmLabel?: string;
17
- removeFavoriteHeader?: string;
18
- removeFavoriteLabel?: string;
19
- removeFavoriteTooltip?: string;
20
- toolbarFunctionsCloseButtonAriaLabel?: string;
21
- guide: GuideProps;
22
- allowCopy?: boolean;
23
- allowPrint?: boolean;
24
- showFavoriteToggle?: boolean;
25
- picker?: PickerTypes;
26
- dispatch: DispatchAction;
27
- };
28
- declare const Functions: React.FC<Props>;
29
- export default Functions;
1
+ import { PickerTypes } from '@telia-ace/knowledge-widget-core';
2
+ import { DispatchAction } from '@telia-ace/knowledge-widget-ui';
3
+ import React from 'react';
4
+ import { GuideProps } from './guide-component';
5
+ export declare type FunctionListItem = {
6
+ type: string;
7
+ child: React.ReactNode;
8
+ };
9
+ declare type Props = {
10
+ header?: string;
11
+ tooltip?: string;
12
+ printActionLabel?: string;
13
+ copyActionLabel?: string;
14
+ addFavoriteTooltip?: string;
15
+ removeFavoriteCancelLabel?: string;
16
+ removeFavoriteConfirmLabel?: string;
17
+ removeFavoriteHeader?: string;
18
+ removeFavoriteLabel?: string;
19
+ removeFavoriteTooltip?: string;
20
+ toolbarFunctionsCloseButtonAriaLabel?: string;
21
+ guide: GuideProps;
22
+ allowCopy?: boolean;
23
+ allowPrint?: boolean;
24
+ showFavoriteToggle?: boolean;
25
+ picker?: PickerTypes;
26
+ dispatch: DispatchAction;
27
+ };
28
+ declare const Functions: React.FC<Props>;
29
+ export default Functions;
@@ -1,69 +1,69 @@
1
- import { ContactMethodType } from '@telia-ace/knowledge-widget-adapters';
2
- import { FavoriteProperties, LanguageProperties, MetaDataProperties } from '@telia-ace/knowledge-widget-component-utilities';
3
- import { DialogItem, PickerTypes } from '@telia-ace/knowledge-widget-core';
4
- import { DataError } from '@telia-ace/knowledge-widget-types-grid';
5
- import { FormComponentInstanceProperties } from '@telia-ace/widget-forms';
6
- import { Container } from '@webprovisions/platform';
7
- export declare type GuideProps = {
8
- id: string;
9
- title: string;
10
- body: string;
11
- connection: string;
12
- categories: number[];
13
- hasHandover: boolean;
14
- allowFeedback: boolean;
15
- perspectives: {
16
- [key: string]: string;
17
- };
18
- translations?: {
19
- [key: string]: string;
20
- };
21
- modified?: string;
22
- published?: string;
23
- publishedBy?: string | null;
24
- modifiedBy?: string | null;
25
- perspective: string | null;
26
- };
27
- export declare type AvailablePerspectives = {
28
- name: string;
29
- title: string;
30
- };
31
- export declare type GuideComponentProps = {
32
- showHeader?: boolean;
33
- showFeedback?: boolean;
34
- feedbackDirection?: 'horizontal' | 'vertical';
35
- feedbackGiven?: 'positive' | 'negative';
36
- contactMethods?: ContactMethodType[];
37
- handoverContactMethods?: ContactMethodType[];
38
- showAnswerVersions?: boolean;
39
- feedbackHeader?: string;
40
- contactHeader?: string;
41
- toolbarFunctionsHeader?: string;
42
- toolbarLanguageHeader?: string;
43
- positiveFeedbackLabel?: string;
44
- negativeFeedbackLabel?: string;
45
- contactFeedbackLabel?: string;
46
- feedbackRecognitionLabel?: string;
47
- defaultAnswerVersionLabel?: string;
48
- backButtonLabel?: string;
49
- toolbarFunctionsTooltip?: string;
50
- toolbarFunctionsCloseButtonAriaLabel?: string;
51
- copyActionLabel?: string;
52
- printActionLabel?: string;
53
- toolbarLanguageTooltip?: string;
54
- toolbar?: ToolbarProps;
55
- guide?: GuideProps;
56
- dialog?: DialogItem[];
57
- error?: DataError;
58
- availablePerspectives?: AvailablePerspectives[];
59
- } & FormComponentInstanceProperties & FavoriteProperties & MetaDataProperties & LanguageProperties;
60
- export declare type ToolbarProps = {
61
- language?: boolean;
62
- guideCategories?: boolean;
63
- allowCopy?: boolean;
64
- allowPrint?: boolean;
65
- showFavoriteToggle?: boolean;
66
- picker?: PickerTypes;
67
- };
68
- export declare const GuideComponent: (container: Container) => Promise<void>;
69
- export default GuideComponent;
1
+ import { ContactMethodType } from '@telia-ace/knowledge-widget-adapters';
2
+ import { FavoriteProperties, LanguageProperties, MetaDataProperties } from '@telia-ace/knowledge-widget-component-utilities';
3
+ import { DialogItem, PickerTypes } from '@telia-ace/knowledge-widget-core';
4
+ import { DataError } from '@telia-ace/knowledge-widget-types-grid';
5
+ import { FormComponentInstanceProperties } from '@telia-ace/widget-forms';
6
+ import { Container } from '@webprovisions/platform';
7
+ export declare type GuideProps = {
8
+ id: string;
9
+ title: string;
10
+ body: string;
11
+ connection: string;
12
+ categories: number[];
13
+ hasHandover: boolean;
14
+ allowFeedback: boolean;
15
+ perspectives: {
16
+ [key: string]: string;
17
+ };
18
+ translations?: {
19
+ [key: string]: string;
20
+ };
21
+ modified?: string;
22
+ published?: string;
23
+ publishedBy?: string | null;
24
+ modifiedBy?: string | null;
25
+ perspective: string | null;
26
+ };
27
+ export declare type AvailablePerspectives = {
28
+ name: string;
29
+ title: string;
30
+ };
31
+ export declare type GuideComponentProps = {
32
+ showHeader?: boolean;
33
+ showFeedback?: boolean;
34
+ feedbackDirection?: 'horizontal' | 'vertical';
35
+ feedbackGiven?: 'positive' | 'negative';
36
+ contactMethods?: ContactMethodType[];
37
+ handoverContactMethods?: ContactMethodType[];
38
+ showAnswerVersions?: boolean;
39
+ feedbackHeader?: string;
40
+ contactHeader?: string;
41
+ toolbarFunctionsHeader?: string;
42
+ toolbarLanguageHeader?: string;
43
+ positiveFeedbackLabel?: string;
44
+ negativeFeedbackLabel?: string;
45
+ contactFeedbackLabel?: string;
46
+ feedbackRecognitionLabel?: string;
47
+ defaultAnswerVersionLabel?: string;
48
+ backButtonLabel?: string;
49
+ toolbarFunctionsTooltip?: string;
50
+ toolbarFunctionsCloseButtonAriaLabel?: string;
51
+ copyActionLabel?: string;
52
+ printActionLabel?: string;
53
+ toolbarLanguageTooltip?: string;
54
+ toolbar?: ToolbarProps;
55
+ guide?: GuideProps;
56
+ dialog?: DialogItem[];
57
+ error?: DataError;
58
+ availablePerspectives?: AvailablePerspectives[];
59
+ } & FormComponentInstanceProperties & FavoriteProperties & MetaDataProperties & LanguageProperties;
60
+ export declare type ToolbarProps = {
61
+ language?: boolean;
62
+ guideCategories?: boolean;
63
+ allowCopy?: boolean;
64
+ allowPrint?: boolean;
65
+ showFavoriteToggle?: boolean;
66
+ picker?: PickerTypes;
67
+ };
68
+ export declare const GuideComponent: (container: Container) => Promise<void>;
69
+ export default GuideComponent;
@@ -1 +1 @@
1
- {"version":3,"file":"guide.19e7d4a1.js","sources":["../src/answer-version-picker.tsx","../src/feedback.tsx","../src/categories.tsx","../src/functions.tsx","../src/languages.tsx","../src/toolbar.tsx","../src/guide.tsx"],"sourcesContent":["import { List, paddedBorderTabStyle, TextLink, useRouteData } from '@telia-ace/knowledge-widget-ui';\r\nimport { appendClassNames } from '@telia-ace/widget-utilities';\r\nimport React, { useMemo } from 'react';\r\nimport styled, { css } from 'styled-components';\r\nimport { AvailablePerspectives, GuideProps } from './guide-component';\r\n\r\ntype Props = {\r\n className?: string;\r\n defaultAnswerVersionLabel: string;\r\n availablePerspectives?: AvailablePerspectives[];\r\n guide: GuideProps;\r\n};\r\n\r\ntype Perspective = { label: string; connection: string };\r\n\r\nconst AnswerVersionPicker: React.FC<Props> = ({\r\n className,\r\n defaultAnswerVersionLabel,\r\n guide: { perspective: selectedPerspective, perspectives: guidePerspectives },\r\n availablePerspectives = [],\r\n}) => {\r\n const { name, params } = useRouteData();\r\n\r\n const perspectives: Perspective[] = useMemo(() => {\r\n if (!guidePerspectives || !availablePerspectives.length) {\r\n return [];\r\n }\r\n\r\n return availablePerspectives\r\n .filter(({ name }) => !!guidePerspectives[name])\r\n .map(({ name, title }) => {\r\n return { label: title, connection: guidePerspectives[name] };\r\n });\r\n }, [guidePerspectives, availablePerspectives]);\r\n\r\n return (\r\n <StyledList\r\n className={appendClassNames(className, 'humany-guide-answer-version-picker')}\r\n items={perspectives}\r\n renderItem={(perspective: Perspective) => {\r\n const label =\r\n perspective.label === 'Default' ? defaultAnswerVersionLabel : perspective.label;\r\n const selected = selectedPerspective === perspective.connection;\r\n const isRoot =\r\n selected && (!params.connection || selectedPerspective === params.connection);\r\n\r\n return (\r\n <li key={perspective.connection} data-version={perspective.connection}>\r\n <VersionLink\r\n key={perspective.connection}\r\n forwardedAs={isRoot ? 'span' : undefined}\r\n text={label}\r\n routeName={name}\r\n selected={selected}\r\n aria-label={label}\r\n title={label}\r\n params={{\r\n ...params,\r\n connection: perspective.connection,\r\n }}\r\n />\r\n </li>\r\n );\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default AnswerVersionPicker;\r\n\r\nconst StyledList = styled(List)`\r\n display: flex;\r\n align-items: center;\r\n flex-wrap: wrap;\r\n\r\n list-style: none;\r\n padding: 0;\r\n margin: 0;\r\n\r\n li:not(:last-child) {\r\n margin: 0 calc(${(p) => p.theme.sizes?.small} * 2) 0 0;\r\n }\r\n\r\n li > span {\r\n cursor: default;\r\n }\r\n`;\r\n\r\nconst VersionLink = styled(TextLink)<{ selected: boolean }>`\r\n font-weight: 300;\r\n color: ${(p) => p.theme.colors?.text};\r\n text-decoration: none;\r\n\r\n ${(p) =>\r\n p.selected &&\r\n css`\r\n font-weight: bold;\r\n text-decoration: underline;\r\n `}\r\n\r\n &:focus-visible {\r\n ${paddedBorderTabStyle};\r\n }\r\n`;\r\n","import { ContactList } from '@telia-ace/knowledge-widget-adapters';\r\nimport {\r\n Feedback as FeedbackUi,\r\n StyledHeaderText,\r\n useDispatch,\r\n useProperties,\r\n} from '@telia-ace/knowledge-widget-ui';\r\nimport React from 'react';\r\nimport styled from 'styled-components';\r\nimport { GuideComponentProps } from './guide-component';\r\n\r\ntype Props = { backButtonShown?: boolean; accordion?: boolean };\r\n\r\nconst StyledContactList = styled(ContactList)<{\r\n accordion: 'true' | 'false';\r\n backButtonShown: 'true' | 'false';\r\n}>`\r\n border-top: ${(p) => p.theme.border};\r\n ${(p) => p.backButtonShown === 'true' && `border-bottom: ${p.theme.border};`}\r\n`;\r\n\r\nconst StyledFeedback = styled(FeedbackUi)<{ accordion: 'true' | 'false' }>`\r\n ${(p) => `padding: ${p.theme.sizes?.large} ${p.theme.sizes?.large};`}\r\n`;\r\n\r\nconst Recognition = styled(StyledHeaderText)<{ accordion: 'true' | 'false' }>`\r\n ${(p) => `padding: ${p.theme.sizes?.large} ${p.theme.sizes?.large};`}\r\n\r\n display: block;\r\n font-size: ${(p) => p.theme.fonts?.normal};\r\n font-weight: bold;\r\n`;\r\n\r\nconst Feedback: React.SFC<Props> = ({ backButtonShown = false, accordion = false }) => {\r\n const dispatch = useDispatch();\r\n const {\r\n loading = false,\r\n dialog = [],\r\n guide,\r\n\r\n handoverContactMethods = [],\r\n contactHeader,\r\n\r\n showFeedback,\r\n feedbackDirection = 'horizontal',\r\n feedbackRecognitionLabel,\r\n feedbackGiven,\r\n feedbackHeader,\r\n positiveFeedbackLabel,\r\n negativeFeedbackLabel,\r\n contactFeedbackLabel,\r\n } = useProperties<GuideComponentProps>();\r\n\r\n if (\r\n !showFeedback ||\r\n !guide ||\r\n !guide.allowFeedback ||\r\n (loading && !feedbackGiven) ||\r\n dialog.length\r\n ) {\r\n return null;\r\n }\r\n\r\n if (feedbackGiven && feedbackRecognitionLabel && !handoverContactMethods.length) {\r\n return (\r\n <Recognition accordion={accordion ? 'true' : 'false'}>\r\n {feedbackRecognitionLabel}\r\n </Recognition>\r\n );\r\n }\r\n\r\n return guide.hasHandover && handoverContactMethods.length ? (\r\n <StyledContactList\r\n backButtonShown={backButtonShown ? 'true' : 'false'}\r\n accordion={accordion ? 'true' : 'false'}\r\n header={contactHeader}\r\n contactMethods={handoverContactMethods}\r\n dispatch={dispatch}\r\n />\r\n ) : (\r\n <StyledFeedback\r\n accordion={accordion ? 'true' : 'false'}\r\n positive={positiveFeedbackLabel}\r\n negative={guide.hasHandover ? contactFeedbackLabel : negativeFeedbackLabel}\r\n header={feedbackHeader}\r\n selected={feedbackGiven}\r\n onFeedback={(feedback) => dispatch('feedback', feedback)}\r\n direction={feedbackDirection}\r\n />\r\n );\r\n};\r\n\r\nexport default Feedback;\r\n","import { Category, PickerTypes } from '@telia-ace/knowledge-widget-core';\r\nimport {\r\n StyledListButton,\r\n SymbolBadge,\r\n Text,\r\n Tooltip,\r\n useContainer,\r\n} from '@telia-ace/knowledge-widget-ui';\r\nimport { buildCategoryTrail } from '@telia-ace/widget-utilities';\r\nimport React, { useEffect, useState } from 'react';\r\nimport styled from 'styled-components';\r\nimport { GuideProps, ToolbarProps } from './guide-component';\r\n\r\ntype Props = {\r\n guide: GuideProps;\r\n toolbar: ToolbarProps;\r\n};\r\n\r\nconst Categories: React.FC<Props> = ({\r\n guide: { categories = [] },\r\n toolbar: { picker = PickerTypes.NONE },\r\n}) => {\r\n const [trail, setTrail] = useState<Category[][]>([]);\r\n const container = useContainer();\r\n\r\n useEffect(() => {\r\n buildCategoryTrail(\r\n 'index',\r\n categories.map((id) => id.toString()),\r\n container\r\n ).then((result) => {\r\n setTrail(result);\r\n });\r\n }, [categories]);\r\n\r\n if (!trail.length) {\r\n return null;\r\n }\r\n\r\n return (\r\n <Tooltip\r\n className=\"humany-guide-category-tooltip\"\r\n sticky={picker === PickerTypes.DRAWER}\r\n content={\r\n <>\r\n {trail.map((segments) => {\r\n return (\r\n <CategoryTrail\r\n className=\"humany-guide-category-trail\"\r\n key={segments.map((c) => c.id).join('.')}\r\n >\r\n {segments.map((category, index: number) => {\r\n return (\r\n <Text\r\n className=\"humany-guide-category-trail-segment\"\r\n key={category.id}\r\n >\r\n {category.symbol && index === 0 && (\r\n <SymbolBadge size={14} symbol={category.symbol} />\r\n )}\r\n {category.title}\r\n {index !== segments.length - 1 && (\r\n <CategorySeparator className=\"humany-category-separator\">\r\n /\r\n </CategorySeparator>\r\n )}\r\n </Text>\r\n );\r\n })}\r\n </CategoryTrail>\r\n );\r\n })}\r\n </>\r\n }\r\n >\r\n {picker === PickerTypes.DRAWER ? (\r\n <StyledListButton\r\n className=\"humany-guide-category-tooltip-button\"\r\n data-has-label=\"false\"\r\n data-has-symbol=\"true\"\r\n >\r\n <CategoriesSymbolBadge\r\n size={19}\r\n symbol={{ type: 'Svg', content: 'information' }}\r\n />\r\n </StyledListButton>\r\n ) : (\r\n <CategoriesSymbolBadge size={19} symbol={{ type: 'Svg', content: 'information' }} />\r\n )}\r\n </Tooltip>\r\n );\r\n};\r\n\r\nexport default Categories;\r\n\r\nconst CategoryTrail = styled.div`\r\n i,\r\n svg {\r\n margin: 0 ${(p) => p.theme.sizes?.small} 0 0;\r\n }\r\n\r\n &:not(:last-child) {\r\n margin: 0 0 ${(p) => p.theme.sizes?.small};\r\n }\r\n`;\r\n\r\nconst CategorySeparator = styled(Text)`\r\n margin: 0 ${(p) => p.theme.sizes?.small};\r\n`;\r\n\r\nconst CategoriesSymbolBadge = styled(SymbolBadge)`\r\n display: block;\r\n`;\r\n","import { PickerTypes } from '@telia-ace/knowledge-widget-core';\r\nimport {\r\n DispatchAction,\r\n DrawerAnimationType,\r\n DrawerList,\r\n DropdownList,\r\n FavoriteButton,\r\n StyledListButton,\r\n StyledText,\r\n SymbolBadge,\r\n useFavorites,\r\n} from '@telia-ace/knowledge-widget-ui';\r\nimport React, { useCallback, useMemo } from 'react';\r\nimport styled from 'styled-components';\r\nimport { GuideProps } from './guide-component';\r\n\r\nexport type FunctionListItem = {\r\n type: string;\r\n child: React.ReactNode;\r\n};\r\n\r\ntype Props = {\r\n header?: string;\r\n tooltip?: string;\r\n printActionLabel?: string;\r\n copyActionLabel?: string;\r\n addFavoriteTooltip?: string;\r\n removeFavoriteCancelLabel?: string;\r\n removeFavoriteConfirmLabel?: string;\r\n removeFavoriteHeader?: string;\r\n removeFavoriteLabel?: string;\r\n removeFavoriteTooltip?: string;\r\n toolbarFunctionsCloseButtonAriaLabel?: string;\r\n guide: GuideProps;\r\n allowCopy?: boolean;\r\n allowPrint?: boolean;\r\n showFavoriteToggle?: boolean;\r\n picker?: PickerTypes;\r\n dispatch: DispatchAction;\r\n};\r\n\r\nconst Functions: React.FC<Props> = ({\r\n header,\r\n tooltip,\r\n printActionLabel,\r\n copyActionLabel,\r\n addFavoriteTooltip,\r\n removeFavoriteCancelLabel,\r\n removeFavoriteConfirmLabel,\r\n removeFavoriteHeader,\r\n removeFavoriteLabel,\r\n removeFavoriteTooltip,\r\n toolbarFunctionsCloseButtonAriaLabel,\r\n allowCopy = false,\r\n allowPrint = false,\r\n showFavoriteToggle = false,\r\n picker = PickerTypes.NONE,\r\n guide,\r\n dispatch,\r\n}) => {\r\n const [favorites, actions] = useFavorites();\r\n\r\n const handleCopy = useCallback(\r\n (event) => {\r\n if (guide) {\r\n dispatch('copy', guide);\r\n }\r\n },\r\n [guide, dispatch]\r\n );\r\n\r\n const handlePrint = useCallback(() => {\r\n if (guide) {\r\n dispatch('print');\r\n }\r\n }, [guide, dispatch]);\r\n\r\n const items = useMemo(() => {\r\n const { id, title } = guide;\r\n\r\n const items: FunctionListItem[] = [];\r\n\r\n if (allowCopy) {\r\n items.push({\r\n type: 'copy',\r\n child: (\r\n <StyledListButton\r\n data-has-label={copyActionLabel ? 'true' : 'false'}\r\n data-has-symbol=\"true\"\r\n title={copyActionLabel}\r\n aria-label={printActionLabel}\r\n onClick={handleCopy}\r\n >\r\n <ColoredSymbolBadge size={16} symbol={{ type: 'Svg', content: 'copy' }} />\r\n {copyActionLabel && <StyledText>{copyActionLabel}</StyledText>}\r\n </StyledListButton>\r\n ),\r\n });\r\n }\r\n\r\n if (allowPrint) {\r\n items.push({\r\n type: 'print',\r\n child: (\r\n <StyledListButton\r\n data-has-label={printActionLabel ? 'true' : 'false'}\r\n data-has-symbol=\"true\"\r\n title={printActionLabel}\r\n aria-label={printActionLabel}\r\n onClick={handlePrint}\r\n >\r\n <ColoredSymbolBadge size={16} symbol={{ type: 'Svg', content: 'print' }} />\r\n {printActionLabel && <StyledText>{printActionLabel}</StyledText>}\r\n </StyledListButton>\r\n ),\r\n });\r\n }\r\n\r\n if (showFavoriteToggle) {\r\n const isFavorite = favorites.indexOf(id) > -1;\r\n items.push({\r\n type: 'favorite',\r\n child: (\r\n <FavoriteButton\r\n id={id}\r\n guideTitle={title}\r\n isFavorite={isFavorite}\r\n buttonLabel={isFavorite ? removeFavoriteTooltip : addFavoriteTooltip}\r\n addFavoriteTooltip={addFavoriteTooltip}\r\n removeFavoriteCancelLabel={removeFavoriteCancelLabel}\r\n removeFavoriteConfirmLabel={removeFavoriteConfirmLabel}\r\n removeFavoriteHeader={removeFavoriteHeader}\r\n removeFavoriteLabel={removeFavoriteLabel}\r\n removeFavoriteTooltip={removeFavoriteTooltip}\r\n actions={actions}\r\n />\r\n ),\r\n });\r\n }\r\n\r\n return items;\r\n }, [\r\n favorites,\r\n guide,\r\n allowCopy,\r\n allowPrint,\r\n showFavoriteToggle,\r\n printActionLabel,\r\n copyActionLabel,\r\n addFavoriteTooltip,\r\n removeFavoriteCancelLabel,\r\n removeFavoriteConfirmLabel,\r\n removeFavoriteHeader,\r\n removeFavoriteLabel,\r\n removeFavoriteTooltip,\r\n ]);\r\n\r\n if (!items.length) {\r\n return null;\r\n }\r\n\r\n const trigger = (\r\n <StyledTriggerButton\r\n tabIndex={0}\r\n title={tooltip}\r\n data-has-symbol=\"true\"\r\n data-has-label=\"false\"\r\n >\r\n <ColoredSymbolBadge symbol={{ type: 'Svg', content: 'options' }} size={18} />\r\n </StyledTriggerButton>\r\n );\r\n\r\n const renderListItem = ({ type, child }: FunctionListItem) => {\r\n return (\r\n <li key={type} data-function-type={type}>\r\n {child}\r\n </li>\r\n );\r\n };\r\n\r\n if (picker === PickerTypes.DROPDOWN) {\r\n return (\r\n <StyledDropdownList\r\n className=\"humany-guide-functions-dropdown-list\"\r\n header={header}\r\n items={items}\r\n trigger={trigger}\r\n renderItem={renderListItem}\r\n closeButtonAriaLabel={toolbarFunctionsCloseButtonAriaLabel}\r\n />\r\n );\r\n }\r\n\r\n if (picker === PickerTypes.DRAWER) {\r\n return (\r\n <DrawerList\r\n className=\"humany-guide-functions-drawer-list\"\r\n animation={{ type: DrawerAnimationType.SlideInBottom }}\r\n header={header}\r\n items={items}\r\n trigger={trigger}\r\n renderItem={renderListItem}\r\n closeButtonAriaLabel={toolbarFunctionsCloseButtonAriaLabel}\r\n />\r\n );\r\n }\r\n\r\n return null;\r\n};\r\n\r\nexport default Functions;\r\n\r\nconst ColoredSymbolBadge = styled(SymbolBadge)`\r\n circle {\r\n fill: ${(p) => p.theme.colors?.text};\r\n }\r\n\r\n line,\r\n path,\r\n rect {\r\n stroke: ${(p) => p.theme.colors?.text};\r\n }\r\n`;\r\n\r\nconst StyledDropdownList = styled(DropdownList)`\r\n display: block;\r\n min-height: auto;\r\n`;\r\n\r\nconst StyledTriggerButton = styled(StyledListButton)<any>`\r\n padding: calc(${(p) => p.theme.sizes?.small} * 2) 0;\r\n`;\r\n","import { LanguageProperties } from '@telia-ace/knowledge-widget-component-utilities';\r\nimport { PickerTypes } from '@telia-ace/knowledge-widget-core';\r\nimport {\r\n DrawerAnimationType,\r\n DrawerList,\r\n DropdownList,\r\n paddedBorderTabStyle,\r\n StyledListButton,\r\n SymbolBadge,\r\n Text,\r\n TextLink,\r\n useRouteData,\r\n} from '@telia-ace/knowledge-widget-ui';\r\nimport { createParams } from '@telia-ace/widget-utilities';\r\nimport React, { useMemo } from 'react';\r\nimport styled from 'styled-components';\r\nimport { GuideProps } from './guide-component';\r\n\r\nexport type LanguageListItem = {\r\n id: string;\r\n key: string;\r\n label: string;\r\n};\r\n\r\ntype Props = Merge<\r\n {\r\n header?: string;\r\n tooltip?: string;\r\n guide: GuideProps;\r\n picker?: PickerTypes;\r\n },\r\n LanguageProperties\r\n>;\r\n\r\nconst getCurrentLanguageLabel = (guide: GuideProps, languages: LanguageListItem[]) => {\r\n return languages.find((l) => l.id === guide.id)?.label || '';\r\n};\r\n\r\nconst Languages: React.FC<Props> = ({\r\n header,\r\n tooltip,\r\n picker = PickerTypes.NONE,\r\n guide,\r\n ...other\r\n}) => {\r\n const { name, params } = useRouteData();\r\n\r\n const items = useMemo(() => {\r\n return Object.keys(guide.translations || {}).reduce((acc: LanguageListItem[], key) => {\r\n const item: Partial<LanguageListItem> = {};\r\n item.key = key;\r\n item.id = (guide.translations || {})[key];\r\n item.label = (other as { [key: string]: string })[`${key}LanguageLabel`];\r\n\r\n if (item.id || item.label) {\r\n acc.push(item as LanguageListItem);\r\n }\r\n\r\n return acc;\r\n }, []);\r\n }, [guide, other]);\r\n\r\n if (!items.length) {\r\n return null;\r\n }\r\n\r\n const currentLanguage = getCurrentLanguageLabel(guide, items);\r\n\r\n const trigger = (\r\n <Trigger\r\n tabIndex={0}\r\n title={tooltip}\r\n data-has-symbol=\"true\"\r\n data-has-label={picker === PickerTypes.DROPDOWN && currentLanguage ? 'true' : 'false'}\r\n >\r\n {picker === PickerTypes.DROPDOWN && (\r\n <>\r\n {currentLanguage && <LanguageButtonText>{currentLanguage}</LanguageButtonText>}\r\n <LanguageCaretSymbolBadge\r\n symbol={{ type: 'Svg', content: 'caret-down' }}\r\n size={11}\r\n />\r\n </>\r\n )}\r\n {picker === PickerTypes.DRAWER && (\r\n <>\r\n <ColoredSymbolBadge symbol={{ type: 'Svg', content: 'language' }} size={20} />\r\n </>\r\n )}\r\n </Trigger>\r\n );\r\n\r\n const renderListItem = ({ label, key, id }: LanguageListItem) => {\r\n return (\r\n <li key={key} data-language={key}>\r\n <LanguageLink\r\n tabIndex={0}\r\n text={label}\r\n routeName={name}\r\n selected={guide.id === id}\r\n params={createParams({\r\n ...params,\r\n connection: undefined,\r\n guide: id,\r\n })}\r\n />\r\n </li>\r\n );\r\n };\r\n\r\n if (picker === PickerTypes.DROPDOWN) {\r\n return (\r\n <StyledDropdownList\r\n className=\"humany-guide-languages-dropdown-list\"\r\n header={header}\r\n items={items}\r\n trigger={trigger}\r\n renderItem={renderListItem}\r\n />\r\n );\r\n }\r\n\r\n if (picker === PickerTypes.DRAWER) {\r\n return (\r\n <DrawerList\r\n className=\"humany-guide-languages-drawer-list\"\r\n animation={{ type: DrawerAnimationType.SlideInBottom }}\r\n header={header}\r\n items={items}\r\n trigger={trigger}\r\n renderItem={renderListItem}\r\n />\r\n );\r\n }\r\n\r\n return null;\r\n};\r\n\r\nexport default Languages;\r\n\r\nconst Trigger = styled(StyledListButton)`\r\n &&& {\r\n margin: 0 ${(p) => `calc(${p.theme.sizes?.small} * 2)`} 0 0;\r\n }\r\n`;\r\n\r\nconst ColoredSymbolBadge = styled(SymbolBadge)`\r\n circle {\r\n fill: ${(p) => p.theme.colors?.text};\r\n }\r\n\r\n line,\r\n path,\r\n rect {\r\n stroke: ${(p) => p.theme.colors?.text};\r\n }\r\n`;\r\n\r\nconst LanguageButtonText = styled(Text)`\r\n margin: 0 ${(p) => p.theme.sizes?.small} 0 0;\r\n font-size: ${(p) => p.theme.fonts?.normal};\r\n`;\r\n\r\nconst LanguageCaretSymbolBadge = styled(SymbolBadge)`\r\n align-self: flex-end;\r\n stroke-width: 2px;\r\n stroke-linecap: round;\r\n\r\n && {\r\n width: 0.6em;\r\n height: 1em;\r\n }\r\n line {\r\n stroke: ${(p) => p.theme.colors?.text};\r\n }\r\n`;\r\n\r\nconst StyledDropdownList = styled(DropdownList)`\r\n display: block;\r\n min-height: auto;\r\n`;\r\n\r\nconst LanguageLink = styled(TextLink)<any>`\r\n color: ${(p) => (p.selected ? p.theme.colors?.primary : p.theme.colors?.text)};\r\n ${(p) => p.selected && 'font-weight: bold;'}\r\n\r\n outline: none;\r\n &:focus-visible {\r\n ${paddedBorderTabStyle}\r\n text-decoration: underline;\r\n }\r\n`;\r\n","import { PickerTypes } from '@telia-ace/knowledge-widget-core';\r\nimport { DispatchAction, useProperties } from '@telia-ace/knowledge-widget-ui';\r\nimport { appendClassNames } from '@telia-ace/widget-utilities';\r\nimport React from 'react';\r\nimport styled from 'styled-components';\r\nimport Categories from './categories';\r\nimport Functions from './functions';\r\nimport { GuideComponentProps, ToolbarProps } from './guide-component';\r\nimport Languages from './languages';\r\n\r\ntype Props = {\r\n className?: string;\r\n dispatch: DispatchAction;\r\n};\r\n\r\nconst isEmpty = (toolbar: ToolbarProps) => {\r\n const {\r\n allowCopy = false,\r\n allowPrint = false,\r\n guideCategories = false,\r\n language = false,\r\n showFavoriteToggle = false,\r\n picker = PickerTypes.NONE,\r\n } = toolbar;\r\n\r\n if (\r\n (!allowCopy && !allowPrint && !language && !showFavoriteToggle && !guideCategories) ||\r\n picker === PickerTypes.NONE\r\n ) {\r\n return true;\r\n }\r\n\r\n return false;\r\n};\r\n\r\nconst Toolbar: React.FC<Props> = ({ className = '', dispatch }) => {\r\n const {\r\n toolbarLanguageHeader,\r\n toolbarFunctionsHeader,\r\n toolbarLanguageTooltip,\r\n toolbarFunctionsTooltip,\r\n toolbarFunctionsCloseButtonAriaLabel,\r\n printActionLabel,\r\n copyActionLabel,\r\n addFavoriteTooltip,\r\n removeFavoriteCancelLabel,\r\n removeFavoriteConfirmLabel,\r\n removeFavoriteHeader,\r\n removeFavoriteLabel,\r\n removeFavoriteTooltip,\r\n guide,\r\n toolbar,\r\n ...other\r\n } = useProperties<GuideComponentProps>();\r\n\r\n if (!guide || !toolbar || isEmpty(toolbar)) {\r\n return null;\r\n }\r\n\r\n const { language, guideCategories, allowCopy, allowPrint, showFavoriteToggle, picker } =\r\n toolbar;\r\n\r\n return (\r\n <Wrapper className={appendClassNames('humany-guide-toolbar', className)}>\r\n {language && Object.keys(guide.translations || {}).length > 1 && (\r\n <Languages\r\n guide={guide}\r\n header={toolbarLanguageHeader}\r\n tooltip={toolbarLanguageTooltip}\r\n picker={picker}\r\n {...other}\r\n />\r\n )}\r\n {guideCategories && <Categories guide={guide} toolbar={toolbar} />}\r\n {(allowCopy || allowPrint || showFavoriteToggle) && (\r\n <Functions\r\n guide={guide}\r\n header={toolbarFunctionsHeader}\r\n tooltip={toolbarFunctionsTooltip}\r\n printActionLabel={printActionLabel}\r\n copyActionLabel={copyActionLabel}\r\n addFavoriteTooltip={addFavoriteTooltip}\r\n removeFavoriteCancelLabel={removeFavoriteCancelLabel}\r\n removeFavoriteConfirmLabel={removeFavoriteConfirmLabel}\r\n removeFavoriteHeader={removeFavoriteHeader}\r\n removeFavoriteLabel={removeFavoriteLabel}\r\n removeFavoriteTooltip={removeFavoriteTooltip}\r\n toolbarFunctionsCloseButtonAriaLabel={toolbarFunctionsCloseButtonAriaLabel}\r\n allowCopy={allowCopy}\r\n allowPrint={allowPrint}\r\n showFavoriteToggle={showFavoriteToggle}\r\n picker={picker}\r\n dispatch={dispatch}\r\n />\r\n )}\r\n </Wrapper>\r\n );\r\n};\r\n\r\nexport default Toolbar;\r\n\r\nconst Wrapper = styled.div`\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n margin: 0 0 0 auto;\r\n\r\n > :not(:last-child) {\r\n margin: 0 calc(${(p) => p.theme.sizes?.small} * 2) 0 0;\r\n }\r\n`;\r\n","import { contactLink, ContactList } from '@telia-ace/knowledge-widget-adapters';\r\nimport { Component, NotFound } from '@telia-ace/knowledge-widget-types-grid';\r\nimport {\r\n Button,\r\n contentBox,\r\n createEmptyComponent,\r\n DialogLink,\r\n DialogList,\r\n embeddedLinkMapper,\r\n genericHtml,\r\n headingElement,\r\n Lightbox,\r\n linkTabStyle,\r\n Loader,\r\n loadingOpacity,\r\n Metadata,\r\n Paragraph,\r\n useChildren,\r\n useContainer,\r\n useDispatch,\r\n useProperties,\r\n useRouteData,\r\n} from '@telia-ace/knowledge-widget-ui';\r\nimport { appendClassNames } from '@telia-ace/widget-utilities';\r\nimport React, { forwardRef, useCallback, useMemo } from 'react';\r\nimport styled, { css } from 'styled-components';\r\nimport AnswerVersionPicker from './answer-version-picker';\r\nimport Feedback from './feedback';\r\nimport { GuideComponentProps } from './guide-component';\r\nimport Toolbar from './toolbar';\r\n\r\ntype Props = { className: string; accordion?: boolean };\r\n\r\nconst Guide = forwardRef<HTMLDivElement, Props>(\r\n ({ className, accordion = false, ...other }, ref) => {\r\n const {\r\n loading = false,\r\n dialog = [],\r\n contactMethods = [],\r\n showHeader = true,\r\n showAnswerVersions = false,\r\n defaultAnswerVersionLabel = 'Default',\r\n backButtonLabel,\r\n metadataByLabel,\r\n metadataModifiedLabel,\r\n metadataPublishedLabel,\r\n availablePerspectives,\r\n metadata,\r\n toolbar,\r\n guide,\r\n error,\r\n } = useProperties<GuideComponentProps>();\r\n const {\r\n params: { connection },\r\n } = useRouteData();\r\n const container = useContainer();\r\n const children = useChildren();\r\n const dispatch = useDispatch();\r\n\r\n const transform = useMemo(() => {\r\n return {\r\n transform: {\r\n img: (attrs: any) => (\r\n <Lightbox attrs={attrs} htmlBody={guide?.body || ''}></Lightbox>\r\n ),\r\n a: (attr: any) => {\r\n const { children, ...otherAttr } = attr;\r\n const connectionId = otherAttr['data-target'];\r\n if (connectionId && dialog.length) {\r\n const item = dialog.find(\r\n ({ connection }: any) => connection === connectionId\r\n );\r\n if (item) {\r\n return <DialogLink {...item}>{children}</DialogLink>;\r\n }\r\n }\r\n\r\n const defaultInstructions = embeddedLinkMapper(container);\r\n\r\n return defaultInstructions(attr);\r\n },\r\n },\r\n };\r\n }, [guide, container, dialog]);\r\n\r\n const handleBackButtonClick = useCallback(() => {\r\n dispatch('back');\r\n }, [dispatch]);\r\n\r\n if (!guide && !error && !loading) {\r\n return createEmptyComponent(container, {\r\n ...other,\r\n className: appendClassNames(className, 'humany-guide'),\r\n });\r\n }\r\n\r\n const { id = '', title = '', body = '', translations = {} } = guide || {};\r\n\r\n if (error && error.status === 404) {\r\n return <NotFound showSearch={false} />;\r\n }\r\n\r\n const showBackButton = !!accordion && !!connection;\r\n const language = Object.keys(translations).find((key) => translations[key] === `${id}`);\r\n\r\n return (\r\n <Wrapper\r\n ref={ref}\r\n {...other}\r\n data-loading={loading}\r\n className={appendClassNames(className, 'humany-guide')}\r\n >\r\n <Content\r\n data-loading={loading}\r\n accordion={accordion ? 'true' : 'false'}\r\n className=\"humany-guide-content\"\r\n >\r\n {((showAnswerVersions && guide) || !!toolbar) && (\r\n <Top className=\"humany-guide-top\">\r\n {showAnswerVersions && guide && (\r\n <AnswerVersionPicker\r\n defaultAnswerVersionLabel={defaultAnswerVersionLabel}\r\n availablePerspectives={availablePerspectives}\r\n guide={guide}\r\n />\r\n )}\r\n {!!toolbar && <Toolbar dispatch={dispatch} />}\r\n </Top>\r\n )}\r\n {!!(title || body) && (\r\n <Body\r\n className=\"humany-guide-body\"\r\n accordion={accordion ? 'true' : 'false'}\r\n header={(showHeader && title) || undefined}\r\n html={body}\r\n htmlParseInstruction={transform}\r\n lang={language}\r\n />\r\n )}\r\n {dialog && body.indexOf('h-option-link') === -1 && (\r\n <StyledDialogList dialog={dialog} />\r\n )}\r\n <StyledContactList\r\n backButtonShown={showBackButton ? 'true' : 'false'}\r\n contactMethods={contactMethods}\r\n dispatch={dispatch}\r\n guideId={guide && guide.id}\r\n />\r\n {!contactMethods.length && (\r\n <Feedback backButtonShown={showBackButton} accordion={accordion} />\r\n )}\r\n {showBackButton && (\r\n <BackButton aria-label={backButtonLabel} onClick={handleBackButtonClick}>\r\n <Caret\r\n width=\"7\"\r\n height=\"13\"\r\n viewBox=\"0 0 7 13\"\r\n fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n >\r\n <line x1=\"6.64645\" y1=\"12.5513\" x2=\"0.648357\" y2=\"6.55319\" />\r\n <line x1=\"0.646447\" y1=\"6.64455\" x2=\"6.64454\" y2=\"0.646465\" />\r\n </Caret>\r\n {backButtonLabel && <span>{backButtonLabel}</span>}\r\n </BackButton>\r\n )}\r\n {metadata && (\r\n <StyledMetadata\r\n {...metadata}\r\n modified={guide?.modified}\r\n published={guide?.published}\r\n modifiedBy={guide?.modifiedBy}\r\n publishedBy={guide?.publishedBy}\r\n byLabel={metadataByLabel}\r\n modifiedLabel={metadataModifiedLabel}\r\n publishedLabel={metadataPublishedLabel}\r\n />\r\n )}\r\n {children.map((child) => (\r\n <StyledComponents\r\n key={child.id}\r\n id={child.id}\r\n branch=\"default\"\r\n {...{ embedded: true }}\r\n />\r\n ))}\r\n </Content>\r\n\r\n <Loader loading={loading} />\r\n </Wrapper>\r\n );\r\n }\r\n);\r\n\r\nexport default Guide;\r\n\r\nconst Wrapper = styled.div<{ 'data-loading': boolean }>`\r\n ${loadingOpacity}\r\n min-width: 0;\r\n`;\r\n\r\nconst Body = styled(Paragraph)<{ accordion: 'true' | 'false' }>`\r\n ${genericHtml}\r\n ${(p) => `padding: ${p.theme.sizes?.large};`}\r\n display: block;\r\n line-height: 1.6em;\r\n ${headingElement(\r\n 'h1',\r\n css`\r\n font-size: ${(p) => p.theme.fonts?.large};\r\n font-weight: normal;\r\n line-height: 1.6em;\r\n line-height: 1.6em;\r\n margin: 0 0 ${(p) => p.theme.sizes?.small};\r\n `\r\n )}\r\n\r\n p {\r\n font-weight: 300;\r\n font-size: ${(p) => p.theme.fonts?.normal};\r\n color: ${(p) => p.theme.colors?.text};\r\n a {\r\n display: inline;\r\n }\r\n }\r\n`;\r\n\r\nconst StyledContactList = styled(ContactList)<{ backButtonShown: 'true' | 'false' }>`\r\n border-top: ${(p) => p.theme.border};\r\n ${(p) => p.backButtonShown === 'true' && `border-bottom: ${p.theme.border};`}\r\n`;\r\n\r\nconst StyledDialogList = styled(DialogList)`\r\n ${(p) => `padding: 0 ${p.theme.sizes?.large} ${p.theme.sizes?.large};`}\r\n display: block;\r\n`;\r\n\r\nconst Top = styled.div`\r\n ${(p) => `padding: calc(${p.theme.sizes?.normal}*2) ${p.theme.sizes?.large};`}\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n border-bottom: ${(p) => p.theme.border};\r\n border-radius: ${(p) => `${p.theme.borderRadius} ${p.theme.borderRadius}`} 0 0;\r\n background-color: #ffffff;\r\n`;\r\n\r\nconst Content = styled.div<{ 'data-loading': boolean; accordion: 'true' | 'false' } & any>`\r\n ${contentBox}\r\n display: block;\r\n > a {\r\n ${contactLink}\r\n }\r\n\r\n ${(p) =>\r\n p.accordion === 'true' &&\r\n css`\r\n white-space: normal;\r\n box-shadow: none;\r\n background-color: #fafafa;\r\n `}\r\n`;\r\n\r\nconst StyledMetadata = styled(Metadata)`\r\n display: block;\r\n ${(p) => `padding: calc(${p.theme.sizes?.normal}*2) ${p.theme.sizes?.large};`}\r\n font-weight: 300;\r\n font-size: ${(p) => p.theme.fonts?.normal};\r\n color: ${(p) => p.theme.colors?.text};\r\n border-top: ${(p) => p.theme.border};\r\n`;\r\n\r\nconst StyledComponents = styled(Component)`\r\n border-top: ${(p) => p.theme.border};\r\n`;\r\n\r\nconst BackButton = styled(Button)`\r\n ${(p) => `padding: ${p.theme.sizes?.normal} calc(${p.theme.sizes?.normal} * 2);`}\r\n color: ${(p) => p.theme.colors?.primary};\r\n text-decoration: underline;\r\n font-size: ${(p) => p.theme.fonts?.normal};\r\n span {\r\n font-weight: 300;\r\n }\r\n &:focus-visible {\r\n ${linkTabStyle}\r\n padding: ${(p) => `calc(${p.theme.sizes?.small} / 2) ${p.theme.sizes?.small}`};\r\n }\r\n`;\r\n\r\nconst Caret = styled.svg`\r\n margin-right: ${(p) => p.theme.sizes?.small};\r\n line {\r\n stroke: ${(p) => p.theme.colors?.primary};\r\n }\r\n`;\r\n"],"names":["AnswerVersionPicker","className","defaultAnswerVersionLabel","selectedPerspective","guidePerspectives","availablePerspectives","name","params","useRouteData","perspectives","useMemo","title","React","StyledList","appendClassNames","perspective","label","selected","isRoot","VersionLink","__spreadProps","__spreadValues","styled","List","p","_a","TextLink","css","paddedBorderTabStyle","StyledContactList","ContactList","StyledFeedback","FeedbackUi","_b","Recognition","StyledHeaderText","Feedback","backButtonShown","accordion","dispatch","useDispatch","loading","dialog","guide","handoverContactMethods","contactHeader","showFeedback","feedbackDirection","feedbackRecognitionLabel","feedbackGiven","feedbackHeader","positiveFeedbackLabel","negativeFeedbackLabel","contactFeedbackLabel","useProperties","feedback","Categories","categories","picker","PickerTypes","trail","setTrail","useState","container","useContainer","useEffect","buildCategoryTrail","id","result","Tooltip","segments","CategoryTrail","c","category","index","Text","SymbolBadge","CategorySeparator","StyledListButton","CategoriesSymbolBadge","Functions","header","tooltip","printActionLabel","copyActionLabel","addFavoriteTooltip","removeFavoriteCancelLabel","removeFavoriteConfirmLabel","removeFavoriteHeader","removeFavoriteLabel","removeFavoriteTooltip","toolbarFunctionsCloseButtonAriaLabel","allowCopy","allowPrint","showFavoriteToggle","favorites","actions","useFavorites","handleCopy","useCallback","event","handlePrint","items","ColoredSymbolBadge","StyledText","isFavorite","FavoriteButton","trigger","StyledTriggerButton","renderListItem","type","child","StyledDropdownList","DrawerList","DrawerAnimationType","DropdownList","getCurrentLanguageLabel","languages","l","Languages","other","__objRest","acc","key","item","currentLanguage","Trigger","LanguageButtonText","LanguageCaretSymbolBadge","LanguageLink","createParams","isEmpty","toolbar","guideCategories","language","Toolbar","toolbarLanguageHeader","toolbarFunctionsHeader","toolbarLanguageTooltip","toolbarFunctionsTooltip","Wrapper","Guide","forwardRef","ref","contactMethods","showHeader","showAnswerVersions","backButtonLabel","metadataByLabel","metadataModifiedLabel","metadataPublishedLabel","metadata","error","connection","children","useChildren","transform","attrs","Lightbox","attr","connectionId","DialogLink","embeddedLinkMapper","handleBackButtonClick","createEmptyComponent","body","translations","NotFound","showBackButton","Content","Top","Body","StyledDialogList","BackButton","Caret","StyledMetadata","StyledComponents","Loader","loadingOpacity","Paragraph","genericHtml","headingElement","DialogList","contentBox","contactLink","Metadata","Component","Button","linkTabStyle"],"mappings":"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"}
1
+ {"version":3,"file":"guide.19e7d4a1.js","sources":["../src/answer-version-picker.tsx","../src/feedback.tsx","../src/categories.tsx","../src/functions.tsx","../src/languages.tsx","../src/toolbar.tsx","../src/guide.tsx"],"sourcesContent":["import { List, paddedBorderTabStyle, TextLink, useRouteData } from '@telia-ace/knowledge-widget-ui';\nimport { appendClassNames } from '@telia-ace/widget-utilities';\nimport React, { useMemo } from 'react';\nimport styled, { css } from 'styled-components';\nimport { AvailablePerspectives, GuideProps } from './guide-component';\n\ntype Props = {\n className?: string;\n defaultAnswerVersionLabel: string;\n availablePerspectives?: AvailablePerspectives[];\n guide: GuideProps;\n};\n\ntype Perspective = { label: string; connection: string };\n\nconst AnswerVersionPicker: React.FC<Props> = ({\n className,\n defaultAnswerVersionLabel,\n guide: { perspective: selectedPerspective, perspectives: guidePerspectives },\n availablePerspectives = [],\n}) => {\n const { name, params } = useRouteData();\n\n const perspectives: Perspective[] = useMemo(() => {\n if (!guidePerspectives || !availablePerspectives.length) {\n return [];\n }\n\n return availablePerspectives\n .filter(({ name }) => !!guidePerspectives[name])\n .map(({ name, title }) => {\n return { label: title, connection: guidePerspectives[name] };\n });\n }, [guidePerspectives, availablePerspectives]);\n\n return (\n <StyledList\n className={appendClassNames(className, 'humany-guide-answer-version-picker')}\n items={perspectives}\n renderItem={(perspective: Perspective) => {\n const label =\n perspective.label === 'Default' ? defaultAnswerVersionLabel : perspective.label;\n const selected = selectedPerspective === perspective.connection;\n const isRoot =\n selected && (!params.connection || selectedPerspective === params.connection);\n\n return (\n <li key={perspective.connection} data-version={perspective.connection}>\n <VersionLink\n key={perspective.connection}\n forwardedAs={isRoot ? 'span' : undefined}\n text={label}\n routeName={name}\n selected={selected}\n aria-label={label}\n title={label}\n params={{\n ...params,\n connection: perspective.connection,\n }}\n />\n </li>\n );\n }}\n />\n );\n};\n\nexport default AnswerVersionPicker;\n\nconst StyledList = styled(List)`\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n\n list-style: none;\n padding: 0;\n margin: 0;\n\n li:not(:last-child) {\n margin: 0 calc(${(p) => p.theme.sizes?.small} * 2) 0 0;\n }\n\n li > span {\n cursor: default;\n }\n`;\n\nconst VersionLink = styled(TextLink)<{ selected: boolean }>`\n font-weight: 300;\n color: ${(p) => p.theme.colors?.text};\n text-decoration: none;\n\n ${(p) =>\n p.selected &&\n css`\n font-weight: bold;\n text-decoration: underline;\n `}\n\n &:focus-visible {\n ${paddedBorderTabStyle};\n }\n`;\n","import { ContactList } from '@telia-ace/knowledge-widget-adapters';\nimport {\n Feedback as FeedbackUi,\n StyledHeaderText,\n useDispatch,\n useProperties,\n} from '@telia-ace/knowledge-widget-ui';\nimport React from 'react';\nimport styled from 'styled-components';\nimport { GuideComponentProps } from './guide-component';\n\ntype Props = { backButtonShown?: boolean; accordion?: boolean };\n\nconst StyledContactList = styled(ContactList)<{\n accordion: 'true' | 'false';\n backButtonShown: 'true' | 'false';\n}>`\n border-top: ${(p) => p.theme.border};\n ${(p) => p.backButtonShown === 'true' && `border-bottom: ${p.theme.border};`}\n`;\n\nconst StyledFeedback = styled(FeedbackUi)<{ accordion: 'true' | 'false' }>`\n ${(p) => `padding: ${p.theme.sizes?.large} ${p.theme.sizes?.large};`}\n`;\n\nconst Recognition = styled(StyledHeaderText)<{ accordion: 'true' | 'false' }>`\n ${(p) => `padding: ${p.theme.sizes?.large} ${p.theme.sizes?.large};`}\n\n display: block;\n font-size: ${(p) => p.theme.fonts?.normal};\n font-weight: bold;\n`;\n\nconst Feedback: React.FC<Props> = ({ backButtonShown = false, accordion = false }) => {\n const dispatch = useDispatch();\n const {\n loading = false,\n dialog = [],\n guide,\n\n handoverContactMethods = [],\n contactHeader,\n\n showFeedback,\n feedbackDirection = 'horizontal',\n feedbackRecognitionLabel,\n feedbackGiven,\n feedbackHeader,\n positiveFeedbackLabel,\n negativeFeedbackLabel,\n contactFeedbackLabel,\n } = useProperties<GuideComponentProps>();\n\n if (\n !showFeedback ||\n !guide ||\n !guide.allowFeedback ||\n (loading && !feedbackGiven) ||\n dialog.length\n ) {\n return null;\n }\n\n if (feedbackGiven && feedbackRecognitionLabel && !handoverContactMethods.length) {\n return (\n <Recognition accordion={accordion ? 'true' : 'false'}>\n {feedbackRecognitionLabel}\n </Recognition>\n );\n }\n\n return guide.hasHandover && handoverContactMethods.length ? (\n <StyledContactList\n backButtonShown={backButtonShown ? 'true' : 'false'}\n accordion={accordion ? 'true' : 'false'}\n header={contactHeader}\n contactMethods={handoverContactMethods}\n dispatch={dispatch}\n />\n ) : (\n <StyledFeedback\n accordion={accordion ? 'true' : 'false'}\n positive={positiveFeedbackLabel}\n negative={guide.hasHandover ? contactFeedbackLabel : negativeFeedbackLabel}\n header={feedbackHeader}\n selected={feedbackGiven}\n onFeedback={(feedback: any) => dispatch('feedback', feedback)}\n direction={feedbackDirection}\n />\n );\n};\n\nexport default Feedback;\n","import { Category, PickerTypes } from '@telia-ace/knowledge-widget-core';\nimport {\n StyledListButton,\n SymbolBadge,\n Text,\n Tooltip,\n useContainer,\n} from '@telia-ace/knowledge-widget-ui';\nimport { buildCategoryTrail } from '@telia-ace/widget-utilities';\nimport React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { GuideProps, ToolbarProps } from './guide-component';\n\ntype Props = {\n guide: GuideProps;\n toolbar: ToolbarProps;\n};\n\nconst Categories: React.FC<Props> = ({\n guide: { categories = [] },\n toolbar: { picker = PickerTypes.NONE },\n}) => {\n const [trail, setTrail] = useState<Category[][]>([]);\n const container = useContainer();\n\n useEffect(() => {\n buildCategoryTrail(\n 'index',\n categories.map((id) => id.toString()),\n container\n ).then((result) => {\n setTrail(result);\n });\n }, [categories]);\n\n if (!trail.length) {\n return null;\n }\n\n return (\n <Tooltip\n className=\"humany-guide-category-tooltip\"\n sticky={picker === PickerTypes.DRAWER}\n content={\n <>\n {trail.map((segments) => {\n return (\n <CategoryTrail\n className=\"humany-guide-category-trail\"\n key={segments.map((c) => c.id).join('.')}\n >\n {segments.map((category, index: number) => {\n return (\n <Text\n className=\"humany-guide-category-trail-segment\"\n key={category.id}\n >\n {category.symbol && index === 0 && (\n <SymbolBadge size={14} symbol={category.symbol} />\n )}\n {category.title}\n {index !== segments.length - 1 && (\n <CategorySeparator className=\"humany-category-separator\">\n /\n </CategorySeparator>\n )}\n </Text>\n );\n })}\n </CategoryTrail>\n );\n })}\n </>\n }\n >\n {picker === PickerTypes.DRAWER ? (\n <StyledListButton\n className=\"humany-guide-category-tooltip-button\"\n data-has-label=\"false\"\n data-has-symbol=\"true\"\n >\n <CategoriesSymbolBadge\n size={19}\n symbol={{ type: 'Svg', content: 'information' }}\n />\n </StyledListButton>\n ) : (\n <CategoriesSymbolBadge size={19} symbol={{ type: 'Svg', content: 'information' }} />\n )}\n </Tooltip>\n );\n};\n\nexport default Categories;\n\nconst CategoryTrail = styled.div`\n i,\n svg {\n margin: 0 ${(p) => p.theme.sizes?.small} 0 0;\n }\n\n &:not(:last-child) {\n margin: 0 0 ${(p) => p.theme.sizes?.small};\n }\n`;\n\nconst CategorySeparator = styled(Text)`\n margin: 0 ${(p) => p.theme.sizes?.small};\n`;\n\nconst CategoriesSymbolBadge = styled(SymbolBadge)`\n display: block;\n`;\n","import { PickerTypes } from '@telia-ace/knowledge-widget-core';\nimport {\n DispatchAction,\n DrawerAnimationType,\n DrawerList,\n DropdownList,\n FavoriteButton,\n StyledListButton,\n StyledText,\n SymbolBadge,\n useFavorites,\n} from '@telia-ace/knowledge-widget-ui';\nimport React, { useCallback, useMemo } from 'react';\nimport styled from 'styled-components';\nimport { GuideProps } from './guide-component';\n\nexport type FunctionListItem = {\n type: string;\n child: React.ReactNode;\n};\n\ntype Props = {\n header?: string;\n tooltip?: string;\n printActionLabel?: string;\n copyActionLabel?: string;\n addFavoriteTooltip?: string;\n removeFavoriteCancelLabel?: string;\n removeFavoriteConfirmLabel?: string;\n removeFavoriteHeader?: string;\n removeFavoriteLabel?: string;\n removeFavoriteTooltip?: string;\n toolbarFunctionsCloseButtonAriaLabel?: string;\n guide: GuideProps;\n allowCopy?: boolean;\n allowPrint?: boolean;\n showFavoriteToggle?: boolean;\n picker?: PickerTypes;\n dispatch: DispatchAction;\n};\n\nconst Functions: React.FC<Props> = ({\n header,\n tooltip,\n printActionLabel,\n copyActionLabel,\n addFavoriteTooltip,\n removeFavoriteCancelLabel,\n removeFavoriteConfirmLabel,\n removeFavoriteHeader,\n removeFavoriteLabel,\n removeFavoriteTooltip,\n toolbarFunctionsCloseButtonAriaLabel,\n allowCopy = false,\n allowPrint = false,\n showFavoriteToggle = false,\n picker = PickerTypes.NONE,\n guide,\n dispatch,\n}) => {\n const [favorites, actions] = useFavorites();\n\n const handleCopy = useCallback(\n (event: any) => {\n if (guide) {\n dispatch('copy', guide);\n }\n },\n [guide, dispatch]\n );\n\n const handlePrint = useCallback(() => {\n if (guide) {\n dispatch('print');\n }\n }, [guide, dispatch]);\n\n const items = useMemo(() => {\n const { id, title } = guide;\n\n const items: FunctionListItem[] = [];\n\n if (allowCopy) {\n items.push({\n type: 'copy',\n child: (\n <StyledListButton\n data-has-label={copyActionLabel ? 'true' : 'false'}\n data-has-symbol=\"true\"\n title={copyActionLabel}\n aria-label={printActionLabel}\n onClick={handleCopy}\n >\n <ColoredSymbolBadge size={16} symbol={{ type: 'Svg', content: 'copy' }} />\n {copyActionLabel && <StyledText>{copyActionLabel}</StyledText>}\n </StyledListButton>\n ),\n });\n }\n\n if (allowPrint) {\n items.push({\n type: 'print',\n child: (\n <StyledListButton\n data-has-label={printActionLabel ? 'true' : 'false'}\n data-has-symbol=\"true\"\n title={printActionLabel}\n aria-label={printActionLabel}\n onClick={handlePrint}\n >\n <ColoredSymbolBadge size={16} symbol={{ type: 'Svg', content: 'print' }} />\n {printActionLabel && <StyledText>{printActionLabel}</StyledText>}\n </StyledListButton>\n ),\n });\n }\n\n if (showFavoriteToggle) {\n const isFavorite = favorites.indexOf(id) > -1;\n items.push({\n type: 'favorite',\n child: (\n <FavoriteButton\n id={id}\n guideTitle={title}\n isFavorite={isFavorite}\n buttonLabel={isFavorite ? removeFavoriteTooltip : addFavoriteTooltip}\n addFavoriteTooltip={addFavoriteTooltip}\n removeFavoriteCancelLabel={removeFavoriteCancelLabel}\n removeFavoriteConfirmLabel={removeFavoriteConfirmLabel}\n removeFavoriteHeader={removeFavoriteHeader}\n removeFavoriteLabel={removeFavoriteLabel}\n removeFavoriteTooltip={removeFavoriteTooltip}\n actions={actions}\n />\n ),\n });\n }\n\n return items;\n }, [\n favorites,\n guide,\n allowCopy,\n allowPrint,\n showFavoriteToggle,\n printActionLabel,\n copyActionLabel,\n addFavoriteTooltip,\n removeFavoriteCancelLabel,\n removeFavoriteConfirmLabel,\n removeFavoriteHeader,\n removeFavoriteLabel,\n removeFavoriteTooltip,\n ]);\n\n if (!items.length) {\n return null;\n }\n\n const trigger = (\n <StyledTriggerButton\n tabIndex={0}\n title={tooltip}\n data-has-symbol=\"true\"\n data-has-label=\"false\"\n >\n <ColoredSymbolBadge symbol={{ type: 'Svg', content: 'options' }} size={18} />\n </StyledTriggerButton>\n );\n\n const renderListItem = ({ type, child }: FunctionListItem) => {\n return (\n <li key={type} data-function-type={type}>\n {child}\n </li>\n );\n };\n\n if (picker === PickerTypes.DROPDOWN) {\n return (\n <StyledDropdownList\n className=\"humany-guide-functions-dropdown-list\"\n header={header}\n items={items}\n trigger={trigger}\n renderItem={renderListItem}\n closeButtonAriaLabel={toolbarFunctionsCloseButtonAriaLabel}\n />\n );\n }\n\n if (picker === PickerTypes.DRAWER) {\n return (\n <DrawerList\n className=\"humany-guide-functions-drawer-list\"\n animation={{ type: DrawerAnimationType.SlideInBottom }}\n header={header}\n items={items}\n trigger={trigger}\n renderItem={renderListItem}\n closeButtonAriaLabel={toolbarFunctionsCloseButtonAriaLabel}\n />\n );\n }\n\n return null;\n};\n\nexport default Functions;\n\nconst ColoredSymbolBadge = styled(SymbolBadge)`\n circle {\n fill: ${(p) => p.theme.colors?.text};\n }\n\n line,\n path,\n rect {\n stroke: ${(p) => p.theme.colors?.text};\n }\n`;\n\nconst StyledDropdownList = styled(DropdownList)`\n display: block;\n min-height: auto;\n`;\n\nconst StyledTriggerButton = styled(StyledListButton)<any>`\n padding: calc(${(p) => p.theme.sizes?.small} * 2) 0;\n`;\n","import { LanguageProperties } from '@telia-ace/knowledge-widget-component-utilities';\nimport { PickerTypes } from '@telia-ace/knowledge-widget-core';\nimport {\n DrawerAnimationType,\n DrawerList,\n DropdownList,\n paddedBorderTabStyle,\n StyledListButton,\n SymbolBadge,\n Text,\n TextLink,\n useRouteData,\n} from '@telia-ace/knowledge-widget-ui';\nimport { createParams } from '@telia-ace/widget-utilities';\nimport React, { useMemo } from 'react';\nimport styled from 'styled-components';\nimport { GuideProps } from './guide-component';\n\nexport type LanguageListItem = {\n id: string;\n key: string;\n label: string;\n};\n\ntype Props = Merge<\n {\n header?: string;\n tooltip?: string;\n guide: GuideProps;\n picker?: PickerTypes;\n },\n LanguageProperties\n>;\n\nconst getCurrentLanguageLabel = (guide: GuideProps, languages: LanguageListItem[]) => {\n return languages.find((l) => l.id === guide.id)?.label || '';\n};\n\nconst Languages: React.FC<Props> = ({\n header,\n tooltip,\n picker = PickerTypes.NONE,\n guide,\n ...other\n}) => {\n const { name, params } = useRouteData();\n\n const items = useMemo(() => {\n return Object.keys(guide.translations || {}).reduce((acc: LanguageListItem[], key) => {\n const item: Partial<LanguageListItem> = {};\n item.key = key;\n item.id = (guide.translations || {})[key];\n item.label = (other as { [key: string]: string })[`${key}LanguageLabel`];\n\n if (item.id || item.label) {\n acc.push(item as LanguageListItem);\n }\n\n return acc;\n }, []);\n }, [guide, other]);\n\n if (!items.length) {\n return null;\n }\n\n const currentLanguage = getCurrentLanguageLabel(guide, items);\n\n const trigger = (\n <Trigger\n tabIndex={0}\n title={tooltip}\n data-has-symbol=\"true\"\n data-has-label={picker === PickerTypes.DROPDOWN && currentLanguage ? 'true' : 'false'}\n >\n {picker === PickerTypes.DROPDOWN && (\n <>\n {currentLanguage && <LanguageButtonText>{currentLanguage}</LanguageButtonText>}\n <LanguageCaretSymbolBadge\n symbol={{ type: 'Svg', content: 'caret-down' }}\n size={11}\n />\n </>\n )}\n {picker === PickerTypes.DRAWER && (\n <>\n <ColoredSymbolBadge symbol={{ type: 'Svg', content: 'language' }} size={20} />\n </>\n )}\n </Trigger>\n );\n\n const renderListItem = ({ label, key, id }: LanguageListItem) => {\n return (\n <li key={key} data-language={key}>\n <LanguageLink\n tabIndex={0}\n text={label}\n routeName={name}\n selected={guide.id === id}\n params={createParams({\n ...params,\n connection: undefined,\n guide: id,\n })}\n />\n </li>\n );\n };\n\n if (picker === PickerTypes.DROPDOWN) {\n return (\n <StyledDropdownList\n className=\"humany-guide-languages-dropdown-list\"\n header={header}\n items={items}\n trigger={trigger}\n renderItem={renderListItem}\n />\n );\n }\n\n if (picker === PickerTypes.DRAWER) {\n return (\n <DrawerList\n className=\"humany-guide-languages-drawer-list\"\n animation={{ type: DrawerAnimationType.SlideInBottom }}\n header={header}\n items={items}\n trigger={trigger}\n renderItem={renderListItem}\n />\n );\n }\n\n return null;\n};\n\nexport default Languages;\n\nconst Trigger = styled(StyledListButton)`\n &&& {\n margin: 0 ${(p) => `calc(${p.theme.sizes?.small} * 2)`} 0 0;\n }\n`;\n\nconst ColoredSymbolBadge = styled(SymbolBadge)`\n circle {\n fill: ${(p) => p.theme.colors?.text};\n }\n\n line,\n path,\n rect {\n stroke: ${(p) => p.theme.colors?.text};\n }\n`;\n\nconst LanguageButtonText = styled(Text)`\n margin: 0 ${(p) => p.theme.sizes?.small} 0 0;\n font-size: ${(p) => p.theme.fonts?.normal};\n`;\n\nconst LanguageCaretSymbolBadge = styled(SymbolBadge)`\n align-self: flex-end;\n stroke-width: 2px;\n stroke-linecap: round;\n\n && {\n width: 0.6em;\n height: 1em;\n }\n line {\n stroke: ${(p) => p.theme.colors?.text};\n }\n`;\n\nconst StyledDropdownList = styled(DropdownList)`\n display: block;\n min-height: auto;\n`;\n\nconst LanguageLink = styled(TextLink)<any>`\n color: ${(p) => (p.selected ? p.theme.colors?.primary : p.theme.colors?.text)};\n ${(p) => p.selected && 'font-weight: bold;'}\n\n outline: none;\n &:focus-visible {\n ${paddedBorderTabStyle}\n text-decoration: underline;\n }\n`;\n","import { PickerTypes } from '@telia-ace/knowledge-widget-core';\nimport { DispatchAction, useProperties } from '@telia-ace/knowledge-widget-ui';\nimport { appendClassNames } from '@telia-ace/widget-utilities';\nimport React from 'react';\nimport styled from 'styled-components';\nimport Categories from './categories';\nimport Functions from './functions';\nimport { GuideComponentProps, ToolbarProps } from './guide-component';\nimport Languages from './languages';\n\ntype Props = {\n className?: string;\n dispatch: DispatchAction;\n};\n\nconst isEmpty = (toolbar: ToolbarProps) => {\n const {\n allowCopy = false,\n allowPrint = false,\n guideCategories = false,\n language = false,\n showFavoriteToggle = false,\n picker = PickerTypes.NONE,\n } = toolbar;\n\n if (\n (!allowCopy && !allowPrint && !language && !showFavoriteToggle && !guideCategories) ||\n picker === PickerTypes.NONE\n ) {\n return true;\n }\n\n return false;\n};\n\nconst Toolbar: React.FC<Props> = ({ className = '', dispatch }) => {\n const {\n toolbarLanguageHeader,\n toolbarFunctionsHeader,\n toolbarLanguageTooltip,\n toolbarFunctionsTooltip,\n toolbarFunctionsCloseButtonAriaLabel,\n printActionLabel,\n copyActionLabel,\n addFavoriteTooltip,\n removeFavoriteCancelLabel,\n removeFavoriteConfirmLabel,\n removeFavoriteHeader,\n removeFavoriteLabel,\n removeFavoriteTooltip,\n guide,\n toolbar,\n ...other\n } = useProperties<GuideComponentProps>();\n\n if (!guide || !toolbar || isEmpty(toolbar)) {\n return null;\n }\n\n const { language, guideCategories, allowCopy, allowPrint, showFavoriteToggle, picker } =\n toolbar;\n\n return (\n <Wrapper className={appendClassNames('humany-guide-toolbar', className)}>\n {language && Object.keys(guide.translations || {}).length > 1 && (\n <Languages\n guide={guide}\n header={toolbarLanguageHeader}\n tooltip={toolbarLanguageTooltip}\n picker={picker}\n {...other}\n />\n )}\n {guideCategories && <Categories guide={guide} toolbar={toolbar} />}\n {(allowCopy || allowPrint || showFavoriteToggle) && (\n <Functions\n guide={guide}\n header={toolbarFunctionsHeader}\n tooltip={toolbarFunctionsTooltip}\n printActionLabel={printActionLabel}\n copyActionLabel={copyActionLabel}\n addFavoriteTooltip={addFavoriteTooltip}\n removeFavoriteCancelLabel={removeFavoriteCancelLabel}\n removeFavoriteConfirmLabel={removeFavoriteConfirmLabel}\n removeFavoriteHeader={removeFavoriteHeader}\n removeFavoriteLabel={removeFavoriteLabel}\n removeFavoriteTooltip={removeFavoriteTooltip}\n toolbarFunctionsCloseButtonAriaLabel={toolbarFunctionsCloseButtonAriaLabel}\n allowCopy={allowCopy}\n allowPrint={allowPrint}\n showFavoriteToggle={showFavoriteToggle}\n picker={picker}\n dispatch={dispatch}\n />\n )}\n </Wrapper>\n );\n};\n\nexport default Toolbar;\n\nconst Wrapper = styled.div`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin: 0 0 0 auto;\n\n > :not(:last-child) {\n margin: 0 calc(${(p) => p.theme.sizes?.small} * 2) 0 0;\n }\n`;\n","import { contactLink, ContactList } from '@telia-ace/knowledge-widget-adapters';\nimport { Component, NotFound } from '@telia-ace/knowledge-widget-types-grid';\nimport {\n Button,\n contentBox,\n createEmptyComponent,\n DialogLink,\n DialogList,\n embeddedLinkMapper,\n genericHtml,\n headingElement,\n Lightbox,\n linkTabStyle,\n Loader,\n loadingOpacity,\n Metadata,\n Paragraph,\n useChildren,\n useContainer,\n useDispatch,\n useProperties,\n useRouteData,\n} from '@telia-ace/knowledge-widget-ui';\nimport { appendClassNames } from '@telia-ace/widget-utilities';\nimport React, { forwardRef, useCallback, useMemo } from 'react';\nimport styled, { css } from 'styled-components';\nimport AnswerVersionPicker from './answer-version-picker';\nimport Feedback from './feedback';\nimport { GuideComponentProps } from './guide-component';\nimport Toolbar from './toolbar';\n\ntype Props = { className: string; accordion?: boolean };\n\nconst Guide = forwardRef<HTMLDivElement, Props>(\n ({ className, accordion = false, ...other }, ref) => {\n const {\n loading = false,\n dialog = [],\n contactMethods = [],\n showHeader = true,\n showAnswerVersions = false,\n defaultAnswerVersionLabel = 'Default',\n backButtonLabel,\n metadataByLabel,\n metadataModifiedLabel,\n metadataPublishedLabel,\n availablePerspectives,\n metadata,\n toolbar,\n guide,\n error,\n } = useProperties<GuideComponentProps>();\n const {\n params: { connection },\n } = useRouteData();\n const container = useContainer();\n const children = useChildren();\n const dispatch = useDispatch();\n\n const transform = useMemo(() => {\n return {\n transform: {\n img: (attrs: any) => (\n <Lightbox attrs={attrs} htmlBody={guide?.body || ''}></Lightbox>\n ),\n a: (attr: any) => {\n const { children, ...otherAttr } = attr;\n const connectionId = otherAttr['data-target'];\n if (connectionId && dialog.length) {\n const item = dialog.find(\n ({ connection }: any) => connection === connectionId\n );\n if (item) {\n return <DialogLink {...item}>{children}</DialogLink>;\n }\n }\n\n const defaultInstructions = embeddedLinkMapper(container);\n\n return defaultInstructions(attr);\n },\n },\n };\n }, [guide, container, dialog]);\n\n const handleBackButtonClick = useCallback(() => {\n dispatch('back');\n }, [dispatch]);\n\n if (!guide && !error && !loading) {\n return createEmptyComponent(container, {\n ...other,\n className: appendClassNames(className, 'humany-guide'),\n });\n }\n\n const { id = '', title = '', body = '', translations = {} } = guide || {};\n\n if (error && error.status === 404) {\n return <NotFound showSearch={false} />;\n }\n\n const showBackButton = !!accordion && !!connection;\n const language = Object.keys(translations).find((key) => translations[key] === `${id}`);\n\n return (\n <Wrapper\n ref={ref}\n {...other}\n data-loading={loading}\n className={appendClassNames(className, 'humany-guide')}\n >\n <Content\n data-loading={loading}\n accordion={accordion ? 'true' : 'false'}\n className=\"humany-guide-content\"\n >\n {((showAnswerVersions && guide) || !!toolbar) && (\n <Top className=\"humany-guide-top\">\n {showAnswerVersions && guide && (\n <AnswerVersionPicker\n defaultAnswerVersionLabel={defaultAnswerVersionLabel}\n availablePerspectives={availablePerspectives}\n guide={guide}\n />\n )}\n {!!toolbar && <Toolbar dispatch={dispatch} />}\n </Top>\n )}\n {!!(title || body) && (\n <Body\n className=\"humany-guide-body\"\n accordion={accordion ? 'true' : 'false'}\n header={(showHeader && title) || undefined}\n html={body}\n htmlParseInstruction={transform}\n lang={language}\n />\n )}\n {dialog && body.indexOf('h-option-link') === -1 && (\n <StyledDialogList dialog={dialog} />\n )}\n <StyledContactList\n backButtonShown={showBackButton ? 'true' : 'false'}\n contactMethods={contactMethods}\n dispatch={dispatch}\n guideId={guide && guide.id}\n />\n {!contactMethods.length && (\n <Feedback backButtonShown={showBackButton} accordion={accordion} />\n )}\n {showBackButton && (\n <BackButton aria-label={backButtonLabel} onClick={handleBackButtonClick}>\n <Caret\n width=\"7\"\n height=\"13\"\n viewBox=\"0 0 7 13\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <line x1=\"6.64645\" y1=\"12.5513\" x2=\"0.648357\" y2=\"6.55319\" />\n <line x1=\"0.646447\" y1=\"6.64455\" x2=\"6.64454\" y2=\"0.646465\" />\n </Caret>\n {backButtonLabel && <span>{backButtonLabel}</span>}\n </BackButton>\n )}\n {metadata && (\n <StyledMetadata\n {...metadata}\n modified={guide?.modified}\n published={guide?.published}\n modifiedBy={guide?.modifiedBy}\n publishedBy={guide?.publishedBy}\n byLabel={metadataByLabel}\n modifiedLabel={metadataModifiedLabel}\n publishedLabel={metadataPublishedLabel}\n />\n )}\n {children.map((child) => (\n <StyledComponents\n key={child.id}\n id={child.id}\n branch=\"default\"\n {...{ embedded: true }}\n />\n ))}\n </Content>\n\n <Loader loading={loading} />\n </Wrapper>\n );\n }\n);\n\nexport default Guide;\n\nconst Wrapper = styled.div<{ 'data-loading': boolean }>`\n ${loadingOpacity}\n min-width: 0;\n`;\n\nconst Body = styled(Paragraph)<{ accordion: 'true' | 'false' }>`\n ${genericHtml}\n ${(p) => `padding: ${p.theme.sizes?.large};`}\n display: block;\n line-height: 1.6em;\n ${headingElement(\n 'h1',\n css`\n font-size: ${(p) => p.theme.fonts?.large};\n font-weight: normal;\n line-height: 1.6em;\n line-height: 1.6em;\n margin: 0 0 ${(p) => p.theme.sizes?.small};\n `\n )}\n\n p {\n font-weight: 300;\n font-size: ${(p) => p.theme.fonts?.normal};\n color: ${(p) => p.theme.colors?.text};\n a {\n display: inline;\n }\n }\n`;\n\nconst StyledContactList = styled(ContactList)<{ backButtonShown: 'true' | 'false' }>`\n border-top: ${(p) => p.theme.border};\n ${(p) => p.backButtonShown === 'true' && `border-bottom: ${p.theme.border};`}\n`;\n\nconst StyledDialogList = styled(DialogList)`\n ${(p) => `padding: 0 ${p.theme.sizes?.large} ${p.theme.sizes?.large};`}\n display: block;\n`;\n\nconst Top = styled.div`\n ${(p) => `padding: calc(${p.theme.sizes?.normal}*2) ${p.theme.sizes?.large};`}\n display: flex;\n justify-content: space-between;\n align-items: center;\n border-bottom: ${(p) => p.theme.border};\n border-radius: ${(p) => `${p.theme.borderRadius} ${p.theme.borderRadius}`} 0 0;\n background-color: #ffffff;\n`;\n\nconst Content = styled.div<{ 'data-loading': boolean; accordion: 'true' | 'false' } & any>`\n ${contentBox}\n display: block;\n > a {\n ${contactLink}\n }\n\n ${(p) =>\n p.accordion === 'true' &&\n css`\n white-space: normal;\n box-shadow: none;\n background-color: #fafafa;\n `}\n`;\n\nconst StyledMetadata = styled(Metadata)`\n display: block;\n ${(p) => `padding: calc(${p.theme.sizes?.normal}*2) ${p.theme.sizes?.large};`}\n font-weight: 300;\n font-size: ${(p) => p.theme.fonts?.normal};\n color: ${(p) => p.theme.colors?.text};\n border-top: ${(p) => p.theme.border};\n`;\n\nconst StyledComponents = styled(Component)`\n border-top: ${(p) => p.theme.border};\n`;\n\nconst BackButton = styled(Button)`\n ${(p) => `padding: ${p.theme.sizes?.normal} calc(${p.theme.sizes?.normal} * 2);`}\n color: ${(p) => p.theme.colors?.primary};\n text-decoration: underline;\n font-size: ${(p) => p.theme.fonts?.normal};\n span {\n font-weight: 300;\n }\n &:focus-visible {\n ${linkTabStyle}\n padding: ${(p) => `calc(${p.theme.sizes?.small} / 2) ${p.theme.sizes?.small}`};\n }\n`;\n\nconst Caret = styled.svg`\n margin-right: ${(p) => p.theme.sizes?.small};\n line {\n stroke: ${(p) => p.theme.colors?.primary};\n }\n`;\n"],"names":["AnswerVersionPicker","className","defaultAnswerVersionLabel","selectedPerspective","guidePerspectives","availablePerspectives","name","params","useRouteData","perspectives","useMemo","title","React","StyledList","appendClassNames","perspective","label","selected","isRoot","VersionLink","__spreadProps","__spreadValues","styled","List","p","_a","TextLink","css","paddedBorderTabStyle","StyledContactList","ContactList","StyledFeedback","FeedbackUi","_b","Recognition","StyledHeaderText","Feedback","backButtonShown","accordion","dispatch","useDispatch","loading","dialog","guide","handoverContactMethods","contactHeader","showFeedback","feedbackDirection","feedbackRecognitionLabel","feedbackGiven","feedbackHeader","positiveFeedbackLabel","negativeFeedbackLabel","contactFeedbackLabel","useProperties","feedback","Categories","categories","picker","PickerTypes","trail","setTrail","useState","container","useContainer","useEffect","buildCategoryTrail","id","result","Tooltip","segments","CategoryTrail","c","category","index","Text","SymbolBadge","CategorySeparator","StyledListButton","CategoriesSymbolBadge","Functions","header","tooltip","printActionLabel","copyActionLabel","addFavoriteTooltip","removeFavoriteCancelLabel","removeFavoriteConfirmLabel","removeFavoriteHeader","removeFavoriteLabel","removeFavoriteTooltip","toolbarFunctionsCloseButtonAriaLabel","allowCopy","allowPrint","showFavoriteToggle","favorites","actions","useFavorites","handleCopy","useCallback","event","handlePrint","items","ColoredSymbolBadge","StyledText","isFavorite","FavoriteButton","trigger","StyledTriggerButton","renderListItem","type","child","StyledDropdownList","DrawerList","DrawerAnimationType","DropdownList","getCurrentLanguageLabel","languages","l","Languages","other","__objRest","acc","key","item","currentLanguage","Trigger","LanguageButtonText","LanguageCaretSymbolBadge","LanguageLink","createParams","isEmpty","toolbar","guideCategories","language","Toolbar","toolbarLanguageHeader","toolbarFunctionsHeader","toolbarLanguageTooltip","toolbarFunctionsTooltip","Wrapper","Guide","forwardRef","ref","contactMethods","showHeader","showAnswerVersions","backButtonLabel","metadataByLabel","metadataModifiedLabel","metadataPublishedLabel","metadata","error","connection","children","useChildren","transform","attrs","Lightbox","attr","connectionId","DialogLink","embeddedLinkMapper","handleBackButtonClick","createEmptyComponent","body","translations","NotFound","showBackButton","Content","Top","Body","StyledDialogList","BackButton","Caret","StyledMetadata","StyledComponents","Loader","loadingOpacity","Paragraph","genericHtml","headingElement","DialogList","contentBox","contactLink","Metadata","Component","Button","linkTabStyle"],"mappings":"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"}
package/dist/guide.d.ts CHANGED
@@ -1,7 +1,7 @@
1
- import React from 'react';
2
- declare type Props = {
3
- className: string;
4
- accordion?: boolean;
5
- };
6
- declare const Guide: React.ForwardRefExoticComponent<Props & React.RefAttributes<HTMLDivElement>>;
7
- export default Guide;
1
+ import React from 'react';
2
+ declare type Props = {
3
+ className: string;
4
+ accordion?: boolean;
5
+ };
6
+ declare const Guide: React.ForwardRefExoticComponent<Props & React.RefAttributes<HTMLDivElement>>;
7
+ export default Guide;
package/dist/index.d.ts CHANGED
@@ -1,2 +1,2 @@
1
- import GuideComponent from './guide-component';
2
- export default GuideComponent;
1
+ import GuideComponent from './guide-component';
2
+ export default GuideComponent;
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/use-feedback.ts","../src/guide-component.ts"],"sourcesContent":["import { updateForm } from '@telia-ace/knowledge-widget-component-utilities';\r\nimport { ComponentNodeController } from '@telia-ace/knowledge-widget-core';\r\nimport {\r\n ContactsResult,\r\n DataClient,\r\n DataType,\r\n FeedbackType,\r\n} from '@telia-ace/knowledge-widget-types-grid';\r\nimport { Container } from '@webprovisions/platform';\r\nimport { GuideComponentProps } from './guide-component';\r\n\r\nexport default (container: Container, controller: ComponentNodeController) => {\r\n controller.actions.create('feedback', (input: 'negative' | 'positive') => {\r\n const type = input === 'negative' ? FeedbackType.Negative : FeedbackType.Positive;\r\n const { guide, submitButtonLabel = 'Submit' } =\r\n controller.properties<GuideComponentProps>();\r\n if (guide) {\r\n const { connection, id, hasHandover } = guide;\r\n controller.writeProperties({\r\n feedbackGiven: input,\r\n loading: hasHandover && type === FeedbackType.Negative,\r\n });\r\n\r\n const { events } = container.get('$widget');\r\n events.dispatch('tracking:feedback-given', {\r\n guide,\r\n categories: guide.categories,\r\n feedbackType: type.toLowerCase(),\r\n });\r\n\r\n return container.getAsync('dataClient').then((dataClient: DataClient) => {\r\n return dataClient.feedback(id, connection, type).then(() => {\r\n if (hasHandover && type === FeedbackType.Negative) {\r\n return dataClient\r\n .fetch(DataType.ContactMethods, { guideId: id })\r\n .then(({ contactMethods }: ContactsResult) => {\r\n return controller.actions.dispatch('handover', {\r\n handoverContactMethods: contactMethods.map((cm) => ({\r\n ...cm,\r\n body: updateForm(cm, {\r\n submit: submitButtonLabel,\r\n }),\r\n })),\r\n loading: false,\r\n });\r\n });\r\n }\r\n });\r\n });\r\n }\r\n });\r\n\r\n controller.actions.create('handover', (input) => {\r\n return controller.writeProperties({ ...input, loading: false });\r\n });\r\n};\r\n","import { ContactMethodType } from '@telia-ace/knowledge-widget-adapters';\r\nimport {\r\n FavoriteProperties,\r\n LanguageProperties,\r\n MetaDataProperties,\r\n updateForm,\r\n useExpand,\r\n useForm,\r\n} from '@telia-ace/knowledge-widget-component-utilities';\r\nimport {\r\n createEventSubscriber,\r\n DialogItem,\r\n extendComponent,\r\n PickerTypes,\r\n} from '@telia-ace/knowledge-widget-core';\r\nimport {\r\n DataClient,\r\n DataError,\r\n DataType,\r\n GuideResult,\r\n} from '@telia-ace/knowledge-widget-types-grid';\r\nimport { createReactComponent } from '@telia-ace/knowledge-widget-ui';\r\nimport { FormComponentInstanceProperties } from '@telia-ace/widget-forms';\r\nimport { RoutingService } from '@telia-ace/widget-routing';\r\nimport { Container, EventManager } from '@webprovisions/platform';\r\nimport * as clipboard from 'clipboard-polyfill';\r\nimport useFeedback from './use-feedback';\r\n\r\nexport type GuideProps = {\r\n id: string;\r\n title: string;\r\n body: string;\r\n connection: string;\r\n categories: number[];\r\n hasHandover: boolean;\r\n allowFeedback: boolean;\r\n perspectives: { [key: string]: string };\r\n translations?: { [key: string]: string };\r\n modified?: string;\r\n published?: string;\r\n publishedBy?: string | null;\r\n modifiedBy?: string | null;\r\n perspective: string | null;\r\n};\r\n\r\nexport type AvailablePerspectives = {\r\n name: string;\r\n title: string;\r\n};\r\n\r\nexport type GuideComponentProps = {\r\n showHeader?: boolean;\r\n showFeedback?: boolean;\r\n feedbackDirection?: 'horizontal' | 'vertical';\r\n feedbackGiven?: 'positive' | 'negative'; // internal\r\n contactMethods?: ContactMethodType[]; // internal\r\n handoverContactMethods?: ContactMethodType[]; // internal\r\n showAnswerVersions?: boolean;\r\n feedbackHeader?: string;\r\n contactHeader?: string;\r\n toolbarFunctionsHeader?: string;\r\n toolbarLanguageHeader?: string;\r\n positiveFeedbackLabel?: string;\r\n negativeFeedbackLabel?: string;\r\n contactFeedbackLabel?: string;\r\n feedbackRecognitionLabel?: string;\r\n defaultAnswerVersionLabel?: string;\r\n backButtonLabel?: string;\r\n toolbarFunctionsTooltip?: string;\r\n toolbarFunctionsCloseButtonAriaLabel?: string;\r\n copyActionLabel?: string;\r\n printActionLabel?: string;\r\n toolbarLanguageTooltip?: string;\r\n toolbar?: ToolbarProps;\r\n guide?: GuideProps; // internal\r\n dialog?: DialogItem[]; // internal\r\n error?: DataError; // internal\r\n availablePerspectives?: AvailablePerspectives[]; // internal\r\n} & FormComponentInstanceProperties &\r\n FavoriteProperties &\r\n MetaDataProperties &\r\n LanguageProperties;\r\n\r\nexport type ToolbarProps = {\r\n language?: boolean;\r\n guideCategories?: boolean;\r\n allowCopy?: boolean;\r\n allowPrint?: boolean;\r\n showFavoriteToggle?: boolean;\r\n picker?: PickerTypes;\r\n};\r\n\r\nconst buildPlainText = ({ title, body }: GuideProps): string => {\r\n let processedHtml = '';\r\n\r\n if (title && title.length) {\r\n processedHtml = title.trim();\r\n }\r\n\r\n if (body && body.length) {\r\n processedHtml = `${processedHtml.trim()}\\n${body.trim()}`;\r\n }\r\n\r\n const div = document.createElement('div');\r\n div.innerHTML = processedHtml;\r\n const links: HTMLAnchorElement[] = Array.from(div.getElementsByTagName('a'));\r\n\r\n let plainText = div.innerText;\r\n\r\n links.forEach((a) => {\r\n plainText = plainText.replace(a.innerText, `[${a.href}] (${a.innerText})`);\r\n });\r\n\r\n return plainText;\r\n};\r\n\r\nconst buildHtml = ({ title, body }: GuideProps): string => {\r\n let processedHtml = '';\r\n\r\n if (title && title.length) {\r\n processedHtml = `<h2>${title.trim()}</h2>`;\r\n }\r\n\r\n if (body && body.length) {\r\n processedHtml = `${processedHtml.trim()}${body.trim()}`;\r\n }\r\n\r\n return processedHtml.trim();\r\n};\r\n\r\nexport const GuideComponent = (container: Container) => {\r\n const { events }: { events: EventManager } = container.get('$widget');\r\n const [subscribe, unsubscribe] = createEventSubscriber(events);\r\n\r\n return createReactComponent(container, 'guide', import('./guide'), (component) => {\r\n const fetch = (params: { [key: string]: any }) => {\r\n component.writeProperties({\r\n loading: true,\r\n error: undefined,\r\n guide: undefined,\r\n });\r\n component.actions.dispatch('fetch', { params });\r\n };\r\n\r\n component.actions.create('copy', (guide: GuideProps) => {\r\n const item = new clipboard.ClipboardItem({\r\n 'text/html': new Blob([buildHtml(guide)], { type: 'text/html' }),\r\n 'text/plain': new Blob([buildPlainText(guide)], { type: 'text/plain' }),\r\n });\r\n\r\n return clipboard.write([item]).then(() => {\r\n events.dispatch('widget:menu-toggled', null);\r\n });\r\n });\r\n\r\n component.actions.create('print', () => {\r\n const elem = document.querySelector('.humany-guide .humany-paragraph');\r\n const a = window.open('', '', 'height=500, width=500');\r\n\r\n events.dispatch('widget:menu-toggled', null);\r\n if (elem && a) {\r\n a.document.write(`<html><body>${elem.innerHTML}</body></html>`);\r\n a.document.close();\r\n a.print();\r\n }\r\n });\r\n\r\n component.actions.create('back', (data, options) => {\r\n if (options.preventDefault) {\r\n return;\r\n }\r\n\r\n return container.getAsync('router').then((router: RoutingService) => {\r\n router.goBack();\r\n });\r\n });\r\n\r\n component.actions.create(\r\n 'fetch',\r\n ({ contactMethods = [], dialog = [], guide, error }: GuideResult) => {\r\n if (error) {\r\n return component.actions.dispatch('fetched', {\r\n error,\r\n guide: undefined,\r\n contactMethods: [],\r\n feedbackGiven: undefined,\r\n handoverContactMethods: [],\r\n showFeedback: false,\r\n loading: true,\r\n });\r\n }\r\n const { showFeedback = true, submitButtonLabel = 'Submit' } =\r\n component.properties<GuideComponentProps>();\r\n\r\n const properties: GuideComponentProps = {\r\n showFeedback,\r\n dialog,\r\n guide,\r\n feedbackGiven: undefined,\r\n handoverContactMethods: [],\r\n contactMethods: contactMethods.map((cm) => ({\r\n ...cm,\r\n body: updateForm(cm, { submit: submitButtonLabel }),\r\n })),\r\n };\r\n\r\n return component.actions.dispatch('fetched', {\r\n ...properties,\r\n loading: true,\r\n });\r\n }\r\n );\r\n\r\n component.actions.create('fetched', (input) => {\r\n return component.writeProperties({ ...input, loading: false });\r\n });\r\n\r\n container.getAsync('router').then((router) => {\r\n const { params } = router.getRouteData();\r\n fetch(params);\r\n });\r\n\r\n subscribe('router:changed', (event: any, { current }: any) => {\r\n fetch(current.routeData.params);\r\n });\r\n\r\n useFeedback(container, component);\r\n useForm(container, component);\r\n useExpand(component);\r\n })\r\n .then(() => {\r\n return extendComponent(container, 'guide', (component) => {\r\n component.actions.watch('guide.fetch', (input, next) => {\r\n const {\r\n params: { guide, connection },\r\n } = input;\r\n\r\n if (guide) {\r\n return container\r\n .getAsync('dataClient')\r\n .then((dataClient: DataClient) =>\r\n dataClient.fetch(DataType.Guide, { connection, guideId: guide })\r\n )\r\n .then(next)\r\n .catch((error) => {\r\n if (error) {\r\n return next(error);\r\n }\r\n });\r\n }\r\n\r\n return next(input);\r\n });\r\n });\r\n })\r\n .then(() => {\r\n unsubscribe();\r\n });\r\n};\r\n\r\nexport default GuideComponent;\r\n"],"names":["useFeedback","container","controller","input","type","FeedbackType","guide","submitButtonLabel","connection","id","hasHandover","events","dataClient","DataType","contactMethods","cm","__spreadProps","__spreadValues","updateForm","buildPlainText","title","body","processedHtml","div","links","plainText","a","buildHtml","GuideComponent","subscribe","unsubscribe","createEventSubscriber","createReactComponent","component","fetch","params","item","clipboard","elem","data","options","router","dialog","error","showFeedback","properties","event","current","useForm","useExpand","extendComponent","next"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/use-feedback.ts","../src/guide-component.ts"],"sourcesContent":["import { updateForm } from '@telia-ace/knowledge-widget-component-utilities';\nimport { ComponentNodeController } from '@telia-ace/knowledge-widget-core';\nimport {\n ContactsResult,\n DataClient,\n DataType,\n FeedbackType,\n} from '@telia-ace/knowledge-widget-types-grid';\nimport { Container } from '@webprovisions/platform';\nimport { GuideComponentProps } from './guide-component';\n\nexport default (container: Container, controller: ComponentNodeController) => {\n controller.actions.create('feedback', (input: 'negative' | 'positive') => {\n const type = input === 'negative' ? FeedbackType.Negative : FeedbackType.Positive;\n const { guide, submitButtonLabel = 'Submit' } =\n controller.properties<GuideComponentProps>();\n if (guide) {\n const { connection, id, hasHandover } = guide;\n controller.writeProperties({\n feedbackGiven: input,\n loading: hasHandover && type === FeedbackType.Negative,\n });\n\n const { events } = container.get('$widget');\n events.dispatch('tracking:feedback-given', {\n guide,\n categories: guide.categories,\n feedbackType: type.toLowerCase(),\n });\n\n return container.getAsync('dataClient').then((dataClient: DataClient) => {\n return dataClient.feedback(id, connection, type).then(() => {\n if (hasHandover && type === FeedbackType.Negative) {\n return dataClient\n .fetch(DataType.ContactMethods, { guideId: id })\n .then(({ contactMethods }: ContactsResult) => {\n return controller.actions.dispatch('handover', {\n handoverContactMethods: contactMethods.map((cm) => ({\n ...cm,\n body: updateForm(cm, {\n submit: submitButtonLabel,\n }),\n })),\n loading: false,\n });\n });\n }\n });\n });\n }\n });\n\n controller.actions.create('handover', (input) => {\n return controller.writeProperties({ ...input, loading: false });\n });\n};\n","import { ContactMethodType } from '@telia-ace/knowledge-widget-adapters';\nimport {\n FavoriteProperties,\n LanguageProperties,\n MetaDataProperties,\n updateForm,\n useExpand,\n useForm,\n} from '@telia-ace/knowledge-widget-component-utilities';\nimport {\n createEventSubscriber,\n DialogItem,\n extendComponent,\n PickerTypes,\n} from '@telia-ace/knowledge-widget-core';\nimport {\n DataClient,\n DataError,\n DataType,\n GuideResult,\n} from '@telia-ace/knowledge-widget-types-grid';\nimport { createReactComponent } from '@telia-ace/knowledge-widget-ui';\nimport { FormComponentInstanceProperties } from '@telia-ace/widget-forms';\nimport { RoutingService } from '@telia-ace/widget-routing';\nimport { Container, EventManager } from '@webprovisions/platform';\nimport * as clipboard from 'clipboard-polyfill';\nimport useFeedback from './use-feedback';\n\nexport type GuideProps = {\n id: string;\n title: string;\n body: string;\n connection: string;\n categories: number[];\n hasHandover: boolean;\n allowFeedback: boolean;\n perspectives: { [key: string]: string };\n translations?: { [key: string]: string };\n modified?: string;\n published?: string;\n publishedBy?: string | null;\n modifiedBy?: string | null;\n perspective: string | null;\n};\n\nexport type AvailablePerspectives = {\n name: string;\n title: string;\n};\n\nexport type GuideComponentProps = {\n showHeader?: boolean;\n showFeedback?: boolean;\n feedbackDirection?: 'horizontal' | 'vertical';\n feedbackGiven?: 'positive' | 'negative'; // internal\n contactMethods?: ContactMethodType[]; // internal\n handoverContactMethods?: ContactMethodType[]; // internal\n showAnswerVersions?: boolean;\n feedbackHeader?: string;\n contactHeader?: string;\n toolbarFunctionsHeader?: string;\n toolbarLanguageHeader?: string;\n positiveFeedbackLabel?: string;\n negativeFeedbackLabel?: string;\n contactFeedbackLabel?: string;\n feedbackRecognitionLabel?: string;\n defaultAnswerVersionLabel?: string;\n backButtonLabel?: string;\n toolbarFunctionsTooltip?: string;\n toolbarFunctionsCloseButtonAriaLabel?: string;\n copyActionLabel?: string;\n printActionLabel?: string;\n toolbarLanguageTooltip?: string;\n toolbar?: ToolbarProps;\n guide?: GuideProps; // internal\n dialog?: DialogItem[]; // internal\n error?: DataError; // internal\n availablePerspectives?: AvailablePerspectives[]; // internal\n} & FormComponentInstanceProperties &\n FavoriteProperties &\n MetaDataProperties &\n LanguageProperties;\n\nexport type ToolbarProps = {\n language?: boolean;\n guideCategories?: boolean;\n allowCopy?: boolean;\n allowPrint?: boolean;\n showFavoriteToggle?: boolean;\n picker?: PickerTypes;\n};\n\nconst buildPlainText = ({ title, body }: GuideProps): string => {\n let processedHtml = '';\n\n if (title && title.length) {\n processedHtml = title.trim();\n }\n\n if (body && body.length) {\n processedHtml = `${processedHtml.trim()}\\n${body.trim()}`;\n }\n\n const div = document.createElement('div');\n div.innerHTML = processedHtml;\n const links: HTMLAnchorElement[] = Array.from(div.getElementsByTagName('a'));\n\n let plainText = div.innerText;\n\n links.forEach((a) => {\n plainText = plainText.replace(a.innerText, `[${a.href}] (${a.innerText})`);\n });\n\n return plainText;\n};\n\nconst buildHtml = ({ title, body }: GuideProps): string => {\n let processedHtml = '';\n\n if (title && title.length) {\n processedHtml = `<h2>${title.trim()}</h2>`;\n }\n\n if (body && body.length) {\n processedHtml = `${processedHtml.trim()}${body.trim()}`;\n }\n\n return processedHtml.trim();\n};\n\nexport const GuideComponent = (container: Container) => {\n const { events }: { events: EventManager } = container.get('$widget');\n const [subscribe, unsubscribe] = createEventSubscriber(events);\n\n return createReactComponent(container, 'guide', import('./guide'), (component) => {\n const fetch = (params: { [key: string]: any }) => {\n component.writeProperties({\n loading: true,\n error: undefined,\n guide: undefined,\n });\n component.actions.dispatch('fetch', { params });\n };\n\n component.actions.create('copy', (guide: GuideProps) => {\n const item = new clipboard.ClipboardItem({\n 'text/html': new Blob([buildHtml(guide)], { type: 'text/html' }),\n 'text/plain': new Blob([buildPlainText(guide)], { type: 'text/plain' }),\n });\n\n return clipboard.write([item]).then(() => {\n events.dispatch('widget:menu-toggled', null);\n });\n });\n\n component.actions.create('print', () => {\n const elem = document.querySelector('.humany-guide .humany-paragraph');\n const a = window.open('', '', 'height=500, width=500');\n\n events.dispatch('widget:menu-toggled', null);\n if (elem && a) {\n a.document.write(`<html><body>${elem.innerHTML}</body></html>`);\n a.document.close();\n a.print();\n }\n });\n\n component.actions.create('back', (data, options) => {\n if (options.preventDefault) {\n return;\n }\n\n return container.getAsync('router').then((router: RoutingService) => {\n router.goBack();\n });\n });\n\n component.actions.create(\n 'fetch',\n ({ contactMethods = [], dialog = [], guide, error }: GuideResult) => {\n if (error) {\n return component.actions.dispatch('fetched', {\n error,\n guide: undefined,\n contactMethods: [],\n feedbackGiven: undefined,\n handoverContactMethods: [],\n showFeedback: false,\n loading: true,\n });\n }\n const { showFeedback = true, submitButtonLabel = 'Submit' } =\n component.properties<GuideComponentProps>();\n\n const properties: GuideComponentProps = {\n showFeedback,\n dialog,\n guide,\n feedbackGiven: undefined,\n handoverContactMethods: [],\n contactMethods: contactMethods.map((cm) => ({\n ...cm,\n body: updateForm(cm, { submit: submitButtonLabel }),\n })),\n };\n\n return component.actions.dispatch('fetched', {\n ...properties,\n loading: true,\n });\n }\n );\n\n component.actions.create('fetched', (input) => {\n return component.writeProperties({ ...input, loading: false });\n });\n\n container.getAsync('router').then((router) => {\n const { params } = router.getRouteData();\n fetch(params);\n });\n\n subscribe('router:changed', (event: any, { current }: any) => {\n fetch(current.routeData.params);\n });\n\n useFeedback(container, component);\n useForm(container, component);\n useExpand(component);\n })\n .then(() => {\n return extendComponent(container, 'guide', (component) => {\n component.actions.watch('guide.fetch', (input, next) => {\n const {\n params: { guide, connection },\n } = input;\n\n if (guide) {\n return container\n .getAsync('dataClient')\n .then((dataClient: DataClient) =>\n dataClient.fetch(DataType.Guide, { connection, guideId: guide })\n )\n .then(next)\n .catch((error) => {\n if (error) {\n return next(error);\n }\n });\n }\n\n return next(input);\n });\n });\n })\n .then(() => {\n unsubscribe();\n });\n};\n\nexport default GuideComponent;\n"],"names":["useFeedback","container","controller","input","type","FeedbackType","guide","submitButtonLabel","connection","id","hasHandover","events","dataClient","DataType","contactMethods","cm","__spreadProps","__spreadValues","updateForm","buildPlainText","title","body","processedHtml","div","links","plainText","a","buildHtml","GuideComponent","subscribe","unsubscribe","createEventSubscriber","createReactComponent","component","fetch","params","item","clipboard","elem","data","options","router","dialog","error","showFeedback","properties","event","current","useForm","useExpand","extendComponent","next"],"mappings":"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"}
@@ -1,17 +1,17 @@
1
- import { LanguageProperties } from '@telia-ace/knowledge-widget-component-utilities';
2
- import { PickerTypes } from '@telia-ace/knowledge-widget-core';
3
- import React from 'react';
4
- import { GuideProps } from './guide-component';
5
- export declare type LanguageListItem = {
6
- id: string;
7
- key: string;
8
- label: string;
9
- };
10
- declare type Props = Merge<{
11
- header?: string;
12
- tooltip?: string;
13
- guide: GuideProps;
14
- picker?: PickerTypes;
15
- }, LanguageProperties>;
16
- declare const Languages: React.FC<Props>;
17
- export default Languages;
1
+ import { LanguageProperties } from '@telia-ace/knowledge-widget-component-utilities';
2
+ import { PickerTypes } from '@telia-ace/knowledge-widget-core';
3
+ import React from 'react';
4
+ import { GuideProps } from './guide-component';
5
+ export declare type LanguageListItem = {
6
+ id: string;
7
+ key: string;
8
+ label: string;
9
+ };
10
+ declare type Props = Merge<{
11
+ header?: string;
12
+ tooltip?: string;
13
+ guide: GuideProps;
14
+ picker?: PickerTypes;
15
+ }, LanguageProperties>;
16
+ declare const Languages: React.FC<Props>;
17
+ export default Languages;
package/dist/toolbar.d.ts CHANGED
@@ -1,8 +1,8 @@
1
- import { DispatchAction } from '@telia-ace/knowledge-widget-ui';
2
- import React from 'react';
3
- declare type Props = {
4
- className?: string;
5
- dispatch: DispatchAction;
6
- };
7
- declare const Toolbar: React.FC<Props>;
8
- export default Toolbar;
1
+ import { DispatchAction } from '@telia-ace/knowledge-widget-ui';
2
+ import React from 'react';
3
+ declare type Props = {
4
+ className?: string;
5
+ dispatch: DispatchAction;
6
+ };
7
+ declare const Toolbar: React.FC<Props>;
8
+ export default Toolbar;
@@ -1,4 +1,4 @@
1
- import { ComponentNodeController } from '@telia-ace/knowledge-widget-core';
2
- import { Container } from '@webprovisions/platform';
3
- declare const _default: (container: Container, controller: ComponentNodeController) => void;
4
- export default _default;
1
+ import { ComponentNodeController } from '@telia-ace/knowledge-widget-core';
2
+ import { Container } from '@webprovisions/platform';
3
+ declare const _default: (container: Container, controller: ComponentNodeController) => void;
4
+ export default _default;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@telia-ace/knowledge-widget-components-guide",
3
- "version": "1.0.23",
3
+ "version": "1.0.24-next.0",
4
4
  "description": "Guide component for ACE Knowledge Widgets.",
5
5
  "license": "SEE LICENSE IN LICENSE.txt",
6
6
  "author": "Telia Company AB",
@@ -26,26 +26,26 @@
26
26
  },
27
27
  "sideEffects": false,
28
28
  "dependencies": {
29
- "@telia-ace/knowledge-widget-adapters": "^1.0.29",
30
- "@telia-ace/knowledge-widget-component-utilities": "^1.0.23",
31
- "@telia-ace/knowledge-widget-core": "^1.0.19",
32
- "@telia-ace/knowledge-widget-types-grid": "^1.0.30",
33
- "@telia-ace/knowledge-widget-ui": "^1.0.25",
34
- "@telia-ace/widget-forms": "^1.0.22",
35
- "@telia-ace/widget-routing": "^1.0.16",
36
- "@telia-ace/widget-utilities": "^1.0.4",
29
+ "@telia-ace/knowledge-widget-adapters": "^1.0.30-next.1",
30
+ "@telia-ace/knowledge-widget-component-utilities": "^1.0.24-next.0",
31
+ "@telia-ace/knowledge-widget-core": "^1.0.20-next.1",
32
+ "@telia-ace/knowledge-widget-types-grid": "^1.0.31-next.1",
33
+ "@telia-ace/knowledge-widget-ui": "^1.0.26-next.1",
34
+ "@telia-ace/widget-forms": "^1.0.23-next.2",
35
+ "@telia-ace/widget-routing": "^1.0.17-next.2",
36
+ "@telia-ace/widget-utilities": "^1.0.5-next.1",
37
37
  "@webprovisions/platform": "^1.1.2",
38
- "clipboard-polyfill": "3.0.2"
38
+ "clipboard-polyfill": "4.0.0-rc1"
39
39
  },
40
40
  "peerDependencies": {
41
- "react": "^16.8.0",
42
- "react-dom": "^16.8.0",
43
- "styled-components": "^4.3.2"
41
+ "react": "^18.2.0",
42
+ "react-dom": "^18.2.0",
43
+ "styled-components": "^5.3.6"
44
44
  },
45
45
  "devDependencies": {
46
- "@types/react": "^16.8.0",
47
- "@types/react-dom": "^16.8.0",
48
- "@types/styled-components": "^5.1.7"
46
+ "@types/react": "^18.0.21",
47
+ "@types/react-dom": "^18.0.6",
48
+ "@types/styled-components": "^5.1.26"
49
49
  },
50
- "gitHead": "db190a67f912245c4145c037972fac2039bda698"
50
+ "gitHead": "a81b35116f1f922623477a03097a1435db43a5ff"
51
51
  }