Skip to content

Commit

Permalink
[#362] Fix deprecated Accordion usage
Browse files Browse the repository at this point in the history
  • Loading branch information
palagdan authored and blcham committed Nov 4, 2024
1 parent 8839517 commit d8a96c7
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 25 deletions.
51 changes: 26 additions & 25 deletions src/components/Question.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ export default class Question extends React.Component {
headerClassName.push(Question.getEmphasizedClass(question));
if (FormUtils.isSection(question))
headerClassName.push("section-background");
if (collapsible) headerClassName.push("cursor-pointer");
if (collapsible) headerClassName.push("pointer");
if (this.isDebugged(question)) {
headerClassName.push("show-irrelevant");
}
Expand Down Expand Up @@ -215,31 +215,32 @@ export default class Question extends React.Component {
return (
<>
<Accordion
defaultActiveKey={!this.state.expanded ? label : undefined}
activeKey={this.state.expanded ? label : undefined}
className="mb-3"
>
<Card className="mb-3">
<Accordion.Toggle
as={Card.Header}
onClick={this._toggleCollapse}
className={this._getHeaderClassName()}
onMouseEnter={this._onMouseEnterHandler}
onMouseLeave={this._onMouseLeaveHandler}
>
<h6 className="d-inline" id={question["@id"]}>
{collapsible &&
!FormUtils.isWizardStep(question) &&
this._renderCollapseToggle()}
{label}
</h6>
{this.renderQuestionIcons()}
{this.props.children}
</Accordion.Toggle>
{collapsible ? (
<Accordion.Collapse>{cardBody}</Accordion.Collapse>
) : (
<>{cardBody}</>
)}
</Card>
<Accordion.Item eventKey={label}>
<Card className="">
<Accordion.Button
as={Card.Header}
onClick={this._toggleCollapse}
className={this._getHeaderClassName()}
onMouseEnter={this._onMouseEnterHandler}
onMouseLeave={this._onMouseLeaveHandler}
>
<h6 className="d-inline" id={question["@id"]}>
{collapsible &&
!FormUtils.isWizardStep(question) &&
this._renderCollapseToggle()}
{label}
</h6>
{this.renderQuestionIcons()}
{this.props.children}
</Accordion.Button>
<Accordion.Body className="p-0">
{collapsible ? cardBody : <>{cardBody}</>}
</Accordion.Body>
</Card>
</Accordion.Item>
</Accordion>
</>
);
Expand Down
8 changes: 8 additions & 0 deletions src/styles/s-forms.css
Original file line number Diff line number Diff line change
Expand Up @@ -208,6 +208,14 @@ input:disabled {
margin-bottom: 0;
}

.accordion-button::after {
background-image: initial;
}

.accordion-button:not(.collapsed)::after {
background-image: initial;
}

.emphasise-on-relevant-icon {
animation: emphasiseOnRelevantIcon 0.5s ease-in;
}
Expand Down

0 comments on commit d8a96c7

Please sign in to comment.