comment.html 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. {extend name="../../base/view/common/base" /}
  2. {block name="style"}
  3. <style>
  4. .layui-unselect dl {max-height:188px;}
  5. </style>
  6. {/block}
  7. <!-- 主体 -->
  8. {block name="body"}
  9. <div class="p-page">
  10. <form class="layui-form gg-form-bar border-x border-t" lay-filter="barsearchform">
  11. <div class="layui-input-inline" style="width:100px;">
  12. <input type="text" name="username" placeholder="请选择评论人" class="layui-input picker-admin" readonly />
  13. <input type="text" name="uid" value="" style="display:none" />
  14. </div>
  15. <div class="layui-input-inline" style="width:300px;">
  16. <input type="text" name="keywords" placeholder="关键字,输入评论内容" class="layui-input"/>
  17. </div>
  18. <div class="layui-input-inline" style="width:150px;">
  19. <button class="layui-btn layui-btn-normal" lay-submit="" lay-filter="table-search"><i class="layui-icon layui-icon-search mr-1"></i>搜索</button>
  20. <button type="reset" class="layui-btn layui-btn-reset" lay-filter="table-reset">清空</button>
  21. </div>
  22. </form>
  23. <div>
  24. <table class="layui-hide" id="test" lay-filter="test"></table>
  25. </div>
  26. </div>
  27. <script type="text/html" id="toolbarDemo">
  28. <h3>任务评论</h3>
  29. </script>
  30. {/block}
  31. <!-- /主体 -->
  32. <!-- 脚本 -->
  33. {block name="script"}
  34. <script>
  35. const moduleInit = ['tool','tablePlus','oaPicker'];
  36. function gouguInit() {
  37. var form = layui.form,table = layui.tablePlus,tool=layui.tool, work = layui.oaSchedule;
  38. layui.commentTable = table.render({
  39. elem: '#test'
  40. ,toolbar: '#toolbarDemo'
  41. ,title:'评论列表'
  42. ,url: "/project/task/comment"
  43. ,cellMinWidth: 80
  44. ,is_excel:true
  45. ,height: 'full-110'
  46. ,cols: [[ //表头
  47. {field: 'id', title: '序号',fixed: 'left', width:80, align:'center'}
  48. ,{field: 'content', title: '评论内容'}
  49. ,{field: 'project', title: '关联项目&任务', width:300,templet:function(d){
  50. var html='';
  51. if(d.labor_type==0){
  52. html='<span class="layui-color-'+d.labor_type+'">-</span>';
  53. }
  54. else if(d.module =='project'){
  55. html='<span class="green">『项目』</span><a data-href="/project/index/view/id/'+d.topic_id+'.html" class="side-a">'+d.topic_name+'</a>';
  56. }
  57. else{
  58. html='<span class="blue">『任务』</span><a data-href="/project/task/view/id/'+d.topic_id+'.html" class="side-a">'+d.topic_name+'</a>';
  59. }
  60. return html;
  61. }}
  62. ,{field: 'to_names', title: '@关联人', width:160}
  63. ,{field: 'admin_name', title: '评论人', align:'center',width:80}
  64. ,{field: 'create_time', title: '评论时间', align:'center',width:150}
  65. ,{field: 'right', title: '操作',fixed:'right', width:90, align:'center',templet:function(d){
  66. if(d.read==0){
  67. return '<button class="layui-btn layui-btn-xs layui-btn-normal" lay-event="read">设为已读</button>';
  68. }
  69. else if(d.read==2){
  70. return '<button class="layui-btn layui-btn-xs layui-btn-danger" lay-event="del">删除</button>';
  71. }
  72. else{
  73. return '-';
  74. }
  75. }}
  76. ]]
  77. });
  78. table.on('tool(test)', function(obj){
  79. var data = obj.data;
  80. if (obj.event === 'read') {
  81. let callback = function (e) {
  82. layer.msg(e.msg);
  83. if (e.code == 0) {
  84. layui.commentTable.reload();
  85. }
  86. }
  87. tool.post("/project/api/read_comment", { id: data.id }, callback);
  88. }
  89. if (obj.event === 'del') {
  90. layer.confirm('确定要删除该评论吗?', { icon: 3, title: '提示' }, function (index) {
  91. let callback = function (e) {
  92. layer.msg(e.msg);
  93. if (e.code == 0) {
  94. obj.del();
  95. }
  96. }
  97. tool.delete("/project/api/delete_comment", { id: data.id }, callback);
  98. layer.close(index);
  99. });
  100. return;
  101. }
  102. return;
  103. });
  104. }
  105. </script>
  106. {/block}
  107. <!-- /脚本 -->