@ndla/ui 50.9.20 → 50.10.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/es/Embed/CopyrightEmbed.js +41 -0
- package/es/Embed/index.js +2 -1
- package/es/Gloss/Gloss.js +10 -10
- package/es/Gloss/GlossExample.js +10 -5
- package/es/Layout/LayoutItem.js +15 -32
- package/es/LicenseByline/EmbedByline.js +5 -5
- package/es/all.css +1 -1
- package/es/index.js +1 -1
- package/es/locale/messages-en.js +3 -1
- package/es/locale/messages-nb.js +3 -1
- package/es/locale/messages-nn.js +4 -2
- package/es/locale/messages-se.js +3 -1
- package/es/locale/messages-sma.js +3 -1
- package/lib/Embed/CopyrightEmbed.d.ts +15 -0
- package/lib/Embed/CopyrightEmbed.js +45 -0
- package/lib/Embed/index.d.ts +1 -0
- package/lib/Embed/index.js +7 -0
- package/lib/Gloss/Gloss.js +10 -10
- package/lib/Gloss/GlossExample.d.ts +2 -2
- package/lib/Gloss/GlossExample.js +10 -5
- package/lib/Layout/LayoutItem.d.ts +1 -1
- package/lib/Layout/LayoutItem.js +14 -31
- package/lib/LicenseByline/EmbedByline.d.ts +6 -1
- package/lib/LicenseByline/EmbedByline.js +5 -5
- package/lib/all.css +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.js +6 -0
- package/lib/locale/messages-en.d.ts +2 -0
- package/lib/locale/messages-en.js +3 -1
- package/lib/locale/messages-nb.d.ts +2 -0
- package/lib/locale/messages-nb.js +3 -1
- package/lib/locale/messages-nn.d.ts +2 -0
- package/lib/locale/messages-nn.js +4 -2
- package/lib/locale/messages-se.d.ts +2 -0
- package/lib/locale/messages-se.js +3 -1
- package/lib/locale/messages-sma.d.ts +2 -0
- package/lib/locale/messages-sma.js +3 -1
- package/package.json +18 -18
- package/src/Embed/CopyrightEmbed.tsx +37 -0
- package/src/Embed/index.ts +1 -0
- package/src/FramedContent/FramedContent.stories.tsx +47 -0
- package/src/Gloss/Gloss.stories.tsx +13 -0
- package/src/Gloss/Gloss.tsx +5 -5
- package/src/Gloss/GlossExample.tsx +30 -14
- package/src/Layout/LayoutItem.tsx +15 -23
- package/src/LicenseByline/EmbedByline.tsx +13 -1
- package/src/index.ts +1 -0
- package/src/locale/messages-en.ts +2 -0
- package/src/locale/messages-nb.ts +2 -0
- package/src/locale/messages-nn.ts +2 -0
- package/src/locale/messages-se.ts +2 -0
- package/src/locale/messages-sma.ts +2 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
2
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3
|
+
/**
|
|
4
|
+
* Copyright (c) 2024-present, NDLA.
|
|
5
|
+
*
|
|
6
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
7
|
+
* LICENSE file in the root directory of this source tree.
|
|
8
|
+
*
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { EmbedByline } from "../LicenseByline";
|
|
12
|
+
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
13
|
+
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
14
|
+
const StyledFigCaption = /*#__PURE__*/_styled("figcaption", {
|
|
15
|
+
target: "eds2zp40",
|
|
16
|
+
label: "StyledFigCaption"
|
|
17
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
18
|
+
name: "1oo694u",
|
|
19
|
+
styles: "background:unset;font-size:unset;padding:unset;color:unset"
|
|
20
|
+
} : {
|
|
21
|
+
name: "1oo694u",
|
|
22
|
+
styles: "background:unset;font-size:unset;padding:unset;color:unset",
|
|
23
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlyaWdodEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjBDIiwiZmlsZSI6IkNvcHlyaWdodEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IENvcHlyaWdodE1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBFbWJlZEJ5bGluZSB9IGZyb20gXCIuLi9MaWNlbnNlQnlsaW5lXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGVtYmVkOiBDb3B5cmlnaHRNZXRhRGF0YTtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFN0eWxlZEZpZ0NhcHRpb24gPSBzdHlsZWQuZmlnY2FwdGlvbmBcbiAgYmFja2dyb3VuZDogdW5zZXQ7XG4gIGZvbnQtc2l6ZTogdW5zZXQ7XG4gIHBhZGRpbmc6IHVuc2V0O1xuICBjb2xvcjogdW5zZXQ7XG5gO1xuXG5jb25zdCBDb3B5cmlnaHRFbWJlZCA9ICh7IGVtYmVkLCBjaGlsZHJlbiB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxmaWd1cmU+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3R5bGVkRmlnQ2FwdGlvbj5cbiAgICAgICAgPEVtYmVkQnlsaW5lIHR5cGU9XCJjb3B5cmlnaHRcIiBjb3B5cmlnaHQ9e2VtYmVkLmVtYmVkRGF0YS5jb3B5cmlnaHR9IGJvdHRvbVJvdW5kZWQgLz5cbiAgICAgIDwvU3R5bGVkRmlnQ2FwdGlvbj5cbiAgICA8L2ZpZ3VyZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlyaWdodEVtYmVkO1xuIl19 */",
|
|
24
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
25
|
+
});
|
|
26
|
+
const CopyrightEmbed = _ref => {
|
|
27
|
+
let {
|
|
28
|
+
embed,
|
|
29
|
+
children
|
|
30
|
+
} = _ref;
|
|
31
|
+
return _jsxs("figure", {
|
|
32
|
+
children: [children, _jsx(StyledFigCaption, {
|
|
33
|
+
children: _jsx(EmbedByline, {
|
|
34
|
+
type: "copyright",
|
|
35
|
+
copyright: embed.embedData.copyright,
|
|
36
|
+
bottomRounded: true
|
|
37
|
+
})
|
|
38
|
+
})]
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
export default CopyrightEmbed;
|
package/es/Embed/index.js
CHANGED
|
@@ -20,4 +20,5 @@ export { ConceptNotionV2 } from "./conceptComponents";
|
|
|
20
20
|
export { default as ConceptListEmbed } from "./ConceptListEmbed";
|
|
21
21
|
export { default as UnknownEmbed } from "./UnknownEmbed";
|
|
22
22
|
export { InlineConcept, BlockConcept } from "./ConceptEmbed";
|
|
23
|
-
export { default as UuDisclaimerEmbed } from "./UuDisclaimerEmbed";
|
|
23
|
+
export { default as UuDisclaimerEmbed } from "./UuDisclaimerEmbed";
|
|
24
|
+
export { default as CopyrightEmbed } from "./CopyrightEmbed";
|
package/es/Gloss/Gloss.js
CHANGED
|
@@ -22,23 +22,23 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
|
22
22
|
const StyledAccordionItem = /*#__PURE__*/_styled(AccordionItem, {
|
|
23
23
|
target: "ebofeyi7",
|
|
24
24
|
label: "StyledAccordionItem"
|
|
25
|
-
})("background-color:", colors.background.lightBlue, ";border:1px solid ", colors.brand.tertiary, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdsb3NzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ2lEIiwiZmlsZSI6Ikdsb3NzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tIFwicmVhY3QtaTE4bmV4dFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBUcmlnZ2VyIH0gZnJvbSBcIkByYWRpeC11aS9yZWFjdC1hY2NvcmRpb25cIjtcbmltcG9ydCB7IEFjY29yZGlvblJvb3QsIEFjY29yZGlvbkl0ZW0sIEFjY29yZGlvbkNvbnRlbnQgfSBmcm9tIFwiQG5kbGEvYWNjb3JkaW9uXCI7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcsIG1pc2MsIGZvbnRzIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IENoZXZyb25Eb3duIH0gZnJvbSBcIkBuZGxhL2ljb25zL2NvbW1vblwiO1xuaW1wb3J0IHsgSUdsb3NzRGF0YSwgSUdsb3NzRXhhbXBsZSB9IGZyb20gXCJAbmRsYS90eXBlcy1iYWNrZW5kL2NvbmNlcHQtYXBpXCI7XG5pbXBvcnQgR2xvc3NFeGFtcGxlIGZyb20gXCIuL0dsb3NzRXhhbXBsZVwiO1xuaW1wb3J0IFNwZWVjaENvbnRyb2wgZnJvbSBcIi4uL0F1ZGlvUGxheWVyL1NwZWVjaENvbnRyb2xcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlOiB7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBsYW5ndWFnZTogc3RyaW5nO1xuICB9O1xuICBnbG9zc0RhdGE/
|
|
25
|
+
})("background-color:", colors.background.lightBlue, ";border:1px solid ", colors.brand.tertiary, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AAiCiD","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
26
26
|
const Wrapper = /*#__PURE__*/_styled("div", {
|
|
27
27
|
target: "ebofeyi6",
|
|
28
28
|
label: "Wrapper"
|
|
29
|
-
})("display:flex;flex-wrap:wrap;justify-content:space-between;padding:", spacing.nsmall, " ", spacing.normal, " 0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdsb3NzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQzBCIiwiZmlsZSI6Ikdsb3NzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tIFwicmVhY3QtaTE4bmV4dFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBUcmlnZ2VyIH0gZnJvbSBcIkByYWRpeC11aS9yZWFjdC1hY2NvcmRpb25cIjtcbmltcG9ydCB7IEFjY29yZGlvblJvb3QsIEFjY29yZGlvbkl0ZW0sIEFjY29yZGlvbkNvbnRlbnQgfSBmcm9tIFwiQG5kbGEvYWNjb3JkaW9uXCI7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcsIG1pc2MsIGZvbnRzIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IENoZXZyb25Eb3duIH0gZnJvbSBcIkBuZGxhL2ljb25zL2NvbW1vblwiO1xuaW1wb3J0IHsgSUdsb3NzRGF0YSwgSUdsb3NzRXhhbXBsZSB9IGZyb20gXCJAbmRsYS90eXBlcy1iYWNrZW5kL2NvbmNlcHQtYXBpXCI7XG5pbXBvcnQgR2xvc3NFeGFtcGxlIGZyb20gXCIuL0dsb3NzRXhhbXBsZVwiO1xuaW1wb3J0IFNwZWVjaENvbnRyb2wgZnJvbSBcIi4uL0F1ZGlvUGxheWVyL1NwZWVjaENvbnRyb2xcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlOiB7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBsYW5ndWFnZTogc3RyaW5nO1xuICB9O1xuICBnbG9zc0RhdGE/
|
|
29
|
+
})("display:flex;flex-wrap:wrap;justify-content:space-between;padding:", spacing.nsmall, " ", spacing.normal, " 0 ", spacing.normal, ";span{", fonts.size.text.content, " font-family:", fonts.sans, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AAsC0B","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
30
30
|
const GlossContainer = /*#__PURE__*/_styled("div", {
|
|
31
31
|
target: "ebofeyi5",
|
|
32
32
|
label: "GlossContainer"
|
|
33
|
-
})("display:flex;align-items:center;flex-wrap:wrap;gap:", spacing.nsmall, ";span
|
|
33
|
+
})("display:flex;align-items:center;flex-wrap:wrap;gap:", spacing.nsmall, ";span[data-pinyin]{font-style:italic;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AAiDiC","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
34
34
|
const GlossSpan = /*#__PURE__*/_styled("span", {
|
|
35
35
|
target: "ebofeyi4",
|
|
36
36
|
label: "GlossSpan"
|
|
37
|
-
})("font-weight:", fonts.weight.bold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
37
|
+
})("font-weight:", fonts.weight.bold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AA2D6B","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
38
38
|
const StyledWrapper = /*#__PURE__*/_styled("div", {
|
|
39
39
|
target: "ebofeyi3",
|
|
40
40
|
label: "StyledWrapper"
|
|
41
|
-
})("display:flex;justify-content:space-between;align-items:center;padding:0 ", spacing.normal, " ", spacing.nsmall, " ", spacing.normal, ";background-color:", colors.background.lightBlue, ";border-radius:", misc.borderRadius, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
+
})("display:flex;justify-content:space-between;align-items:center;padding:0 ", spacing.normal, " ", spacing.nsmall, " ", spacing.normal, ";background-color:", colors.background.lightBlue, ";border-radius:", misc.borderRadius, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AA+DgC","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
42
42
|
const StyledAccordionContent = /*#__PURE__*/_styled(AccordionContent, {
|
|
43
43
|
target: "ebofeyi2",
|
|
44
44
|
label: "StyledAccordionContent"
|
|
@@ -48,17 +48,17 @@ const StyledAccordionContent = /*#__PURE__*/_styled(AccordionContent, {
|
|
|
48
48
|
} : {
|
|
49
49
|
name: "1hcx8jb",
|
|
50
50
|
styles: "padding:0",
|
|
51
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
51
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AAwEuD","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */",
|
|
52
52
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
53
53
|
});
|
|
54
54
|
const StyledTrigger = /*#__PURE__*/_styled(Trigger, {
|
|
55
55
|
target: "ebofeyi1",
|
|
56
56
|
label: "StyledTrigger"
|
|
57
|
-
})("background-color:transparent;cursor:pointer;border:none;padding:", spacing.xsmall, ";border-radius:", misc.borderRadiusLarge, ";color:", colors.brand.primary, ";&:hover,&:focus-visible{color:", colors.white, ";background-color:", colors.brand.primary, ";}&[data-state=\"open\"]{background-color:", colors.brand.lighter, ";&:hover,&:focus-visible{background-color:", colors.brand.primary, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
57
|
+
})("background-color:transparent;cursor:pointer;border:none;padding:", spacing.xsmall, ";border-radius:", misc.borderRadiusLarge, ";color:", colors.brand.primary, ";&:hover,&:focus-visible{color:", colors.white, ";background-color:", colors.brand.primary, ";}&[data-state=\"open\"]{background-color:", colors.brand.lighter, ";&:hover,&:focus-visible{background-color:", colors.brand.primary, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AA4EqC","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
58
58
|
const StyledChevron = /*#__PURE__*/_styled(ChevronDown, {
|
|
59
59
|
target: "ebofeyi0",
|
|
60
60
|
label: "StyledChevron"
|
|
61
|
-
})("transition:all 200ms ease-in-out;[data-styled-trigger][data-state=\"open\"]>&{transform:rotate(180deg);}min-width:", spacing.normal, ";min-height:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
61
|
+
})("transition:all 200ms ease-in-out;[data-styled-trigger][data-state=\"open\"]>&{transform:rotate(180deg);}min-width:", spacing.normal, ";min-height:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Gloss.tsx"],"names":[],"mappings":"AAiGyC","file":"Gloss.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { Trigger } from \"@radix-ui/react-accordion\";\nimport { AccordionRoot, AccordionItem, AccordionContent } from \"@ndla/accordion\";\nimport { colors, spacing, misc, fonts } from \"@ndla/core\";\nimport { ChevronDown } from \"@ndla/icons/common\";\nimport { IGlossData, IGlossExample } from \"@ndla/types-backend/concept-api\";\nimport GlossExample from \"./GlossExample\";\nimport SpeechControl from \"../AudioPlayer/SpeechControl\";\n\nexport interface Props {\n  title: {\n    title: string;\n    language: string;\n  };\n  glossData?: IGlossData;\n  audio?: {\n    title: string;\n    src?: string;\n  };\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst StyledAccordionItem = styled(AccordionItem)`\n  background-color: ${colors.background.lightBlue};\n  border: 1px solid ${colors.brand.tertiary};\n`;\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  padding: ${spacing.nsmall} ${spacing.normal} 0 ${spacing.normal};\n  span {\n    ${fonts.size.text.content}\n    font-family: ${fonts.sans};\n  }\n`;\n\nconst GlossContainer = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  gap: ${spacing.nsmall};\n  span[data-pinyin] {\n    font-style: italic;\n  }\n`;\n\nconst GlossSpan = styled.span`\n  font-weight: ${fonts.weight.bold};\n`;\n\nconst StyledWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0 ${spacing.normal} ${spacing.nsmall} ${spacing.normal};\n  background-color: ${colors.background.lightBlue};\n  border-radius: ${misc.borderRadius};\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  padding: 0;\n`;\n\nconst StyledTrigger = styled(Trigger)`\n  background-color: transparent;\n  cursor: pointer;\n  border: none;\n  padding: ${spacing.xsmall};\n  border-radius: ${misc.borderRadiusLarge};\n  color: ${colors.brand.primary};\n  &:hover,\n  &:focus-visible {\n    color: ${colors.white};\n    background-color: ${colors.brand.primary};\n  }\n  &[data-state=\"open\"] {\n    background-color: ${colors.brand.lighter};\n    &:hover,\n    &:focus-visible {\n      background-color: ${colors.brand.primary};\n    }\n  }\n`;\n\nconst StyledChevron = styled(ChevronDown)`\n  transition: all 200ms ease-in-out;\n  [data-styled-trigger][data-state=\"open\"] > & {\n    transform: rotate(180deg);\n  }\n  min-width: ${spacing.normal};\n  min-height: ${spacing.normal};\n`;\n\nconst getFilteredExamples = (\n  glossData: IGlossData | undefined,\n  exampleIds: string | undefined,\n  exampleLangs: string | undefined,\n): IGlossExample[][] => {\n  if (exampleIds !== undefined || exampleLangs !== undefined) {\n    const exampleIdsList = exampleIds?.toString()?.split(\",\") ?? [];\n    const exampleLangsList = exampleLangs?.split(\",\") ?? [];\n\n    const filteredExamples =\n      glossData?.examples?.map((examples, i) => {\n        if (exampleIdsList.includes(i.toString())) {\n          return examples.filter((e) => exampleLangsList.includes(e.language));\n        } else return [];\n      }) ?? [];\n    const examplesWithoutEmpty = filteredExamples.filter((el) => !!el.length);\n    return examplesWithoutEmpty;\n  } else return glossData?.examples ?? [];\n};\n\nconst Gloss = ({ title, glossData, audio, exampleIds, exampleLangs }: Props) => {\n  const { t } = useTranslation();\n\n  const filteredExamples = useMemo(\n    () => getFilteredExamples(glossData, exampleIds, exampleLangs),\n    [exampleIds, exampleLangs, glossData],\n  );\n\n  return (\n    <>\n      {glossData && (\n        <AccordionRoot type=\"single\" collapsible>\n          <StyledAccordionItem value=\"1\">\n            <Wrapper>\n              <GlossContainer>\n                <GlossSpan lang={glossData.originalLanguage}>{glossData.gloss}</GlossSpan>\n                {glossData.transcriptions.traditional && (\n                  <span\n                    key={t(\"gloss.transcriptions.traditional\")}\n                    aria-label={t(\"gloss.transcriptions.traditional\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.traditional}\n                  </span>\n                )}\n                {glossData.transcriptions.pinyin && (\n                  <span\n                    data-pinyin=\"\"\n                    key={t(\"gloss.transcriptions.pinyin\")}\n                    aria-label={t(\"gloss.transcriptions.pinyin\")}\n                    lang={glossData.originalLanguage}\n                  >\n                    {glossData.transcriptions.pinyin}\n                  </span>\n                )}\n                {glossData.wordClass && (\n                  <span aria-label={t(\"gloss.wordClass\")}>{t(`wordClass.${glossData.wordClass}`).toLowerCase()}</span>\n                )}\n              </GlossContainer>\n              {audio?.src && <SpeechControl src={audio.src} title={audio.title}></SpeechControl>}\n            </Wrapper>\n            {filteredExamples.length > 0 ? (\n              <>\n                <StyledWrapper>\n                  <span lang={title.language}>{title.title}</span>\n                  <StyledTrigger data-styled-trigger aria-label={t(\"gloss.examples\")}>\n                    <StyledChevron />\n                  </StyledTrigger>\n                </StyledWrapper>\n                <StyledAccordionContent>\n                  {filteredExamples.map((examples, index) => (\n                    <div key={`gloss-example-${index}`}>\n                      {examples.map((example, innerIndex) => (\n                        <GlossExample\n                          key={`gloss-example-${index}-${innerIndex}`}\n                          example={example}\n                          originalLanguage={glossData.originalLanguage}\n                          index={innerIndex}\n                        />\n                      ))}\n                    </div>\n                  ))}\n                </StyledAccordionContent>\n              </>\n            ) : (\n              <StyledWrapper>\n                <span lang={title.language}>{title.title}</span>\n              </StyledWrapper>\n            )}\n          </StyledAccordionItem>\n        </AccordionRoot>\n      )}\n    </>\n  );\n};\n\nexport default Gloss;\n"]} */"));
|
|
62
62
|
const getFilteredExamples = (glossData, exampleIds, exampleLangs) => {
|
|
63
63
|
if (exampleIds !== undefined || exampleLangs !== undefined) {
|
|
64
64
|
const exampleIdsList = exampleIds?.toString()?.split(",") ?? [];
|
|
@@ -119,6 +119,7 @@ const Gloss = _ref => {
|
|
|
119
119
|
children: title.title
|
|
120
120
|
}), _jsx(StyledTrigger, {
|
|
121
121
|
"data-styled-trigger": true,
|
|
122
|
+
"aria-label": t("gloss.examples"),
|
|
122
123
|
children: _jsx(StyledChevron, {})
|
|
123
124
|
})]
|
|
124
125
|
}), _jsx(StyledAccordionContent, {
|
|
@@ -126,8 +127,7 @@ const Gloss = _ref => {
|
|
|
126
127
|
children: examples.map((example, innerIndex) => _jsx(GlossExample, {
|
|
127
128
|
example: example,
|
|
128
129
|
originalLanguage: glossData.originalLanguage,
|
|
129
|
-
index: innerIndex
|
|
130
|
-
lastExampleIndex: examples.length - 1
|
|
130
|
+
index: innerIndex
|
|
131
131
|
}, `gloss-example-${index}-${innerIndex}`))
|
|
132
132
|
}, `gloss-example-${index}`))
|
|
133
133
|
})]
|
package/es/Gloss/GlossExample.js
CHANGED
|
@@ -14,27 +14,28 @@ import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
|
14
14
|
const StyledGlossExampleWrapper = /*#__PURE__*/_styled("div", {
|
|
15
15
|
target: "ess9y4n2",
|
|
16
16
|
label: "StyledGlossExampleWrapper"
|
|
17
|
-
})("&:first-of-type{border-top:1px solid ", colors.brand.
|
|
17
|
+
})("&[data-is-standalone=\"true\"]{&:first-of-type{border-top:1px solid ", colors.brand.lighter, ";}}&:first-of-type&:not([data-is-standalone=\"true\"]){border-top:1px solid ", colors.brand.primary, ";}&[data-is-standalone=\"false\"]{&:not(:last-child){div{border-bottom:1px solid ", colors.brand.lighter, ";border-radius:0;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdsb3NzRXhhbXBsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0I0QyIsImZpbGUiOiJHbG9zc0V4YW1wbGUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgZm9udHMsIG1pc2MgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgSUdsb3NzRXhhbXBsZSB9IGZyb20gXCJAbmRsYS90eXBlcy1iYWNrZW5kL2NvbmNlcHQtYXBpXCI7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSBcIkBuZGxhL3R5cG9ncmFwaHlcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gIGV4YW1wbGU6IElHbG9zc0V4YW1wbGU7XG4gIG9yaWdpbmFsTGFuZ3VhZ2U6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNTdGFuZGFsb25lPzogYm9vbGVhbjtcbn1cblxuY29uc3QgU3R5bGVkR2xvc3NFeGFtcGxlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gICZbZGF0YS1pcy1zdGFuZGFsb25lPVwidHJ1ZVwiXSB7XG4gICAgJjpmaXJzdC1vZi10eXBlIHtcbiAgICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5saWdodGVyfTtcbiAgICB9XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUmOm5vdChbZGF0YS1pcy1zdGFuZGFsb25lPVwidHJ1ZVwiXSkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgfVxuXG4gICZbZGF0YS1pcy1zdGFuZGFsb25lPVwiZmFsc2VcIl0ge1xuICAgICY6bm90KDpsYXN0LWNoaWxkKSB7XG4gICAgICBkaXYge1xuICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRHbG9zc0V4YW1wbGUgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5ub3JtYWx9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kLmRlZmF1bHR9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5saWdodGVyfTtcbiAgYm9yZGVyLXRvcDogbm9uZTtcblxuICAmW2RhdGEtaXMtZmlyc3Q9XCJ0cnVlXCJdIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kLmxpZ2h0Qmx1ZX07XG4gIH1cbiAgJltkYXRhLWlzLXN0YW5kYWxvbmU9XCJmYWxzZVwiXSB7XG4gICAgYm9yZGVyOiBub25lO1xuICAgIGJvcmRlci1yYWRpdXM6ICR7bWlzYy5ib3JkZXJSYWRpdXN9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICAmW2RhdGEtaXMtZmlyc3Q9XCJ0cnVlXCJdIHtcbiAgICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gIH1cbiAgJltkYXRhLXBpbnlpbl0ge1xuICAgIGZvbnQtc3R5bGU6IGl0YWxpYztcbiAgfVxuYDtcblxuY29uc3QgR2xvc3NFeGFtcGxlID0gKHsgZXhhbXBsZSwgb3JpZ2luYWxMYW5ndWFnZSwgaW5kZXgsIGlzU3RhbmRhbG9uZSA9IGZhbHNlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEdsb3NzRXhhbXBsZVdyYXBwZXIgZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9PlxuICAgICAgPFN0eWxlZEdsb3NzRXhhbXBsZSBkYXRhLWlzLWZpcnN0PXtpbmRleCA9PT0gMH0gbGFuZz17ZXhhbXBsZS5sYW5ndWFnZX0gZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9PlxuICAgICAgICA8U3R5bGVkVGV4dCBkYXRhLWlzLWZpcnN0PXtpbmRleCA9PT0gMH0gdGV4dFN0eWxlPVwibWV0YS10ZXh0LW1lZGl1bVwiIG1hcmdpbj1cIm5vbmVcIj5cbiAgICAgICAgICB7ZXhhbXBsZS5leGFtcGxlfVxuICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICA8L1N0eWxlZEdsb3NzRXhhbXBsZT5cbiAgICAgIHtleGFtcGxlLnRyYW5zY3JpcHRpb25zLnBpbnlpbiAmJiAoXG4gICAgICAgIDxTdHlsZWRHbG9zc0V4YW1wbGVcbiAgICAgICAgICBsYW5nPXtvcmlnaW5hbExhbmd1YWdlfVxuICAgICAgICAgIGRhdGEtaXMtc3RhbmRhbG9uZT17aXNTdGFuZGFsb25lfVxuICAgICAgICAgIGRhdGEtaXMtbGFzdD17ZXhhbXBsZS50cmFuc2NyaXB0aW9ucy50cmFkaXRpb25hbD8ubGVuZ3RoID09PSAwfVxuICAgICAgICA+XG4gICAgICAgICAgPFN0eWxlZFRleHQgZGF0YS1waW55aW4gdGV4dFN0eWxlPVwibWV0YS10ZXh0LW1lZGl1bVwiIG1hcmdpbj1cIm5vbmVcIj5cbiAgICAgICAgICAgIHtleGFtcGxlLnRyYW5zY3JpcHRpb25zPy5waW55aW59XG4gICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICA8L1N0eWxlZEdsb3NzRXhhbXBsZT5cbiAgICAgICl9XG4gICAgICB7ZXhhbXBsZS50cmFuc2NyaXB0aW9ucy50cmFkaXRpb25hbCAmJiAoXG4gICAgICAgIDxTdHlsZWRHbG9zc0V4YW1wbGUgbGFuZz17b3JpZ2luYWxMYW5ndWFnZX0gZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9IGRhdGEtaXMtbGFzdD5cbiAgICAgICAgICA8U3R5bGVkVGV4dCB0ZXh0U3R5bGU9XCJtZXRhLXRleHQtbWVkaXVtXCIgbWFyZ2luPVwibm9uZVwiPlxuICAgICAgICAgICAge2V4YW1wbGUudHJhbnNjcmlwdGlvbnM/LnRyYWRpdGlvbmFsfVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgPC9TdHlsZWRHbG9zc0V4YW1wbGU+XG4gICAgICApfVxuICAgIDwvU3R5bGVkR2xvc3NFeGFtcGxlV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEdsb3NzRXhhbXBsZTtcbiJdfQ== */"));
|
|
18
18
|
const StyledGlossExample = /*#__PURE__*/_styled("div", {
|
|
19
19
|
target: "ess9y4n1",
|
|
20
20
|
label: "StyledGlossExample"
|
|
21
|
-
})("padding:", spacing.small, " ", spacing.normal, ";
|
|
21
|
+
})("padding:", spacing.small, " ", spacing.normal, ";background-color:", colors.background.default, ";border:1px solid ", colors.brand.lighter, ";border-top:none;&[data-is-first=\"true\"]{background-color:", colors.background.lightBlue, ";}&[data-is-standalone=\"false\"]{border:none;border-radius:", misc.borderRadius, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdsb3NzRXhhbXBsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUNxQyIsImZpbGUiOiJHbG9zc0V4YW1wbGUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgZm9udHMsIG1pc2MgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgSUdsb3NzRXhhbXBsZSB9IGZyb20gXCJAbmRsYS90eXBlcy1iYWNrZW5kL2NvbmNlcHQtYXBpXCI7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSBcIkBuZGxhL3R5cG9ncmFwaHlcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gIGV4YW1wbGU6IElHbG9zc0V4YW1wbGU7XG4gIG9yaWdpbmFsTGFuZ3VhZ2U6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNTdGFuZGFsb25lPzogYm9vbGVhbjtcbn1cblxuY29uc3QgU3R5bGVkR2xvc3NFeGFtcGxlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gICZbZGF0YS1pcy1zdGFuZGFsb25lPVwidHJ1ZVwiXSB7XG4gICAgJjpmaXJzdC1vZi10eXBlIHtcbiAgICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5saWdodGVyfTtcbiAgICB9XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUmOm5vdChbZGF0YS1pcy1zdGFuZGFsb25lPVwidHJ1ZVwiXSkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgfVxuXG4gICZbZGF0YS1pcy1zdGFuZGFsb25lPVwiZmFsc2VcIl0ge1xuICAgICY6bm90KDpsYXN0LWNoaWxkKSB7XG4gICAgICBkaXYge1xuICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRHbG9zc0V4YW1wbGUgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5ub3JtYWx9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kLmRlZmF1bHR9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5saWdodGVyfTtcbiAgYm9yZGVyLXRvcDogbm9uZTtcblxuICAmW2RhdGEtaXMtZmlyc3Q9XCJ0cnVlXCJdIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kLmxpZ2h0Qmx1ZX07XG4gIH1cbiAgJltkYXRhLWlzLXN0YW5kYWxvbmU9XCJmYWxzZVwiXSB7XG4gICAgYm9yZGVyOiBub25lO1xuICAgIGJvcmRlci1yYWRpdXM6ICR7bWlzYy5ib3JkZXJSYWRpdXN9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICAmW2RhdGEtaXMtZmlyc3Q9XCJ0cnVlXCJdIHtcbiAgICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gIH1cbiAgJltkYXRhLXBpbnlpbl0ge1xuICAgIGZvbnQtc3R5bGU6IGl0YWxpYztcbiAgfVxuYDtcblxuY29uc3QgR2xvc3NFeGFtcGxlID0gKHsgZXhhbXBsZSwgb3JpZ2luYWxMYW5ndWFnZSwgaW5kZXgsIGlzU3RhbmRhbG9uZSA9IGZhbHNlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEdsb3NzRXhhbXBsZVdyYXBwZXIgZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9PlxuICAgICAgPFN0eWxlZEdsb3NzRXhhbXBsZSBkYXRhLWlzLWZpcnN0PXtpbmRleCA9PT0gMH0gbGFuZz17ZXhhbXBsZS5sYW5ndWFnZX0gZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9PlxuICAgICAgICA8U3R5bGVkVGV4dCBkYXRhLWlzLWZpcnN0PXtpbmRleCA9PT0gMH0gdGV4dFN0eWxlPVwibWV0YS10ZXh0LW1lZGl1bVwiIG1hcmdpbj1cIm5vbmVcIj5cbiAgICAgICAgICB7ZXhhbXBsZS5leGFtcGxlfVxuICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICA8L1N0eWxlZEdsb3NzRXhhbXBsZT5cbiAgICAgIHtleGFtcGxlLnRyYW5zY3JpcHRpb25zLnBpbnlpbiAmJiAoXG4gICAgICAgIDxTdHlsZWRHbG9zc0V4YW1wbGVcbiAgICAgICAgICBsYW5nPXtvcmlnaW5hbExhbmd1YWdlfVxuICAgICAgICAgIGRhdGEtaXMtc3RhbmRhbG9uZT17aXNTdGFuZGFsb25lfVxuICAgICAgICAgIGRhdGEtaXMtbGFzdD17ZXhhbXBsZS50cmFuc2NyaXB0aW9ucy50cmFkaXRpb25hbD8ubGVuZ3RoID09PSAwfVxuICAgICAgICA+XG4gICAgICAgICAgPFN0eWxlZFRleHQgZGF0YS1waW55aW4gdGV4dFN0eWxlPVwibWV0YS10ZXh0LW1lZGl1bVwiIG1hcmdpbj1cIm5vbmVcIj5cbiAgICAgICAgICAgIHtleGFtcGxlLnRyYW5zY3JpcHRpb25zPy5waW55aW59XG4gICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICA8L1N0eWxlZEdsb3NzRXhhbXBsZT5cbiAgICAgICl9XG4gICAgICB7ZXhhbXBsZS50cmFuc2NyaXB0aW9ucy50cmFkaXRpb25hbCAmJiAoXG4gICAgICAgIDxTdHlsZWRHbG9zc0V4YW1wbGUgbGFuZz17b3JpZ2luYWxMYW5ndWFnZX0gZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9IGRhdGEtaXMtbGFzdD5cbiAgICAgICAgICA8U3R5bGVkVGV4dCB0ZXh0U3R5bGU9XCJtZXRhLXRleHQtbWVkaXVtXCIgbWFyZ2luPVwibm9uZVwiPlxuICAgICAgICAgICAge2V4YW1wbGUudHJhbnNjcmlwdGlvbnM/LnRyYWRpdGlvbmFsfVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgPC9TdHlsZWRHbG9zc0V4YW1wbGU+XG4gICAgICApfVxuICAgIDwvU3R5bGVkR2xvc3NFeGFtcGxlV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEdsb3NzRXhhbXBsZTtcbiJdfQ== */"));
|
|
22
22
|
const StyledText = /*#__PURE__*/_styled(Text, {
|
|
23
23
|
target: "ess9y4n0",
|
|
24
24
|
label: "StyledText"
|
|
25
|
-
})("&[data-is-first=\"true\"]{font-weight:", fonts.weight.bold, ";color:", colors.text.primary, ";}&[data-pinyin]{font-style:italic;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
25
|
+
})("&[data-is-first=\"true\"]{font-weight:", fonts.weight.bold, ";color:", colors.text.primary, ";}&[data-pinyin]{font-style:italic;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdsb3NzRXhhbXBsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0QrQiIsImZpbGUiOiJHbG9zc0V4YW1wbGUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgZm9udHMsIG1pc2MgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgSUdsb3NzRXhhbXBsZSB9IGZyb20gXCJAbmRsYS90eXBlcy1iYWNrZW5kL2NvbmNlcHQtYXBpXCI7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSBcIkBuZGxhL3R5cG9ncmFwaHlcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQcm9wcyB7XG4gIGV4YW1wbGU6IElHbG9zc0V4YW1wbGU7XG4gIG9yaWdpbmFsTGFuZ3VhZ2U6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNTdGFuZGFsb25lPzogYm9vbGVhbjtcbn1cblxuY29uc3QgU3R5bGVkR2xvc3NFeGFtcGxlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gICZbZGF0YS1pcy1zdGFuZGFsb25lPVwidHJ1ZVwiXSB7XG4gICAgJjpmaXJzdC1vZi10eXBlIHtcbiAgICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5saWdodGVyfTtcbiAgICB9XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUmOm5vdChbZGF0YS1pcy1zdGFuZGFsb25lPVwidHJ1ZVwiXSkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgfVxuXG4gICZbZGF0YS1pcy1zdGFuZGFsb25lPVwiZmFsc2VcIl0ge1xuICAgICY6bm90KDpsYXN0LWNoaWxkKSB7XG4gICAgICBkaXYge1xuICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQubGlnaHRlcn07XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDA7XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRHbG9zc0V4YW1wbGUgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9ICR7c3BhY2luZy5ub3JtYWx9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kLmRlZmF1bHR9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2NvbG9ycy5icmFuZC5saWdodGVyfTtcbiAgYm9yZGVyLXRvcDogbm9uZTtcblxuICAmW2RhdGEtaXMtZmlyc3Q9XCJ0cnVlXCJdIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kLmxpZ2h0Qmx1ZX07XG4gIH1cbiAgJltkYXRhLWlzLXN0YW5kYWxvbmU9XCJmYWxzZVwiXSB7XG4gICAgYm9yZGVyOiBub25lO1xuICAgIGJvcmRlci1yYWRpdXM6ICR7bWlzYy5ib3JkZXJSYWRpdXN9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICAmW2RhdGEtaXMtZmlyc3Q9XCJ0cnVlXCJdIHtcbiAgICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuYm9sZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gIH1cbiAgJltkYXRhLXBpbnlpbl0ge1xuICAgIGZvbnQtc3R5bGU6IGl0YWxpYztcbiAgfVxuYDtcblxuY29uc3QgR2xvc3NFeGFtcGxlID0gKHsgZXhhbXBsZSwgb3JpZ2luYWxMYW5ndWFnZSwgaW5kZXgsIGlzU3RhbmRhbG9uZSA9IGZhbHNlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEdsb3NzRXhhbXBsZVdyYXBwZXIgZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9PlxuICAgICAgPFN0eWxlZEdsb3NzRXhhbXBsZSBkYXRhLWlzLWZpcnN0PXtpbmRleCA9PT0gMH0gbGFuZz17ZXhhbXBsZS5sYW5ndWFnZX0gZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9PlxuICAgICAgICA8U3R5bGVkVGV4dCBkYXRhLWlzLWZpcnN0PXtpbmRleCA9PT0gMH0gdGV4dFN0eWxlPVwibWV0YS10ZXh0LW1lZGl1bVwiIG1hcmdpbj1cIm5vbmVcIj5cbiAgICAgICAgICB7ZXhhbXBsZS5leGFtcGxlfVxuICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICA8L1N0eWxlZEdsb3NzRXhhbXBsZT5cbiAgICAgIHtleGFtcGxlLnRyYW5zY3JpcHRpb25zLnBpbnlpbiAmJiAoXG4gICAgICAgIDxTdHlsZWRHbG9zc0V4YW1wbGVcbiAgICAgICAgICBsYW5nPXtvcmlnaW5hbExhbmd1YWdlfVxuICAgICAgICAgIGRhdGEtaXMtc3RhbmRhbG9uZT17aXNTdGFuZGFsb25lfVxuICAgICAgICAgIGRhdGEtaXMtbGFzdD17ZXhhbXBsZS50cmFuc2NyaXB0aW9ucy50cmFkaXRpb25hbD8ubGVuZ3RoID09PSAwfVxuICAgICAgICA+XG4gICAgICAgICAgPFN0eWxlZFRleHQgZGF0YS1waW55aW4gdGV4dFN0eWxlPVwibWV0YS10ZXh0LW1lZGl1bVwiIG1hcmdpbj1cIm5vbmVcIj5cbiAgICAgICAgICAgIHtleGFtcGxlLnRyYW5zY3JpcHRpb25zPy5waW55aW59XG4gICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICA8L1N0eWxlZEdsb3NzRXhhbXBsZT5cbiAgICAgICl9XG4gICAgICB7ZXhhbXBsZS50cmFuc2NyaXB0aW9ucy50cmFkaXRpb25hbCAmJiAoXG4gICAgICAgIDxTdHlsZWRHbG9zc0V4YW1wbGUgbGFuZz17b3JpZ2luYWxMYW5ndWFnZX0gZGF0YS1pcy1zdGFuZGFsb25lPXtpc1N0YW5kYWxvbmV9IGRhdGEtaXMtbGFzdD5cbiAgICAgICAgICA8U3R5bGVkVGV4dCB0ZXh0U3R5bGU9XCJtZXRhLXRleHQtbWVkaXVtXCIgbWFyZ2luPVwibm9uZVwiPlxuICAgICAgICAgICAge2V4YW1wbGUudHJhbnNjcmlwdGlvbnM/LnRyYWRpdGlvbmFsfVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgPC9TdHlsZWRHbG9zc0V4YW1wbGU+XG4gICAgICApfVxuICAgIDwvU3R5bGVkR2xvc3NFeGFtcGxlV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEdsb3NzRXhhbXBsZTtcbiJdfQ== */"));
|
|
26
26
|
const GlossExample = _ref => {
|
|
27
27
|
let {
|
|
28
28
|
example,
|
|
29
29
|
originalLanguage,
|
|
30
30
|
index,
|
|
31
|
-
|
|
31
|
+
isStandalone = false
|
|
32
32
|
} = _ref;
|
|
33
33
|
return _jsxs(StyledGlossExampleWrapper, {
|
|
34
|
+
"data-is-standalone": isStandalone,
|
|
34
35
|
children: [_jsx(StyledGlossExample, {
|
|
35
36
|
"data-is-first": index === 0,
|
|
36
|
-
"data-is-last": index === lastExampleIndex,
|
|
37
37
|
lang: example.language,
|
|
38
|
+
"data-is-standalone": isStandalone,
|
|
38
39
|
children: _jsx(StyledText, {
|
|
39
40
|
"data-is-first": index === 0,
|
|
40
41
|
textStyle: "meta-text-medium",
|
|
@@ -43,6 +44,8 @@ const GlossExample = _ref => {
|
|
|
43
44
|
})
|
|
44
45
|
}), example.transcriptions.pinyin && _jsx(StyledGlossExample, {
|
|
45
46
|
lang: originalLanguage,
|
|
47
|
+
"data-is-standalone": isStandalone,
|
|
48
|
+
"data-is-last": example.transcriptions.traditional?.length === 0,
|
|
46
49
|
children: _jsx(StyledText, {
|
|
47
50
|
"data-pinyin": true,
|
|
48
51
|
textStyle: "meta-text-medium",
|
|
@@ -51,6 +54,8 @@ const GlossExample = _ref => {
|
|
|
51
54
|
})
|
|
52
55
|
}), example.transcriptions.traditional && _jsx(StyledGlossExample, {
|
|
53
56
|
lang: originalLanguage,
|
|
57
|
+
"data-is-standalone": isStandalone,
|
|
58
|
+
"data-is-last": true,
|
|
54
59
|
children: _jsx(StyledText, {
|
|
55
60
|
textStyle: "meta-text-medium",
|
|
56
61
|
margin: "none",
|