Index.cshtml 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. @page
  2. @model Admin.Pages.Member.Wallet.List.IndexModel
  3. @{
  4. ViewData["Title"] = "지갑 관리";
  5. }
  6. <div class="container-fluid">
  7. <h3>@ViewData["Title"]</h3>
  8. <hr />
  9. <partial name="_StatusMessage" />
  10. <div class="row g-2 mb-2">
  11. <div class="col-12 col-lg-auto">
  12. <div class="row g-2">
  13. <div class="col-auto col-md-auto">
  14. <select id="search" class="form-select">
  15. <option value="1" selected="@(Model.Parameter.Search == 1)">회원 ID</option>
  16. <option value="2" selected="@(Model.Parameter.Search == 2)">회원 별명</option>
  17. <option value="3" selected="@(Model.Parameter.Search == 3)">회원 이메일</option>
  18. <option value="4" selected="@(Model.Parameter.Search == 4)">지갑 ID</option>
  19. </select>
  20. </div>
  21. <div class="col col-md-auto">
  22. <input type="search" id="keyword" class="form-control" maxlength="100" value="@Model.Parameter.Keyword" />
  23. </div>
  24. </div>
  25. </div>
  26. <div class="col-12 col-sm">
  27. <div class="row g-2">
  28. <div class="col-12 col-md-auto">
  29. <div class="row row-cols-2 g-2">
  30. <div class="col">
  31. <input type="datetime-local" name="startAt" id="startAt" class="form-control" value="@Model.Parameter.StartAt" />
  32. </div>
  33. <div class="col d-none">
  34. ~
  35. </div>
  36. <div class="col">
  37. <input type="datetime-local" name="endAt" id="endAt" class="form-control" value="@Model.Parameter.EndAt" />
  38. </div>
  39. </div>
  40. </div>
  41. <div class="col col-md-auto text-center">
  42. <button type="submit" id="btnSearch" class="btn btn-primary w-100">검색</button>
  43. </div>
  44. </div>
  45. </div>
  46. </div>
  47. <hr />
  48. <div class="row g-2 align-items-end">
  49. <div class="col">
  50. Total : @Model.Total
  51. </div>
  52. <div class="col text-end">
  53. <select name="per_page" id="perPage" class="form-select w-auto d-inline-block" form="fAdminList">
  54. <option value="10" selected="@(Model.Parameter.PerPage == 10)">10</option>
  55. <option value="20" selected="@(Model.Parameter.PerPage == 20)">20</option>
  56. <option value="50" selected="@(Model.Parameter.PerPage == 50)">50</option>
  57. <option value="100" selected="@(Model.Parameter.PerPage == 100)">100</option>
  58. </select>
  59. </div>
  60. </div>
  61. <div class="table-responsive">
  62. <table class="table table-bordered table-hover mt-3">
  63. <colgroup>
  64. <col style="width: 5%;" />
  65. <col />
  66. <col />
  67. <col />
  68. <col />
  69. <col />
  70. <col />
  71. <col />
  72. </colgroup>
  73. <thead>
  74. <tr>
  75. <th>No</th>
  76. <th>지갑 ID</th>
  77. <th>회원</th>
  78. <th>보유 P</th>
  79. <th>후원 받은 P</th>
  80. <th>변동 일시</th>
  81. <th>등록 일시</th>
  82. <th>비고</th>
  83. </tr>
  84. </thead>
  85. @if (Model.List == null || Model.List.Count <= 0)
  86. {
  87. <tbody>
  88. <tr>
  89. <td colspan="8">No Data.</td>
  90. </tr>
  91. </tbody>
  92. }
  93. else
  94. {
  95. @foreach (var row in Model.List)
  96. {
  97. <tbody>
  98. <tr>
  99. <td>@row.Num</td>
  100. <td>@row.ID</td>
  101. <td>[@row.MemberID] @row.MemberEmail, @row.MemberName</td>
  102. <td>@row.Balance</td>
  103. <td>@row.DonationBalance</td>
  104. <td>@row.UpdatedAt</td>
  105. <td>@row.CreatedAt</td>
  106. <td>
  107. <a class="btn btn-sm btn-outline-success" href="@row.ChargeURL">충전</a>
  108. </td>
  109. </tr>
  110. </tbody>
  111. }
  112. }
  113. </table>
  114. <partial name="_Pagination" model="Model.Pagination" />
  115. </div>
  116. <div>
  117. <ul class="form-text text-muted">
  118. <li>회원 ID는 회원 번호(PK)로 조회가 가능합니다.</li>
  119. <li>지갑 ID는 지갑 번호(PK)로 조회가 가능합니다.</li>
  120. </ul>
  121. </div>
  122. </div>
  123. @section Scripts {
  124. <script>
  125. function updateQueryString() {
  126. let queryParams = new URLSearchParams();
  127. queryParams.set("search", document.getElementById("search").value);
  128. queryParams.set("keyword", document.getElementById("keyword").value);
  129. queryParams.set("startAt", document.getElementById("startAt").value);
  130. queryParams.set("endAt", document.getElementById("endAt").value);
  131. queryParams.set("perPage", document.getElementById("perPage").value);
  132. window.location.href = window.location.pathname + "?" + queryParams.toString();
  133. }
  134. $(document).on("change", "#perPage", function () {
  135. updateQueryString();
  136. });
  137. $(document).on("click", "#btnSearch", function(e) {
  138. e.preventDefault();
  139. updateQueryString();
  140. });
  141. $(document).on("keyup", "#keyword, #startAt, #endAt", function(e) {
  142. if (e.which === 13 || e.key === "Enter") {
  143. e.preventDefault();
  144. updateQueryString();
  145. }
  146. });
  147. </script>
  148. }