Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
mine929
dr_py
提交
1251cd89
dr_py
项目概览
mine929
/
dr_py
与 Fork 源项目一致
Fork自
晚风拂柳颜 / dr_py
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
dr_py
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
1251cd89
编写于
9月 21, 2022
作者:
H
hjdhnx
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
增加多选操作并调试成功
上级
3e0d1fdd
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
117 addition
and
11 deletion
+117
-11
base/rules.db
base/rules.db
+0
-0
controllers/layui.py
controllers/layui.py
+16
-1
templates/layui_list.html
templates/layui_list.html
+101
-10
未找到文件。
base/rules.db
浏览文件 @
1251cd89
无法预览此类型文件
controllers/layui.py
浏览文件 @
1251cd89
...
...
@@ -7,7 +7,7 @@
from
flask
import
Blueprint
,
request
,
render_template
,
jsonify
,
make_response
,
redirect
from
utils.web
import
getParmas
,
get_interval
,
layuiBack
,
verfy_token
from
utils.cfg
import
cfg
from
controllers.service
import
storage_service
from
controllers.service
import
storage_service
,
rules_service
from
utils.system
import
getHost
from
utils.files
import
getCustonDict
,
custom_merge
from
utils.encode
import
parseText
...
...
@@ -48,7 +48,22 @@ def layui_rule_list():
alists_str
=
'[]'
,
live_url
=
live_url
,
config
=
new_conf
)
merged_config
=
custom_merge
(
parseText
(
html
),
customConfig
)
sites
=
merged_config
[
'sites'
]
rules
=
rules_service
()
rule_list
=
rules
.
query_all
()
rule_names
=
list
(
map
(
lambda
x
:
x
[
'name'
],
rule_list
))
# print(rule_list)
# print(rule_names)
for
i
in
range
(
len
(
sites
)):
sites
[
i
][
'id'
]
=
i
+
1
site_name
=
sites
[
i
][
'api'
].
split
(
'rule='
)[
1
].
split
(
'&'
)[
0
]
if
'rule='
in
sites
[
i
][
'api'
]
else
sites
[
i
][
'key'
]
# print(site_name)
if
site_name
in
rule_names
:
site_rule
=
rule_list
[
rule_names
.
index
(
site_name
)]
sites
[
i
][
'state'
]
=
1
if
site_rule
[
'state'
]
is
None
else
site_rule
[
'state'
]
else
:
sites
[
i
][
'state'
]
=
1
sites
[
i
][
'site_name'
]
=
site_name
new_sites
=
sites
[(
page
-
1
)
*
limit
:
page
*
limit
]
# print(new_sites)
return
layuiBack
(
'获取成功'
,
new_sites
,
count
=
len
(
sites
))
templates/layui_list.html
浏览文件 @
1251cd89
...
...
@@ -18,6 +18,10 @@
<script
type=
"text/html"
id=
"toolbarDemo"
>
<
div
class
=
"
layui-btn-container
"
>
<
button
class
=
"
layui-btn layui-btn-sm
"
id
=
"
moreTest
"
>
多选操作
<
i
class
=
"
layui-icon layui-icon-down layui-font-12
"
><
/i
>
<
/button
>
<
button
class
=
"
layui-btn layui-btn-sm
"
lay
-
event
=
"
getCheckData
"
>
获取选中行数据
<
/button
>
<
button
class
=
"
layui-btn layui-btn-sm
"
lay
-
event
=
"
getData
"
>
获取当前页数据
<
/button
>
<
button
class
=
"
layui-btn layui-btn-sm
"
lay
-
event
=
"
isAll
"
>
是否全选
<
/button
>
...
...
@@ -31,10 +35,7 @@
<
button
class
=
"
layui-btn layui-btn-sm layui-btn-primary
"
lay
-
event
=
"
default-row
"
>
单行
<
/button
>
<
button
class
=
"
layui-btn layui-btn-sm
"
id
=
"
moreTest
"
>
更多测试
<
i
class
=
"
layui-icon layui-icon-down layui-font-12
"
><
/i
>
<
/button
>
<
/div
>
</script>
...
...
@@ -52,11 +53,14 @@
</script>
<script>
layui
.
use
([
'
table
'
,
'
dropdown
'
],
function
(){
var
table
=
layui
.
table
;
var
dropdown
=
layui
.
dropdown
;
var
$
=
layui
.
$
;
var
form
=
layui
.
form
;
layer
.
msg
(
'
本页面展示数据为未来功能,<br>可能并没有实际作用,等道长弃坑后续有缘人补上。
'
,
{
closeBtn
:
1
,
icon
:
6
,
...
...
@@ -64,6 +68,34 @@ layui.use(['table', 'dropdown'], function(){
offset
:
'
21px
'
});
function
setState
(
data
,
to_set_state
){
if
(
data
.
length
<
1
){
return
layer
.
msg
(
'
请至少选择一行
'
);
}
to_set_state
=
to_set_state
||
0
;
console
.
log
(
data
);
let
site_names
=
data
.
map
(
it
=>
it
.
site_name
);
let
site_names_str
=
site_names
.
join
(
'
,
'
);
console
.
log
(
'
准备将
'
+
site_names_str
+
'
的显示状态设置为:
'
+
to_set_state
);
let
params
=
{
"
names
"
:
site_names_str
};
console
.
log
(
params
);
$
.
post
(
"
/admin/rule_state/
"
+
to_set_state
,
params
,
function
(
data
,
status
){
console
.
log
(
data
);
if
(
data
.
code
===
200
){
// alert(data.msg);
// location.reload();
table
.
reload
(
'
test
'
,
{
// page: {
// curr: 3 //重新从第 1 页开始
// }
});
}
else
{
console
.
log
(
'
修改失败了...
'
);
return
false
}
});
}
// 创建渲染实例
table
.
render
({
elem
:
'
#test
'
...
...
@@ -79,16 +111,28 @@ layui.use(['table', 'dropdown'], function(){
// ,totalRow: true // 开启合计行
,
page
:
true
,
limit
:
12
,
limits
:[
10
,
20
,
40
,
60
,
80
,
100
,
150
,
200
]
,
cols
:
[[
{
type
:
'
checkbox
'
,
fixed
:
'
left
'
}
// ,{field: 'id', fixed: 'left',title: 'ID', width: 20, sort: true,totalRowText: '合计:'}
,{
field
:
'
id
'
,
title
:
'
ID
'
,
width
:
20
,
sort
:
true
}
,{
field
:
'
name
'
,
title
:
'
名称
'
,
width
:
120
}
,{
field
:
'
site_name
'
,
title
:
'
存储名称
'
,
width
:
120
}
,{
field
:
'
name
'
,
title
:
'
显示名称
'
,
width
:
120
}
,{
field
:
'
key
'
,
title
:
'
唯一标识
'
,
width
:
120
}
,{
field
:
'
type
'
,
title
:
'
<i class="layui-icon layui-icon-email">类型</i>
'
,
minWidth
:
80
}
,{
field
:
'
searchable
'
,
title
:
'
可搜索
'
,
minWidth
:
80
}
,{
field
:
'
quickSearch
'
,
title
:
'
可快搜
'
,
minWidth
:
80
}
,{
field
:
'
filterable
'
,
title
:
'
可筛选
'
,
minWidth
:
80
}
,
{
field
:
'
state
'
,
title
:
'
是否显示
'
,
minWidth
:
80
,
templet
:
function
(
res
)
{
let
menuId
=
res
.
site_name
;
if
(
res
.
state
===
1
)
{
return
"
<input type='checkbox' menuId = '
"
+
menuId
+
"
' lay-filter='state' lay-skin='switch' lay-text='显示|已隐藏' checked>
"
}
else
if
(
res
.
state
===
0
)
{
return
"
<input type='checkbox' menuId = '
"
+
menuId
+
"
' lay-filter='state' lay-skin='switch' lay-text='显示|已隐藏'>
"
}
}
}
// ,{field:'city', width:115, title: '城市', minWidth:115, templet: '#cityTpl', exportTemplet: function(d, obj){
// //console.log(obj)
// // 处理该字段的导出数据
...
...
@@ -172,6 +216,12 @@ layui.use(['table', 'dropdown'], function(){
dropdown
.
render
({
elem
:
'
#moreTest
'
//可绑定在任意元素中,此处以上述按钮为例
,
data
:
[{
id
:
'
show
'
,
title
:
'
显示
'
},{
id
:
'
hide
'
,
title
:
'
隐藏
'
},{
id
:
'
add
'
,
title
:
'
添加
'
},{
...
...
@@ -186,6 +236,14 @@ layui.use(['table', 'dropdown'], function(){
var
checkStatus
=
table
.
checkStatus
(
id
)
var
data
=
checkStatus
.
data
;
// 获取选中的数据
switch
(
obj
.
id
){
case
'
show
'
:
// console.log(obj);
setState
(
data
,
1
)
break
;
case
'
hide
'
:
// console.log(obj);
setState
(
data
,
0
)
break
;
case
'
add
'
:
layer
.
open
({
title
:
'
添加
'
,
...
...
@@ -270,13 +328,21 @@ layui.use(['table', 'dropdown'], function(){
console
.
log
(
obj
);
let
params
=
{
"
names
"
:[
obj_name
].
join
(
'
,
'
)};
console
.
log
(
params
);
$
.
post
(
"
/admin/rule_state/0
"
,
params
,
function
(
data
,
status
){
console
.
log
(
data
);
if
(
data
.
code
===
200
){
alert
(
data
.
msg
);
$
.
post
(
"
/admin/rule_state/0
"
,
params
,
function
(
res
,
status
){
console
.
log
(
res
);
if
(
res
.
code
===
200
){
data
.
state
=
0
;
obj
.
update
({
// 这里的字段必须要在 table.render.cols.filed 有定义,否则无法触发表格渲染
// key 决定是否重新渲染某一列,value 由 templet 里的语句进行逻辑处理
state
:
data
.
state
});
// $('input[menuid="'+obj_name+'"]').removeAttr('checked');
// table.render();
// alert(data.msg);
// location.reload();
}
else
{
alert
(
data
.
msg
);
//
alert(data.msg);
console
.
log
(
'
修改失败了...
'
);
return
false
}
...
...
@@ -325,6 +391,31 @@ layui.use(['table', 'dropdown'], function(){
update
[
field
]
=
value
;
obj
.
update
(
update
);
});
form
.
on
(
'
switch(state)
'
,
function
(
data
)
{
let
site_name
=
data
.
elem
.
attributes
[
'
menuId
'
].
nodeValue
;
let
to_set_state
=
data
.
elem
.
checked
?
1
:
0
;
console
.
log
(
'
准备将
'
+
site_name
+
'
的显示状态设置为:
'
+
to_set_state
);
let
params
=
{
"
names
"
:[
site_name
].
join
(
'
,
'
)};
console
.
log
(
params
);
$
.
post
(
"
/admin/rule_state/
"
+
to_set_state
,
params
,
function
(
data
,
status
){
console
.
log
(
data
);
if
(
data
.
code
===
200
){
// alert(data.msg);
// location.reload();
}
else
{
// alert(data.msg);
console
.
log
(
'
修改失败了...
'
);
data
.
elem
.
checked
=
!
to_set_state
;
return
false
}
});
// console.log(data.value); // 开关value值,也可以通过data.elem.value得到
// let menuId = data.elem.attributes['menuId'].nodeValue;
//console.log(data.elem); // 得到checkbox原始DOM对象
// console.log(data.othis); // 得到美化后的DOM对象
});
});
</script>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录