index.tpl 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1">
  7. <title>我的项目 - Powered by MinDoc</title>
  8. <!-- Bootstrap -->
  9. <link href="{{cdncss "/static/bootstrap/css/bootstrap.min.css"}}" rel="stylesheet" type="text/css">
  10. <link href="{{cdncss "/static/font-awesome/css/font-awesome.min.css"}}" rel="stylesheet" type="text/css">
  11. <link href="{{cdncss "/static/bootstrap/plugins/bootstrap-fileinput/4.4.7/css/fileinput.min.css"}}" rel="stylesheet" type="text/css">
  12. <link href="{{cdncss "/static/bootstrap/plugins/bootstrap-fileinput/4.4.7/themes/explorer-fa/theme.css"}}" rel="stylesheet" type="text/css">
  13. <link href="{{cdncss "/static/select2/4.0.5/css/select2.min.css"}}" rel="stylesheet">
  14. <link href="{{cdncss "/static/css/main.css" "version"}}" rel="stylesheet">
  15. <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
  16. <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
  17. <!--[if lt IE 9]>
  18. <script src="/static/html5shiv/3.7.3/html5shiv.min.js"></script>
  19. <script src="/static/respond.js/1.4.2/respond.min.js"></script>
  20. <![endif]-->
  21. </head>
  22. <body>
  23. <div class="manual-reader">
  24. {{template "widgets/header.tpl" .}}
  25. <div class="container manual-body">
  26. <div class="row">
  27. <div class="page-left">
  28. <ul class="menu">
  29. <li {{if eq .ControllerName "BookController"}}class="active"{{end}}><a href="{{urlfor "BookController.Index"}}" class="item"><i class="fa fa-sitemap" aria-hidden="true"></i> 我的项目</a> </li>
  30. <li {{if eq .ControllerName "BlogController"}}class="active"{{end}}><a href="{{urlfor "BlogController.ManageList"}}" class="item"><i class="fa fa-file" aria-hidden="true"></i> 我的文章</a> </li>
  31. </ul>
  32. </div>
  33. <div class="page-right">
  34. <div class="m-box">
  35. <div class="box-head">
  36. <strong class="box-title">项目列表</strong>
  37. &nbsp;
  38. <button type="button" data-toggle="modal" data-target="#addBookDialogModal" class="btn btn-success btn-sm pull-right">添加项目</button>
  39. <button type="button" data-toggle="modal" data-target="#importBookDialogModal" class="btn btn-primary btn-sm pull-right" style="margin-right: 5px;">导入项目</button>
  40. </div>
  41. </div>
  42. <div class="box-body" id="bookList">
  43. <div class="book-list">
  44. <template v-if="lists.length <= 0">
  45. <div class="text-center">暂无数据</div>
  46. </template>
  47. <template v-else>
  48. <div class="list-item" v-for="item in lists">
  49. <div class="book-title">
  50. <div class="pull-left">
  51. <a :href="'{{.BaseUrl}}/book/' + item.identify + '/dashboard'" title="项目概要" data-toggle="tooltip">
  52. <template v-if="item.privately_owned == 0">
  53. <i class="fa fa-unlock" aria-hidden="true"></i>
  54. </template>
  55. <template v-else-if="item.privately_owned == 1">
  56. <i class="fa fa-lock" aria-hidden="true"></i>
  57. </template>
  58. ${item.book_name}
  59. </a>
  60. </div>
  61. <div class="pull-right">
  62. <div class="btn-group">
  63. <a :href="'{{.BaseUrl}}/book/' + item.identify + '/dashboard'" class="btn btn-default">设置</a>
  64. <a href="javascript:;" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  65. <span class="caret"></span>
  66. <span class="sr-only">Toggle Dropdown</span>
  67. </a>
  68. <ul class="dropdown-menu">
  69. <li><a :href="'{{urlfor "DocumentController.Index" ":key" ""}}' + item.identify" target="_blank">阅读</a></li>
  70. <template v-if="item.role_id != 3">
  71. <li><a :href="'{{.BaseUrl}}/api/' + item.identify + '/edit'" target="_blank">编辑</a></li>
  72. </template>
  73. <template v-if="item.role_id == 0">
  74. <li><a :href="'javascript:deleteBook(\''+item.identify+'\');'">删除</a></li>
  75. <li><a :href="'javascript:copyBook(\''+item.identify+'\');'">复制</a></li>
  76. </template>
  77. </ul>
  78. </div>
  79. {{/*<a :href="'{{urlfor "DocumentController.Index" ":key" ""}}' + item.identify" title="查看文档" data-toggle="tooltip" target="_blank"><i class="fa fa-eye"></i> 查看文档</a>*/}}
  80. {{/*<template v-if="item.role_id != 3">*/}}
  81. {{/*<a :href="'/api/' + item.identify + '/edit'" title="编辑文档" data-toggle="tooltip" target="_blank"><i class="fa fa-edit" aria-hidden="true"></i> 编辑文档</a>*/}}
  82. {{/*</template>*/}}
  83. </div>
  84. <div class="clearfix"></div>
  85. </div>
  86. <div class="desc-text">
  87. <template v-if="item.description === ''">
  88. &nbsp;
  89. </template>
  90. <template v-else="">
  91. <a :href="'{{.BaseUrl}}/book/' + item.identify + '/dashboard'" title="项目概要" style="font-size: 12px;">
  92. ${item.description}
  93. </a>
  94. </template>
  95. </div>
  96. <div class="info">
  97. <span title="创建时间" data-toggle="tooltip" data-placement="bottom"><i class="fa fa-clock-o"></i>
  98. ${(new Date(item.create_time)).format("yyyy-MM-dd hh:mm:ss")}
  99. </span>
  100. <span title="创建者" data-toggle="tooltip" data-placement="bottom"><i class="fa fa-user"></i> ${item.create_name}</span>
  101. <span title="文档数量" data-toggle="tooltip" data-placement="bottom"><i class="fa fa-pie-chart"></i> ${item.doc_count}</span>
  102. <span title="项目角色" data-toggle="tooltip" data-placement="bottom"><i class="fa fa-user-secret"></i> ${item.role_name}</span>
  103. <template v-if="item.last_modify_text !== ''">
  104. <span title="最后编辑" data-toggle="tooltip" data-placement="bottom"><i class="fa fa-pencil"></i> 最后编辑: ${item.last_modify_text}</span>
  105. </template>
  106. </div>
  107. </div>
  108. </template>
  109. </div>
  110. <template v-if="lists.length >= 0">
  111. <nav class="pagination-container">
  112. {{.PageHtml}}
  113. </nav>
  114. </template>
  115. </div>
  116. </div>
  117. </div>
  118. </div>
  119. {{template "widgets/footer.tpl" .}}
  120. </div>
  121. <!-- Modal -->
  122. <div class="modal fade" id="addBookDialogModal" tabindex="-1" role="dialog" aria-labelledby="addBookDialogModalLabel">
  123. <div class="modal-dialog modal-lg" role="document" style="min-width: 900px;">
  124. <form method="post" autocomplete="off" action="{{urlfor "BookController.Create"}}" id="addBookDialogForm" enctype="multipart/form-data">
  125. <div class="modal-content">
  126. <div class="modal-header">
  127. <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  128. <h4 class="modal-title" id="myModalLabel">添加项目</h4>
  129. </div>
  130. <div class="modal-body">
  131. <div class="form-group">
  132. <div class="pull-left" style="width: 620px">
  133. <div class="form-group required">
  134. <label class="text-label col-sm-2">项目空间</label>
  135. <div class="col-sm-10">
  136. <select class="js-data-example-ajax-add form-control" multiple="multiple" name="itemId" id="itemId">
  137. {{if .Item}}<option value="{{.Item.ItemId}}" selected>{{.Item.ItemName}}</option> {{end}}
  138. </select>
  139. </div>
  140. <div class="clearfix"></div>
  141. </div>
  142. <div class="form-group required">
  143. <label class="text-label col-sm-2">项目标题</label>
  144. <div class="col-sm-10">
  145. <input type="text" class="form-control" placeholder="标题(不超过100字)" name="book_name" id="bookName">
  146. </div>
  147. <div class="clearfix"></div>
  148. </div>
  149. <div class="form-group">
  150. <div class="pull-left" style="padding: 7px 5px 6px 0">
  151. {{urlfor "DocumentController.Index" ":key" ""}}
  152. </div>
  153. <input type="text" class="form-control pull-left" style="width: 410px;vertical-align: middle" placeholder="项目唯一标识(不超过50字)" name="identify" id="identify">
  154. <div class="clearfix"></div>
  155. <p class="text" style="font-size: 12px;color: #999;margin-top: 6px;">文档标识只能包含小写字母、数字,以及“-”、“.”和“_”符号.</p>
  156. </div>
  157. <div class="form-group">
  158. <textarea name="description" id="description" class="form-control" placeholder="描述信息不超过500个字符" style="height: 90px;"></textarea>
  159. </div>
  160. <div class="form-group">
  161. <div class="col-lg-6">
  162. <label>
  163. <input type="radio" name="privately_owned" value="0" checked> 公开<span class="text">(任何人都可以访问)</span>
  164. </label>
  165. </div>
  166. <div class="col-lg-6">
  167. <label>
  168. <input type="radio" name="privately_owned" value="1"> 私有<span class="text">(只要参与者或使用令牌才能访问)</span>
  169. </label>
  170. </div>
  171. <div class="clearfix"></div>
  172. </div>
  173. </div>
  174. <div class="pull-right text-center" style="width: 235px;">
  175. <canvas id="bookCover" height="230px" width="170px"><img src="{{cdnimg "/static/images/book.jpg"}}"> </canvas>
  176. </div>
  177. </div>
  178. <div class="clearfix"></div>
  179. </div>
  180. <div class="modal-footer">
  181. <span id="form-error-message"></span>
  182. <button type="button" class="btn btn-default" data-dismiss="modal">取消</button>
  183. <button type="button" class="btn btn-success" id="btnSaveDocument" data-loading-text="保存中...">保存</button>
  184. </div>
  185. </div>
  186. </form>
  187. </div>
  188. </div>
  189. <!--END Modal-->
  190. <!-- importBookDialogModal -->
  191. <div class="modal fade" id="importBookDialogModal" tabindex="-1" role="dialog" aria-labelledby="importBookDialogModalLabel">
  192. <div class="modal-dialog" role="document" style="min-width: 900px;">
  193. <form method="post" autocomplete="off" action="{{urlfor "BookController.Import"}}" id="importBookDialogForm" enctype="multipart/form-data">
  194. <div class="modal-content">
  195. <div class="modal-header">
  196. <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  197. <h4 class="modal-title">导入项目</h4>
  198. </div>
  199. <div class="modal-body">
  200. <div class="form-group">
  201. <div class="form-group required">
  202. <label class="text-label">项目空间</label>
  203. <select class="js-data-example-ajax-import form-control" multiple="multiple" name="itemId">
  204. {{if .Item}}<option value="{{.Item.ItemId}}" selected>{{.Item.ItemName}}</option> {{end}}
  205. </select>
  206. </div>
  207. <div class="form-group required">
  208. <label class="text-label">项目标题</label>
  209. <input type="text" class="form-control" placeholder="项目标题(不超过100字)" name="book_name" maxlength="100" value="">
  210. </div>
  211. <div class="form-group required">
  212. <label class="text-label">项目标识</label>
  213. <input type="text" class="form-control" placeholder="项目唯一标识(不超过50字)" name="identify" value="">
  214. <div class="clearfix"></div>
  215. <p class="text" style="font-size: 12px;color: #999;margin-top: 6px;">文档标识只能包含小写字母、数字,以及“-”、“.”和“_”符号.</p>
  216. </div>
  217. <div class="form-group">
  218. <label class="text-label">项目描述</label>
  219. <textarea name="description" id="description" class="form-control" placeholder="描述信息不超过500个字符" style="height: 90px;"></textarea>
  220. </div>
  221. <div class="form-group">
  222. <div class="col-lg-6">
  223. <label>
  224. <input type="radio" name="privately_owned" value="0" checked> 公开<span class="text">(任何人都可以访问)</span>
  225. </label>
  226. </div>
  227. <div class="col-lg-6">
  228. <label>
  229. <input type="radio" name="privately_owned" value="1"> 私有<span class="text">(只要参与者或使用令牌才能访问)</span>
  230. </label>
  231. </div>
  232. <div class="clearfix"></div>
  233. </div>
  234. <div class="form-group">
  235. <div class="file-loading">
  236. <input id="import-book-upload" name="import-file" type="file" accept=".zip">
  237. </div>
  238. <div id="kartik-file-errors"></div>
  239. </div>
  240. </div>
  241. <div class="clearfix"></div>
  242. </div>
  243. <div class="modal-footer">
  244. <span id="import-book-form-error-message" style="background-color: #ffffff;border: none;margin: 0;padding: 0;"></span>
  245. <button type="button" class="btn btn-default" data-dismiss="modal">取消</button>
  246. <button type="button" class="btn btn-success" id="btnImportBook" data-loading-text="创建中...">创建</button>
  247. </div>
  248. </div>
  249. </form>
  250. </div>
  251. </div>
  252. <!--END importBookDialogModal-->
  253. <!-- Delete Book Modal -->
  254. <div class="modal fade" id="deleteBookModal" tabindex="-1" role="dialog" aria-labelledby="deleteBookModalLabel">
  255. <div class="modal-dialog" role="document">
  256. <form method="post" id="deleteBookForm" action="{{urlfor "BookController.Delete"}}">
  257. <input type="hidden" name="identify" value="">
  258. <div class="modal-content">
  259. <div class="modal-header">
  260. <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  261. <h4 class="modal-title">删除项目</h4>
  262. </div>
  263. <div class="modal-body">
  264. <span style="font-size: 14px;font-weight: 400;">确定删除项目吗?</span>
  265. <p></p>
  266. <p class="text error-message">删除项目后将无法找回。</p>
  267. </div>
  268. <div class="modal-footer">
  269. <span id="form-error-message2" class="error-message"></span>
  270. <button type="button" class="btn btn-default" data-dismiss="modal">取消</button>
  271. <button type="submit" id="btnDeleteBook" class="btn btn-primary" data-loading-text="删除中...">确定删除</button>
  272. </div>
  273. </div>
  274. </form>
  275. </div>
  276. </div>
  277. <script src="{{cdnjs "/static/jquery/1.12.4/jquery.min.js"}}" type="text/javascript"></script>
  278. <script src="{{cdnjs "/static/bootstrap/js/bootstrap.min.js"}}" type="text/javascript"></script>
  279. <script src="{{cdnjs "/static/vuejs/vue.min.js"}}" type="text/javascript"></script>
  280. <script src="{{cdnjs "/static/js/jquery.form.js"}}" type="text/javascript"></script>
  281. <script src="{{cdnjs "/static/bootstrap/plugins/bootstrap-fileinput/4.4.7/js/fileinput.min.js"}}"></script>
  282. <script src="{{cdnjs "/static/bootstrap/plugins/bootstrap-fileinput/4.4.7/js/locales/zh.js"}}"></script>
  283. <script src="{{cdnjs "/static/layer/layer.js"}}" type="text/javascript" ></script>
  284. <script src="{{cdnjs "/static/select2/4.0.5/js/select2.full.min.js"}}"></script>
  285. <script src="{{cdnjs "/static/select2/4.0.5/js/i18n/zh-CN.js"}}"></script>
  286. <script src="{{cdnjs "/static/js/main.js"}}" type="text/javascript"></script>
  287. <script type="text/javascript">
  288. /**
  289. * 绘制项目封面
  290. * @param $id
  291. * @param $font
  292. */
  293. function drawBookCover($id,$font) {
  294. var draw = document.getElementById($id);
  295. //确认浏览器是否支持<canvas>元素
  296. if (draw.getContext) {
  297. var context = draw.getContext('2d');
  298. //绘制红色矩形,绿色描边
  299. context.fillStyle = '#eee';
  300. context.strokeStyle = '#d4d4d5';
  301. context.strokeRect(0,0,170,230);
  302. context.fillRect(0,0,170,230);
  303. //设置字体样式
  304. context.font = "600 20px Helvetica";
  305. context.textAlign = "left";
  306. //设置字体填充颜色
  307. context.fillStyle = "#3E403E";
  308. var font = $.trim($font);
  309. var lineWidth = 0; //当前行的绘制的宽度
  310. var lastTextIndex = 0; //已经绘制上canvas最后的一个字符的下标
  311. var drawWidth = 155,lineHeight = 25,drawStartX = 15,drawStartY=65;
  312. //由于改变canvas 的高度会导致绘制的纹理被清空,所以,不预先绘制,先放入到一个数组当中
  313. var arr = [];
  314. for(var i = 0; i<font.length; i++){
  315. //获取当前的截取的字符串的宽度
  316. lineWidth = context.measureText(font.substr(lastTextIndex,i-lastTextIndex)).width;
  317. if(lineWidth > drawWidth){
  318. //判断最后一位是否是标点符号
  319. if(judgePunctuationMarks(font[i-1])){
  320. arr.push(font.substr(lastTextIndex,i-lastTextIndex));
  321. lastTextIndex = i;
  322. }else{
  323. arr.push(font.substr(lastTextIndex,i-lastTextIndex-1));
  324. lastTextIndex = i-1;
  325. }
  326. }
  327. //将最后多余的一部分添加到数组
  328. if(i === font.length - 1){
  329. arr.push(font.substr(lastTextIndex,i-lastTextIndex+1));
  330. }
  331. }
  332. for(var i =0; i<arr.length; i++){
  333. context.fillText(arr[i],drawStartX,drawStartY+i*lineHeight);
  334. }
  335. //判断是否是需要避开的标签符号
  336. function judgePunctuationMarks(value) {
  337. var arr = [".",",",";","?","!",":","\"",",","。","?","!",";",":","、"];
  338. for(var i = 0; i< arr.length; i++){
  339. if(value === arr[i]){
  340. return true;
  341. }
  342. }
  343. return false;
  344. }
  345. }else{
  346. console.log("浏览器不支持")
  347. }
  348. }
  349. /**
  350. * 将base64格式的图片转换为二进制
  351. * @param dataURI
  352. * @returns {Blob}
  353. */
  354. function dataURItoBlob(dataURI) {
  355. var byteString = atob(dataURI.split(',')[1]);
  356. var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];
  357. var ab = new ArrayBuffer(byteString.length);
  358. var ia = new Uint8Array(ab);
  359. for (var i = 0; i < byteString.length; i++) {
  360. ia[i] = byteString.charCodeAt(i);
  361. }
  362. return new Blob([ab], {type: mimeString});
  363. }
  364. /**
  365. * 删除项目
  366. */
  367. function deleteBook($id) {
  368. $("#deleteBookModal").find("input[name='identify']").val($id);
  369. $("#deleteBookModal").modal("show");
  370. }
  371. /**
  372. * 复制项目
  373. * */
  374. function copyBook($id){
  375. var index = layer.load()
  376. $.ajax({
  377. url : "{{urlfor "BookController.Copy"}}" ,
  378. data : {"identify":$id},
  379. type : "POST",
  380. dataType : "json",
  381. success : function ($res) {
  382. layer.close(index);
  383. if ($res.errcode === 0) {
  384. window.app.lists.splice(0, 0, $res.data);
  385. $("#addBookDialogModal").modal("hide");
  386. } else {
  387. layer.msg($res.message);
  388. }
  389. },
  390. error : function () {
  391. layer.close(index);
  392. layer.msg('服务器异常');
  393. }
  394. });
  395. }
  396. $(function () {
  397. /**
  398. * 处理创建项目弹窗
  399. * */
  400. $("#addBookDialogModal").on("show.bs.modal",function () {
  401. window.bookDialogModal = $(this).find("#addBookDialogForm").html();
  402. drawBookCover("bookCover","默认封面");
  403. $('.js-data-example-ajax-add').select2({
  404. language: "zh-CN",
  405. minimumInputLength : 1,
  406. minimumResultsForSearch: Infinity,
  407. maximumSelectionLength:1,
  408. width : "100%",
  409. ajax: {
  410. url: '{{urlfor "BookController.ItemsetsSearch"}}',
  411. dataType: 'json',
  412. data: function (params) {
  413. return {
  414. q: params.term, // search term
  415. page: params.page
  416. };
  417. },
  418. processResults: function (data, params) {
  419. return {
  420. results : data.data.results
  421. }
  422. }
  423. }
  424. });
  425. }).on("hidden.bs.modal",function () {
  426. $(this).find("#addBookDialogForm").html(window.bookDialogModal);
  427. });
  428. /**
  429. * 处理导入项目弹窗
  430. * */
  431. $("#importBookDialogModal").on("show.bs.modal",function () {
  432. window.importBookDialogModal = $(this).find("#importBookDialogForm").html();
  433. $("#import-book-upload").fileinput({
  434. 'uploadUrl':"{{urlfor "BookController.Import"}}",
  435. 'theme': 'fa',
  436. 'showPreview': false,
  437. 'showUpload' : false,
  438. 'required': true,
  439. 'validateInitialCount': true,
  440. "language" : "zh",
  441. 'allowedFileExtensions': ['zip'],
  442. 'msgPlaceholder' : '请选择Zip文件',
  443. 'elErrorContainer' : "#import-book-form-error-message",
  444. 'uploadExtraData' : function () {
  445. var book = {};
  446. var $then = $("#importBookDialogForm");
  447. book.book_name = $then.find("input[name='book_name']").val();
  448. book.identify = $then.find("input[name='identify']").val();
  449. book.description = $then.find('textarea[name="description"]').val()
  450. return book;
  451. }
  452. });
  453. $('.js-data-example-ajax-import').select2({
  454. language: "zh-CN",
  455. minimumInputLength : 1,
  456. minimumResultsForSearch: Infinity,
  457. maximumSelectionLength:1,
  458. width : "100%",
  459. ajax: {
  460. url: '{{urlfor "BookController.ItemsetsSearch"}}',
  461. dataType: 'json',
  462. data: function (params) {
  463. return {
  464. q: params.term, // search term
  465. page: params.page
  466. };
  467. },
  468. processResults: function (data, params) {
  469. return {
  470. results : data.data.results
  471. }
  472. }
  473. }
  474. });
  475. }).on("hidden.bs.modal",function () {
  476. $(this).find("#importBookDialogForm").html(window.importBookDialogModal);
  477. });
  478. /**
  479. * 创建项目
  480. */
  481. $("body").on("click","#btnSaveDocument",function () {
  482. var $this = $(this);
  483. var itemId = $("#itemId").val();
  484. if (itemId <= 0) {
  485. return showError("请选择项目空间")
  486. }
  487. var bookName = $.trim($("#bookName").val());
  488. if (bookName === "") {
  489. return showError("项目标题不能为空")
  490. }
  491. if (bookName.length > 100) {
  492. return showError("项目标题必须小于100字符");
  493. }
  494. var identify = $.trim($("#identify").val());
  495. if (identify === "") {
  496. return showError("项目标识不能为空");
  497. }
  498. if (identify.length > 50) {
  499. return showError("项目标识必须小于50字符");
  500. }
  501. var description = $.trim($("#description").val());
  502. if (description.length > 500) {
  503. return showError("描述信息不超过500个字符");
  504. }
  505. $this.button("loading");
  506. var draw = document.getElementById("bookCover");
  507. var form = document.getElementById("addBookDialogForm");
  508. var fd = new FormData(form);
  509. if (draw.getContext) {
  510. var dataURL = draw.toDataURL("png", 100);
  511. var blob = dataURItoBlob(dataURL);
  512. fd.append('image-file', blob,(new Date()).valueOf() + ".png");
  513. }
  514. $.ajax({
  515. url : "{{urlfor "BookController.Create"}}",
  516. data: fd,
  517. type: "POST",
  518. dataType :"json",
  519. processData: false,
  520. contentType: false
  521. }).success(function (res) {
  522. $this.button("reset");
  523. if (res.errcode === 0) {
  524. window.app.lists.splice(0, 0, res.data);
  525. $("#addBookDialogModal").modal("hide");
  526. } else {
  527. showError(res.message);
  528. }
  529. $this.button("reset");
  530. }).error(function () {
  531. $this.button("reset");
  532. return showError("服务器异常");
  533. });
  534. return false;
  535. }).on("blur","#bookName",function () {
  536. var txt = $("#bookName").val();
  537. if(txt !== ""){
  538. drawBookCover("bookCover",txt);
  539. }
  540. }).on("click","#btnImportBook",function () {
  541. console.log("aa");
  542. var $then = $(this).parents("#importBookDialogForm");
  543. var itemId = $then.find("input[name='itemId']").val();
  544. if (itemId <= 0) {
  545. return showError("请选择项目空间")
  546. }
  547. var bookName = $.trim($then.find("input[name='book_name']").val());
  548. if (bookName === "") {
  549. return showError("项目标题不能为空","#import-book-form-error-message");
  550. }
  551. if (bookName.length > 100) {
  552. return showError("项目标题必须小于100字符","#import-book-form-error-message");
  553. }
  554. var identify = $.trim($then.find("input[name='identify']").val());
  555. if (identify === "") {
  556. return showError("项目标识不能为空","#import-book-form-error-message");
  557. }
  558. var description = $.trim($then.find('textarea[name="description"]').val());
  559. if (description.length > 500) {
  560. return showError("描述信息不超过500个字符","#import-book-form-error-message");
  561. }
  562. var filesCount = $('#import-book-upload').fileinput('getFilesCount');
  563. console.log(filesCount)
  564. if (filesCount <= 0) {
  565. return showError("请选择需要上传的文件","#import-book-form-error-message");
  566. }
  567. //$("#importBookDialogForm").submit();
  568. $("#btnImportBook").button("loading");
  569. $('#import-book-upload').fileinput('upload');
  570. }).on("fileuploaded","#import-book-upload",function (event, data, previewId, index){
  571. if(data.response.errcode === 0 || data.response.errcode === '0'){
  572. showSuccess(data.response.message,"#import-book-form-error-message");
  573. }else{
  574. showError(data.response.message,"#import-book-form-error-message");
  575. }
  576. $("#btnImportBook").button("reset");
  577. return true;
  578. });
  579. /**
  580. * 删除项目
  581. */
  582. $("#deleteBookForm").ajaxForm({
  583. beforeSubmit : function () {
  584. $("#btnDeleteBook").button("loading");
  585. },
  586. success : function (res) {
  587. if(res.errcode === 0){
  588. window.location = window.location.href;
  589. }else{
  590. showError(res.message,"#form-error-message2");
  591. }
  592. $("#btnDeleteBook").button("reset");
  593. },
  594. error : function () {
  595. showError("服务器异常","#form-error-message2");
  596. $("#btnDeleteBook").button("reset");
  597. }
  598. });
  599. window.app = new Vue({
  600. el : "#bookList",
  601. data : {
  602. lists : {{.Result}}
  603. },
  604. delimiters : ['${','}'],
  605. methods : {
  606. }
  607. });
  608. Vue.nextTick(function () {
  609. $("[data-toggle='tooltip']").tooltip();
  610. });
  611. });
  612. </script>
  613. </body>
  614. </html>