@onsvisual/svelte-components 1.0.40 → 1.0.42

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (223) hide show
  1. package/README.md +24 -24
  2. package/dist/css/main.css +513 -513
  3. package/dist/datavis/BarChart/BarChart.stories.svelte +84 -84
  4. package/dist/datavis/BarChart/docs/component.md +19 -19
  5. package/dist/datavis/Chart/Chart.stories.svelte +128 -128
  6. package/dist/datavis/Chart/docs/component.md +31 -31
  7. package/dist/datavis/Chart/docs/example.md +28 -28
  8. package/dist/datavis/ColumnChart/ColumnChart.stories.svelte +84 -84
  9. package/dist/datavis/ColumnChart/docs/component.md +19 -19
  10. package/dist/datavis/DataCard/DataCard.stories.svelte +45 -45
  11. package/dist/datavis/DataCard/DataCard.svelte +70 -70
  12. package/dist/datavis/DataCard/Sparkline.svelte +117 -117
  13. package/dist/datavis/DataCard/docs/component.md +20 -20
  14. package/dist/datavis/DataCard/docs/example.md +25 -25
  15. package/dist/datavis/DotPlotChart/DotPlotChart.stories.svelte +40 -40
  16. package/dist/datavis/DotPlotChart/docs/component.md +19 -19
  17. package/dist/datavis/LineChart/LineChart.stories.svelte +64 -64
  18. package/dist/datavis/LineChart/docs/component.md +31 -31
  19. package/dist/datavis/ScatterChart/ScatterChart.stories.svelte +55 -55
  20. package/dist/datavis/ScatterChart/docs/component.md +53 -53
  21. package/dist/datavis/Table/Table.stories.svelte +48 -48
  22. package/dist/datavis/Table/Table.svelte +161 -161
  23. package/dist/datavis/Table/docs/component.md +20 -20
  24. package/dist/datavis/demo-data/data-scatter.js +40 -40
  25. package/dist/datavis/demo-data/data.js +18 -18
  26. package/dist/datavis/intro.mdx +21 -21
  27. package/dist/decorators/Blockquote/Blockquote.stories.svelte +25 -25
  28. package/dist/decorators/Blockquote/Blockquote.svelte +27 -27
  29. package/dist/decorators/Blockquote/docs/component.md +10 -10
  30. package/dist/decorators/Divider/Divider.stories.svelte +29 -29
  31. package/dist/decorators/Divider/Divider.svelte +52 -52
  32. package/dist/decorators/Divider/docs/component.md +12 -12
  33. package/dist/decorators/Em/Em.stories.svelte +30 -30
  34. package/dist/decorators/Em/Em.svelte +58 -58
  35. package/dist/decorators/Em/docs/component.md +12 -12
  36. package/dist/decorators/Icon/Icon.stories.svelte +27 -27
  37. package/dist/decorators/Icon/Icon.svelte +93 -93
  38. package/dist/decorators/Icon/docs/component.md +10 -10
  39. package/dist/decorators/Indent/Indent.stories.svelte +22 -22
  40. package/dist/decorators/Indent/Indent.svelte +3 -3
  41. package/dist/decorators/Indent/docs/component.md +10 -10
  42. package/dist/index.js +86 -86
  43. package/dist/inputs/Button/Button.stories.svelte +70 -70
  44. package/dist/inputs/Button/Button.svelte +152 -152
  45. package/dist/inputs/Button/Button.svelte.d.ts +2 -2
  46. package/dist/inputs/Button/docs/component.md +17 -17
  47. package/dist/inputs/ButtonGroup/ButtonGroup.stories.svelte +40 -40
  48. package/dist/inputs/ButtonGroup/ButtonGroup.svelte +57 -57
  49. package/dist/inputs/ButtonGroup/ButtonGroupItem.svelte +101 -101
  50. package/dist/inputs/ButtonGroup/docs/component.md +23 -23
  51. package/dist/inputs/Checkbox/Checkbox.stories.svelte +34 -34
  52. package/dist/inputs/Checkbox/Checkbox.svelte +180 -180
  53. package/dist/inputs/Checkbox/docs/component.md +14 -14
  54. package/dist/inputs/Checkboxes/Checkboxes.stories.svelte +34 -34
  55. package/dist/inputs/Checkboxes/Checkboxes.svelte +62 -62
  56. package/dist/inputs/Checkboxes/docs/component.md +20 -20
  57. package/dist/inputs/Checkboxes/docs/example.md +16 -16
  58. package/dist/inputs/Dropdown/Dropdown.stories.svelte +54 -54
  59. package/dist/inputs/Dropdown/Dropdown.svelte +66 -66
  60. package/dist/inputs/Dropdown/docs/component.md +22 -22
  61. package/dist/inputs/ErrorPanel/ErrorPanel.stories.svelte +25 -25
  62. package/dist/inputs/ErrorPanel/ErrorPanel.svelte +24 -24
  63. package/dist/inputs/ErrorPanel/docs/component.md +14 -14
  64. package/dist/inputs/ErrorSummary/ErrorSummary.stories.svelte +34 -34
  65. package/dist/inputs/ErrorSummary/ErrorSummary.svelte +47 -47
  66. package/dist/inputs/ErrorSummary/docs/component.md +17 -17
  67. package/dist/inputs/ErrorSummary/docs/example.md +12 -12
  68. package/dist/inputs/Input/Input.stories.svelte +73 -73
  69. package/dist/inputs/Input/Input.svelte +151 -151
  70. package/dist/inputs/Input/docs/component.md +16 -16
  71. package/dist/inputs/Radios/Radio.svelte +90 -90
  72. package/dist/inputs/Radios/Radios.stories.svelte +51 -51
  73. package/dist/inputs/Radios/Radios.svelte +62 -62
  74. package/dist/inputs/Radios/docs/component.md +24 -24
  75. package/dist/inputs/Radios/docs/example.md +21 -21
  76. package/dist/inputs/Select/Select.stories.svelte +63 -63
  77. package/dist/inputs/Select/Select.svelte +326 -326
  78. package/dist/inputs/Select/docs/component.md +27 -27
  79. package/dist/inputs/Textarea/Textarea.stories.svelte +40 -40
  80. package/dist/inputs/Textarea/Textarea.svelte +113 -113
  81. package/dist/inputs/Textarea/docs/component.md +16 -16
  82. package/dist/inputs/Toolbar/HelpModal.svelte +234 -234
  83. package/dist/inputs/Toolbar/ToolControl.svelte +23 -23
  84. package/dist/inputs/Toolbar/ToolControls.svelte +9 -9
  85. package/dist/inputs/Toolbar/Toolbar.stories.svelte +148 -148
  86. package/dist/inputs/Toolbar/Toolbar.svelte +70 -70
  87. package/dist/inputs/Toolbar/ToolbarButton.svelte +184 -184
  88. package/dist/inputs/Toolbar/ToolbarDivider.svelte +29 -29
  89. package/dist/inputs/Toolbar/ToolbarIcon.svelte +106 -106
  90. package/dist/inputs/Toolbar/ToolbarsContainer.svelte +69 -69
  91. package/dist/inputs/Toolbar/docs/component.md +101 -101
  92. package/dist/intro.mdx +66 -66
  93. package/dist/js/menuOptions.js +14 -14
  94. package/dist/js/utils.js +133 -133
  95. package/dist/js/withParams.js +43 -43
  96. package/dist/layout/Accordion/Accordion.stories.svelte +30 -30
  97. package/dist/layout/Accordion/Accordion.svelte +55 -55
  98. package/dist/layout/Accordion/AccordionItem.svelte +51 -51
  99. package/dist/layout/Accordion/accordion.js +64 -64
  100. package/dist/layout/Accordion/details.js +83 -83
  101. package/dist/layout/Accordion/docs/component.md +19 -19
  102. package/dist/layout/AnalyticsBanner/AnalyticsBanner.stories.svelte +16 -16
  103. package/dist/layout/AnalyticsBanner/AnalyticsBanner.svelte +314 -314
  104. package/dist/layout/AnalyticsBanner/docs/component.md +44 -44
  105. package/dist/layout/BackLink/BackLink.stories.svelte +16 -16
  106. package/dist/layout/BackLink/BackLink.svelte +30 -30
  107. package/dist/layout/BackLink/docs/component.md +12 -12
  108. package/dist/layout/Breadcrumb/Breadcrumb.stories.svelte +31 -31
  109. package/dist/layout/Breadcrumb/Breadcrumb.svelte +69 -69
  110. package/dist/layout/Breadcrumb/docs/component.md +15 -15
  111. package/dist/layout/Card/Card.stories.svelte +39 -39
  112. package/dist/layout/Card/Card.svelte +127 -127
  113. package/dist/layout/Card/docs/component.md +14 -14
  114. package/dist/layout/Card/docs/eg-images.md +27 -27
  115. package/dist/layout/Card/docs/eg-links.md +12 -12
  116. package/dist/layout/Card/docs/eg-spans.md +12 -12
  117. package/dist/layout/Contents/Contents.stories.svelte +27 -27
  118. package/dist/layout/Contents/Contents.svelte +51 -51
  119. package/dist/layout/Contents/docs/component.md +18 -18
  120. package/dist/layout/DescriptionList/DescriptionList.stories.svelte +22 -22
  121. package/dist/layout/DescriptionList/DescriptionList.svelte +59 -59
  122. package/dist/layout/DescriptionList/docs/component.md +18 -18
  123. package/dist/layout/Details/Details.stories.svelte +32 -32
  124. package/dist/layout/Details/Details.svelte +75 -75
  125. package/dist/layout/Details/docs/component.md +14 -14
  126. package/dist/layout/DocumentList/Document.svelte +103 -103
  127. package/dist/layout/DocumentList/DocumentList.stories.svelte +88 -88
  128. package/dist/layout/DocumentList/DocumentList.svelte +33 -33
  129. package/dist/layout/DocumentList/docs/component.md +28 -28
  130. package/dist/layout/DocumentList/docs/example.md +23 -23
  131. package/dist/layout/ErrorPage/ErrorPage.stories.svelte +18 -18
  132. package/dist/layout/ErrorPage/ErrorPage.svelte +48 -48
  133. package/dist/layout/ErrorPage/docs/component.md +13 -13
  134. package/dist/layout/Footer/Footer.stories.svelte +24 -24
  135. package/dist/layout/Footer/Footer.svelte +366 -366
  136. package/dist/layout/Footer/docs/component.md +10 -10
  137. package/dist/layout/Grid/Grid.stories.svelte +50 -50
  138. package/dist/layout/Grid/Grid.svelte +117 -117
  139. package/dist/layout/Grid/GridCell.svelte +65 -65
  140. package/dist/layout/Grid/docs/component.md +14 -14
  141. package/dist/layout/Header/Header.stories.svelte +26 -26
  142. package/dist/layout/Header/Header.svelte +875 -875
  143. package/dist/layout/Header/docs/component.md +11 -11
  144. package/dist/layout/Hero/Hero.stories.svelte +79 -79
  145. package/dist/layout/Hero/Hero.svelte +364 -364
  146. package/dist/layout/Hero/docs/component.md +14 -14
  147. package/dist/layout/Highlight/Highlight.stories.svelte +29 -29
  148. package/dist/layout/Highlight/Highlight.svelte +77 -77
  149. package/dist/layout/Highlight/docs/component.md +12 -12
  150. package/dist/layout/Image/Image.stories.svelte +23 -23
  151. package/dist/layout/Image/Image.svelte +29 -29
  152. package/dist/layout/Image/docs/component.md +15 -15
  153. package/dist/layout/List/Li.svelte +3 -3
  154. package/dist/layout/List/List.stories.svelte +40 -40
  155. package/dist/layout/List/List.svelte +46 -46
  156. package/dist/layout/List/docs/component.md +14 -14
  157. package/dist/layout/List/docs/example.md +12 -12
  158. package/dist/layout/NavSections/NavSection.svelte +90 -90
  159. package/dist/layout/NavSections/NavSections.stories.svelte +51 -51
  160. package/dist/layout/NavSections/NavSections.svelte +160 -160
  161. package/dist/layout/NavSections/docs/component.md +25 -25
  162. package/dist/layout/Notice/Notice.stories.svelte +61 -61
  163. package/dist/layout/Notice/Notice.svelte +56 -56
  164. package/dist/layout/Notice/docs/component.md +14 -14
  165. package/dist/layout/PhaseBanner/PhaseBanner.stories.svelte +24 -24
  166. package/dist/layout/PhaseBanner/PhaseBanner.svelte +66 -66
  167. package/dist/layout/PhaseBanner/docs/component.md +14 -14
  168. package/dist/layout/RelatedContent/RelatedContent.stories.svelte +36 -36
  169. package/dist/layout/RelatedContent/RelatedContent.svelte +54 -54
  170. package/dist/layout/RelatedContent/docs/component.md +16 -16
  171. package/dist/layout/Scroller/Scroller.stories.svelte +60 -60
  172. package/dist/layout/Scroller/Scroller.svelte +368 -368
  173. package/dist/layout/Scroller/ScrollerSection.svelte +70 -70
  174. package/dist/layout/Scroller/docs/component.md +39 -39
  175. package/dist/layout/Section/Section.stories.svelte +33 -33
  176. package/dist/layout/Section/Section.svelte +60 -60
  177. package/dist/layout/Section/docs/component.md +12 -12
  178. package/dist/layout/ShareButtons/ShareButtons.stories.svelte +20 -20
  179. package/dist/layout/ShareButtons/ShareButtons.svelte +131 -131
  180. package/dist/layout/ShareButtons/docs/component.md +14 -14
  181. package/dist/layout/SkipLink/SkipLink.stories.svelte +16 -16
  182. package/dist/layout/SkipLink/SkipLink.svelte +9 -9
  183. package/dist/layout/SkipLink/docs/component.md +11 -11
  184. package/dist/layout/Summary/Summary.stories.svelte +21 -21
  185. package/dist/layout/Summary/Summary.svelte +60 -60
  186. package/dist/layout/Summary/docs/component.md +17 -17
  187. package/dist/layout/Tabs/Tab.svelte +53 -53
  188. package/dist/layout/Tabs/Tabs.stories.svelte +29 -29
  189. package/dist/layout/Tabs/Tabs.svelte +89 -89
  190. package/dist/layout/Tabs/docs/component.md +16 -16
  191. package/dist/layout/Tabs/tabs.js +302 -302
  192. package/dist/layout/Timeline/Timeline.stories.svelte +44 -44
  193. package/dist/layout/Timeline/Timeline.svelte +17 -17
  194. package/dist/layout/Timeline/TimelineItem.svelte +14 -14
  195. package/dist/layout/Timeline/docs/component.md +27 -27
  196. package/dist/layout/Timeline/docs/example.md +20 -20
  197. package/dist/templates/EmbedArticle/EmbedArticle.stories.svelte +72 -72
  198. package/dist/templates/EmbedArticle/docs/component.md +56 -56
  199. package/dist/templates/FeatureArticle/FeatureArticle.stories.svelte +150 -150
  200. package/dist/templates/FeatureArticle/docs/component.md +125 -125
  201. package/dist/templates/StandardArticle/StandardArticle.stories.svelte +86 -86
  202. package/dist/templates/StandardArticle/docs/component.md +76 -76
  203. package/dist/templates/intro.mdx +18 -18
  204. package/dist/wrappers/Container/Container.stories.svelte +38 -38
  205. package/dist/wrappers/Container/Container.svelte +77 -77
  206. package/dist/wrappers/Container/docs/component.md +12 -12
  207. package/dist/wrappers/Embed/Embed.stories.svelte +24 -24
  208. package/dist/wrappers/Embed/Embed.svelte +44 -44
  209. package/dist/wrappers/Embed/docs/component.md +15 -15
  210. package/dist/wrappers/LazyLoad/LazyLoad.stories.svelte +37 -37
  211. package/dist/wrappers/LazyLoad/LazyLoad.svelte +50 -50
  212. package/dist/wrappers/LazyLoad/docs/component.md +29 -29
  213. package/dist/wrappers/Main/Main.stories.svelte +24 -24
  214. package/dist/wrappers/Main/Main.svelte +11 -11
  215. package/dist/wrappers/Main/docs/component.md +16 -16
  216. package/dist/wrappers/Observe/Observe.stories.svelte +29 -29
  217. package/dist/wrappers/Observe/Observe.svelte +35 -35
  218. package/dist/wrappers/Observe/docs/component.md +22 -22
  219. package/dist/wrappers/Theme/Theme.stories.svelte +70 -70
  220. package/dist/wrappers/Theme/Theme.svelte +76 -76
  221. package/dist/wrappers/Theme/docs/component.md +10 -10
  222. package/dist/wrappers/Theme/themes.js +70 -70
  223. package/package.json +88 -88
