Write.cshtml 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. @page
  2. @model Admin.Pages.Member.Grade.WriteModel
  3. @{
  4. ViewData["Title"] = "회원등급 등록";
  5. }
  6. <div class="container">
  7. <h3>@ViewData["Title"]</h3>
  8. <hr />
  9. <partial name="_StatusMessage" />
  10. <form name="f_admin_write" id="fAdminWrite" method="post" accept-charset="utf-8" autocomplete="off" enctype="multipart/form-data">
  11. <div class="row mb-2">
  12. <label asp-for="Input.ImageFile" class="col-sm-2 col-form-label">이미지</label>
  13. <div class="col-sm-10">
  14. <div id="memberGradePrev" hidden>
  15. <img class="img-fluid img-thumbnail" alt="이미지 미리보기" /><br/>
  16. <button type="button" id="btnRemovePrev" class="btn btn-sm btn-danger mt-2 mb-2">삭제</button>
  17. </div>
  18. <input type="file" asp-for="Input.ImageFile" class="form-control" accept="image/*" />
  19. <span asp-validation-for="Input.ImageFile" class="text-danger"></span>
  20. </div>
  21. </div>
  22. <div class="row mb-2">
  23. <label asp-for="Input.KorName" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 한글 명</label>
  24. <div class="col-sm-10">
  25. <input type="text" asp-for="Input.KorName" class="form-control" required />
  26. <span asp-validation-for="Input.KorName" class="text-danger"></span>
  27. </div>
  28. </div>
  29. <div class="row mb-2">
  30. <label asp-for="Input.EngName" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 영문 명</label>
  31. <div class="col-sm-10">
  32. <input type="text" asp-for="Input.EngName" class="form-control" required />
  33. <span asp-validation-for="Input.EngName" class="text-danger"></span>
  34. </div>
  35. </div>
  36. <div class="row mb-2">
  37. <label asp-for="Input.Description" class="col-sm-2 col-form-label">내용</label>
  38. <div class="col-sm-10">
  39. <textarea asp-for="Input.Description" class="form-control" placeholder="최대 1000자" rows="2" maxlength="1000"></textarea>
  40. <span asp-validation-for="Input.Description" class="text-danger"></span>
  41. </div>
  42. </div>
  43. <div class="row mb-2">
  44. <label asp-for="Input.Order" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 순서</label>
  45. <div class="col-sm-10">
  46. <input type="number" asp-for="Input.Order" class="form-control d-inline w-auto" min="-9999" max="9999" required />
  47. <span asp-validation-for="Input.Order" class="text-danger"></span>
  48. </div>
  49. </div>
  50. <div class="row mb-2">
  51. <label asp-for="Input.TotalDonationCount" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 누적 후원 횟수</label>
  52. <div class="col-sm-10">
  53. <div class="input-group">
  54. <input type="number" asp-for="Input.TotalDonationCount" class="form-control w-auto flex-grow-0" min="0" max="1000000000" required />
  55. <span asp-validation-for="Input.TotalDonationCount" class="text-danger"></span>
  56. <div class="input-group-text">회</div>
  57. </div>
  58. </div>
  59. </div>
  60. <div class="row mb-2">
  61. <label asp-for="Input.TotalDonationAmount" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 누적 후원 금액</label>
  62. <div class="col-sm-10">
  63. <div class="input-group">
  64. <input type="number" asp-for="Input.TotalDonationAmount" class="form-control w-auto flex-grow-0" min="0" max="1000000000" required />
  65. <span asp-validation-for="Input.TotalDonationAmount" class="text-danger"></span>
  66. <div class="input-group-text">원</div>
  67. </div>
  68. </div>
  69. </div>
  70. <div class="row mb-2">
  71. <label asp-for="Input.TextColor" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 표시 색상</label>
  72. <div class="col-sm-10">
  73. <input type="text" asp-for="Input.TextColor" class="form-control w-auto flex-grow-0" minlength="4" maxlength="7" required />
  74. <div class="form-text text-muted">
  75. 색상 코드는 #RRGGBB 형식으로 입력하세요. (예: #FF5733)
  76. </div>
  77. </div>
  78. </div>
  79. <div class="row mb-2">
  80. <label asp-for="Input.IsActive" class="col-sm-2 col-form-label">사용 여부</label>
  81. <div class="col-sm-10 align-content-center">
  82. <div class="form-check-inline">
  83. <input type="checkbox" asp-for="Input.IsActive" class="form-check-input" />
  84. <label class="form-check-label" asp-for="Input.IsActive">
  85. 사용합니다.
  86. </label>
  87. <span asp-validation-for="Input.IsActive" class="text-danger"></span>
  88. </div>
  89. </div>
  90. </div>
  91. <hr/>
  92. <div class="d-grid gap-2 text-center d-md-block">
  93. <button type="submit" class="btn btn-sm btn-success">저장</button>
  94. <a asp-page="Index" class="btn btn-sm btn-secondary">취소</a>
  95. </div>
  96. <br/>
  97. </form>
  98. </div>
  99. @section Scripts {
  100. <script>
  101. setupImagePreview("Input_ImageFile", "memberGradePrev");
  102. </script>
  103. }