Write.cshtml 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. @page
  2. @model Admin.Pages.Banner.List.WriteModel
  3. @{
  4. ViewData["Title"] = "배너 등록";
  5. }
  6. <div class="container">
  7. <h3>@ViewData["Title"]</h3>
  8. <hr />
  9. <partial name="_StatusMessage" />
  10. <form 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.PositionID" class="col-sm-2 col-form-label"><span>*</span> 배너 위치</label>
  13. <div class="col-sm-10">
  14. <div class="row">
  15. <div class="col col-md-auto">
  16. <select asp-for="Input.PositionID" class="form-select" asp-items="Model.Positions" required></select>
  17. </div>
  18. </div>
  19. <span asp-validation-for="Input.PositionID" class="text-danger"></span>
  20. </div>
  21. </div>
  22. <div class="row mb-2">
  23. <label asp-for="Input.Subject" class="col-sm-2 col-form-label"><span>*</span> 배너 명</label>
  24. <div class="col-sm-10">
  25. <input asp-for="Input.Subject" class="form-control" required/>
  26. <span asp-validation-for="Input.Subject" class="text-danger"></span>
  27. </div>
  28. </div>
  29. <div class="row mb-2">
  30. <label asp-for="Input.Link" class="col-sm-2 col-form-label"></label>
  31. <div class="col-sm-10">
  32. <input asp-for="Input.Link" class="form-control" type="url" />
  33. <span asp-validation-for="Input.Link" class="text-danger"></span>
  34. </div>
  35. </div>
  36. <div class="row mb-2">
  37. <label class="col-sm-2 col-form-label">이미지</label>
  38. <div class="col-sm-10">
  39. <div class="mb-3">
  40. <label asp-for="Input.DesktopImageFile" class="form-label">Desktop</label>
  41. <div id="DesktopBannerPrev" hidden>
  42. <img class="img-fluid img-thumbnail" alt="이미지(Desktop) 미리보기" /><br/>
  43. <button type="button" class="btn btn-sm btn-danger mt-2 mb-2 btn-remove-preview">삭제</button>
  44. </div>
  45. <input asp-for="Input.DesktopImageFile" type="file" class="form-control" accept="image/*" />
  46. <span asp-validation-for="Input.DesktopImageFile" class="text-danger"></span>
  47. </div>
  48. <div>
  49. <label asp-for="Input.MobileImageFile" class="form-label">Mobile</label>
  50. <div id="MobileBannerPrev" hidden>
  51. <img class="img-fluid img-thumbnail" alt="이미지(Mobile) 미리보기" /><br/>
  52. <button type="button" class="btn btn-sm btn-danger mt-2 mb-2 btn-remove-preview">삭제</button>
  53. </div>
  54. <input asp-for="Input.MobileImageFile" type="file" class="form-control" accept="image/*" />
  55. <span asp-validation-for="Input.MobileImageFile" class="text-danger"></span>
  56. </div>
  57. </div>
  58. </div>
  59. <div class="row mb-2">
  60. <label asp-for="Input.Order" class="col-sm-2 col-form-label"><span class="text-danger">*</span> 순서</label>
  61. <div class="col-sm-10">
  62. <div class="row">
  63. <div class="col col-md-auto">
  64. <input asp-for="Input.Order" class="form-control" type="number" min="-9999" max="9999" required />
  65. </div>
  66. </div>
  67. <span asp-validation-for="Input.Order" class="text-danger"></span>
  68. </div>
  69. </div>
  70. <div class="row mb-2">
  71. <label class="col-sm-2 col-form-label">사용 기간</label>
  72. <div class="col-sm-10">
  73. <div class="row g-2">
  74. <div class="col col-md-auto">
  75. <input asp-for="Input.StartAt" class="form-control" />
  76. <span asp-validation-for="Input.StartAt" class="text-danger"></span>
  77. </div>
  78. <div class="col-auto d-none d-md-block align-self-center">~</div>
  79. <div class="col col-md-auto">
  80. <input asp-for="Input.EndAt" class="form-control" />
  81. <span asp-validation-for="Input.EndAt" class="text-danger"></span>
  82. </div>
  83. </div>
  84. <span class="text-muted form-text">
  85. 사용 기간을 설정하지 않으면 무제한으로 사용됩니다.
  86. </span>
  87. </div>
  88. </div>
  89. <div class="row mb-2">
  90. <label asp-for="Input.IsActive" class="col-sm-2 col-form-label">사용 여부</label>
  91. <div class="col-sm-10 align-content-center">
  92. <div class="form-check-inline">
  93. <input type="checkbox" asp-for="Input.IsActive" class="form-check-input" />
  94. <label class="form-check-label" asp-for="Input.IsActive">사용합니다.</label>
  95. <span asp-validation-for="Input.IsActive" class="text-danger"></span>
  96. </div>
  97. </div>
  98. </div>
  99. <hr />
  100. <div class="row">
  101. <div class="col text-center p-3">
  102. <button type="submit" class="btn btn-success">저장</button>
  103. <a href="/Banner/List?@Model.QueryString" class="btn btn-secondary">취소</a>
  104. </div>
  105. </div>
  106. <br/>
  107. </form>
  108. </div>
  109. @section Scripts {
  110. <script>
  111. setupImagePreview("Input_DesktopImageFile", "DesktopBannerPrev");
  112. setupImagePreview("Input_MobileImageFile", "MobileBannerPrev");
  113. </script>
  114. }