cityprice.js 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. layui.use([ 'laypage', 'layer', 'table', 'element','form','upload'], function(){
  2. var laypage = layui.laypage //分页
  3. ,$ = layui.jquery
  4. ,layer = layui.layer //弹层
  5. ,table = layui.table //表格
  6. ,element = layui.element //元素操作
  7. ,form = layui.form
  8. ,upload = layui.upload;
  9. var type_id = $('input[name="type"]').val();
  10. var tableIds = 'videolist'; //表格ID
  11. //第一个实例
  12. table.render({
  13. elem: '#'+tableIds
  14. ,url: '/pushcityprice/priceform' //数据接口
  15. ,where:{token:csrfToken,type:type_id}
  16. ,method:'post'
  17. ,page: true //开启分页
  18. ,text:'数据加载中'
  19. ,id:'tablerReload'
  20. ,height : 600
  21. ,limit:15
  22. ,cols: [[ //表头
  23. {type:'numbers',title:'序号',width:50},
  24. {field: 'city_name', title: '区域名称', align:'center'},
  25. {field: 'sort', title: '排序',width:100, event:'sortData',edit: 'text', align:'center',sort: true,templet:"#sortBox"}
  26. ,{field: 'create_at', title: '添加时间',width:150, align:'center'}
  27. ,{field: 'is_show', title: '审核',align:'center',width:100, templet:function (d) {
  28. if(d.is_show == 2){
  29. return '<input type="checkbox" value="'+d.id+'" name="open" lay-skin="switch" lay-filter="switchTest" lay-text="|">'
  30. } else {
  31. return '<input type="checkbox" checked value="'+d.id+'" name="open" lay-skin="switch" lay-filter="switchTest" lay-text="|">'
  32. }
  33. }}
  34. ,{fixed: 'right',title:'操作', width: 165, align:'center', toolbar: '#operate'}
  35. ]]
  36. });
  37. // 列表点击放大图片
  38. $('.layui-table-main').on('click','.layui_magnify', function(){
  39. var _src = $(this).attr('src');
  40. layui.layer.open({
  41. type: 1,
  42. title: false, //是否显示标题
  43. area: ['95%', '55%'],
  44. shade: 0.6, //透明度
  45. closeBtn: 1, //按钮 1有,0无
  46. shadeClose: true,
  47. content: '<img style="width:100%;height:100%" src="'+_src+'">',
  48. });
  49. });
  50. //监听指定开关
  51. form.on('switch(switchTest)', function(data){
  52. layer.confirm('确定要修改此操作吗?',{btn: ['确定', '取消']},function () {
  53. $.post('/pushcityprice/priceeditanddel',{id:data.value,type:'show'},function (data) {
  54. layer.msg(data.msg);
  55. table.reload('tablerReload');
  56. })
  57. },function (aa) {
  58. table.reload('tablerReload'); //重新加载
  59. })
  60. });
  61. //列表操作
  62. table.on('tool('+tableIds+')', function(obj){
  63. var layEvent = obj.event,
  64. data = obj.data;
  65. if(layEvent === 'sortData'){ //修改排序
  66. table.on('edit('+tableIds+')', function(obj){
  67. var data = obj.data;
  68. // console.log(data)
  69. $.post('/pushcityprice/priceeditanddel',{id:data.id,type:'sort',sort:data.sort},function (data) {
  70. if(data.code == 200)
  71. {
  72. layer.msg(data.msg);
  73. } else if(data.code == 300 ) {
  74. layer.msg(data.msg);
  75. }
  76. })
  77. })
  78. // layer.prompt({
  79. // formType: 2
  80. // ,title: '排序热门区域:<span style="color:red">'+data.city_name+'</span>'
  81. // ,value: data.sort
  82. // }, function(value, index){
  83. // $.post('/pushcityprice/priceeditanddel',{id:data.id,type:'sort',sort:value},function (data) {
  84. // layer.msg(data.msg);
  85. // table.reload('tablerReload');
  86. // })
  87. // });
  88. }else if(layEvent === 'del') {
  89. layer.confirm('您确定要删除吗?',{ btn: ['确定', '取消']},function () {
  90. $.post('/pushcityprice/priceeditanddel',{id:data.id,type:'del'},function (data) {
  91. layer.msg(data.msg);
  92. table.reload('tablerReload');
  93. })
  94. })
  95. }
  96. });
  97. //添加图片上传
  98. upload.render({
  99. elem: '#test1'
  100. ,url: '/house/createimg'
  101. ,data:{token:csrfToken}
  102. ,field:'img'
  103. ,size:1000 //限制上传图片的大小,单位为KB
  104. ,exts: 'png|jpg|jpeg' //只允许上传压缩文件
  105. ,auto:false
  106. ,bindAction:'#addcity'
  107. ,choose: function(obj){
  108. obj.preview(function(index, file, result){
  109. $('#breviary_img').attr('src', result); //图片链接(base64)
  110. });
  111. }
  112. });
  113. // 图片放大浏览
  114. $('.layui_magnify').click(function(){
  115. var _src = $(this).attr('src');
  116. layui.layer.open({
  117. type: 1,
  118. title: false, //是否显示标题
  119. area: ['60%', '80%'],
  120. shade: 0.6, //透明度
  121. closeBtn: 1, //按钮 1有,0无
  122. shadeClose: true,
  123. content: '<img style="width:100%;height:100%" src="'+_src+'">',
  124. });
  125. })
  126. // 新增
  127. var $ = layui.$, active = {
  128. addData: function(){ //获取选中数据
  129. var index = layui.layer.open({
  130. type: 2,
  131. title: '添加热门区域',
  132. closeBtn: 1, //不显示关闭按钮
  133. area: ['800px','500px'],
  134. content: '/pushcityprice/priceadd?type='+type_id //iframe的url,no代表不显示滚动条
  135. ,success:function (layero, index) {
  136. },
  137. end:function () {
  138. table.reload('tablerReload');
  139. }
  140. });
  141. },
  142. reload:function(){//搜索
  143. var form = pfgs_serialize($('form'));
  144. var name = '';
  145. var house_name = '';
  146. if(form.input_house == 'name'){
  147. name = form.input_house_text;
  148. } else if(form.input_house == 'house_name'){
  149. house_name = form.input_house_text;
  150. }
  151. table.reload('tablerReload',{
  152. where:{
  153. title:name,
  154. house_name:house_name,
  155. city:form.input_city,
  156. type_name:form.type_name
  157. }
  158. })
  159. },
  160. };
  161. $('.demoTable .layui-btn').on('click', function(){
  162. var type = $(this).data('type');
  163. active[type] ? active[type].call(this) : '';
  164. });
  165. $('.The_house').focus(function(){
  166. indexOpen = parent.layui.layer.open({
  167. type: 2,
  168. title: '选择需要添加的区域',
  169. area: ['','100%'],
  170. content: '/publicuse/cityprice?type=2',
  171. success:function (layero, index) {
  172. }
  173. });
  174. parent.layui.layer.full(indexOpen);
  175. //改变窗口大小时,重置弹窗的宽高,防止超出可视区域(如F12调出debug的操作)
  176. $(window).on("resize",function(){
  177. parent.layui.layer.full(indexOpen);
  178. })
  179. })
  180. //添加页面提交数据
  181. form.on('submit(add)', function(data){
  182. var trArry = $('.layui-input-block table.layui-table tbody tr');
  183. var dataObj = [{}];
  184. var dataArry = new Array();
  185. $.each(trArry,function(key,val){
  186. // var _title = $(this).find('input[name="matingName"]').val();
  187. var _rout = $(this).find('input[name="id"]').val();
  188. // dataObj[key] = {name:_title,id:_rout} //把数据以数组对象的方式保存
  189. dataArry.push(_rout)
  190. // dataArry.push(dataObj[key])
  191. })
  192. layer.msg('数据提交中,请稍候',{icon: 16,time:false,shade:0.8}); //数据提交提示
  193. $.post("/pushcityprice/pricdeaddform",{city_id:dataArry,type:type_id},function(data){
  194. if(data.data != null){
  195. layer.msg(ReturnInfo(data.data),{icon:5});
  196. return ;
  197. }
  198. layer.msg(data.msg);
  199. })
  200. return false;
  201. });
  202. form.on('submit(edit_choice)', function(data){
  203. var index = layer.msg('数据提交中,请稍候',{icon: 16,time:false,shade:0.8}); //数据提交提示
  204. var formData = new FormData($('form')[0]);
  205. $.ajax({
  206. type : "post",
  207. url : "/push/choiceeditform",
  208. data : formData,
  209. contentType: false, //jax 中 contentType 设置为 false 是为了避免 JQuery 对其操作,从而失去分界符,而使服务器不能正常解析文件
  210. processData: false, //当设置为true的时候,jquery ajax 提交的时候不会序列化 data,而是直接使用data
  211. error : function(request) {
  212. layer.close(index);
  213. layer.msg("请联系管理员");
  214. },
  215. success : function(data) {
  216. if(data.data != null){
  217. layer.msg(ReturnInfo(data.data),{icon:5});
  218. return ;
  219. }
  220. layer.msg(data.msg);
  221. parent.layer.close(oindex); //再执行关闭
  222. }
  223. });
  224. return false;
  225. });
  226. })