diff --git a/packages/code-connect/components/ExpandableSection/ExandableSectionTruncate.figma.tsx b/packages/code-connect/components/ExpandableSection/ExandableSectionTruncate.figma.tsx
new file mode 100644
index 00000000000..ee1b39cd94d
--- /dev/null
+++ b/packages/code-connect/components/ExpandableSection/ExandableSectionTruncate.figma.tsx
@@ -0,0 +1,51 @@
+import figma from '@figma/code-connect';
+import { ExpandableSection } from '@patternfly/react-core';
+
+// TODO: DESIGN: Create toggle component
+// onToggle={() => {}} // only required if the user wants to be able to have other side effects when opening/closing
+// isExpanded={() => {}} // only required if the user wants to be able to have other side effects when opening/closing
+
+// Documentation for ExpandableSection can be found at https://www.patternfly.org/components/expandable-section
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2769-146',
+ {
+ props: {
+ toggleText: figma.string('Toggle Text More'),
+ isExpanded: false
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? 'Show less basic example content' : `${props.toggleText}`}
+ >
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2769-146',
+ {
+ variant: { State: 'Expanded' },
+ props: {
+ toggleText: figma.string('Toggle Text Less'),
+ defaultContentSectionText: figma.string('Default Truncate Text'),
+ isExpanded: true
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? 'Show less basic example content' : `${props.toggleText}`}
+ variant="truncate"
+ >
+ {props.defaultContentSectionText}
+
+ )
+ }
+);
diff --git a/packages/code-connect/components/ExpandableSection/ExpandableSection.figma.tsx b/packages/code-connect/components/ExpandableSection/ExpandableSection.figma.tsx
new file mode 100644
index 00000000000..0ab02245273
--- /dev/null
+++ b/packages/code-connect/components/ExpandableSection/ExpandableSection.figma.tsx
@@ -0,0 +1,158 @@
+import figma from '@figma/code-connect';
+import { ExpandableSection, ExpandableSectionToggle, Stack, StackItem } from '@patternfly/react-core';
+
+// TODO: DESIGN: This component needs to be overhauled. Using the base component approach present in
+// other components would significantly reduce complexity.
+// TODO: DESIGN: Create toggle component
+// onToggle={() => {}} // only required if the user wants to be able to have other side effects when opening/closing
+// isExpanded={() => {}} // only required if the user wants to be able to have other side effects when opening/closing
+
+// Documentation for ExpandableSection can be found at https://www.patternfly.org/components/expandable-section
+
+const customToggleContent = `
+
+ You can also use icons
+
+ or badges
+ 4
+ !
+
+`;
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ props: {
+ toggleText: figma.string('Toggle Text More')
+ },
+ example: (props) => (
+ {}}
+ toggleText={isExpanded ? 'Show less basic example content' : `${props.toggleText}`}
+ >
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ variant: { State: 'Expanded Basic' },
+ props: {
+ // enum
+ expandedContentSectionText: figma.string('Expanded Text'),
+ toggleText: figma.string('Toggle Text Less')
+ },
+ example: (props) => (
+ {}}
+ toggleText={isExpanded ? `${props.toggleText}` : 'Show less basic example content'}
+ >
+ {props.expandedContentSectionText}
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ variant: { State: 'Expand Detached' },
+ props: {
+ // enum
+ expandedContentSectionText: figma.string('Expanded Text'),
+ toggleText: figma.string('Toggle Text Less'),
+ toggleId: 'toggle-id',
+ contentId: 'content-id'
+ },
+ example: (props) => (
+
+
+
+ {props.expandedContentSectionText}
+
+
+
+ {}}
+ toggleId={props.toggleId}
+ contentId={props.contentId}
+ direction="up"
+ >
+ {isExpanded ? `${props.toggleText}` : 'Show less basic example content'}
+
+
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ variant: { State: 'Expanded Indent' },
+ props: {
+ // enum
+ expandedContentSectionText: figma.string('Expanded Text'),
+ toggleText: figma.string('Toggle Text Less'),
+ toggleId: 'toggle-id',
+ contentId: 'content-id'
+ },
+ example: (props) => (
+ {}}
+ >
+ {props.expandedContentSectionText}
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ variant: { State: 'Default Custom Content' },
+ example: () => (
+ {}}>
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ variant: { State: 'Expanded Custom Content' },
+ example: () => (
+ {}}>
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2404-21',
+ {
+ variant: { State: 'Expanded Custom with Component swap' },
+ example: () => (
+ {}}>
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
diff --git a/packages/code-connect/components/ExpandableSection/ExpandableSectionDisclosure.figma.tsx b/packages/code-connect/components/ExpandableSection/ExpandableSectionDisclosure.figma.tsx
new file mode 100644
index 00000000000..fd4a6cd190d
--- /dev/null
+++ b/packages/code-connect/components/ExpandableSection/ExpandableSectionDisclosure.figma.tsx
@@ -0,0 +1,133 @@
+import figma from '@figma/code-connect';
+import { ExpandableSection } from '@patternfly/react-core';
+
+const customToggleContent = `
+
+ You can also use icons
+
+ or badges
+ 4
+ !
+
+`;
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2810-80',
+ {
+ props: {
+ toggleText: figma.string('Toggle Text More'),
+ isExpanded: false
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? 'Show less basic example content' : `${props.toggleText}`}
+ >
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2810-80',
+ {
+ variant: { State: 'Expanded' },
+ props: {
+ toggleText: figma.string('Toggle Text Less'),
+ expandedContentSectionText: figma.string('Expanded Text'),
+ isExpanded: true
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? `${props.toggleText}` : 'Show more basic example content'}
+ >
+ {props.expandedContentSectionText}
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2810-80',
+ {
+ variant: { State: 'Expand Uncontrolled' },
+ props: {
+ toggleText: figma.string('Toggle Text More'),
+ expandedContentSectionText: figma.string('Expanded Text'),
+ isExpanded: true
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? `${props.toggleText}` : 'Show less basic example content'}
+ >
+ {props.expandedContentSectionText}
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2810-80',
+ {
+ variant: { State: 'Expanded Indent' },
+ props: {
+ expandedContentSectionText: figma.string('Expanded Text'),
+ toggleText: figma.string('Toggle Text More'),
+ isExpanded: true
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? `${props.toggleText}` : 'Show less basic example content'}
+ >
+ {props.expandedContentSectionText}
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2810-80',
+ {
+ variant: { State: 'Default Custom Content' },
+ example: () => (
+ {}}>
+ This content is visible only when the component is expanded.
+
+ )
+ }
+);
+
+figma.connect(
+ ExpandableSection,
+ 'https://www.figma.com/design/aEBBvq0J3EPXxHvv6WgDx9/PatternFly-6--Components-Test?node-id=2810-80',
+ {
+ variant: { State: 'Expanded Custom Content' },
+ props: {
+ toggleText: figma.string('Toggle Text More'),
+ expandedContentSectionText: figma.string('Expanded Text'),
+ isExpanded: true
+ },
+ example: (props) => (
+ {}}
+ toggleText={props.isExpanded ? `${props.toggleText}` : 'Show less basic example content'}
+ >
+ {props.expandedContentSectionText}
+
+ )
+ }
+);