form.html 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. {extend name="../../admin/view/main"}
  2. {block name="style"}
  3. <style>
  4. .keys-container .layui-card {
  5. width: 580px;
  6. height: 578px;
  7. position: absolute;
  8. border: 1px solid #ccc
  9. }
  10. .keys-container .layui-card .layui-card-body {
  11. height: 495px;
  12. padding-right: 50px
  13. }
  14. .keys-container .layui-card .layui-card-body [data-tips-image] {
  15. width: 112px;
  16. height: auto
  17. }
  18. .keys-container .layui-card .layui-card-body .layui-form-label {
  19. width: 60px;
  20. color: #6c6c6c;
  21. font-weight: 700;
  22. }
  23. .keys-container .layui-card .layui-card-body .layui-form-label + .layui-input-block {
  24. margin-left: 100px;
  25. }
  26. </style>
  27. {/block}
  28. {block name="content"}
  29. <div class="nowrap think-box-shadow" style="width:910px">
  30. <div class='mobile-preview inline-block'>
  31. <div class='mobile-header'>公众号</div>
  32. <div class='mobile-body' data-iframe-box></div>
  33. </div>
  34. <div class="keys-container inline-block absolute margin-left-10 margin-right-15">
  35. <form class="layui-form" onsubmit="return false" autocomplete="off" data-auto="true" action="{:request()->url()}" method="post">
  36. <div class="layui-card relative">
  37. <div class="layui-card-header layui-bg-gray text-center">编辑关键字</div>
  38. <div class="layui-card-body">
  39. <div class="layui-form-item margin-top-10">
  40. <label class="layui-form-label">延迟时间</label>
  41. <div class="layui-input-block">
  42. <input required readonly placeholder='请输入延迟时间' maxlength='20' id="timeInput" name='time' class="layui-input" value='{$vo.time|default="00小时00分00秒"}'>
  43. <script>layui.laydate.render({elem: '#timeInput', type: "time", format: 'HH小时mm分ss秒', btns: ['confirm']});</script>
  44. </div>
  45. </div>
  46. <div class="layui-form-item">
  47. <label class="layui-form-label label-required">规则状态</label>
  48. <div class="layui-input-block">
  49. {foreach ['1'=>'启用','0'=>'禁用'] as $k=>$v}
  50. <label class="think-radio">
  51. <!--{if (!isset($vo.status) and $k eq '1') or (isset($vo.status) and $vo.status eq $k)}-->
  52. <input type="radio" checked name="status" value="{$k}"> {$v}
  53. <!--{else}-->
  54. <input type="radio" name="status" value="{$k}"> {$v}
  55. <!--{/if}-->
  56. </label>
  57. {/foreach}
  58. </div>
  59. </div>
  60. <div class="layui-form-item">
  61. <label class="layui-form-label label-required">消息类型</label>
  62. <div class="layui-input-block">
  63. {foreach $types as $k=>$v}
  64. <label class="think-radio">
  65. <!--{if (!isset($vo.type) and $k eq 'text') or (isset($vo.type) and$vo.type eq $k)}-->
  66. <input name="type" checked type="radio" value="{$k}"> {$v}
  67. <!--{else}-->
  68. <input name="type" type="radio" value="{$k}"> {$v}
  69. <!--{/if}-->
  70. </label>
  71. {/foreach}
  72. </div>
  73. </div>
  74. <div class="layui-form-item" data-keys-type='text'>
  75. <label class="layui-form-label">回复文字</label>
  76. <div class="layui-input-block">
  77. <textarea name="content" required placeholder="请输入回复文字" maxlength="10000" class="layui-textarea">{$vo.content|raw|default='说点什么吧'}</textarea>
  78. </div>
  79. </div>
  80. <div class="layui-form-item" data-keys-type='news'>
  81. <label class="layui-form-label label-required">选取图文</label>
  82. <div class="layui-input-block">
  83. <input type="hidden" name="news_id" value="{$vo.news_id|default=0}">
  84. <a class="layui-btn layui-btn-sm layui-btn-primary" data-title="选择图文" data-iframe="{:url('wechat/news/select')}?field={:encode('news_id')}">选择图文</a>
  85. </div>
  86. </div>
  87. <div class="layui-form-item" data-keys-type='image'>
  88. <label class="layui-form-label label-required">图片地址</label>
  89. <div class="layui-input-block">
  90. <input class="layui-input padding-right-30" onchange="$(this).nextAll('img').attr('src', this.value)" value="{$vo.image_url|default=$defaultImage}" name="image_url" required placeholder="请上传图片或输入图片URL地址  ">
  91. <a data-file="btn" data-type="bmp,png,jpeg,jpg,gif" data-field="image_url" class="input-right-icon"><i class="layui-icon layui-icon-upload"></i></a>
  92. <p class="help-block">文件最大2Mb,支持bmp/png/jpeg/jpg/gif格式</p>
  93. <img data-tips-image src='{$vo.image_url|default=$defaultImage}' alt="img">
  94. </div>
  95. </div>
  96. <div class="layui-form-item" data-keys-type='voice'>
  97. <label class="layui-form-label">上传语音</label>
  98. <div class="layui-input-block">
  99. <input class='layui-input padding-right-30' value="{$vo.voice_url|default=''}" name="voice_url" required title="请上传语音文件或输入语音URL地址  ">
  100. <a data-file="btn" data-type="mp3,wma,wav,amr" data-field="voice_url" class="input-right-icon"><i class="layui-icon layui-icon-upload"></i></a>
  101. <p class="help-block">文件最大2Mb,播放长度不超过60s,mp3/wma/wav/amr格式</p>
  102. </div>
  103. </div>
  104. <div class="layui-form-item" data-keys-type='music'>
  105. <label class="layui-form-label">音乐标题</label>
  106. <div class="layui-input-block">
  107. <input class='layui-input' value="{$vo.music_title|default='音乐标题'}" name="music_title" required title="请输入音乐标题">
  108. </div>
  109. </div>
  110. <div class="layui-form-item" data-keys-type='music'>
  111. <label class="layui-form-label label-required">上传音乐</label>
  112. <div class="layui-input-block">
  113. <input class='layui-input padding-right-30' value="{$vo.music_url|default=''}" name="music_url" required title="请上传音乐文件或输入音乐URL地址  ">
  114. <a data-file="btn" data-type="mp3,wma,wav,amr" data-field="music_url" class="input-right-icon"><i class="layui-icon layui-icon-upload"></i></a>
  115. </div>
  116. </div>
  117. <div class="layui-form-item" data-keys-type='music'>
  118. <label class="layui-form-label">音乐描述</label>
  119. <div class="layui-input-block">
  120. <input name="music_desc" class="layui-input" value="{$vo.music_desc|default='音乐描述'|raw}">
  121. </div>
  122. </div>
  123. <div class="layui-form-item" data-keys-type='music'>
  124. <label class="layui-form-label">音乐图片</label>
  125. <div class="layui-input-block">
  126. <input class="layui-input padding-right-30" value="{$vo.music_image|default=$defaultImage}" name="music_image" required title="请上传音乐图片或输入音乐图片URL地址  ">
  127. <a data-file="btn" data-type="jpg,png" data-field="music_image" class="input-right-icon"><i class="layui-icon layui-icon-upload"></i></a>
  128. <p class="help-block">文件最大64KB,只支持JPG格式</p>
  129. </div>
  130. </div>
  131. <div class="layui-form-item" data-keys-type='video'>
  132. <label class="layui-form-label">视频标题</label>
  133. <div class="layui-input-block">
  134. <input class='layui-input' value="{$vo.video_title|default='视频标题'}" name="video_title" required placeholder="请输入视频标题">
  135. </div>
  136. </div>
  137. <div class="layui-form-item" data-keys-type='video'>
  138. <label class="layui-form-label">上传视频</label>
  139. <div class="layui-input-block">
  140. <input class='layui-input padding-right-30' value="{$vo.video_url|default=''}" name="video_url" required title="请上传视频或输入音乐视频URL地址  ">
  141. <a data-file="btn" data-type="mp4" data-field="video_url" class="input-right-icon"><i class="layui-icon layui-icon-upload"></i></a>
  142. <p class="help-block">文件最大10MB,只支持MP4格式</p>
  143. </div>
  144. </div>
  145. <div class="layui-form-item" data-keys-type='video'>
  146. <label class="layui-form-label">视频描述</label>
  147. <div class="layui-input-block">
  148. <input value="{$vo.video_desc|default='视频描述'}" name="video_desc" maxlength="50" class="layui-input">
  149. </div>
  150. </div>
  151. <div class="text-center padding-bottom-10 absolute full-width" style="bottom:0;margin-left:-15px">
  152. <div class="hr-line-dashed margin-top-10 margin-bottom-10"></div>
  153. {if isset($vo['id'])}<input type='hidden' value='{$vo.id}' name='id'>{/if}
  154. {if isset($vo['code'])}<input type='hidden' value='{$vo.code}' name='code'>{/if}
  155. <button class="layui-btn menu-submit">保存数据</button>
  156. <button data-history-back class="layui-btn layui-btn-danger" type='button'>取消编辑</button>
  157. </div>
  158. </div>
  159. </div>
  160. </form>
  161. </div>
  162. </div>
  163. {/block}
  164. {block name="script"}
  165. <script>
  166. (function ($body) {
  167. /*! 刷新预览显示 */
  168. function showReview(params, location) {
  169. if (params['type'] === 'news') {
  170. location = '{:url("@wechat/api.view/news")}?id=_id_'.replace('_id_', params.content);
  171. } else {
  172. location = '{:url("@wechat/api.view/_type_")}?'.replace('_type_', params.type) + $.param(params || {});
  173. }
  174. var iframe = '<iframe id="phone-preview" frameborder="0" marginheight="0" marginwidth="0"></iframe>';
  175. $('[data-iframe-box]').empty().append($(iframe).attr('src', location));
  176. }
  177. $body.off('change', '[name="news_id"]').on('change', '[name="news_id"]', function () {
  178. /*! 图文显示预览 */
  179. showReview({type: 'news', content: this.value});
  180. }).off('change', '[name="content"]').on('change', '[name="content"]', function () {
  181. /*! 文字显示预览 */
  182. showReview({type: 'text', content: this.value});
  183. }).off('change', '[name="image_url"]').on('change', '[name="image_url"]', function () {
  184. /*! 图片显示预览 */
  185. showReview({type: 'image', content: this.value});
  186. }).off('change', '[name="voice_url"]').on('change', '[name="voice_url"]', function () {
  187. /*! 语音显示预览 */
  188. showReview({type: 'voice', content: this.value});
  189. });
  190. /*! 音乐显示预览 */
  191. var musicSelector = '[name="music_url"],[name="music_title"],[name="music_desc"],[name="music_image"]';
  192. $body.off('change', musicSelector).on('change', musicSelector, function () {
  193. var params = {type: 'music'}, $parent = $(this).parents('form');
  194. params.url = $parent.find('[name="music_url"]').val();
  195. params.desc = $parent.find('[name="music_desc"]').val();
  196. params.title = $parent.find('[name="music_title"]').val();
  197. params.image = $parent.find('[name="music_image"]').val();
  198. showReview(params);
  199. });
  200. /*! 视频显示预览 */
  201. var videoSelector = '[name="video_title"],[name="video_url"],[name="video_desc"]';
  202. $body.off('change', videoSelector).on('change', videoSelector, function () {
  203. var params = {type: 'video'}, $parent = $(this).parents('form');
  204. params.url = $parent.find('[name="video_url"]').val();
  205. params.desc = $parent.find('[name="video_desc"]').val();
  206. params.title = $parent.find('[name="video_title"]').val();
  207. showReview(params);
  208. });
  209. /*! 默认类型事件 */
  210. $body.off('click', 'input[name=type]').on('click', 'input[name=type]', function () {
  211. var value = $(this).val(), $form = $(this).parents('form');
  212. if (value === 'customservice') value = 'text';
  213. var $current = $form.find('[data-keys-type="' + value + '"]').removeClass('layui-hide');
  214. $form.find('[data-keys-type]').not($current).addClass('layui-hide');
  215. switch (value) {
  216. case 'news':
  217. return $('[name="news_id"]').trigger('change');
  218. case 'text':
  219. case 'customservice':
  220. return $('[name="content"]').trigger('change');
  221. case 'image':
  222. return $('[name="image_url"]').trigger('change');
  223. case 'video':
  224. return $('[name="video_url"]').trigger('change');
  225. case 'music':
  226. return $('[name="music_url"]').trigger('change');
  227. case 'voice':
  228. return $('[name="voice_url"]').trigger('change');
  229. }
  230. });
  231. /*! 默认事件触发 */
  232. $('input[name=type]:checked').map(function () {
  233. $(this).trigger('click');
  234. });
  235. })($('body'));
  236. </script>
  237. {/block}