Write.cshtml 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. @page
  2. @model Admin.Pages.Forum.Posts.List.WriteModel
  3. @using Microsoft.AspNetCore.Mvc.Rendering
  4. @{
  5. ViewData["Title"] = "게시글 등록";
  6. }
  7. <div class="container">
  8. <h3 class="mb-3">@ViewData["Title"]</h3>
  9. <hr />
  10. <partial name="_StatusMessage" />
  11. <form id="fPostWrite" method="post" accept-charset="utf-8" autocomplete="off" enctype="multipart/form-data">
  12. <!-- 게시판 -->
  13. <div class="row mb-2">
  14. <label class="col-sm-2 col-form-label"><span class="text-danger">*</span> 게시판</label>
  15. <div class="col-sm-10">
  16. @if ((Model.BoardList?.Count ?? 0) > 0)
  17. {
  18. <select asp-for="Input.BoardID" class="form-select w-auto" required asp-items="@Model.BoardList">
  19. <option value="">- 선택 -</option>
  20. </select>
  21. }
  22. else
  23. {
  24. <input type="number" asp-for="Input.BoardID" class="form-control w-auto" required />
  25. }
  26. </div>
  27. </div>
  28. <!-- 제목 -->
  29. <div class="row mb-2">
  30. <label 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.Subject" class="form-control"
  33. required maxlength="255" placeholder="제목을 입력하세요 (최대 255자)" />
  34. </div>
  35. </div>
  36. <!-- 내용 -->
  37. <div class="row mb-2">
  38. <label class="col-sm-2 col-form-label">내용</label>
  39. <div class="col-sm-10">
  40. <textarea asp-for="Input.Content" class="form-control" rows="12" maxlength="8000"
  41. placeholder="내용을 입력하세요 (최대 8000자)"></textarea>
  42. </div>
  43. </div>
  44. <!-- 썸네일 -->
  45. <div class="row mb-2">
  46. <label class="col-sm-2 col-form-label">대표 이미지(썸네일)</label>
  47. <div class="col-sm-10">
  48. <input type="file" asp-for="Input.ThumbnailFile" class="form-control" accept="image/*" />
  49. </div>
  50. </div>
  51. <!-- 상태 -->
  52. <div class="row mb-2">
  53. <label class="col-sm-2 col-form-label">상태</label>
  54. <div class="col-sm-10 align-content-center">
  55. <div class="form-check form-check-inline">
  56. <input class="form-check-input" type="checkbox" asp-for="Input.IsNotice" />
  57. <label class="form-check-label" for="Input_IsNotice">공지</label>
  58. </div>
  59. <div class="form-check form-check-inline">
  60. <input class="form-check-input" type="checkbox" asp-for="Input.IsSecret" />
  61. <label class="form-check-label" for="Input_IsSecret">비밀</label>
  62. </div>
  63. <div class="form-check form-check-inline">
  64. <input class="form-check-input" type="checkbox" asp-for="Input.IsAnonymous" />
  65. <label class="form-check-label" for="Input_IsAnonymous">익명</label>
  66. </div>
  67. </div>
  68. </div>
  69. <hr />
  70. <div class="d-grid gap-2 text-center d-md-block">
  71. <button type="submit" class="btn btn-success">저장</button>
  72. <a class="btn btn-secondary btn-cancel" href="/Forum/Posts/List">취소</a>
  73. </div>
  74. <br />
  75. </form>
  76. </div>
  77. @section Scripts {
  78. <script>
  79. $(function () {
  80. $(".btn-cancel").on("click", function (e) {
  81. const s = $("input[name='Input.Subject']").val()?.trim();
  82. const c = $("textarea[name='Input.Content']").val()?.trim();
  83. if (s || c) {
  84. e.preventDefault();
  85. if (confirm("내용이나 제목이 남아 있습니다. 글 작성을 취소하시겠습니까?")) {
  86. location.href = $(this).attr("href");
  87. }
  88. }
  89. });
  90. });
  91. </script>
  92. }