@@ -1,44 +1,44 @@
1
- This component will display a cookie banner and export a function that allows you to push events to the Google Analytics dataLayer array.
2
-
3
- <!-- prettier-ignore -->
4
- ```html
5
- <script>
6
- import { AnalyticsBanner, AnalyticsEvent } from "@onsvisual/svelte-components";
7
-
8
- // Example of an analytics event triggered by another event "e"
9
- function doAnalyticsEvent(e) {
10
- // Assumes that e.detail is in the form {key1: "value1", key2: "value2", etc}
11
- AnalyticsEvent({event: "eventName", ...e.detail});
12
- }
13
- </script>
14
-
15
- <AnalyticsBanner analyticsId="{id_string}" />
16
- <!-- Rest of page content -->
17
- ```
18
-
19
- `AnalyticsBanner` can also take props.
20
-
21
- ```
22
- const analyticsProps = {
23
- contentTitle: "Weekly deaths dashboard",
24
- releaseDate: data.dates.current.replaceAll("-", ""),
25
- nextReleaseDate: data.dates.next.replaceAll("-", ""),
26
- outputSeries: "weeklyprovisionalfiguresondeathsregisteredinenglandandwales",
27
- contentType: "dashboard",
28
- };
29
-
30
- <AnalyticsBanner {analyticsProps}/>
31
- ```
32
-
33
- An example analytics events. See this [doc](https://officenationalstatistics.sharepoint.com/:w:/r/sites/digpub/_layouts/15/Doc.aspx?sourcedoc=%7BBA405554-4040-4B61-9559-851F5C55DA39%7D&file=Google%20Analytics%20-%20GTM%20requirements.docx&action=default&mobileredirect=true) for more details (need to be on network).
34
-
35
- ```javascript
36
- analyticsEvent({
37
- event: "interaction",
38
- interactionType: "accordion",
39
- interactionValue: e?.detail?.open ? "open" : "close",
40
- label,
41
- sectionTitle,
42
- sectionNumber
43
- });
44
- ```
1
+ This component will display a cookie banner and export a function that allows you to push events to the Google Analytics dataLayer array.
2
+
3
+ <!-- prettier-ignore -->
4
+ ```html
5
+ <script>
6
+ import { AnalyticsBanner, AnalyticsEvent } from "@onsvisual/svelte-components";
7
+
8
+ // Example of an analytics event triggered by another event "e"
9
+ function doAnalyticsEvent(e) {
10
+ // Assumes that e.detail is in the form {key1: "value1", key2: "value2", etc}
11
+ AnalyticsEvent({event: "eventName", ...e.detail});
12
+ }
13
+ </script>
14
+
15
+ <AnalyticsBanner analyticsId="{id_string}" />
16
+ <!-- Rest of page content -->
17
+ ```
18
+
19
+ `AnalyticsBanner` can also take props.
20
+
21
+ ```
22
+ const analyticsProps = {
23
+ contentTitle: "Weekly deaths dashboard",
24
+ releaseDate: data.dates.current.replaceAll("-", ""),
25
+ nextReleaseDate: data.dates.next.replaceAll("-", ""),
26
+ outputSeries: "weeklyprovisionalfiguresondeathsregisteredinenglandandwales",
27
+ contentType: "dashboard",
28
+ };
29
+
30
+ <AnalyticsBanner {analyticsProps}/>
31
+ ```
32
+
33
+ An example analytics events. See this [doc](https://officenationalstatistics.sharepoint.com/:w:/r/sites/digpub/_layouts/15/Doc.aspx?sourcedoc=%7BBA405554-4040-4B61-9559-851F5C55DA39%7D&file=Google%20Analytics%20-%20GTM%20requirements.docx&action=default&mobileredirect=true) for more details (need to be on network).
34
+
35
+ ```javascript
36
+ analyticsEvent({
37
+ event: "interaction",
38
+ interactionType: "accordion",
39
+ interactionValue: e?.detail?.open ? "open" : "close",
40
+ label,
41
+ sectionTitle,
42
+ sectionNumber
43
+ });
44
+ ```
@@ -1,16 +1,16 @@
1
- <script module>
2
- import { defineMeta } from "@storybook/addon-svelte-csf";
3
- import { withComponentDocs } from "../../js/withParams.js";
4
- import BackLink from "./BackLink.svelte";
5
- import componentDocs from "./docs/component.md?raw";
6
-
7
- const { Story } = defineMeta({
8
- title: "Layout/BackLink",
9
- component: BackLink,
10
- tags: ["autodocs"],
11
- argTypes: {},
12
- parameters: withComponentDocs(componentDocs)
13
- });
14
- </script>
15
-
16
- <Story name="Default" args={{}} />
1
+ <script module>
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+ import { withComponentDocs } from "../../js/withParams.js";
4
+ import BackLink from "./BackLink.svelte";
5
+ import componentDocs from "./docs/component.md?raw";
6
+
7
+ const { Story } = defineMeta({
8
+ title: "Layout/BackLink",
9
+ component: BackLink,
10
+ tags: ["autodocs"],
11
+ argTypes: {},
12
+ parameters: withComponentDocs(componentDocs)
13
+ });
14
+ </script>
15
+
16
+ <Story name="Default" args={{}} />
@@ -1,30 +1,30 @@
1
- <script>
2
- /**
3
- * Href for top of page or contents section
4
- * @type {string}
5
- */
6
- export let href = "#top";
7
- /**
8
- * Optional: Add a CSS class to the link
9
- * @type {string|null}
10
- */
11
- export let cls = null;
12
- </script>
13
-
14
- <div class="ons-back-to-top ons-js-back-to-top ons-back-to-top__enabled ons-u-mb-l {cls || ''}">
15
- <a {href} class="ons-back-to-top__link">
16
- <span
17
- ><svg
18
- class="ons-icon ons-icon--xs"
19
- viewBox="0 0 13 20"
20
- xmlns="http://www.w3.org/2000/svg"
21
- focusable="false"
22
- fill="currentColor"
23
- role="img"
24
- title="ons-icon-arrow-up"
25
- >
26
- <path fill="currentColor" d="M6.5 0L0 6.5 1.4 8l4-4v12.7h2V4l4.3 4L13 6.4z"></path>
27
- </svg><span class="ons-back-to-top__description">Back to top</span>
28
- </span>
29
- </a>
30
- </div>
1
+ <script>
2
+ /**
3
+ * Href for top of page or contents section
4
+ * @type {string}
5
+ */
6
+ export let href = "#top";
7
+ /**
8
+ * Optional: Add a CSS class to the link
9
+ * @type {string|null}
10
+ */
11
+ export let cls = null;
12
+ </script>
13
+
14
+ <div class="ons-back-to-top ons-js-back-to-top ons-back-to-top__enabled ons-u-mb-l {cls || ''}">
15
+ <a {href} class="ons-back-to-top__link">
16
+ <span
17
+ ><svg
18
+ class="ons-icon ons-icon--xs"
19
+ viewBox="0 0 13 20"
20
+ xmlns="http://www.w3.org/2000/svg"
21
+ focusable="false"
22
+ fill="currentColor"
23
+ role="img"
24
+ title="ons-icon-arrow-up"
25
+ >
26
+ <path fill="currentColor" d="M6.5 0L0 6.5 1.4 8l4-4v12.7h2V4l4.3 4L13 6.4z"></path>
27
+ </svg><span class="ons-back-to-top__description">Back to top</span>
28
+ </span>
29
+ </a>
30
+ </div>
@@ -1,12 +1,12 @@
1
- Link that can be used to return to the top of a page, or to a table of contents.
2
-
3
- Based on [this ONS Design System component](https://service-manual.ons.gov.uk/design-system/components/back-to-top).
4
-
5
- <!-- prettier-ignore -->
6
- ```html
7
- <script>
8
- import { BackLink } from "@onsvisual/svelte-components";
9
- </script>
10
-
11
- <BackLink href="#top" />
12
- ```
1
+ Link that can be used to return to the top of a page, or to a table of contents.
2
+
3
+ Based on [this ONS Design System component](https://service-manual.ons.gov.uk/design-system/components/back-to-top).
4
+
5
+ <!-- prettier-ignore -->
6
+ ```html
7
+ <script>
8
+ import { BackLink } from "@onsvisual/svelte-components";
9
+ </script>
10
+
11
+ <BackLink href="#top" />
12
+ ```
@@ -1,31 +1,31 @@
1
- <script module>
2
- import { defineMeta } from "@storybook/addon-svelte-csf";
3
- import { withComponentDocs } from "../../js/withParams.js";
4
- import Breadcrumb from "./Breadcrumb.svelte";
5
- import componentDocs from "./docs/component.md?raw";
6
-
7
- const { Story } = defineMeta({
8
- title: "Layout/Breadcrumb",
9
- component: Breadcrumb,
10
- tags: ["autodocs"],
11
- argTypes: {},
12
- parameters: withComponentDocs(componentDocs)
13
- });
14
- </script>
15
-
16
- <Story
17
- name="Default"
18
- args={{
19
- links: [
20
- { label: "Home", href: "/" },
21
- { label: "Parent page", href: "/parent" }
22
- ]
23
- }}
24
- />
25
-
26
- <Story
27
- name="Single back link"
28
- args={{
29
- href: "/"
30
- }}
31
- />
1
+ <script module>
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+ import { withComponentDocs } from "../../js/withParams.js";
4
+ import Breadcrumb from "./Breadcrumb.svelte";
5
+ import componentDocs from "./docs/component.md?raw";
6
+
7
+ const { Story } = defineMeta({
8
+ title: "Layout/Breadcrumb",
9
+ component: Breadcrumb,
10
+ tags: ["autodocs"],
11
+ argTypes: {},
12
+ parameters: withComponentDocs(componentDocs)
13
+ });
14
+ </script>
15
+
16
+ <Story
17
+ name="Default"
18
+ args={{
19
+ links: [
20
+ { label: "Home", href: "/" },
21
+ { label: "Parent page", href: "/parent" }
22
+ ]
23
+ }}
24
+ />
25
+
26
+ <Story
27
+ name="Single back link"
28
+ args={{
29
+ href: "/"
30
+ }}
31
+ />
@@ -1,69 +1,69 @@
1
- <script>
2
- import Container from "../../wrappers/Container/Container.svelte";
3
-
4
- /**
5
- * An array of links in the format {label, href}
6
- * @type {object[]}
7
- */
8
- export let links = [];
9
- /**
10
- * Optional: Link href if component is used for a single back-link
11
- * @type {string|null}
12
- */
13
- export let backHref = null;
14
- /**
15
- * Sets the width of the container
16
- * @type {"narrow"|"medium"|"wide"|"wider"|"full"}
17
- */
18
- export let width = "wide";
19
- /**
20
- * Optional: Set an additional CSS class for the component
21
- * @type {string|null}
22
- */
23
- export let cls = null;
24
- /**
25
- * Optional: Sets a base theme ("light", "dark", null etc)
26
- * @type {"light"|"dark"|"paleblue"|"blue"|"navyblue"|"grey"|null}
27
- */
28
- export let theme = null;
29
- /**
30
- * Optional: Define additional props to override the base theme
31
- * @type {object}
32
- */
33
- export let themeOverrides = {};
34
- /**
35
- * Optional: Overrides the base theme background (accepts any valid CSS background value)
36
- * @type {string|null}
37
- */
38
- export let background = null;
39
- </script>
40
-
41
- <Container {width} {theme} {themeOverrides} {background} {cls}>
42
- <nav class="ons-breadcrumbs" aria-label="Breadcrumbs">
43
- <ol class="ons-breadcrumbs__items ons-u-fs-s">
44
- {#each backHref ? [{ label: "Back", href: backHref }] : links as link}
45
- <li class="ons-breadcrumbs__item">
46
- {#if link.href}
47
- <a class="ons-breadcrumbs__link" href={link.href}>{link.label}</a>
48
- {:else}
49
- {link.label}
50
- {/if}
51
- <svg
52
- class="ons-icon"
53
- viewBox="0 0 8 13"
54
- xmlns="http://www.w3.org/2000/svg"
55
- focusable="false"
56
- fill="currentColor"
57
- role="img"
58
- title="ons-icon-chevron"
59
- >
60
- <path
61
- d="M5.74,14.28l-.57-.56a.5.5,0,0,1,0-.71h0l5-5-5-5a.5.5,0,0,1,0-.71h0l.57-.56a.5.5,0,0,1,.71,0h0l5.93,5.93a.5.5,0,0,1,0,.7L6.45,14.28a.5.5,0,0,1-.71,0Z"
62
- transform="translate(-5.02 -1.59)"
63
- />
64
- </svg>
65
- </li>
66
- {/each}
67
- </ol>
68
- </nav>
69
- </Container>
1
+ <script>
2
+ import Container from "../../wrappers/Container/Container.svelte";
3
+
4
+ /**
5
+ * An array of links in the format {label, href}
6
+ * @type {object[]}
7
+ */
8
+ export let links = [];
9
+ /**
10
+ * Optional: Link href if component is used for a single back-link
11
+ * @type {string|null}
12
+ */
13
+ export let backHref = null;
14
+ /**
15
+ * Sets the width of the container
16
+ * @type {"narrow"|"medium"|"wide"|"wider"|"full"}
17
+ */
18
+ export let width = "wide";
19
+ /**
20
+ * Optional: Set an additional CSS class for the component
21
+ * @type {string|null}
22
+ */
23
+ export let cls = null;
24
+ /**
25
+ * Optional: Sets a base theme ("light", "dark", null etc)
26
+ * @type {"light"|"dark"|"paleblue"|"blue"|"navyblue"|"grey"|null}
27
+ */
28
+ export let theme = null;
29
+ /**
30
+ * Optional: Define additional props to override the base theme
31
+ * @type {object}
32
+ */
33
+ export let themeOverrides = {};
34
+ /**
35
+ * Optional: Overrides the base theme background (accepts any valid CSS background value)
36
+ * @type {string|null}
37
+ */
38
+ export let background = null;
39
+ </script>
40
+
41
+ <Container {width} {theme} {themeOverrides} {background} {cls}>
42
+ <nav class="ons-breadcrumbs" aria-label="Breadcrumbs">
43
+ <ol class="ons-breadcrumbs__items ons-u-fs-s">
44
+ {#each backHref ? [{ label: "Back", href: backHref }] : links as link}
45
+ <li class="ons-breadcrumbs__item">
46
+ {#if link.href}
47
+ <a class="ons-breadcrumbs__link" href={link.href}>{link.label}</a>
48
+ {:else}
49
+ {link.label}
50
+ {/if}
51
+ <svg
52
+ class="ons-icon"
53
+ viewBox="0 0 8 13"
54
+ xmlns="http://www.w3.org/2000/svg"
55
+ focusable="false"
56
+ fill="currentColor"
57
+ role="img"
58
+ title="ons-icon-chevron"
59
+ >
60
+ <path
61
+ d="M5.74,14.28l-.57-.56a.5.5,0,0,1,0-.71h0l5-5-5-5a.5.5,0,0,1,0-.71h0l.57-.56a.5.5,0,0,1,.71,0h0l5.93,5.93a.5.5,0,0,1,0,.7L6.45,14.28a.5.5,0,0,1-.71,0Z"
62
+ transform="translate(-5.02 -1.59)"
63
+ />
64
+ </svg>
65
+ </li>
66
+ {/each}
67
+ </ol>
68
+ </nav>
69
+ </Container>
@@ -1,15 +1,15 @@
1
- Displays a breadcrumb with the current page's parents.
2
-
3
- Based on [this ONS Design System component](https://service-manual.ons.gov.uk/design-system/components/breadcrumbs).
4
-
5
- <!-- prettier-ignore -->
6
- ```html
7
- <script>
8
- import { Breadcrumb } from "@onsvisual/svelte-components";
9
- </script>
10
-
11
- <Breadcrumb links="{[
12
- {label: 'Home', href: '/'},
13
- {label: 'Parent page', href: '/parent'}
14
- ]}" />
15
- ```
1
+ Displays a breadcrumb with the current page's parents.
2
+
3
+ Based on [this ONS Design System component](https://service-manual.ons.gov.uk/design-system/components/breadcrumbs).
4
+
5
+ <!-- prettier-ignore -->
6
+ ```html
7
+ <script>
8
+ import { Breadcrumb } from "@onsvisual/svelte-components";
9
+ </script>
10
+
11
+ <Breadcrumb links="{[
12
+ {label: 'Home', href: '/'},
13
+ {label: 'Parent page', href: '/parent'}
14
+ ]}" />
15
+ ```
@@ -1,39 +1,39 @@
1
- <script module>
2
- import { defineMeta } from "@storybook/addon-svelte-csf";
3
- import { withComponentDocs } from "../../js/withParams.js";
4
- import { lipsum } from "../../js/utils.js";
5
- import Card from "./Card.svelte";
6
- import Grid from "../Grid/Grid.svelte";
7
- import componentDocs from "./docs/component.md?raw";
8
-
9
- const { Story } = defineMeta({
10
- title: "Layout/Card",
11
- component: Card,
12
- tags: ["autodocs"],
13
- argTypes: {},
14
- parameters: withComponentDocs(componentDocs)
15
- });
16
- </script>
17
-
18
- {#snippet template(args)}
19
- <Grid>
20
- <Card title="Card one" {...args}>{lipsum(1)}</Card>
21
- <Card title="Card two" {...args}>{lipsum(1, 1)}</Card>
22
- <Card title="Card three" {...args}>{lipsum(1, 2)}</Card>
23
- </Grid>
24
- {/snippet}
25
-
26
- <Story name="Default" args={{}} {template} />
27
-
28
- <Story name="Cards with links" args={{ href: "#0" }} {template} />
29
-
30
- <Story name="Featured cards with baseline" args={{ mode: "featured", baseline: true }} {template} />
31
-
32
- <Story
33
- name="Featured cards with image"
34
- args={{
35
- mode: "featured",
36
- image: "https://service-manual.ons.gov.uk/img/small/placeholder-card.png"
37
- }}
38
- {template}
39
- />
1
+ <script module>
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+ import { withComponentDocs } from "../../js/withParams.js";
4
+ import { lipsum } from "../../js/utils.js";
5
+ import Card from "./Card.svelte";
6
+ import Grid from "../Grid/Grid.svelte";
7
+ import componentDocs from "./docs/component.md?raw";
8
+
9
+ const { Story } = defineMeta({
10
+ title: "Layout/Card",
11
+ component: Card,
12
+ tags: ["autodocs"],
13
+ argTypes: {},
14
+ parameters: withComponentDocs(componentDocs)
15
+ });
16
+ </script>
17
+
18
+ {#snippet template(args)}
19
+ <Grid>
20
+ <Card title="Card one" {...args}>{lipsum(1)}</Card>
21
+ <Card title="Card two" {...args}>{lipsum(1, 1)}</Card>
22
+ <Card title="Card three" {...args}>{lipsum(1, 2)}</Card>
23
+ </Grid>
24
+ {/snippet}
25
+
26
+ <Story name="Default" args={{}} {template} />
27
+
28
+ <Story name="Cards with links" args={{ href: "#0" }} {template} />
29
+
30
+ <Story name="Featured cards with baseline" args={{ mode: "featured", baseline: true }} {template} />
31
+
32
+ <Story
33
+ name="Featured cards with image"
34
+ args={{
35
+ mode: "featured",
36
+ image: "https://service-manual.ons.gov.uk/img/small/placeholder-card.png"
37
+ }}
38
+ {template}
39
+ />