Edit.cshtml 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. @model bitforum.Models.Page.Banner.BannerItem
  2. @{
  3. ViewData["Title"] = "배너 수정";
  4. var bannerPositions = ViewBag.BannerPositions as SelectList;
  5. }
  6. <div class="container">
  7. <h3>@ViewData["Title"]</h3>
  8. <hr />
  9. <partial name="_StatusMessage" />
  10. <partial name="_Editor" />
  11. <form name="f_admin_write" id="fAdminWrite" method="post" accept-charset="utf-8" autocomplete="off" action="/Page/Banner/Item/Update" enctype="multipart/form-data">
  12. <input type="hidden" asp-for="ID" />
  13. <div class="row mb-2">
  14. <label for="PositionID" class="col-sm-2 col-form-label">위치</label>
  15. <div class="col-sm-10">
  16. <select asp-for="PositionID" asp-items="bannerPositions" class="form-select w-auto" required></select>
  17. <span asp-validation-for="PositionID" class="text-danger"></span>
  18. </div>
  19. </div>
  20. <div class="row mb-2">
  21. <label for="Subject" class="col-sm-2 col-form-label">배너 명</label>
  22. <div class="col-sm-10">
  23. <input type="text" asp-for="Subject" class="form-control" required />
  24. <span asp-validation-for="Subject" class="text-danger"></span>
  25. </div>
  26. </div>
  27. <div class="row mb-2">
  28. <label for="Image" class="col-sm-2 col-form-label">이미지</label>
  29. <div class="col-sm-10">
  30. @if (Model.Image is not null && Model.Image != string.Empty)
  31. {
  32. <img src="@Url.Content(Model.Image)" class="img-fluid img-thumbnail" alt="@Model.Subject" />
  33. <div class="form-check-inline">
  34. <input type="checkbox" name="IsImageRemove" id="IsImageRemove" class="form-check-input" value="true" />
  35. <label for="IsImageRemove" class="form-check-label">삭제</label>
  36. </div>
  37. <input type="hidden" asp-for="Image" class="form-control" value="" />
  38. }
  39. else
  40. {
  41. <div id="previewBanner" hidden><img class="img-fluid img-thumbnail" alt="이미지 미리보기" /></div>
  42. <input type="file" asp-for="Image" class="form-control" accept="image/*" />
  43. <span asp-validation-for="Image" class="text-danger"></span>
  44. }
  45. </div>
  46. </div>
  47. <div class="row mb-2">
  48. <label class="col-sm-2 col-form-label">크기</label>
  49. <div class="col-sm-10">
  50. <div class="row g-2">
  51. <div class="col col-md-auto">
  52. <div class="input-group">
  53. <label for="Width" class="input-group-text">가로</label>
  54. <input type="number" asp-for="Width" class="form-control" min="1" />
  55. </div>
  56. <span asp-validation-for="Width" class="text-danger"></span>
  57. </div>
  58. <div class="col-auto d-none d-md-block align-self-center">~</div>
  59. <div class="col col-md-auto">
  60. <div class="input-group">
  61. <label for="Height" class="input-group-text">세로</label>
  62. <input type="number" asp-for="Height" class="form-control" min="1" />
  63. <span asp-validation-for="Height" class="text-danger"></span>
  64. </div>
  65. </div>
  66. </div>
  67. <span class="text-muted form-text">
  68. 설정하지 않으면 자동 크기로 사용됩니다.
  69. </span>
  70. </div>
  71. </div>
  72. <div class="row mb-2">
  73. <label for="Link" class="col-sm-2 col-form-label">주소</label>
  74. <div class="col-sm-10">
  75. <input type="url" asp-for="Link" class="form-control" />
  76. <span asp-validation-for="Link" class="text-danger"></span>
  77. <span class="text-muted form-text">
  78. 배너 클릭 시 페이지 이동 주소를 지정합니다.
  79. </span>
  80. </div>
  81. </div>
  82. <div class="row mb-2">
  83. <label for="Order" class="col-sm-2 col-form-label">순서</label>
  84. <div class="col-sm-10 align-content-center">
  85. <div class="form-check-inline">
  86. <input type="number" asp-for="Order" class="form-control" min="-999" max="999" required />
  87. <span asp-validation-for="Order" class="text-danger"></span>
  88. </div>
  89. </div>
  90. </div>
  91. <div class="row mb-2">
  92. <label for="IsActive" class="col-sm-2 col-form-label">사용 여부</label>
  93. <div class="col-sm-10 align-content-center">
  94. <div class="form-check-inline">
  95. <input type="checkbox" asp-for="IsActive" class="form-check-input" />
  96. <label class="form-check-label" for="IsActive">
  97. 사용합니다.
  98. </label>
  99. <span asp-validation-for="IsActive" class="text-danger"></span>
  100. </div>
  101. </div>
  102. </div>
  103. <div class="row mb-2">
  104. <label class="col-sm-2 col-form-label">사용 기간</label>
  105. <div class="col-sm-10">
  106. <div class="row g-2">
  107. <div class="col col-md-auto">
  108. <input type="date" asp-for="StartAt" class="form-control" />
  109. <span asp-validation-for="StartAt" class="text-danger"></span>
  110. </div>
  111. <div class="col-auto d-none d-md-block align-self-center">~</div>
  112. <div class="col col-md-auto">
  113. <input type="date" asp-for="EndAt" class="form-control" />
  114. <span asp-validation-for="EndAt" class="text-danger"></span>
  115. </div>
  116. </div>
  117. <span class="text-muted form-text">
  118. 사용 기간을 설정하지 않으면 무제한으로 사용됩니다.
  119. </span>
  120. </div>
  121. </div>
  122. @if (Model.UpdatedAt is not null)
  123. {
  124. <div class="row mb-2">
  125. <label class="col-sm-2 col-form-label">수정일시</label>
  126. <div class="col-sm-10">
  127. <input asp-for="UpdatedAt" class="form-control-plaintext" type="text" readonly />
  128. </div>
  129. </div>
  130. }
  131. @if (Model.CreatedAt is not null)
  132. {
  133. <div class="row mb-2">
  134. <label class="col-sm-2 col-form-label">등록일시</label>
  135. <div class="col-sm-10">
  136. <input asp-for="CreatedAt" class="form-control-plaintext" type="text" readonly />
  137. </div>
  138. </div>
  139. }
  140. <hr />
  141. <div class="d-grid gap-2 text-center d-md-block">
  142. <button type="submit" class="btn btn-sm btn-success">저장</button>
  143. <a asp-action="Index" class="btn btn-sm btn-secondary">취소</a>
  144. </div>
  145. <br />
  146. </form>
  147. </div>
  148. <script type="module">
  149. document.addEventListener("DOMContentLoaded", function () {
  150. const previewImage = document.getElementById("previewBanner");
  151. document.getElementById("Image").addEventListener("change", function (e) {
  152. console.log(1);
  153. const file = e.target.files[0];
  154. const image = previewImage.children[0];
  155. if (file && file.type.startsWith("image/")) {
  156. const reader = new FileReader();
  157. reader.onload = function (e) {
  158. image.src = e.target.result;
  159. previewImage.removeAttribute("hidden");
  160. };
  161. reader.readAsDataURL(file);
  162. } else {
  163. image.src = "";
  164. previewImage.setAttribute("hidden");
  165. }
  166. });
  167. // 배너 이미지 삭제
  168. let oldImageSrc = "";
  169. document.getElementById("isImageRemove").addEventListener("change", function (e) {
  170. let image = document.getElementById("Image");
  171. if (e.target.checked) {
  172. oldImageSrc = image.src;
  173. image.src = "";
  174. } else {
  175. image.src = oldImageSrc;
  176. }
  177. });
  178. });
  179. </script>