create.php 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. {extend name="public/container"}
  2. {block name='head_top'}
  3. <style>
  4. .layui-form-item .special-label {
  5. width: 50px;
  6. float: left;
  7. height: 30px;
  8. line-height: 38px;
  9. margin-left: 10px;
  10. margin-top: 5px;
  11. border-radius: 5px;
  12. background-color: #0092DC;
  13. text-align: center;
  14. }
  15. .layui-form-item .special-label i {
  16. display: inline-block;
  17. width: 18px;
  18. height: 18px;
  19. font-size: 18px;
  20. color: #fff;
  21. }
  22. .layui-form-item .label-box {
  23. border: 1px solid;
  24. border-radius: 10px;
  25. position: relative;
  26. padding: 10px;
  27. height: 30px;
  28. color: #fff;
  29. background-color: #393D49;
  30. text-align: center;
  31. cursor: pointer;
  32. display: inline-block;
  33. line-height: 10px;
  34. }
  35. .layui-form-item .label-box p {
  36. line-height: inherit;
  37. }
  38. .edui-default .edui-for-image .edui-icon {
  39. background-position: -380px 0px;
  40. }
  41. .layui-tab-title .layui-this:after {
  42. border-bottom-color: #fff !important;
  43. }
  44. </style>
  45. <script type="text/javascript" charset="utf-8" src="{__ADMIN_PATH}plug/ueditor/third-party/zeroclipboard/ZeroClipboard.js"></script>
  46. <script type="text/javascript" charset="utf-8" src="{__ADMIN_PATH}plug/ueditor/ueditor.config.js"></script>
  47. <script type="text/javascript" charset="utf-8" src="{__ADMIN_PATH}plug/ueditor/ueditor.all.min.js"></script>
  48. {/block}
  49. {block name="content"}
  50. <div class="layui-fluid">
  51. <div class="layui-card" id="app" v-cloak>
  52. <div class="layui-card-header">添加消息</div>
  53. <div class="layui-card-body">
  54. <form action="" class="layui-form">
  55. <div class="layui-form-item">
  56. <div class="layui-form-item submit">
  57. <label class="layui-form-label">消息名称:</label>
  58. <div class="layui-input-block">
  59. <input type="text" name="name" style="width: 600px" v-model.trim="formData.name" autocomplete="off" placeholder="请输入消息名称" maxlength="20" class="layui-input">
  60. </div>
  61. </div>
  62. <div class="layui-form-item submit">
  63. <label class="layui-form-label">模版常数:</label>
  64. <div class="layui-input-block">
  65. <input type="text" name="template_const" style="width: 600px" v-model.trim="formData.template_const" autocomplete="off" placeholder="请输入模版常数" class="layui-input">
  66. </div>
  67. </div>
  68. <div class="layui-form-item submit">
  69. <label class="layui-form-label">模板编号:</label>
  70. <div class="layui-input-block">
  71. <input type="text" name="tempkey" style="width: 600px" v-model.trim="formData.tempkey" autocomplete="off" placeholder="请输入模板编号" class="layui-input">
  72. </div>
  73. </div>
  74. <div class="layui-form-item submit">
  75. <label class="layui-form-label">短信模板ID:</label>
  76. <div class="layui-input-block">
  77. <input type="text" name="temp_id" style="width: 600px" v-model.trim="formData.temp_id" autocomplete="off" placeholder="请输入短信模板ID" class="layui-input">
  78. </div>
  79. </div>
  80. <div class="layui-form-item" style="margin-top: 10px;">
  81. <label class="layui-form-label">短信内容:</label>
  82. <div class="layui-input-block">
  83. <textarea placeholder="请输入短信内容" v-model="formData.sms_content" style="width: 600px" class="layui-textarea"></textarea>
  84. </div>
  85. </div>
  86. <div class="layui-form-item">
  87. <label class="layui-form-label">公众号模板:</label>
  88. <div class="layui-input-block">
  89. <input type="radio" name="is_wechat" value="1" title="显示" v-model="formData.is_wechat" lay-filter="is_wechat" >
  90. <input type="radio" name="is_wechat" value="0" title="隐藏" v-model="formData.is_wechat" lay-filter="is_wechat">
  91. </div>
  92. </div>
  93. <div class="layui-form-item">
  94. <label class="layui-form-label">发送短信:</label>
  95. <div class="layui-input-block">
  96. <input type="radio" name="is_sms" value="1" title="显示" v-model="formData.is_sms" lay-filter="is_sms" >
  97. <input type="radio" name="is_sms" value="0" title="隐藏" v-model="formData.is_sms" lay-filter="is_sms">
  98. </div>
  99. </div>
  100. <div class="layui-form-item submit">
  101. <div class="layui-input-block">
  102. <button class="layui-btn layui-btn-normal" type="button" @click="save">立即提交</button>
  103. <button class="layui-btn layui-btn-primary clone" type="button" @click="clone_form">取消</button>
  104. </div>
  105. </div>
  106. </form>
  107. </div>
  108. </div>
  109. </div>
  110. <script type="text/javascript" src="{__ADMIN_PATH}js/layuiList.js"></script>
  111. {/block}
  112. {block name='script'}
  113. <script>
  114. require(['vue','helper','zh-cn','request','plupload'],function(Vue,$h) {
  115. new Vue({
  116. el: "#app",
  117. data: {
  118. formData:{
  119. name:'',
  120. template_const:'',
  121. tempkey: '',
  122. temp_id: '',
  123. sms_content: '',
  124. is_wechat: 1,
  125. is_sms: 1
  126. }
  127. },
  128. methods:{
  129. clone_form: function () {
  130. var that = this;
  131. var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  132. parent.layer.close(index); //再执行关闭
  133. },
  134. save:function () {
  135. var that=this;
  136. if (!that.formData.name) return layList.msg('请输入消息名称');
  137. if (!that.formData.template_const) return layList.msg('请输入模版常数');
  138. if (!that.formData.tempkey) return layList.msg('请输入模板编号');
  139. layList.loadFFF();
  140. layList.basePost(layList.U({a: 'save_message'}), that.formData, function (res) {
  141. layList.loadClear();
  142. layList.layer.confirm('添加成功,您要继续消息管理吗?', {
  143. btn: ['继续添加', '立即提交'] //按钮
  144. }, function (index) {
  145. layList.layer.close(index);
  146. }, function () {
  147. parent.layer.closeAll();
  148. });
  149. }, function (res) {
  150. layList.msg(res.msg);
  151. layList.loadClear();
  152. });
  153. }
  154. },
  155. mounted:function () {
  156. var that=this;
  157. that.$nextTick(function () {
  158. layList.form.render();
  159. layList.form.on('radio(is_wechat)',function (data) {
  160. that.formData.is_wechat=data.value;
  161. });
  162. layList.form.on('radio(is_sms)',function (data) {
  163. that.formData.is_sms=data.value;
  164. });
  165. });
  166. }
  167. })
  168. })
  169. </script>
  170. {/block}