@digigov/react-modules 1.2.0-a32ad9b2 → 1.2.0-a594a958
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/Faq/__stories__/Default.d.ts +1 -1
- package/Faq/index.js +1 -1
- package/Faq/index.js.map +2 -2
- package/FilteredResults/__stories__/Default.d.ts +1 -1
- package/cjs/Faq/index.js +1 -1
- package/cjs/Faq/index.js.map +2 -2
- package/index.js +1 -1
- package/package.json +6 -6
- package/src/Faq/__stories__/Default.tsx +1 -1
- package/src/Faq/index.tsx +1 -1
- package/src/FilteredResults/__stories__/Default.tsx +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
export declare const Default: () => React.JSX.Element;
|
|
2
|
+
export declare const Default: (_: any) => React.JSX.Element;
|
package/Faq/index.js
CHANGED
package/Faq/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/Faq/index.tsx"],
|
|
4
|
-
"sourcesContent": ["import React, { useEffect, useContext } from 'react';\nimport { Field } from '@digigov/form/Field';\nimport FormBuilder from '@digigov/form/FormBuilder';\nimport { FormContext } from '@digigov/form/FormContext';\nimport Results from '@digigov/react-modules/Faq/Results';\nimport { createId } from '@digigov/react-modules/Faq/utils';\nimport PageTitleContainer, {\n PageTitleHeading,\n} from '@digigov/ui/app/PageTitleContainer';\nimport {\n Accordion,\n AccordionSection,\n AccordionSectionContent,\n AccordionSectionSummary,\n AccordionSectionSummaryHeading,\n} from '@digigov/ui/content/Accordion';\nimport { useAccordion } from '@digigov/ui/content/Accordion/hooks';\nimport Markdown from '@digigov/ui/content/Markdown';\nimport { SearchButton } from '@digigov/ui/form/SearchContainer';\nimport { Stack } from '@digigov/ui/layouts';\nimport { Aside } from '@digigov/ui/layouts/Basic/Aside';\nimport { Container } from '@digigov/ui/layouts/Basic/Container';\nimport { Main } from '@digigov/ui/layouts/Basic/Main';\nimport Grid from '@digigov/ui/layouts/Grid';\nimport SectionBreak from '@digigov/ui/layouts/SectionBreak';\nimport { BackToTop } from '@digigov/ui/navigation/BackToTopLink';\nimport NavList, { NavListItemAction } from '@digigov/ui/navigation/NavList';\nimport { Heading } from '@digigov/ui/typography/Heading';\nimport Hint from '@digigov/ui/typography/Hint';\n\nexport interface sectionsConfigType {\n sections: SectionType[];\n}\n\nexport interface QaType {\n id?: string;\n question: string;\n answer: string;\n}\n\nexport interface SectionType {\n id: string;\n title: string;\n qa: QaType[];\n}\n\nexport interface TocType {\n title: string;\n placement: 'top' | 'left' | 'right' | 'none';\n}\n\nexport interface SearchFilterType {\n title?: string;\n}\n\nexport interface ContentsType {\n title: string;\n toc: TocType;\n search?: SearchFilterType;\n}\n\nexport interface NavigationListProps {\n title?: string;\n sections: SectionType[];\n}\n\nexport interface FaqProps {\n contents: ContentsType;\n sections: SectionType[];\n initialSections: sectionsConfigType;\n search: (values: Record<string, string>) => void;\n submitValues: { text: string };\n activeQa: string;\n onActiveQa: (v: string) => void;\n}\n\nconst FormBuilderSyncValues = ({ values, autoSubmit }) => {\n const form = useContext(FormContext);\n const previousValues = form.getValues();\n useEffect(() => {\n const mergedObject = { ...values, ...previousValues };\n let shouldSubmit = false;\n for (const key in mergedObject) {\n // catching the filters that have been parsed from url & avoid continuous submitting\n if (values[key] !== undefined && previousValues[key] !== values[key]) {\n shouldSubmit = true;\n previousValues[key] = values[key];\n form.setValue(key, values[key]);\n }\n }\n if (autoSubmit && shouldSubmit) {\n form.submit();\n }\n }, [autoSubmit, form, previousValues, values]);\n return <></>;\n};\n\nconst NavigationList = React.forwardRef<HTMLUListElement, NavigationListProps>(\n function NavigationList({ title, sections }, ref) {\n return (\n <NavList ref={ref} layout=\"vertical\" marginBottom={10}>\n {title && (\n <Heading size=\"md\" id=\"contents\" marginBottom={4}>\n {title}\n </Heading>\n )}\n {sections &&\n sections.length > 0 &&\n sections.map(({ id, title }, index) => (\n <NavListItemAction key={index} href={`#${createId(id, title)}`}>\n {title}\n </NavListItemAction>\n ))}\n </NavList>\n );\n }\n);\n\nexport const Faq = React.forwardRef<HTMLDivElement, FaqProps>(function FAQ(\n {\n contents,\n sections,\n initialSections,\n submitValues,\n activeQa,\n onActiveQa,\n search,\n },\n ref\n) {\n const { section, currentOpen, onOpen, close } = useAccordion({\n singleOpen: true,\n defaultOpen: 0,\n });\n const placement = contents.toc?.placement || 'none';\n const filteredSections = sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const primarySections = initialSections.sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const hash = window.location.hash.slice(1);\n const currentId = activeQa ? activeQa : hash;\n\n useEffect(() => {\n if (onActiveQa) {\n if (currentOpen && activeQa !== currentOpen) {\n onActiveQa(currentOpen as string);\n }\n }\n }, [activeQa, currentOpen, onActiveQa]);\n\n useEffect(() => {\n if (activeQa && activeQa !== currentOpen) {\n onOpen(activeQa);\n }\n }, [activeQa, currentOpen, onOpen]);\n\n useEffect(() => {\n // Scroll to the target element if it exists\n if (currentId) {\n const element = document.getElementById(currentId);\n if (element) {\n element.scrollIntoView({ behavior: 'smooth', block: 'start' });\n }\n }\n }, [activeQa, currentId, hash]);\n\n const Onclose = (activeQa) => {\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('text');\n urlParams.delete('activeQa');\n window.history.pushState({}, '', '?' + urlParams.toString());\n onActiveQa('');\n close(activeQa);\n };\n const handleSubmit = (data) => {\n search(data);\n onActiveQa('');\n close(activeQa);\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('activeQa');\n window.history.replaceState({}, '', '?' + urlParams.toString());\n };\n\n return (\n <Container ref={ref}>\n {placement !== 'none' && placement === 'left' && (\n <Aside sticky={false}>\n <NavigationList title={contents.toc?.title} sections={sections} />\n </Aside>\n )}\n <Main>\n <PageTitleContainer>\n <PageTitleHeading size=\"xl\" id=\"faq\">\n {contents?.title}\n </PageTitleHeading>\n </PageTitleContainer>\n {placement !== 'none' && placement === 'top' && (\n <NavigationList title={contents?.toc?.title} sections={sections} />\n )}\n\n {contents.search && (\n <FormBuilder onSubmit={handleSubmit} initial={{ text: '' }}>\n {submitValues && (\n <FormBuilderSyncValues values={submitValues} autoSubmit={true} />\n )}\n <Stack\n direction=\"row\"\n flexWrap=\"nowrap\"\n alignItems=\"flex-end\"\n spacing={4}\n >\n <Grid container style={{ width: '100%' }}>\n <Field\n type=\"string\"\n key=\"text\"\n name=\"text\"\n placeholder=\"\u0391\u03BD\u03B1\u03B6\u03B7\u03C4\u03AE\u03C3\u03C4\u03B5 \u03C3\u03C7\u03B5\u03C4\u03B9\u03BA\u03AC \u03BC\u03B5 \u03C4\u03B7\u03BD \u03B5\u03C1\u03CE\u03C4\u03B7\u03C3\u03AE \u03C3\u03B1\u03C2\"\n label={{ primary: contents.search.title }}\n />\n </Grid>\n <SearchButton\n type=\"submit\"\n mb={10}\n style={{ minHeight: '2.75rem' }}\n />\n </Stack>\n {filteredSections !== primarySections && (\n <Results\n filteredSections={filteredSections}\n primarySections={primarySections}\n Onclose={Onclose}\n activeQa={activeQa}\n />\n )}\n </FormBuilder>\n )}\n <Grid>\n {sections && sections.length > 0 ? (\n sections.map(({ id: sectionId, title, qa }, index) => (\n <React.Fragment key={index}>\n <Heading id={createId(sectionId, title)} size=\"lg\">\n {title}\n </Heading>\n <Accordion marginBottom={qa && qa.length > 0 ? 12 : 0}>\n {qa?.map(({ id, question, answer }, indx) => (\n <AccordionSection\n key={indx}\n {...section(createId(id, question))}\n >\n <AccordionSectionSummary>\n <AccordionSectionSummaryHeading\n aria-controls={createId(id, question)}\n >\n {question}\n </AccordionSectionSummaryHeading>\n </AccordionSectionSummary>\n <AccordionSectionContent id={createId(id, question)}>\n <Markdown content={answer} />\n </AccordionSectionContent>\n </AccordionSection>\n ))}\n </Accordion>\n <SectionBreak visible={false} />\n </React.Fragment>\n ))\n ) : (\n <Hint marginBottom={10}>\u0394\u03B5\u03BD \u03B2\u03C1\u03AD\u03B8\u03B7\u03BA\u03B1\u03BD \u03B1\u03C0\u03BF\u03C4\u03B5\u03BB\u03AD\u03C3\u03BC\u03B1\u03C4\u03B1.</Hint>\n )}\n </Grid>\n <BackToTop topLimitId=\"contents\" id=\"back-to-top\">\n \u0395\u03C0\u03B9\u03C3\u03C4\u03C1\u03BF\u03C6\u03AE \u03C3\u03C4\u03B1 \u03A0\u03B5\u03C1\u03B9\u03B5\u03C7\u03CC\u03BC\u03B5\u03BD\u03B1\n </BackToTop>\n </Main>\n {placement !== 'none' && placement === 'right' && (\n <Aside sticky={false}>\n <NavigationList title={contents?.toc?.title} sections={sections} />\n </Aside>\n )}\n </Container>\n );\n});\nexport default Faq;\n"],
|
|
5
|
-
"mappings": "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
|
|
4
|
+
"sourcesContent": ["import React, { useEffect, useContext } from 'react';\nimport { Field } from '@digigov/form/Field';\nimport FormBuilder from '@digigov/form/FormBuilder';\nimport { FormContext } from '@digigov/form/FormContext';\nimport Results from '@digigov/react-modules/Faq/Results';\nimport { createId } from '@digigov/react-modules/Faq/utils';\nimport PageTitleContainer, {\n PageTitleHeading,\n} from '@digigov/ui/app/PageTitleContainer';\nimport {\n Accordion,\n AccordionSection,\n AccordionSectionContent,\n AccordionSectionSummary,\n AccordionSectionSummaryHeading,\n} from '@digigov/ui/content/Accordion';\nimport { useAccordion } from '@digigov/ui/content/Accordion/hooks';\nimport Markdown from '@digigov/ui/content/Markdown';\nimport { SearchButton } from '@digigov/ui/form/SearchContainer';\nimport { Stack } from '@digigov/ui/layouts';\nimport { Aside } from '@digigov/ui/layouts/Basic/Aside';\nimport { Container } from '@digigov/ui/layouts/Basic/Container';\nimport { Main } from '@digigov/ui/layouts/Basic/Main';\nimport Grid from '@digigov/ui/layouts/Grid';\nimport SectionBreak from '@digigov/ui/layouts/SectionBreak';\nimport { BackToTop } from '@digigov/ui/navigation/BackToTopLink';\nimport NavList, { NavListItemAction } from '@digigov/ui/navigation/NavList';\nimport { Heading } from '@digigov/ui/typography/Heading';\nimport Hint from '@digigov/ui/typography/Hint';\n\nexport interface sectionsConfigType {\n sections: SectionType[];\n}\n\nexport interface QaType {\n id?: string;\n question: string;\n answer: string;\n}\n\nexport interface SectionType {\n id: string;\n title: string;\n qa: QaType[];\n}\n\nexport interface TocType {\n title: string;\n placement: 'top' | 'left' | 'right' | 'none';\n}\n\nexport interface SearchFilterType {\n title?: string;\n}\n\nexport interface ContentsType {\n title: string;\n toc: TocType;\n search?: SearchFilterType;\n}\n\nexport interface NavigationListProps {\n title?: string;\n sections: SectionType[];\n}\n\nexport interface FaqProps {\n contents: ContentsType;\n sections: SectionType[];\n initialSections: sectionsConfigType;\n search: (values: Record<string, string>) => void;\n submitValues: { text: string };\n activeQa: string;\n onActiveQa: (v: string) => void;\n}\n\nconst FormBuilderSyncValues = ({ values, autoSubmit }) => {\n const form = useContext(FormContext);\n const previousValues = form.getValues();\n useEffect(() => {\n const mergedObject = { ...values, ...previousValues };\n let shouldSubmit = false;\n for (const key in mergedObject) {\n // catching the filters that have been parsed from url & avoid continuous submitting\n if (values[key] !== undefined && previousValues[key] !== values[key]) {\n shouldSubmit = true;\n previousValues[key] = values[key];\n form.setValue(key, values[key]);\n }\n }\n if (autoSubmit && shouldSubmit) {\n form.submit();\n }\n }, [autoSubmit, form, previousValues, values]);\n return <></>;\n};\n\nconst NavigationList = React.forwardRef<HTMLUListElement, NavigationListProps>(\n function NavigationList({ title, sections }, ref) {\n return (\n <NavList ref={ref} layout=\"vertical\" marginBottom={10}>\n {title && (\n <Heading size=\"md\" id=\"contents\" marginBottom={4}>\n {title}\n </Heading>\n )}\n {sections &&\n sections.length > 0 &&\n sections.map(({ id, title }, index) => (\n <NavListItemAction key={index} href={`#${createId(id, title)}`}>\n {title}\n </NavListItemAction>\n ))}\n </NavList>\n );\n }\n);\n\nexport const Faq = React.forwardRef<HTMLDivElement, FaqProps>(function FAQ(\n {\n contents,\n sections,\n initialSections,\n submitValues,\n activeQa,\n onActiveQa,\n search,\n },\n ref\n) {\n const { section, currentOpen, onOpen, close } = useAccordion({\n singleOpen: true,\n defaultOpen: 0,\n });\n const placement = contents.toc?.placement || 'none';\n const filteredSections = sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const primarySections = initialSections.sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const hash = window.location.hash.slice(1);\n const currentId = activeQa ? activeQa : hash;\n\n useEffect(() => {\n if (onActiveQa) {\n if (currentOpen && activeQa !== currentOpen) {\n onActiveQa(currentOpen as string);\n }\n }\n }, [activeQa, currentOpen, onActiveQa]);\n\n useEffect(() => {\n if (activeQa && activeQa !== currentOpen) {\n onOpen(activeQa);\n }\n }, [activeQa, currentOpen, onOpen]);\n\n useEffect(() => {\n // Scroll to the target element if it exists\n if (currentId) {\n const element = document.getElementById(currentId);\n if (element) {\n element.scrollIntoView({ behavior: 'smooth', block: 'start' });\n }\n }\n }, [activeQa, currentId, hash]);\n\n const Onclose = (activeQa) => {\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('text');\n urlParams.delete('activeQa');\n window.history.pushState({}, '', '?' + urlParams.toString());\n onActiveQa('');\n close(activeQa);\n };\n const handleSubmit = (data) => {\n search(data);\n onActiveQa('');\n close(activeQa);\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('activeQa');\n window.history.replaceState({}, '', '?' + urlParams.toString());\n };\n\n return (\n <Container ref={ref}>\n {placement !== 'none' && placement === 'left' && (\n <Aside sticky={false}>\n <NavigationList title={contents.toc?.title} sections={sections} />\n </Aside>\n )}\n <Main>\n <PageTitleContainer>\n <PageTitleHeading size=\"xl\" id=\"faq\">\n {contents?.title}\n </PageTitleHeading>\n </PageTitleContainer>\n {placement !== 'none' && placement === 'top' && (\n <NavigationList title={contents?.toc?.title} sections={sections} />\n )}\n\n {contents.search && (\n <FormBuilder onSubmit={handleSubmit} initial={{ text: '' }}>\n {submitValues && (\n <FormBuilderSyncValues values={submitValues} autoSubmit={true} />\n )}\n <Stack\n direction=\"row\"\n flexWrap=\"nowrap\"\n alignItems=\"flex-end\"\n spacing={4}\n >\n <Grid container style={{ width: '100%' }}>\n <Field\n type=\"string\"\n key=\"text\"\n name=\"text\"\n placeholder=\"\u0391\u03BD\u03B1\u03B6\u03B7\u03C4\u03AE\u03C3\u03C4\u03B5 \u03C3\u03C7\u03B5\u03C4\u03B9\u03BA\u03AC \u03BC\u03B5 \u03C4\u03B7\u03BD \u03B5\u03C1\u03CE\u03C4\u03B7\u03C3\u03AE \u03C3\u03B1\u03C2\"\n label={{ primary: contents.search.title }}\n />\n </Grid>\n <SearchButton\n type=\"submit\"\n mb={{ md: 10 }}\n style={{ minHeight: '2.75rem' }}\n />\n </Stack>\n {filteredSections !== primarySections && (\n <Results\n filteredSections={filteredSections}\n primarySections={primarySections}\n Onclose={Onclose}\n activeQa={activeQa}\n />\n )}\n </FormBuilder>\n )}\n <Grid>\n {sections && sections.length > 0 ? (\n sections.map(({ id: sectionId, title, qa }, index) => (\n <React.Fragment key={index}>\n <Heading id={createId(sectionId, title)} size=\"lg\">\n {title}\n </Heading>\n <Accordion marginBottom={qa && qa.length > 0 ? 12 : 0}>\n {qa?.map(({ id, question, answer }, indx) => (\n <AccordionSection\n key={indx}\n {...section(createId(id, question))}\n >\n <AccordionSectionSummary>\n <AccordionSectionSummaryHeading\n aria-controls={createId(id, question)}\n >\n {question}\n </AccordionSectionSummaryHeading>\n </AccordionSectionSummary>\n <AccordionSectionContent id={createId(id, question)}>\n <Markdown content={answer} />\n </AccordionSectionContent>\n </AccordionSection>\n ))}\n </Accordion>\n <SectionBreak visible={false} />\n </React.Fragment>\n ))\n ) : (\n <Hint marginBottom={10}>\u0394\u03B5\u03BD \u03B2\u03C1\u03AD\u03B8\u03B7\u03BA\u03B1\u03BD \u03B1\u03C0\u03BF\u03C4\u03B5\u03BB\u03AD\u03C3\u03BC\u03B1\u03C4\u03B1.</Hint>\n )}\n </Grid>\n <BackToTop topLimitId=\"contents\" id=\"back-to-top\">\n \u0395\u03C0\u03B9\u03C3\u03C4\u03C1\u03BF\u03C6\u03AE \u03C3\u03C4\u03B1 \u03A0\u03B5\u03C1\u03B9\u03B5\u03C7\u03CC\u03BC\u03B5\u03BD\u03B1\n </BackToTop>\n </Main>\n {placement !== 'none' && placement === 'right' && (\n <Aside sticky={false}>\n <NavigationList title={contents?.toc?.title} sections={sections} />\n </Aside>\n )}\n </Container>\n );\n});\nexport default Faq;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["NavigationList", "title", "section", "activeQa"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
export declare const Default: () => React.JSX.Element;
|
|
2
|
+
export declare const Default: (_: any) => React.JSX.Element;
|
package/cjs/Faq/index.js
CHANGED
package/cjs/Faq/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/Faq/index.tsx"],
|
|
4
|
-
"sourcesContent": ["import React, { useEffect, useContext } from 'react';\nimport { Field } from '@digigov/form/Field';\nimport FormBuilder from '@digigov/form/FormBuilder';\nimport { FormContext } from '@digigov/form/FormContext';\nimport Results from '@digigov/react-modules/Faq/Results';\nimport { createId } from '@digigov/react-modules/Faq/utils';\nimport PageTitleContainer, {\n PageTitleHeading,\n} from '@digigov/ui/app/PageTitleContainer';\nimport {\n Accordion,\n AccordionSection,\n AccordionSectionContent,\n AccordionSectionSummary,\n AccordionSectionSummaryHeading,\n} from '@digigov/ui/content/Accordion';\nimport { useAccordion } from '@digigov/ui/content/Accordion/hooks';\nimport Markdown from '@digigov/ui/content/Markdown';\nimport { SearchButton } from '@digigov/ui/form/SearchContainer';\nimport { Stack } from '@digigov/ui/layouts';\nimport { Aside } from '@digigov/ui/layouts/Basic/Aside';\nimport { Container } from '@digigov/ui/layouts/Basic/Container';\nimport { Main } from '@digigov/ui/layouts/Basic/Main';\nimport Grid from '@digigov/ui/layouts/Grid';\nimport SectionBreak from '@digigov/ui/layouts/SectionBreak';\nimport { BackToTop } from '@digigov/ui/navigation/BackToTopLink';\nimport NavList, { NavListItemAction } from '@digigov/ui/navigation/NavList';\nimport { Heading } from '@digigov/ui/typography/Heading';\nimport Hint from '@digigov/ui/typography/Hint';\n\nexport interface sectionsConfigType {\n sections: SectionType[];\n}\n\nexport interface QaType {\n id?: string;\n question: string;\n answer: string;\n}\n\nexport interface SectionType {\n id: string;\n title: string;\n qa: QaType[];\n}\n\nexport interface TocType {\n title: string;\n placement: 'top' | 'left' | 'right' | 'none';\n}\n\nexport interface SearchFilterType {\n title?: string;\n}\n\nexport interface ContentsType {\n title: string;\n toc: TocType;\n search?: SearchFilterType;\n}\n\nexport interface NavigationListProps {\n title?: string;\n sections: SectionType[];\n}\n\nexport interface FaqProps {\n contents: ContentsType;\n sections: SectionType[];\n initialSections: sectionsConfigType;\n search: (values: Record<string, string>) => void;\n submitValues: { text: string };\n activeQa: string;\n onActiveQa: (v: string) => void;\n}\n\nconst FormBuilderSyncValues = ({ values, autoSubmit }) => {\n const form = useContext(FormContext);\n const previousValues = form.getValues();\n useEffect(() => {\n const mergedObject = { ...values, ...previousValues };\n let shouldSubmit = false;\n for (const key in mergedObject) {\n // catching the filters that have been parsed from url & avoid continuous submitting\n if (values[key] !== undefined && previousValues[key] !== values[key]) {\n shouldSubmit = true;\n previousValues[key] = values[key];\n form.setValue(key, values[key]);\n }\n }\n if (autoSubmit && shouldSubmit) {\n form.submit();\n }\n }, [autoSubmit, form, previousValues, values]);\n return <></>;\n};\n\nconst NavigationList = React.forwardRef<HTMLUListElement, NavigationListProps>(\n function NavigationList({ title, sections }, ref) {\n return (\n <NavList ref={ref} layout=\"vertical\" marginBottom={10}>\n {title && (\n <Heading size=\"md\" id=\"contents\" marginBottom={4}>\n {title}\n </Heading>\n )}\n {sections &&\n sections.length > 0 &&\n sections.map(({ id, title }, index) => (\n <NavListItemAction key={index} href={`#${createId(id, title)}`}>\n {title}\n </NavListItemAction>\n ))}\n </NavList>\n );\n }\n);\n\nexport const Faq = React.forwardRef<HTMLDivElement, FaqProps>(function FAQ(\n {\n contents,\n sections,\n initialSections,\n submitValues,\n activeQa,\n onActiveQa,\n search,\n },\n ref\n) {\n const { section, currentOpen, onOpen, close } = useAccordion({\n singleOpen: true,\n defaultOpen: 0,\n });\n const placement = contents.toc?.placement || 'none';\n const filteredSections = sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const primarySections = initialSections.sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const hash = window.location.hash.slice(1);\n const currentId = activeQa ? activeQa : hash;\n\n useEffect(() => {\n if (onActiveQa) {\n if (currentOpen && activeQa !== currentOpen) {\n onActiveQa(currentOpen as string);\n }\n }\n }, [activeQa, currentOpen, onActiveQa]);\n\n useEffect(() => {\n if (activeQa && activeQa !== currentOpen) {\n onOpen(activeQa);\n }\n }, [activeQa, currentOpen, onOpen]);\n\n useEffect(() => {\n // Scroll to the target element if it exists\n if (currentId) {\n const element = document.getElementById(currentId);\n if (element) {\n element.scrollIntoView({ behavior: 'smooth', block: 'start' });\n }\n }\n }, [activeQa, currentId, hash]);\n\n const Onclose = (activeQa) => {\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('text');\n urlParams.delete('activeQa');\n window.history.pushState({}, '', '?' + urlParams.toString());\n onActiveQa('');\n close(activeQa);\n };\n const handleSubmit = (data) => {\n search(data);\n onActiveQa('');\n close(activeQa);\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('activeQa');\n window.history.replaceState({}, '', '?' + urlParams.toString());\n };\n\n return (\n <Container ref={ref}>\n {placement !== 'none' && placement === 'left' && (\n <Aside sticky={false}>\n <NavigationList title={contents.toc?.title} sections={sections} />\n </Aside>\n )}\n <Main>\n <PageTitleContainer>\n <PageTitleHeading size=\"xl\" id=\"faq\">\n {contents?.title}\n </PageTitleHeading>\n </PageTitleContainer>\n {placement !== 'none' && placement === 'top' && (\n <NavigationList title={contents?.toc?.title} sections={sections} />\n )}\n\n {contents.search && (\n <FormBuilder onSubmit={handleSubmit} initial={{ text: '' }}>\n {submitValues && (\n <FormBuilderSyncValues values={submitValues} autoSubmit={true} />\n )}\n <Stack\n direction=\"row\"\n flexWrap=\"nowrap\"\n alignItems=\"flex-end\"\n spacing={4}\n >\n <Grid container style={{ width: '100%' }}>\n <Field\n type=\"string\"\n key=\"text\"\n name=\"text\"\n placeholder=\"\u0391\u03BD\u03B1\u03B6\u03B7\u03C4\u03AE\u03C3\u03C4\u03B5 \u03C3\u03C7\u03B5\u03C4\u03B9\u03BA\u03AC \u03BC\u03B5 \u03C4\u03B7\u03BD \u03B5\u03C1\u03CE\u03C4\u03B7\u03C3\u03AE \u03C3\u03B1\u03C2\"\n label={{ primary: contents.search.title }}\n />\n </Grid>\n <SearchButton\n type=\"submit\"\n mb={10}\n style={{ minHeight: '2.75rem' }}\n />\n </Stack>\n {filteredSections !== primarySections && (\n <Results\n filteredSections={filteredSections}\n primarySections={primarySections}\n Onclose={Onclose}\n activeQa={activeQa}\n />\n )}\n </FormBuilder>\n )}\n <Grid>\n {sections && sections.length > 0 ? (\n sections.map(({ id: sectionId, title, qa }, index) => (\n <React.Fragment key={index}>\n <Heading id={createId(sectionId, title)} size=\"lg\">\n {title}\n </Heading>\n <Accordion marginBottom={qa && qa.length > 0 ? 12 : 0}>\n {qa?.map(({ id, question, answer }, indx) => (\n <AccordionSection\n key={indx}\n {...section(createId(id, question))}\n >\n <AccordionSectionSummary>\n <AccordionSectionSummaryHeading\n aria-controls={createId(id, question)}\n >\n {question}\n </AccordionSectionSummaryHeading>\n </AccordionSectionSummary>\n <AccordionSectionContent id={createId(id, question)}>\n <Markdown content={answer} />\n </AccordionSectionContent>\n </AccordionSection>\n ))}\n </Accordion>\n <SectionBreak visible={false} />\n </React.Fragment>\n ))\n ) : (\n <Hint marginBottom={10}>\u0394\u03B5\u03BD \u03B2\u03C1\u03AD\u03B8\u03B7\u03BA\u03B1\u03BD \u03B1\u03C0\u03BF\u03C4\u03B5\u03BB\u03AD\u03C3\u03BC\u03B1\u03C4\u03B1.</Hint>\n )}\n </Grid>\n <BackToTop topLimitId=\"contents\" id=\"back-to-top\">\n \u0395\u03C0\u03B9\u03C3\u03C4\u03C1\u03BF\u03C6\u03AE \u03C3\u03C4\u03B1 \u03A0\u03B5\u03C1\u03B9\u03B5\u03C7\u03CC\u03BC\u03B5\u03BD\u03B1\n </BackToTop>\n </Main>\n {placement !== 'none' && placement === 'right' && (\n <Aside sticky={false}>\n <NavigationList title={contents?.toc?.title} sections={sections} />\n </Aside>\n )}\n </Container>\n );\n});\nexport default Faq;\n"],
|
|
5
|
-
"mappings": "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
|
|
4
|
+
"sourcesContent": ["import React, { useEffect, useContext } from 'react';\nimport { Field } from '@digigov/form/Field';\nimport FormBuilder from '@digigov/form/FormBuilder';\nimport { FormContext } from '@digigov/form/FormContext';\nimport Results from '@digigov/react-modules/Faq/Results';\nimport { createId } from '@digigov/react-modules/Faq/utils';\nimport PageTitleContainer, {\n PageTitleHeading,\n} from '@digigov/ui/app/PageTitleContainer';\nimport {\n Accordion,\n AccordionSection,\n AccordionSectionContent,\n AccordionSectionSummary,\n AccordionSectionSummaryHeading,\n} from '@digigov/ui/content/Accordion';\nimport { useAccordion } from '@digigov/ui/content/Accordion/hooks';\nimport Markdown from '@digigov/ui/content/Markdown';\nimport { SearchButton } from '@digigov/ui/form/SearchContainer';\nimport { Stack } from '@digigov/ui/layouts';\nimport { Aside } from '@digigov/ui/layouts/Basic/Aside';\nimport { Container } from '@digigov/ui/layouts/Basic/Container';\nimport { Main } from '@digigov/ui/layouts/Basic/Main';\nimport Grid from '@digigov/ui/layouts/Grid';\nimport SectionBreak from '@digigov/ui/layouts/SectionBreak';\nimport { BackToTop } from '@digigov/ui/navigation/BackToTopLink';\nimport NavList, { NavListItemAction } from '@digigov/ui/navigation/NavList';\nimport { Heading } from '@digigov/ui/typography/Heading';\nimport Hint from '@digigov/ui/typography/Hint';\n\nexport interface sectionsConfigType {\n sections: SectionType[];\n}\n\nexport interface QaType {\n id?: string;\n question: string;\n answer: string;\n}\n\nexport interface SectionType {\n id: string;\n title: string;\n qa: QaType[];\n}\n\nexport interface TocType {\n title: string;\n placement: 'top' | 'left' | 'right' | 'none';\n}\n\nexport interface SearchFilterType {\n title?: string;\n}\n\nexport interface ContentsType {\n title: string;\n toc: TocType;\n search?: SearchFilterType;\n}\n\nexport interface NavigationListProps {\n title?: string;\n sections: SectionType[];\n}\n\nexport interface FaqProps {\n contents: ContentsType;\n sections: SectionType[];\n initialSections: sectionsConfigType;\n search: (values: Record<string, string>) => void;\n submitValues: { text: string };\n activeQa: string;\n onActiveQa: (v: string) => void;\n}\n\nconst FormBuilderSyncValues = ({ values, autoSubmit }) => {\n const form = useContext(FormContext);\n const previousValues = form.getValues();\n useEffect(() => {\n const mergedObject = { ...values, ...previousValues };\n let shouldSubmit = false;\n for (const key in mergedObject) {\n // catching the filters that have been parsed from url & avoid continuous submitting\n if (values[key] !== undefined && previousValues[key] !== values[key]) {\n shouldSubmit = true;\n previousValues[key] = values[key];\n form.setValue(key, values[key]);\n }\n }\n if (autoSubmit && shouldSubmit) {\n form.submit();\n }\n }, [autoSubmit, form, previousValues, values]);\n return <></>;\n};\n\nconst NavigationList = React.forwardRef<HTMLUListElement, NavigationListProps>(\n function NavigationList({ title, sections }, ref) {\n return (\n <NavList ref={ref} layout=\"vertical\" marginBottom={10}>\n {title && (\n <Heading size=\"md\" id=\"contents\" marginBottom={4}>\n {title}\n </Heading>\n )}\n {sections &&\n sections.length > 0 &&\n sections.map(({ id, title }, index) => (\n <NavListItemAction key={index} href={`#${createId(id, title)}`}>\n {title}\n </NavListItemAction>\n ))}\n </NavList>\n );\n }\n);\n\nexport const Faq = React.forwardRef<HTMLDivElement, FaqProps>(function FAQ(\n {\n contents,\n sections,\n initialSections,\n submitValues,\n activeQa,\n onActiveQa,\n search,\n },\n ref\n) {\n const { section, currentOpen, onOpen, close } = useAccordion({\n singleOpen: true,\n defaultOpen: 0,\n });\n const placement = contents.toc?.placement || 'none';\n const filteredSections = sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const primarySections = initialSections.sections.reduce(\n (acc, section) => acc + (section.qa.length || 0),\n 0\n );\n const hash = window.location.hash.slice(1);\n const currentId = activeQa ? activeQa : hash;\n\n useEffect(() => {\n if (onActiveQa) {\n if (currentOpen && activeQa !== currentOpen) {\n onActiveQa(currentOpen as string);\n }\n }\n }, [activeQa, currentOpen, onActiveQa]);\n\n useEffect(() => {\n if (activeQa && activeQa !== currentOpen) {\n onOpen(activeQa);\n }\n }, [activeQa, currentOpen, onOpen]);\n\n useEffect(() => {\n // Scroll to the target element if it exists\n if (currentId) {\n const element = document.getElementById(currentId);\n if (element) {\n element.scrollIntoView({ behavior: 'smooth', block: 'start' });\n }\n }\n }, [activeQa, currentId, hash]);\n\n const Onclose = (activeQa) => {\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('text');\n urlParams.delete('activeQa');\n window.history.pushState({}, '', '?' + urlParams.toString());\n onActiveQa('');\n close(activeQa);\n };\n const handleSubmit = (data) => {\n search(data);\n onActiveQa('');\n close(activeQa);\n const urlParams = new URLSearchParams(window.location.search);\n urlParams.delete('activeQa');\n window.history.replaceState({}, '', '?' + urlParams.toString());\n };\n\n return (\n <Container ref={ref}>\n {placement !== 'none' && placement === 'left' && (\n <Aside sticky={false}>\n <NavigationList title={contents.toc?.title} sections={sections} />\n </Aside>\n )}\n <Main>\n <PageTitleContainer>\n <PageTitleHeading size=\"xl\" id=\"faq\">\n {contents?.title}\n </PageTitleHeading>\n </PageTitleContainer>\n {placement !== 'none' && placement === 'top' && (\n <NavigationList title={contents?.toc?.title} sections={sections} />\n )}\n\n {contents.search && (\n <FormBuilder onSubmit={handleSubmit} initial={{ text: '' }}>\n {submitValues && (\n <FormBuilderSyncValues values={submitValues} autoSubmit={true} />\n )}\n <Stack\n direction=\"row\"\n flexWrap=\"nowrap\"\n alignItems=\"flex-end\"\n spacing={4}\n >\n <Grid container style={{ width: '100%' }}>\n <Field\n type=\"string\"\n key=\"text\"\n name=\"text\"\n placeholder=\"\u0391\u03BD\u03B1\u03B6\u03B7\u03C4\u03AE\u03C3\u03C4\u03B5 \u03C3\u03C7\u03B5\u03C4\u03B9\u03BA\u03AC \u03BC\u03B5 \u03C4\u03B7\u03BD \u03B5\u03C1\u03CE\u03C4\u03B7\u03C3\u03AE \u03C3\u03B1\u03C2\"\n label={{ primary: contents.search.title }}\n />\n </Grid>\n <SearchButton\n type=\"submit\"\n mb={{ md: 10 }}\n style={{ minHeight: '2.75rem' }}\n />\n </Stack>\n {filteredSections !== primarySections && (\n <Results\n filteredSections={filteredSections}\n primarySections={primarySections}\n Onclose={Onclose}\n activeQa={activeQa}\n />\n )}\n </FormBuilder>\n )}\n <Grid>\n {sections && sections.length > 0 ? (\n sections.map(({ id: sectionId, title, qa }, index) => (\n <React.Fragment key={index}>\n <Heading id={createId(sectionId, title)} size=\"lg\">\n {title}\n </Heading>\n <Accordion marginBottom={qa && qa.length > 0 ? 12 : 0}>\n {qa?.map(({ id, question, answer }, indx) => (\n <AccordionSection\n key={indx}\n {...section(createId(id, question))}\n >\n <AccordionSectionSummary>\n <AccordionSectionSummaryHeading\n aria-controls={createId(id, question)}\n >\n {question}\n </AccordionSectionSummaryHeading>\n </AccordionSectionSummary>\n <AccordionSectionContent id={createId(id, question)}>\n <Markdown content={answer} />\n </AccordionSectionContent>\n </AccordionSection>\n ))}\n </Accordion>\n <SectionBreak visible={false} />\n </React.Fragment>\n ))\n ) : (\n <Hint marginBottom={10}>\u0394\u03B5\u03BD \u03B2\u03C1\u03AD\u03B8\u03B7\u03BA\u03B1\u03BD \u03B1\u03C0\u03BF\u03C4\u03B5\u03BB\u03AD\u03C3\u03BC\u03B1\u03C4\u03B1.</Hint>\n )}\n </Grid>\n <BackToTop topLimitId=\"contents\" id=\"back-to-top\">\n \u0395\u03C0\u03B9\u03C3\u03C4\u03C1\u03BF\u03C6\u03AE \u03C3\u03C4\u03B1 \u03A0\u03B5\u03C1\u03B9\u03B5\u03C7\u03CC\u03BC\u03B5\u03BD\u03B1\n </BackToTop>\n </Main>\n {placement !== 'none' && placement === 'right' && (\n <Aside sticky={false}>\n <NavigationList title={contents?.toc?.title} sections={sections} />\n </Aside>\n )}\n </Container>\n );\n});\nexport default Faq;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["React", "NavigationList", "NavList", "title", "section", "activeQa", "PageTitleContainer", "FormBuilder", "Grid", "Results", "Markdown", "SectionBreak", "Hint"]
|
|
7
7
|
}
|
package/index.js
CHANGED
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@digigov/react-modules",
|
|
3
|
-
"version": "1.2.0-
|
|
3
|
+
"version": "1.2.0-a594a958",
|
|
4
4
|
"description": "@digigov patterns based on ui components",
|
|
5
5
|
"main": "./cjs/index.js",
|
|
6
6
|
"module": "./index.js",
|
|
7
7
|
"dependencies": {
|
|
8
|
-
"@digigov/react-icons": "2.0.0-
|
|
9
|
-
"@digigov/form": "2.0.0-
|
|
10
|
-
"@digigov/ui": "2.0.0-
|
|
8
|
+
"@digigov/react-icons": "2.0.0-a594a958",
|
|
9
|
+
"@digigov/form": "2.0.0-a594a958",
|
|
10
|
+
"@digigov/ui": "2.0.0-a594a958",
|
|
11
11
|
"dompurify": "3.0.6"
|
|
12
12
|
},
|
|
13
13
|
"peerDependencies": {
|
|
@@ -15,8 +15,8 @@
|
|
|
15
15
|
"clsx": "1.1.1",
|
|
16
16
|
"react": "^18.3.0 || ^19.1.0",
|
|
17
17
|
"react-dom": "^18.3.0 || ^19.1.0",
|
|
18
|
-
"@digigov/react-core": "2.0.0-
|
|
19
|
-
"@digigov/css": "2.0.0-
|
|
18
|
+
"@digigov/react-core": "2.0.0-a594a958",
|
|
19
|
+
"@digigov/css": "2.0.0-a594a958"
|
|
20
20
|
},
|
|
21
21
|
"private": false,
|
|
22
22
|
"typings": "./index.d.ts"
|
package/src/Faq/index.tsx
CHANGED