This is a live set of examples of how to use JSS. For more information on using JSS, please see the documentation.
The content and layout of this page is defined in /data/routes/styleguide/en.yml
Implementation: /src/components/**/Styleguide-FieldUsage-Text.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Text.sitecore.js
textarea for editing; consumption in JSS is the same as single-line text.Implementation: /src/components/**/Styleguide-FieldUsage-Text.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Text.sitecore.js
Implementation: /src/components/**/Styleguide-FieldUsage-RichText.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-RichText.sitecore.js
This is a sample rich text field. HTML is always supported. In Sitecore, editors will see a WYSIWYG editor for these fields.
Another sample rich text field, using options. Keep markup entered in rich text fields as simple as possible - ideally bare tags only (no classes). Adding a wrapping class can help with styling within rich text blocks.
Implementation: /src/components/**/Styleguide-FieldUsage-Image.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Image.sitecore.js
Plain image

Advanced image (not editable)

Srcset responsive image

Implementation: /src/components/**/Styleguide-FieldUsage-File.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-File.sitecore.js
Implementation: /src/components/**/Styleguide-FieldUsage-Number.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Number.sitecore.js
JS value type: number
JS value: 1.21
Implementation: /src/components/**/Styleguide-FieldUsage-Checkbox.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Checkbox.sitecore.js
checkbox is truecheckbox2 is falseBoth Date and DateTime field types are available. Choosing DateTime will make Sitecore show editing UI for time; both types store complete date and time values internally. Date values in JSS are formatted using ISO 8601 formatted strings, for example 2012-04-23T18:25:43.511Z.
new Date().toISOString()), and is different from how Sitecore stores date field values internally. Sitecore-formatted dates will not work.Implementation: /src/components/**/Styleguide-FieldUsage-Date.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Date.sitecore.js
A General Link is a field that represents an <a> tag.
Implementation: /src/components/**/Styleguide-FieldUsage-Link.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Link.sitecore.js
  
    Item Links are a way to reference another content item to use data from it.
    Referenced items may be shared.
    To reference multiple content items, use a Content List field.
    Note: Sitecore does not support inline editing of Item Link fields. The value must be edited in Experience Editor by using the edit rendering fields button (looks like a pencil) with the whole component selected.
  
Implementation: /src/components/**/Styleguide-FieldUsage-ItemLink.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-ItemLink.sitecore.js
Field: ItemLink Demo (Shared) Item 1 Text Field
Field: Referenced item textField
  
    Content Lists are a way to reference zero or more other content items.
    Referenced items may be shared.
    To reference a single content item, use an Item Link field.
    Note: Sitecore does not support inline editing of Content List fields. The value must be edited in Experience Editor by using the edit rendering fields button (looks like a pencil) with the whole component selected.
  
Implementation: /src/components/**/Styleguide-FieldUsage-ContentList.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-ContentList.sitecore.js
Field: ContentList Demo (Shared) Item 1 Text Field
Field: ContentList Demo (Shared) Item 2 Text Field
Field: Hello World Item 1
Field: Hello World Item 2
  
    Any Sitecore field type can be consumed by JSS.
    In this sample we consume the Integer field type.
    Note: For field types with complex data, custom FieldSerializers may need to be implemented on the Sitecore side.
  
