sp-dev-fx-webparts/samples/react-accordion-dynamic-sec.../README.md

7.9 KiB

Dynamic Accordion - FAQ Builder

Summary

  • This sample is based on Erik Benke and Mike Zimmerman's Accordion Section FAQ Builder web part. It adds extended support for single FAQs list based on Category and dynamic properties selection.
  • Adds a collapsible accordion section to an Office 365 SharePoint page or Teams Tab.
  • Ideal for displaying FAQs.
  • When adding the web part, you'll be prompted to select a list from a property panel dropdown (target list must be created with FAQ type Question and Answer.).
  • The web part expects a column called Category of type choice that will be used as the category.
  • The web part will automatically load all the properties in two dropdowns. One for Accordion Title and One for Accordion Content that must be html type.
  • This will generate an accordion with one section for each item in the list.
  • Modifications/deletions/additions to the list items in the target list of an added web part are automatically reflected on the page.
  • To deploy to a Teams tab see current Microsoft documentation.

Web Part in Action

Usage

1) Create or use a list for FAQs. It can have the FAQ format e.g. Title and a Content columns. You can also used the attached STP file if needed.:

  • The value in the Accordion Title property for each item will appear in the heading bars of the Accordion.
  • The value in the Accordion Content property for each item will appear in the collapsible content section of the Accordion
  • When creating the columns, select "Multiple lines of text". Rich text is now supported within the Content column.

Create list for use with the Accordion FAQ list Template for use with the Accordion FAQ Site Script use with the Accordion

2) Add the Dynamic Accordion Section web part to your page & select your list, category, title and content columns. Click Apply and Publish:

Select list and other properties from property panel for use with the Accordion Completed properties.

Compatibility

⚠️ Important
Every SPFx version is only compatible with specific version(s) of Node.js. In order to be able to build this sample, please ensure that the version of Node on your workstation matches one of the versions listed in this section. This sample will not work on a different version of Node.
Refer to https://aka.ms/spfx-matrix for more information on SPFx compatibility.

SPFx 1.20.0 Node.js v18 Compatible with SharePoint Online Does not work with SharePoint 2019 Does not work with SharePoint 2016 (Feature Pack 2) Local Workbench Incompatible Hosted Workbench Compatible Compatible with Remote Containers

Applies to

Prerequisites

Please create the list as described above

Contributors

Version history

Version Date Comments
1.0 September 20, 2020 Reused [Erik Benke] and [Mike Zimmerman] web part
1.1 September 20, 2020 Added Support for Dynamic Column selection for reuseability, Dynamic Property Selection for Columns
1.8 August 8, 2021 Add configuration for sorting the items
2.0 April 2, 2023 Upgrade to SPFX 1.16.1
2.0 October 10, 2024 Upgrade to SPFX 1.20.1

Minimal Path to Awesome

  • Clone or download this repository
  • Run in command line:
    • npm install to install the npm dependencies
    • gulp serve to display in Developer Workbench (recommend using your tenant workbench so you can test with real lists within your site)
  • To package and deploy:
    • Use gulp bundle --ship & gulp package-solution --ship
    • Add the .sppkg to your SharePoint App Catalog

This sample can also be opened with VS Code Remote Development. Visit https://aka.ms/spfx-devcontainer for further instructions.

Help

We do not support samples, but we this community is always willing to help, and we want to improve these samples. We use GitHub to track issues, which makes it easy for community members to volunteer their time and help resolve issues.

You can try looking at issues related to this sample to see if anybody else is having the same issues.

You can also try looking at discussions related to this sample and see what the community is saying.

If you encounter any issues while using this sample, create a new issue.

For questions regarding this sample, create a new question.

Finally, if you have an idea for improvement, make a suggestion.

Disclaimer

THIS CODE IS PROVIDED AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.