save.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. <style>
  2. .ck-editor__editable_inline {
  3. height: 400px !important;
  4. }
  5. </style>
  6. <article class="cl pd-20">
  7. <form action="{:url('save')}" method="post" class="form form-horizontal" id="form-save">
  8. <input type="hidden" name="id" value="{$data['id']}">
  9. <input type="hidden" name="cjid" value="{$data['cjid']}">
  10. <input type="hidden" name="content_type" value="{$data['content_type']}">
  11. <div class="row cl">
  12. <label class="form-label col-xs-4 col-sm-2">
  13. <span class="c-red">*</span>栏目:</label>
  14. <div class="formControls col-xs-8 col-sm-6">
  15. <span class="select-box inline">
  16. <select name="cid" class="select" id="cid">
  17. <option value="">所有栏目</option>
  18. {foreach $category_tree as $value}
  19. <option value="{$value.id}" {eq name='data.cid' value="$value.id" }selected{/eq}>{$value.name}
  20. </option>
  21. {notempty name="value.child"}
  22. {foreach $value.child as $val}
  23. <option value="{$val.id}" {eq name='data.cid' value="$val.id" }selected{/eq}>--{$val.name}
  24. </option>
  25. {notempty name="val.child"}
  26. {foreach $val.child as $vo}
  27. <option value="{$vo.id}" {eq name='data.cid' value="$vo.id" }selected{/eq}>&nbsp;&nbsp;└
  28. --{$vo.name}
  29. </option>
  30. {/foreach}
  31. {/notempty}
  32. {/foreach}
  33. {/notempty}
  34. {/foreach}
  35. </select>
  36. </span>
  37. </div>
  38. <div class="col-3"> </div>
  39. </div>
  40. <div class="row cl">
  41. <label class="form-label col-xs-4 col-sm-2">
  42. <span class="c-red">*</span>标题:</label>
  43. <div class="formControls col-xs-8 col-sm-6">
  44. <input type="text" class="input-text" value="{$data.title}" placeholder="请填写标题" id="title" name="title">
  45. </div>
  46. <div class="col-3"> </div>
  47. </div>
  48. <div class="row cl">
  49. <label class="form-label col-xs-4 col-sm-2">
  50. 作者: </label>
  51. <div class="formControls col-xs-4 col-sm-2">
  52. <input type="text" class="input-text" value="{$data.writer}" placeholder="作者" id="writer" name="writer">
  53. </div>
  54. <label class="form-label col-xs-4 col-sm-2">
  55. 来源:</label>
  56. <div class="formControls col-xs-4 col-sm-2">
  57. <input type="text" class="input-text" value="{$data.source}" placeholder="来源" id="source" name="source">
  58. </div>
  59. <div class="col-3"> </div>
  60. </div>
  61. <div class="row cl">
  62. <div class="col-3"> </div>
  63. </div>
  64. <div class="row cl">
  65. <label class="form-label col-xs-4 col-sm-2">
  66. 标题图:</label>
  67. <div class="formControls col-xs-6 col-sm-4">
  68. <input type="text" class="input-text" value="{$data.titlepic}" name="titlepic" id="titlepic">
  69. <div style="width: 160px;height: 160px;">
  70. <a href="javascript:void(0);" onclick="addTitlePic()">
  71. <img id="view-titlepic"
  72. src="{$data.titlepic ? $data.titlepic : '/static/images/upload_picture.png'}" alt="标题图"
  73. title="{$data.titlepic ? '更换' : '添加'}标题图" style="max-width: 160px;max-height: 160px;">
  74. </a>
  75. </div>
  76. </div>
  77. <label class="form-label col-xs-2 col-sm-2">
  78. <a class="btn btn-success radius" href="javascript:addTitlePic();">{$data.titlepic ? '更换' :
  79. '添加'}标题图</a></label>
  80. <div class="col-3"> </div>
  81. </div>
  82. <div class="row cl">
  83. <label class="form-label col-xs-4 col-sm-2">
  84. 关键词:</label>
  85. <div class="formControls col-xs-8 col-sm-6">
  86. <input type="text" class="input-text" value="{$data.keywords}" placeholder="关键词" id="keywords"
  87. name="keywords">
  88. <span class="c-red">多个关键词用英文','分割</span>
  89. </div>
  90. <div class="col-3"> </div>
  91. </div>
  92. <div class="row cl">
  93. <label class="form-label col-xs-4 col-sm-2">内容简介:</label>
  94. <div class="formControls col-xs-8 col-sm-6">
  95. <textarea name="summary" id="summary" cols="" rows="" class="textarea" placeholder="说点什么...最多输入500个字符"
  96. datatype="*10-100" dragonfly="true" onKeyUp="textarealength(this,500)">{$data.summary}</textarea>
  97. <p class="textarea-numberbar">
  98. <em class="textarea-length">0</em>/500
  99. </p>
  100. </div>
  101. <div class="col-3"> </div>
  102. </div>
  103. <div class="row cl">
  104. <label class="form-label col-xs-4 col-sm-2">文章正文:</label>
  105. </div>
  106. <div class="row cl">
  107. <label class="form-label col-xs-1 col-sm-1"></label>
  108. <div class="formControls col-xs-11 col-sm-10">
  109. <div id="editor">{$data.content|raw}</div>
  110. </div>
  111. </div>
  112. <div class="row cl">
  113. <label class="form-label col-xs-2 col-sm-2">
  114. 点击量:</label>
  115. <div class="formControls col-xs-4 col-sm-2">
  116. <input type="number" class="input-text" value="{$data.hits}" id="hits" name="hits"
  117. style="width: 120px;">
  118. </div>
  119. <label class="form-label col-xs-2 col-sm-2">
  120. 排序:</label>
  121. <div class="formControls col-xs-4 col-sm-2">
  122. <input type="number" class="input-text" value="{$data.sort}" id="sort" name="sort"
  123. style="width: 120px;">
  124. </div>
  125. </div>
  126. <div class="row cl">
  127. <div class="col-xs-8 col-sm-9 col-xs-offset-4 col-sm-offset-3">
  128. <button type="button" class="btn btn-success radius" id="form-button-save">确&nbsp;定</button>
  129. <button type="button" class="btn btn-default radius" onclick="window.history.back();"
  130. style="margin-left:20px;">取&nbsp;消</button>
  131. </div>
  132. </div>
  133. </form>
  134. </article>
  135. <!--请在下方写此页面业务相关的脚本-->
  136. <script type="text/javascript" src="/static/plugins/jquery.validation/1.14.0/jquery.validate.js"></script>
  137. <script type="text/javascript" src="/static/plugins/jquery.validation/1.14.0/messages_zh.js"></script>
  138. <script type="text/javascript" src="/static/plugins/jquery.validation/1.14.0/validate-methods.js"></script>
  139. <script type="text/javascript" src="/static/plugins/ckeditor/ckeditor5/ckeditor.js"></script>
  140. <script type="text/javascript">
  141. $(function () {
  142. ClassicEditor.create(document.querySelector('#editor'), {
  143. toolbar: {
  144. items: [
  145. 'sourceEditing', '|',
  146. 'bold', 'italic', 'strikethrough', 'underline', 'subscript', 'superscript', '|',
  147. 'heading', '|',
  148. 'fontfamily', 'fontsize', 'fontColor', 'fontBackgroundColor', 'highlight', '|',
  149. 'alignment', 'outdent', 'indent', '|',
  150. 'undo', 'redo',
  151. '-',
  152. 'link', 'imageUpload', 'imageInsert', 'mediaEmbed', 'insertTable', '|',
  153. 'code', 'codeBlock', 'blockQuote', '|',
  154. 'findAndReplace', 'horizontalLine', 'numberedList', 'bulletedList',
  155. ],
  156. shouldNotGroupWhenFull: true
  157. },
  158. licenseKey: '',
  159. //图片上传
  160. simpleUpload: {
  161. // The URL the images are uploaded to.
  162. uploadUrl: '/sys/file_manager/ckeditorUploadImage?infoid={$data.id}&cjid={$data.cjid}'
  163. },
  164. //自定义字体
  165. fontFamily: {
  166. options: [
  167. 'default',
  168. '微软雅黑,Microsoft YaHei',
  169. '新宋体,NSimSun',
  170. '楷体_GB2312,KaiTi_GB2312',
  171. '黑体,SimHei',
  172. '隶书,LiSu',
  173. '幼园,YouYuan',
  174. 'Blackoak Std',
  175. 'Arial',
  176. 'Georgia',
  177. 'Tahoma',
  178. 'Trebuchet MS',
  179. 'verdana',
  180. ]
  181. },
  182. }).then(editor => {
  183. window.editor = editor;
  184. }).catch(error => {
  185. console.error('Oops, something went wrong!');
  186. console.error('Please, report the following error on https://github.com/ckeditor/ckeditor5/issues with the build id and the error stack trace:');
  187. console.warn('Build id: z4e2d8lqju9w-6lwv92tbu4hm');
  188. console.error(error);
  189. });
  190. })
  191. function validator(params) {
  192. return $("#form-save").validate({
  193. debug: true,
  194. rules: {
  195. title: {
  196. required: true,
  197. }
  198. , summary: {
  199. maxlength: 500,
  200. }
  201. , sort: {
  202. max: 99
  203. }
  204. , cid: {
  205. required: true
  206. }
  207. },
  208. messages: {
  209. title: {
  210. required: "标题不能为空"
  211. }
  212. , cid: {
  213. required: "栏目不能为空"
  214. }
  215. }
  216. });
  217. }
  218. $("#form-button-save").click(function () {
  219. if (!validator().form()) {
  220. return false
  221. }
  222. const content = window.editor.getData();
  223. $("<input/>").attr("type","hidden").attr("name", "content").val(content).appendTo($("#form-save"));
  224. $("#form-save")[0].submit();
  225. })
  226. //添加标题图
  227. function addTitlePic() {
  228. let url = '{:url("file_manager/uploadimg", ["_layer"=>true,"img_id"=>"titlepic","infoid"=>$data.id,"cjid"=>$data.cjid])}'
  229. layer_show('添加标题图', url, 800, 500);
  230. }
  231. </script>