contract.html 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>添加</title>
  6. <meta name="viewport"
  7. content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
  8. <link href="../../css/mui.min.css" rel="stylesheet" />
  9. <link rel="stylesheet" href="../../css/animate.min.css" />
  10. <style>
  11. .mui-bar-nav~.mui-content{padding-top: 54px;}
  12. .bg{padding: 15px;text-align: center;}
  13. input{height: 45px!important;font-size: 14px;}
  14. textarea{font-size: 14px;}
  15. .m_box {padding: 10px 10px 25px 15px;box-shadow: 0 1px 6px #dbdbdb;}
  16. .btn{width: 230px;margin-top: -21px;}
  17. .img_list{font-size: 13px;color: darkgray;}
  18. .row .sm3{padding: 5px;width: 33.33%;}
  19. .img{width: 60px;border-radius: 3px;border: 1px solid darkgray;margin-bottom: 5px;}
  20. .img.active{border: 1px solid green;}
  21. .ht{text-align: left;padding-left: 20px;margin-top: -20px;padding-bottom: 10px;font-size: 14px;}
  22. .row label{float: left;padding-bottom: 7px;font-size: 15px;}
  23. .sa.active{color: green;}
  24. .mb6{margin-bottom: -6px!important;}
  25. </style>
  26. </head>
  27. <body>
  28. <div id="app">
  29. <header class="mui-bar mui-bar-nav">
  30. <a class="mui-action-back mui-icon mui-icon-left-nav mui-pull-left"></a>
  31. <h1 class="mui-title">发送合同</h1>
  32. </header>
  33. <div class="mui-content animated fadeInUp" style="margin-top: 10px;">
  34. <div class="bg">
  35. <div class="m_box">
  36. <div class="input-group">
  37. 合同接收人: {{items.nickName}}
  38. </div>
  39. <div class="row mb6">
  40. <label>合同名称</label>
  41. <input type="tel" v-model="item.contract_content" placeholder="输入合同名称">
  42. <div class="clear"></div>
  43. </div>
  44. <div class="row mb6" style="margin-top: -10px;">
  45. <label>合同金额</label>
  46. <input type="tel" v-model="item.contract_amount" placeholder="输入合同金额">
  47. <div class="clear"></div>
  48. </div>
  49. <div class="row mb6">
  50. <label>附加条款</label>
  51. <textarea rows="3" v-model="item.remark" placeholder="附加条款"> </textarea>
  52. <div class="clear"></div>
  53. </div>
  54. <div class="row">
  55. <label>请选择合同模板</label>
  56. <div class="clear"></div>
  57. </div>
  58. <div class="img_list">
  59. <div class="row">
  60. <div class="sm3" v-for="(item,index) in contract_list" @click="select(item,index)">
  61. <img :src="item.contract_url" class="img" :class="{active:curr==index}" @click.stop="view(item.contract_url)" />
  62. <div class="sa" :class="{active:curr==index}">{{item.title}}</div>
  63. </div>
  64. <div class="clear"></div>
  65. </div>
  66. </div>
  67. </div>
  68. <button class="btn" @click="ok()">确认发送</button>
  69. </div>
  70. </div>
  71. </div>
  72. <script src="../../js/mui.min.js"></script>
  73. <script src="../../js/app.js"></script>
  74. <script src="../../js/vue.min.js"></script>
  75. <script>
  76. var vm = new Vue({
  77. el: "#app",
  78. data: {
  79. contract_list: [],
  80. curr: 0,
  81. item: {
  82. client: getUser().id,
  83. templete_id: ''
  84. },
  85. items: {},
  86. },
  87. mounted: function() {
  88. mui.plusReady(function() {
  89. console.log("res===" + JSON.stringify(plus.webview.currentWebview().param));
  90. if (plus.webview.currentWebview().param != null) {
  91. vm.items = plus.webview.currentWebview().param;
  92. vm.item.trustee = plus.webview.currentWebview().param.userId;
  93. vm.item.parttime_id = plus.webview.currentWebview().param.parttime_id;
  94. //vm.item.client_status = 1; //发送表示委托人同意
  95. //获取合同列表
  96. request(urls().contract_templete_list, {}, function(res) {
  97. vm.contract_list = res.data;
  98. setTimeout(() => {
  99. plus.nativeUI.closeWaiting();
  100. }, 500)
  101. })
  102. }
  103. })
  104. },
  105. methods: {
  106. //编辑
  107. ok: function() {
  108. if (vm.item.templete_id == '') {
  109. mui.alert('请选择合同模板');
  110. return;
  111. }
  112. this.item.status=0;
  113. this.item.client_status = 0;
  114. this.item.trustee_status= 0;
  115. request(urls().send_contract, this.item, function(res) {
  116. if (res.result == true) {
  117. mui.toast("操作成功");
  118. plus.webview.getWebviewById("detail").reload(true);
  119. } else {
  120. mui.toast(res.msg);
  121. }
  122. plsetTimeout(() => {
  123. plus.nativeUI.closeWaiting();
  124. }, 500) })
  125. },
  126. //选择合同模板
  127. select: function(item, index) {
  128. this.curr = index;
  129. this.item.templete_id=item.id;
  130. },
  131. view: function(img) {
  132. plus.nativeUI.previewImage([img], {
  133. current: 0,
  134. loop: true,
  135. indicator: 'number'
  136. });
  137. }
  138. }
  139. })
  140. </script>
  141. </body>
  142. </html>