Implementation: /src/components/**/Styleguide-FieldUsage-Custom.tsx
Definition: /sitecore/definitions/components/**/Styleguide-FieldUsage-Custom.sitecore.js
JSS provides powerful options to reuse content, whether it's sharing a common piece of text across pages or sketching out a site with repeating lorem ipsum content.
Implementation: /src/components/**/Styleguide-Layout-Reuse.tsx
Definition: /sitecore/definitions/components/**/Styleguide-Layout-Reuse.sitecore.js
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque felis mauris, pretium id neque vitae, vulputate pellentesque tortor. Mauris hendrerit dolor et ipsum lobortis bibendum non finibus neque. Morbi volutpat aliquam magna id posuere. Duis commodo cursus dui, nec interdum velit congue nec. Aliquam erat volutpat. Aliquam facilisis, sapien quis fringilla tincidunt, magna nulla feugiat neque, a consectetur arcu orci eu augue.
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque felis mauris, pretium id neque vitae, vulputate pellentesque tortor. Mauris hendrerit dolor et ipsum lobortis bibendum non finibus neque. Morbi volutpat aliquam magna id posuere. Duis commodo cursus dui, nec interdum velit congue nec. Aliquam erat volutpat. Aliquam facilisis, sapien quis fringilla tincidunt, magna nulla feugiat neque, a consectetur arcu orci eu augue.
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque felis mauris, pretium id neque vitae, vulputate pellentesque tortor. Mauris hendrerit dolor et ipsum lobortis bibendum non finibus neque. Morbi volutpat aliquam magna id posuere. Duis commodo cursus dui, nec interdum velit congue nec. Aliquam erat volutpat. Aliquam facilisis, sapien quis fringilla tincidunt, magna nulla feugiat neque, a consectetur arcu orci eu augue.
Mix and match reused and local content. Check out /data/routes/styleguide/en.yml to see how.
Creating hierarchical components like tabs is made simpler in JSS because it's easy to introspect the layout structure.
Implementation: /src/components/**/Styleguide-Layout-Tabs.tsx
Definition: /sitecore/definitions/components/**/Styleguide-Layout-Tabs.sitecore.js
Tab 1 contents!
The Sitecore Context contains route-level data about the current context - for example, pageState enables conditionally executing code based on whether Sitecore is in Experience Editor or not.
Implementation: /src/components/**/Styleguide-SitecoreContext.tsx
Definition: /sitecore/definitions/components/**/Styleguide-SitecoreContext.sitecore.js
The current Sitecore Context is...
{
  "route": {
    "name": "styleguide",
    "displayName": "styleguide",
    "fields": {
      "pageTitle": {
        "value": "Styleguide | Sitecore JSS"
      }
    },
    "databaseName": "master",
    "deviceId": "fe5d7fdf-89c0-4d99-9aa3-b5fbd009c9f3",
    "itemId": "004775c9-e903-5743-9b03-adb08132b527",
    "itemLanguage": "en",
    "itemVersion": 1,
    "layoutId": "37b153e5-bf43-5107-8d25-33490357ba9a",
    "templateId": "899228a0-a4ce-570a-ae24-97566af3dab6",
    "templateName": "App Route",
    "placeholders": {
      "jss-main": [
        {
          "uid": "e02ddb9b-a062-5e50-924a-1940d7e053ce",
          "componentName": "ContentBlock",
          "dataSource": "{FC691C32-1859-5AF2-B7F7-9A4A2A62E5F3}",
          "params": {},
          "fields": {
            "heading": {
              "value": "JSS Styleguide"
            },
            "content": {
              "value": "<p>This is a live set of examples of how to use JSS. For more information on using JSS, please see <a href=\"https://jss.sitecore.com\" target=\"_blank\" rel=\"noopener noreferrer\">the documentation</a>.</p>\r\n<p>The content and layout of this page is defined in <code>/data/routes/styleguide/en.yml</code></p>\r\n"
            }
          }
        },
        {
          "uid": "34a6553c-81de-5cd3-989e-853f6cb6df8c",
          "componentName": "Styleguide-Layout",
          "dataSource": "",
          "params": {},
          "placeholders": {
            "jss-styleguide-layout": [
              {
                "uid": "b7c779da-2b75-586c-b40d-081fcb864256",
                "componentName": "Styleguide-Section",
                "dataSource": "{DA49FBE6-3CEC-5AA5-AD94-E40621F72BAD}",
                "params": {},
                "fields": {
                  "heading": {
                    "value": "Content Data"
                  }
                },
                "placeholders": {
                  "jss-styleguide-section": [
                    {
                      "uid": "63b0c99e-dac7-5670-9d66-c26a78000eae",
                      "componentName": "Styleguide-FieldUsage-Text",
                      "dataSource": "{C86337CD-67A3-5A11-9A87-E964C77FD002}",
                      "params": {},
                      "fields": {
                        "sample": {
                          "value": "This is a sample text field. <mark>HTML is encoded.</mark> In Sitecore, editors will see a <input type=\"text\">."
                        },
                        "sample2": {
                          "value": "This is another sample text field using rendering options. <mark>HTML supported with encode=false.</mark> Cannot edit because editable=false."
                        },
                        "description": {
                          "value": ""
                        },
                        "heading": {
                          "value": "Single-Line Text"
                        }
                      }
                    },
                    {
                      "uid": "f1ea3bb5-1175-5055-ab11-9c48bf69427a",
                      "componentName": "Styleguide-FieldUsage-Text",
                      "dataSource": "{496CA42D-3016-5E93-89A5-415E19552104}",
                      "params": {},
                      "fields": {
                        "sample": {
                          "value": "This is a sample multi-line text field. <mark>HTML is encoded.</mark> In Sitecore, editors will see a textarea."
                        },
                        "sample2": {
                          "value": "This is another sample multi-line text field using rendering options. <mark>HTML supported with encode=false.</mark>"
                        },
                        "description": {
                          "value": "<small>Multi-line text tells Sitecore to use a <code>textarea</code> for editing; consumption in JSS is the same as single-line text.</small>"
                        },
                        "heading": {
                          "value": "Multi-Line Text"
                        }
                      }
                    },
                    {
                      "uid": "69cebc00-446b-5141-ad1e-450b8d6ee0ad",
                      "componentName": "Styleguide-FieldUsage-RichText",
                      "dataSource": "{46C7CE5E-EC21-576E-BC4C-E31F7E5003F2}",
                      "params": {},
                      "fields": {
                        "sample": {
                          "value": "<p>This is a sample rich text field. <mark>HTML is always supported.</mark> In Sitecore, editors will see a WYSIWYG editor for these fields.</p>"
                        },
                        "sample2": {
                          "value": "<p>Another sample rich text field, using options. Keep markup entered in rich text fields as simple as possible - ideally bare tags only (no classes). Adding a wrapping class can help with styling within rich text blocks.</p>\r\n<marquee>But you can use any valid HTML in a rich text field!</marquee>\r\n"
                        },
                        "description": {
                          "value": ""
                        },
                        "heading": {
                          "value": "Rich Text"
                        }
                      }
                    },
                    {
                      "uid": "5630c0e6-0430-5f6a-af9e-2d09d600a386",
                      "componentName": "Styleguide-FieldUsage-Image",
                      "dataSource": "{46A8EBEF-8276-5A41-855A-BB8B79CC3615}",
                      "params": {},
                      "fields": {
                        "sample1": {
                          "value": {
                            "src": "/-/media/xmcloudpreview/data/media/img/sc_logo.png?iar=0&ttc=63896970003&tt=AB2F1439256EC6E636955623448CD59A&hash=870A0F27DF274C6828E8C9CE839BBF23",
                            "alt": "Sitecore Logo"
                          }
                        },
                        "sample2": {
                          "value": {
                            "src": "/-/media/xmcloudpreview/data/media/img/jss_logo.png?iar=0&ttc=63896970003&tt=0EB08838494823A7D28E6A5750936F9F&hash=DC7552412C2542ED25E5A5AF1B0E5C74",
                            "alt": "Sitecore JSS Logo"
                          }
                        },
                        "description": {
                          "value": ""
                        },
                        "heading": {
                          "value": "Image"
                        }
                      }
                    },
                    {
                      "uid": "bad43ef7-8940-504d-a09b-976c17a9a30c",
                      "componentName": "Styleguide-FieldUsage-File",
                      "dataSource": "{EC6B0090-768E-5B80-A67C-E3192B06BBAB}",
                      "params": {},
                      "fields": {
                        "file": {
                          "value": {
                            "src": "/-/media/xmcloudpreview/data/media/files/jss.pdf?ttc=63896970003&tt=BD5B6717515AA6C501E0D2212ACE64E6",
                            "name": "jss",
                            "displayName": "jss",
                            "title": "Example File",
                            "keywords": "",
                            "description": "This data will be added to the Sitecore Media Library on import",
                            "extension": "pdf",
                            "mimeType": "application/pdf",
                            "size": "156897"
                          }
                        },
                        "description": {
                          "value": "<small>Note: Sitecore does not support inline editing of File fields. The value must be edited in Experience Editor by using the edit rendering fields button (looks like a pencil) with the whole component selected.</small>\r\n"
                        },
                        "heading": {
                          "value": "File"
                        }
                      }
                    },
                    {
                      "uid": "ff90d4bd-e50d-5bbf-9213-d25968c9ae75",
                      "componentName": "Styleguide-FieldUsage-Number",
                      "dataSource": "{A0F0CF98-DD1B-5260-9D5D-CA3D7AEB0A89}",
                      "params": {},
                      "fields": {
                        "sample": {
                          "value": 1.21
                        },
                        "description": {
                          "value": "<small>Number tells Sitecore to use a number entry for editing.</small>"
                        },
                        "heading": {
                          "value": "Number"
                        }
                      }
                    },
                    {
                      "uid": "b5c1c74a-a81d-59b2-85d8-09bc109b1f70",
                      "componentName": "Styleguide-FieldUsage-Checkbox",
                      "dataSource": "{1997D5AA-D375-5255-A509-A84149BC9061}",
                      "params": {},
                      "fields": {
                        "checkbox": {
                          "value": true
                        },
                        "checkbox2": {
                          "value": false
                        },
                        "description": {
                          "value": "<small>Note: Sitecore does not support inline editing of Checkbox fields. The value must be edited in Experience Editor by using the edit rendering fields button (looks like a pencil) with the whole component selected.</small>\r\n"
                        },
                        "heading": {
                          "value": "Checkbox"
                        }
                      }
                    },
                    {
                      "uid": "f166a7d6-9ec8-5c53-b825-33405db7f575",
                      "componentName": "Styleguide-FieldUsage-Date",
                      "dataSource": "{B66A78DE-A697-544B-B1D6-1CE992869421}",
                      "params": {},
                      "fields": {
                        "date": {
                          "value": "2012-05-04T00:00:00Z"
                        },
                        "dateTime": {
                          "value": "2018-03-14T15:00:00Z"
                        },
                        "description": {
                          "value": "<p><small>Both <code>Date</code> and <code>DateTime</code> field types are available. Choosing <code>DateTime</code> will make Sitecore show editing UI for time; both types store complete date and time values internally. Date values in JSS are formatted using <a href=\"https://en.wikipedia.org/wiki/ISO_8601#Combined_date_and_time_representations\" target=\"_blank\">ISO 8601 formatted strings</a>, for example <code>2012-04-23T18:25:43.511Z</code>.</small></p>\r\n<div class=\"alert alert-warning\"><small>Note: this is a JavaScript date format (e.g. <code>new Date().toISOString()</code>), and is different from how Sitecore stores date field values internally. Sitecore-formatted dates will not work.</small></div>\r\n"
                        },
                        "heading": {
                          "value": "Date"
                        }
                      }
                    },
                    {
                      "uid": "56a9562a-6813-579b-8ed2-fddab1bfd3d2",
                      "componentName": "Styleguide-FieldUsage-Link",
                      "dataSource": "{C4ECF853-D3EA-5D84-A76E-3685CB94F1B6}",
                      "params": {},
                      "fields": {
                        "emailLink": {
                          "value": {
                            "href": "mailto:[email protected]",
                            "linktype": "mailto",
                            "text": "Send an Email",
                            "url": "mailto:[email protected]"
                          }
                        },
                        "externalLink": {
                          "value": {
                            "href": "https://www.sitecore.com",
                            "linktype": "external",
                            "text": "Link to Sitecore",
                            "url": "https://www.sitecore.com"
                          }
                        },
                        "internalLink": {
                          "value": {
                            "href": "/en/",
                            "id": "{33CBF0FB-F5CE-5C8D-91F6-0B0F07A64B7D}",
                            "linktype": "internal"
                          }
                        },
                        "paramsLink": {
                          "value": {
                            "href": "https://dev.sitecore.net",
                            "class": "font-weight-bold",
                            "target": "_blank",
                            "title": "<a> title attribute",
                            "linktype": "external",
                            "text": "Sitecore Dev Site",
                            "url": "https://dev.sitecore.net"
                          }
                        },
                        "description": {
                          "value": "<p>A <em>General Link</em> is a field that represents an <code><a></code> tag.</p>"
                        },
                        "heading": {
                          "value": "General Link"
                        }
                      }
                    },
                    {
                      "uid": "a44ad1f8-0582-5248-9df9-52429193a68b",
                      "componentName": "Styleguide-FieldUsage-ItemLink",
                      "dataSource": "{F25B956E-8A73-5478-83FC-B73F52E79A3F}",
                      "params": {},
                      "fields": {
                        "localItemLink": {
                          "id": "cf523723-461a-5201-a151-157c7bcb0143",
                          "url": "/en/styleguide/Page-Components/styleguide-jss-styleguide-section-B73482E131E5A083D77A50554BC74A4758E29636DF6824F6E2F272EE778C28A095/styleguide-jss-styleguide-section-B75151F05CFDC4CAFFE44E5BAED9D59BEA82565EC11CE75B7DEF3634495EC1DAB7",
                          "name": "styleguide-jss-styleguide-section-B75151F05CFDC4CAFFE44E5BAED9D59BEA82565EC11CE75B7DEF3634495EC1DAB7",
                          "displayName": "Styleguide-FieldUsage-ItemLink-10-item-0",
                          "fields": {
                            "textField": {
                              "value": "Referenced item textField"
                            }
                          }
                        },
                        "sharedItemLink": {
                          "id": "1d46c32e-e1e6-5d6b-8bd0-61cc6d97011f",
                          "url": "/en/Content/Styleguide/ItemLinkField/Item1",
                          "name": "Item1",
                          "displayName": "Styleguide Item Link Item 1 (Shared)",
                          "fields": {
                            "textField": {
                              "value": "ItemLink Demo (Shared) Item 1 Text Field"
                            }
                          }
                        },
                        "description": {
                          "value": "<p>\r\n  <small>\r\n    Item Links are a way to reference another content item to use data from it.\r\n    Referenced items may be shared.\r\n    To reference multiple content items, use a <em>Content List</em> field.<br />\r\n    <strong>Note:</strong> Sitecore does not support inline editing of Item Link fields. The value must be edited in Experience Editor by using the edit rendering fields button (looks like a pencil) with the whole component selected.\r\n  </small>\r\n</p>\r\n"
                        },
                        "heading": {
                          "value": "Item Link"
                        }
                      }
                    },
                    {
                      "uid": "2f609d40-8ad9-540e-901e-23aa2600f3eb",
                      "componentName": "Styleguide-FieldUsage-ContentList",
                      "dataSource": "{ABC2BEE5-1DA2-5E29-9D98-B5105BBFF56D}",
                      "params": {},
                      "fields": {
                        "localContentList": [
                          {
                            "id": "bdfb5d57-1226-5935-8cf0-396cafb8a5da",
                            "url": "/en/styleguide/Page-Components/styleguide-jss-styleguide-section-B7985C8DEA10AB2C5CC77ABC90CF4126F21840592E09B2C6DB07D84D314CDCE0D4/styleguide-jss-styleguide-section-B7BF1F3509A82A38C71B36F25C4E58E2D04EC965C308A1147E993853137210F241",
                            "name": "styleguide-jss-styleguide-section-B7BF1F3509A82A38C71B36F25C4E58E2D04EC965C308A1147E993853137210F241",
                            "displayName": "Styleguide-FieldUsage-ContentList-11-item-0",
                            "fields": {
                              "textField": {
                                "value": "Hello World Item 1"
                              }
                            }
                          },
                          {
                            "id": "6bb59b60-ee2b-5146-8645-c3be42d2da3a",
                            "url": "/en/styleguide/Page-Components/styleguide-jss-styleguide-section-B7985C8DEA10AB2C5CC77ABC90CF4126F21840592E09B2C6DB07D84D314CDCE0D4/styleguide-jss-styleguide-section-B76CB8FB6A660296D91AE50FD7559AF62453A1891C9828A22C84E7E2A9914E7DD8",
                            "name": "styleguide-jss-styleguide-section-B76CB8FB6A660296D91AE50FD7559AF62453A1891C9828A22C84E7E2A9914E7DD8",
                            "displayName": "Styleguide-FieldUsage-ContentList-11-item-1",
                            "fields": {
                              "textField": {
                                "value": "Hello World Item 2"
                              }
                            }
                          }
                        ],
                        "sharedContentList": [
                          {
                            "id": "aaff7b48-ad02-598a-9e9d-169f2bdb0fab",
                            "url": "/en/Content/Styleguide/ContentListField/Item1",
                            "name": "Item1",
                            "displayName": "Styleguide Content List Item 1 (Shared)",
                            "fields": {
                              "textField": {
                                "value": "ContentList Demo (Shared) Item 1 Text Field"
                              }
                            }
                          },
                          {
                            "id": "a48fa0fb-85db-53e7-bedf-2a1dd729765d",
                            "url": "/en/Content/Styleguide/ContentListField/Item2",
                            "name": "Item2",
                            "displayName": "Styleguide Content List Item 2 (Shared)",
                            "fields": {
                              "textField": {
                                "value": "ContentList Demo (Shared) Item 2 Text Field"
                              }
                            }
                          }
                        ],
                        "description": {
                          "value": "<p>\r\n  <small>\r\n    Content Lists are a way to reference zero or more other content items.\r\n    Referenced items may be shared.\r\n    To reference a single content item, use an <em>Item Link</em> field.<br />\r\n    <strong>Note:</strong> Sitecore does not support inline editing of Content List fields. The value must be edited in Experience Editor by using the edit rendering fields button (looks like a pencil) with the whole component selected.\r\n  </small>\r\n</p>\r\n"
                        },
                        "heading": {
                          "value": "Content List"
                        }
                      }
                    },
                    {
                      "uid": "352ed63d-796a-5523-89f5-9a991dda4a8f",
                      "componentName": "Styleguide-FieldUsage-Custom",
                      "dataSource": "{F51589FC-33D0-5E56-B41C-0CB6A415E6C3}",
                      "params": {},
                      "fields": {
                        "customIntField": {
                          "value": 31337
                        },
                        "description": {
                          "value": "<p>\r\n  <small>\r\n    Any Sitecore field type can be consumed by JSS.\r\n    In this sample we consume the <em>Integer</em> field type.<br />\r\n    <strong>Note:</strong> For field types with complex data, custom <code>FieldSerializer</code>s may need to be implemented on the Sitecore side.\r\n  </small>\r\n</p>\r\n"
                        },
                        "heading": {
                          "value": "Custom Fields"
                        }
                      }
                    }
                  ]
                }
              },
              {
                "uid": "7de41a1a-24e4-5963-8206-3bb0b7d9dd69",
                "componentName": "Styleguide-Section",
                "dataSource": "{BB00AC3D-C65F-5BA1-8E6D-4B420BBA10C7}",
                "params": {},
                "fields": {
                  "heading": {
                    "value": "Layout Patterns"
                  }
                },
                "placeholders": {
                  "jss-styleguide-section": [
                    {
                      "uid": "3a5d9c50-d8c1-5a12-8da8-5d56c2a5a69a",
                      "componentName": "Styleguide-Layout-Reuse",
                      "dataSource": "{2971D454-7AA4-5F1A-A40F-792870BF71E9}",
                      "params": {},
                      "fields": {
                        "description": {
                          "value": "<p>JSS provides powerful options to reuse content, whether it's sharing a common piece of text across pages or sketching out a site with repeating <em>lorem ipsum</em> content.</p>"
                        },
                        "heading": {
                          "value": "Reusing Content"
                        }
                      },
                      "placeholders": {
                        "jss-reuse-example": [
                          {
                            "uid": "aa328b8a-d6e1-5b37-8143-250d2e93d6b8",
                            "componentName": "ContentBlock",
                            "dataSource": "{37BC45CE-D082-5A54-9A35-EA87FE70B049}",
                            "params": {},
                            "fields": {
                              "heading": {
                                "value": ""
                              },
                              "content": {
                                "value": "<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque felis mauris, pretium id neque vitae, vulputate pellentesque tortor. Mauris hendrerit dolor et ipsum lobortis bibendum non finibus neque. Morbi volutpat aliquam magna id posuere. Duis commodo cursus dui, nec interdum velit congue nec. Aliquam erat volutpat. Aliquam facilisis, sapien quis fringilla tincidunt, magna nulla feugiat neque, a consectetur arcu orci eu augue.</p>"
                              }
                            }
                          },
                          {
                            "uid": "c4330d34-623c-556c-bf4c-97c93d40fb1e",
                            "componentName": "ContentBlock",
                            "dataSource": "{37BC45CE-D082-5A54-9A35-EA87FE70B049}",
                            "params": {},
                            "fields": {
                              "heading": {
                                "value": ""
                              },
                              "content": {
                                "value": "<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque felis mauris, pretium id neque vitae, vulputate pellentesque tortor. Mauris hendrerit dolor et ipsum lobortis bibendum non finibus neque. Morbi volutpat aliquam magna id posuere. Duis commodo cursus dui, nec interdum velit congue nec. Aliquam erat volutpat. Aliquam facilisis, sapien quis fringilla tincidunt, magna nulla feugiat neque, a consectetur arcu orci eu augue.</p>"
                              }
                            }
                          },
                          {
                            "uid": "a42d8b1c-193d-5627-9130-f7f7f87617f1",
                            "componentName": "ContentBlock",
                            "dataSource": "{E21B7FEF-ADBA-5EB9-B5C1-864226392FA2}",
                            "params": {},
                            "fields": {
                              "heading": {
                                "value": ""
                              },
                              "content": {
                                "value": "<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque felis mauris, pretium id neque vitae, vulputate pellentesque tortor. Mauris hendrerit dolor et ipsum lobortis bibendum non finibus neque. Morbi volutpat aliquam magna id posuere. Duis commodo cursus dui, nec interdum velit congue nec. Aliquam erat volutpat. Aliquam facilisis, sapien quis fringilla tincidunt, magna nulla feugiat neque, a consectetur arcu orci eu augue.</p>"
                              }
                            }
                          },
                          {
                            "uid": "0f4cb47a-979e-5139-b50b-a8e40c73c236",
                            "componentName": "ContentBlock",
                            "dataSource": "{0EC0803F-5EDE-54C9-997E-763A75BD3CC0}",
                            "params": {},
                            "fields": {
                              "heading": {
                                "value": ""
                              },
                              "content": {
                                "value": "<p>Mix and match reused and local content. Check out <code>/data/routes/styleguide/en.yml</code> to see how.</p>"
                              }
                            }
                          }
                        ]
                      }
                    },
                    {
                      "uid": "538e4831-f157-50bb-ac74-277fcac9fddb",
                      "componentName": "Styleguide-Layout-Tabs",
                      "dataSource": "{D21AFD84-49E7-5390-A096-38C2EE341973}",
                      "params": {},
                      "fields": {
                        "description": {
                          "value": "<p>Creating hierarchical components like tabs is made simpler in JSS because it's easy to introspect the layout structure.</p>"
                        },
                        "heading": {
                          "value": "Tabs"
                        }
                      },
                      "placeholders": {
                        "jss-tabs": [
                          {
                            "uid": "7ecb2ed2-ac9b-58d1-8365-10ca74824af7",
                            "componentName": "Styleguide-Layout-Tabs-Tab",
                            "dataSource": "{D94A1E67-562F-5275-89D6-959544A571B6}",
                            "params": {},
                            "fields": {
                              "content": {
                                "value": "<p>Tab 1 contents!</p>"
                              },
                              "title": {
                                "value": "Tab 1"
                              }
                            }
                          },
                          {
                            "uid": "afd64900-0a61-50eb-a674-a7a884e0d496",
                            "componentName": "Styleguide-Layout-Tabs-Tab",
                            "dataSource": "{95511B48-0217-58BF-8CE7-33D31475F704}",
                            "params": {},
                            "fields": {
                              "content": {
                                "value": "<p>Tab 2 contents!</p>"
                              },
                              "title": {
                                "value": "Tab 2"
                              }
                            }
                          },
                          {
                            "uid": "44c12983-3a84-5462-84c0-6ca1430050c8",
                            "componentName": "Styleguide-Layout-Tabs-Tab",
                            "dataSource": "{2E3F3E29-856F-5268-A184-C45CD9CBA27D}",
                            "params": {},
                            "fields": {
                              "content": {
                                "value": "<p>Tab 3 contents!</p>"
                              },
                              "title": {
                                "value": "Tab 3"
                              }
                            }
                          }
                        ]
                      }
                    }
                  ]
                }
              },
              {
                "uid": "2d806c25-dd46-51e3-93de-63cf9035122c",
                "componentName": "Styleguide-Section",
                "dataSource": "{77650E0E-332B-576F-8372-945742E28AA8}",
                "params": {},
                "fields": {
                  "heading": {
                    "value": "Sitecore Patterns"
                  }
                },
                "placeholders": {
                  "jss-styleguide-section": [
                    {
                      "uid": "471fa16a-bb82-5c42-9c95-e7eab1e3bd30",
                      "componentName": "Styleguide-SitecoreContext",
                      "dataSource": "{AEE74ED4-A920-5CC0-B42E-DA96109148CC}",
                      "params": {},
                      "fields": {
                        "description": {
                          "value": "<p><small>The Sitecore Context contains route-level data about the current context - for example, <code>pageState</code> enables conditionally executing code based on whether Sitecore is in Experience Editor or not.</small></p>"
                        },
                        "heading": {
                          "value": "Sitecore Context"
                        }
                      }
                    },
                    {
                      "uid": "21f21053-8f8a-5436-bc79-e674e246a2fc",
                      "componentName": "Styleguide-RouteFields",
                      "dataSource": "{9F3C21F8-CA99-5C8D-9A69-7A0808AFC2A5}",
                      "params": {},
                      "fields": {
                        "description": {
                          "value": "<p><small>Route-level content fields are defined on the <em>route</em> instead of on a <em>component</em>. This allows multiple components to share the field data on the same route - and querying is much easier on route level fields, making <em>custom route types</em> ideal for filterable/queryable data such as articles.</small></p>"
                        },
                        "heading": {
                          "value": "Route-level Fields"
                        }
                      }
                    },
                    {
                      "uid": "a0a66136-c21f-52e8-a2ea-f04dcfa6a027",
                      "componentName": "Styleguide-ComponentParams",
                      "dataSource": "{F52DC641-08FD-5A07-9CE6-9BC5FCE821E1}",
                      "params": {
                        "cssClass": "alert alert-success",
                        "columns": "5",
                        "useCallToAction": "true"
                      },
                      "fields": {
                        "description": {
                          "value": "<p><small>Component params (also called Rendering Parameters) allow storing non-content parameters for a component. These params should be used for more technical options such as CSS class names or structural settings.</small></p>"
                        },
                        "heading": {
                          "value": "Component Params"
                        }
                      }
                    },
                    {
                      "uid": "7f765fcb-3b10-58fd-8aa7-b346ef38c9bb",
                      "componentName": "Styleguide-Tracking",
                      "dataSource": "{D60C2E9C-B0AF-5BB6-9DBD-576094E21973}",
                      "params": {},
                      "fields": {
                        "description": {
                          "value": "<p><small>JSS supports tracking Sitecore analytics events from within apps. Give it a try with this handy interactive demo.</small></p>"
                        },
                        "heading": {
                          "value": "Tracking"
                        }
                      }
                    }
                  ]
                }
              },
              {
                "uid": "66af8f03-0b52-5425-a6af-6fb54f2d64d9",
                "componentName": "Styleguide-Section",
                "dataSource": "{41274775-68F2-59EF-97C5-8668CBA16397}",
                "params": {},
                "fields": {
                  "heading": {
                    "value": "Multilingual Patterns"
                  }
                },
                "placeholders": {
                  "jss-styleguide-section": [
                    {
                      "uid": "cf1b5d2b-c949-56e7-9594-66afaceaca9d",
                      "componentName": "Styleguide-Multilingual",
                      "dataSource": "{65421A9E-28A0-5BDA-BF6D-F9DF1702C68F}",
                      "params": {},
                      "fields": {
                        "sample": {
                          "value": "This text can be translated in en.yml"
                        },
                        "description": {
                          "value": ""
                        },
                        "heading": {
                          "value": "Translation Patterns"
                        }
                      }
                    }
                  ]
                }
              }
            ]
          }
        }
      ]
    }
  },
  "itemId": "004775c9-e903-5743-9b03-adb08132b527",
  "pageEditing": false,
  "site": {
    "name": "xmcloudpreview"
  },
  "pageState": "normal",
  "editMode": "chromes",
  "language": "en",
  "itemPath": "/styleguide"
}Route-level content fields are defined on the route instead of on a component. This allows multiple components to share the field data on the same route - and querying is much easier on route level fields, making custom route types ideal for filterable/queryable data such as articles.
Implementation: /src/components/**/Styleguide-RouteFields.tsx
Definition: /sitecore/definitions/components/**/Styleguide-RouteFields.sitecore.js
Route level pageTitle field: Styleguide | Sitecore JSS
Component params (also called Rendering Parameters) allow storing non-content parameters for a component. These params should be used for more technical options such as CSS class names or structural settings.
Implementation: /src/components/**/Styleguide-ComponentParams.tsx
Definition: /sitecore/definitions/components/**/Styleguide-ComponentParams.sitecore.js
The CSS class of this paragraph (alert alert-success) is set using a param
truestringcolumns param: 5
JSS supports tracking Sitecore analytics events from within apps. Give it a try with this handy interactive demo.
Implementation: /src/components/**/Styleguide-Tracking.tsx
Definition: /sitecore/definitions/components/**/Styleguide-Tracking.sitecore.js
Note: The JSS tracker API is disabled by default. Consult the tracking documentation to enable it.
Implementation: /src/components/**/Styleguide-Multilingual.tsx
Definition: /sitecore/definitions/components/**/Styleguide-Multilingual.sitecore.js
This text can be translated in en.yml
This is a static dictionary entry from /data/dictionary: This is a dictionary entry in English as a demonstration
The current language is: en