DiscDialog.razor 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. @inject IJSRuntime js;
  2. @code {
  3. [Parameter, Required] public FeDisc Disc { get; set; }
  4. }
  5. <Modal @ref="modal">
  6. <Title>@Disc?.Name</Title>
  7. <Body>
  8. <div class="container-fluid">
  9. <div class="row">
  10. <div class="col-md-4 mb-1"><img class="card-img-top" src="@Disc?.CoverPath" onerror="this.src='blazor-192.png'"></div>
  11. <div class="col-md-8">
  12. <ul class="nav nav-tabs justify-content-center nav-fill" id="ModalDiscTab" role="tablist">
  13. @foreach (var subSet in (Disc?.TrackSets).KeepNoEmpty().WithIndex())
  14. {
  15. <li class="nav-item " role="presentation">
  16. <button class="nav-link" id="main-tab" data-bs-toggle="tab" data-bs-target="#tracks-@subSet.index" type="button">
  17. @subSet.item?.Name
  18. </button>
  19. </li>
  20. }
  21. @if (Disc?.Bks != null)
  22. {
  23. <li class="nav-item " role="presentation">
  24. <button class="nav-link" id="main-tab" data-bs-toggle="tab" data-bs-target="#tracks-BK" type="button">
  25. BK
  26. </button>
  27. </li>
  28. }
  29. </ul>
  30. <div class="tab-content" id="ModalDiscTabContent">
  31. @foreach (var subSet in (Disc?.TrackSets).KeepNoEmpty().WithIndex())
  32. {
  33. <div class="tab-pane fade" id="tracks-@subSet.index" role="tabpanel">
  34. <DiscDialogTrackSetTable TrackSet="subSet.item"></DiscDialogTrackSetTable>
  35. </div>
  36. }
  37. @if (Disc?.Bks != null)
  38. {
  39. <div class="tab-pane fade p-2" id="tracks-BK" role="tabpanel">
  40. <DiscDialogBkSilder Bks="Disc.Bks"></DiscDialogBkSilder>
  41. </div>
  42. }
  43. </div>
  44. </div>
  45. </div>
  46. </div>
  47. </Body>
  48. </Modal>
  49. @code {
  50. private Modal modal { get; set; }
  51. public void Show()
  52. {
  53. js.InvokeVoidAsync("ResetModalDisc");
  54. modal.Show();
  55. }
  56. }