I have a construct of nested accordions which I want to show a plus and minus button when I open and collapse them.
<div style="padding: 10px">
<div class="accordion" id="base-data">
<div class="card">
<div class="card-header" id="headingOne">
<div id="buttonContainer" class="mb-0">
<button class="btn btn-link fa fa-plus collapsed" id="buttonBaseData" type="button" data-toggle="collapse" data-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne" style="font-size:25px">
Basisdaten
</button>
</div>
</div>
<div id="collapseOne" class="collapse" aria-labelledby="headingOne" data-parent="#base-data">
<div class="card-body">
<partial name="_PartialBaseData" />
</div>
</div>
</div>
</div>
<div class="accordion" id="apll-data">
<div class="card">
<div class="card-header" id="headingTwo">
<h2 class="mb-0">
<button class="btn btn-link collapsed fa fa-plus" type="button" data-toggle="collapse" data-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo" style="font-size:25px">
Antragsdaten
</button>
</h2>
</div>
<div id="collapseTwo" class="collapse" aria-labelledby="headingTwo" data-parent="#apll-data">
<div class="card-body">
<partial name="_PartialApplicationData" />
</div>
</div>
</div>
</div>
<div class="accordion" id="check-data">
<div class="card">
<div class="card-header" id="headingThree">
<h2 class="mb-0">
<button class="btn btn-link fa fa-plus collapsed" type="button" data-toggle="collapse" data-target="#collapseThree" aria-expanded="false" aria-controls="collapseThree" style="font-size:25px">
Überprüfung
</button>
</h2>
</div>
<div id="collapseThree" class="collapse" aria-labelledby="headingThree" data-parent="#check-data">
<div class="card-body">
<partial name="_PartialDataVerification" />
</div>
</div>
</div>
</div>
</div>
Now the partial tag contains the other accordions which will be injected in this place. For example these are the nested accordions in the _PartialApplicationData html file:
<div class="row">
<div class="col">
<div class="accordion" id="pvp-data">
<div class="card">
<div class="card-header" id="headingPVP">
<h2 class="mb-0">
<button class="btn btn-link fa fa-plus collapsed" type="button" data-toggle="collapse" data-target="#collapsePVP" aria-expanded="false" aria-controls="collapsePVP" style="font-size:25px">
PVP Daten
</button>
</h2>
</div>
<div id="collapsePVP" class="collapse" aria-labelledby="headingPVP" data-parent="#pvp-data">
<div class="card-body">
<partial name="_PartialPVPData" />
</div>
</div>
</div>
</div>
</div>
<div class="col">
<div class="accordion" id="foe-data">
<div class="card">
<div class="card-header" id="headingPVP">
<h2 class="mb-0">
<button class="btn btn-link fa fa-plus collapsed" type="button" data-toggle="collapse" data-target="#collapseFoe" aria-expanded="false" aria-controls="collapseFoe" style="font-size:25px">
Förderer Daten
</button>
</h2>
</div>
<div id="collapseFoe" class="collapse" aria-labelledby="headingFoe" data-parent="#foe-data">
<div class="card-body">
<partial name="_PartialFoerdererData" />
</div>
</div>
</div>
</div>
</div>
<div class="col">
<div class="accordion" id="bank-data">
<div class="card">
<div class="card-header" id="headingBank">
<h2 class="mb-0">
<button class="btn btn-link collapsed" type="button" data-toggle="collapse" data-target="#collapseBank" aria-expanded="false" aria-controls="collapseBank" style="font-size:25px">
Bankdaten
</button>
</h2>
</div>
<div id="collapseBank" class="collapse" aria-labelledby="headingBank" data-parent="#bank-data">
<div class="card-body">
<partial name="_PartialBankData" />
</div>
</div>
</div>
</div>
</div>
<div class="col">
<div class="accordion" id="identification-data">
<div class="card">
<div class="card-header" id="headingIdentification">
<h2 class="mb-0">
<button class="btn btn-link collapsed" type="button" data-toggle="collapse" data-target="#collapseIdentification" aria-expanded="false" aria-controls="collapseIdentification" style="font-size:25px">
Identifikationsdateien
</button>
</h2>
</div>
<div id="collapseIdentification" class="collapse" aria-labelledby="headingIdentification" data-parent="#identification-data">
<div class="card-body">
<partial name="_PartialIdentificationData" />
</div>
</div>
</div>
</div>
</div>
</div>
What I did try is following jquery code:
$(document).ready(function () {
// Toggle plus minus icon on show hide of collapse element
$(".collapse").on('show.bs.collapse', function () {
$(this).prev(".card-header").find(".fa").removeClass("fa-plus").addClass("fa-minus").addClass("fas");
}).on('hide.bs.collapse', function () {
$(this).prev(".card-header").find(".fa").removeClass("fa-minus").addClass("fa-plus").addClass("fas");
});
});
Now when theres only one accordion then it works but when I open and close the nested ones the parent accordion changes the icon too which I dont want. What should I do to make this happen? I saw the other questions but they were not related to nested accordions.