Files
HTCloud/HT.Cloud.Web/Areas/SystemOrganize/Views/DataPrivilegeRule/RuleForm.cshtml

260 lines
12 KiB
Plaintext
Raw Normal View History

2023-03-03 16:07:50 +08:00
@{
ViewBag.Title = "Form";
Layout = "~/Views/Shared/_Form.cshtml";
}
<script>
layui.use(['jquery', 'form', 'laydate', 'common', 'xmSelect', 'optimizeSelectOption'], function () {
var form = layui.form,
$ = layui.$,
common = layui.common,
xmSelect = layui.xmSelect;
var keyValue = $.request("keyValue");
var module = $.request("module");
var cout = 0;
$(function () {
initControl();
if (!!keyValue) {
var tempdata = common.parentWindow().layui.table.cache.currentTableId;
var Filters = [];
for (var i = 0; i < tempdata.length; i++) {
if (keyValue == tempdata[i].F_Id) {
Filters = JSON.parse(tempdata[i].Filters);
$('#Description').val(tempdata[i].Description);
break;
}
}
for (var i = 0; i < Filters.length; i++) {
$('#NF-add').click();
$('#fields' + i).val(Filters[i].Key);
$('#symbol' + i).val(Filters[i].Contrast);
$('#lookname' + i).val(Filters[i].Text);
$('#values' + i).val(Filters[i].Value);
}
form.render();
}
else {
$('#NF-add').click();
form.render();
}
form.render();
});
wcLoading.close();
function initControl() {
$("#fields").bindSelect({
url: "/SystemManage/ModuleFields/GetSelectJson?moduleId=" + module,
});
}
$(document).on('click', '#NF-add', function () {
var target = $('#ruledata');
var html = $("#divInputTemplate").prop("outerHTML");
html = html.replace(/rulecontext/g, "rulecontext" + cout); // 替换多个
html = html.replace(/条件规则/g, "条件规则" + (cout + 1)); // 替换多个
html = html.replace(/fields/g, "fields" + cout); // 替换多个
html = html.replace(/symbol/g, "symbol" + cout); // 替换多个
html = html.replace(/lookname/g, "lookname" + cout); // 替换多个
html = html.replace(/condition/g, "condition" + cout); // 替换多个
html = html.replace(/divInputTemplate/g, "divInput" + cout);
html = html.replace(/values/g, "values" + cout);
html = html.replace(/searchCout/g, cout);
var obj = $(html);
obj.removeClass("layui-hide");
obj.appendTo(target);
cout++;
form.render();
});
//select验证
form.verify({
required: function (value, item) {
var msg = "必填项不能为空";
value = $.trim(value);
var isEmpty = !value || value.length < 1;
// 当前验证元素是select且为空时,将页面定位至layui渲染的select处或自定义想定位的位置
if (item.tagName == 'SELECT' && isEmpty) {
$("html").animate({
scrollTop: $(item).siblings(".layui-form-select").offset().top - 74
}, 50);
}
if (isEmpty) {
return msg;
}
}
});
//监听提交
var lock = false;
form.on('submit(saveBtn)', function (data) {
if (!lock) {
var index = parent.layer.load(0, {
shade: [0.5, '#000'], //0.1透明度的背景
});
var postData = {};
postData.Operation = data.field.Operation;
postData.Description = data.field.Description;
if (!!keyValue) {
postData.F_Id = keyValue;
}
else {
postData.F_Id = uuid();
}
var Filters = [];
for (var i = 0; i < cout; i++) {
var temp = {};
temp["Key"] = $('#fields' + + i).val();
temp["Contrast"] = $('#symbol' + + i).val();
temp["Text"] = $('#lookname' + + i).val();
temp["Value"] = $('#values' + + i).val();
if(temp["Key"]!="{loginRole}" && temp["Key"]!="{loginUser}" && temp["Key"]!="{loginOrg}")
{
temp["Value"] = null;
}
if (!temp["Value"]) {
temp["Value"] = temp["Text"];
}
if (!!temp["Key"]) {
Filters.push(temp);
}
}
postData.Filters = JSON.stringify(Filters);
var tempdata = common.parentWindow().layui.table.cache.currentTableId;
if (!!keyValue) {
for (var i = 0; i < tempdata.length; i++) {
if (keyValue == tempdata[i].F_Id) {
tempdata[i].Filters = postData.Filters;
tempdata[i].Description = postData.Description;
break;
}
}
}
else {
tempdata.push(postData);
}
common.modalMsg("操作成功", "success");
common.parentWindow().layui.table.reload('currentTableId', {
data: tempdata
});
parent.layer.close(index);
common.modalClose();
lock = false;
}
return false;
});
});
function deleteRule(data) {
var obj = document.getElementById(data);//建议使用ID
if (obj != null) {
obj.parentNode.removeChild(obj);
}
layui.use(['jquery', 'form', 'laydate', 'common'], function () {
layui.form.render();
});
}
function search(data) {
var fields = $('#fields' + data).val();
if (fields != '{loginRole}' && fields != '{loginUser}' && fields != '{loginOrg}') {
return false;
}
$('#lookname' + data).val(null);
$('#values' + data).val(null);
layui.use(['jquery', 'form', 'common'], function () {
var form = layui.form,
$ = layui.$,
common = layui.common;
//不同弹窗
if (fields == '{loginRole}') {
common.modalOpen({
title: "选择角色",
url: "/SystemOrganize/Role/AddForm?name=" + "lookname" + data + "&value=" + "values" + data,
width: "650px",
height: "600px",
});
}
else if (fields == '{loginUser}') {
common.modalOpen({
title: "选择用户",
url: "/SystemOrganize/User/AddForm?name=" + "lookname" + data + "&value=" + "values" + data,
width: "650px",
height: "600px",
});
}
else if (fields == '{loginOrg}') {
common.modalOpen({
title: "选择组织",
url: "/SystemOrganize/Organize/AddForm?name=" + "lookname" + data + "&value=" + "values" + data,
width: "650px",
height: "600px",
});
}
else {
return false;
}
});
}
</script>
<body>
<div class="layui-input-item layui-hide" id="divInputTemplate">
<label class="layui-form-label required">条件规则</label>
<div class="layui-input-block" style="padding-right: 70px;">
<div class="layui-input-block" style="margin-left:0px">
<select id="condition" name="condition" lay-verify="required" disabled lay-search>
<option value="and" selected>并且</option>
<option value="or">或者</option>
</select>
</div>
<div class="layui-input-inline" style="width:145px">
<select id="fields" name="fields" lay-verify="required" lay-search>
<option value="">请选择</option>
<option value="{loginRole}">{当前登录用户的角色}</option>
<option value="{loginUser}">{当前登录的用户}</option>
<option value="{loginOrg}">{当前登录用户的部门}</option>
</select>
</div>
<div class="layui-input-inline" style="width:100px">
<select id="symbol" name="symbol" lay-verify="required" lay-search>
<option value="">请选择</option>
<option value=">=">大于等于</option>
<option value="<=">小于等于</option>
<option value="==">等于</option>
<option value="!=">不等于</option>
<option value="contains">包含</option>
<option value="in">属于</option>
<option value="intersect">含有任意一个</option>
</select>
</div>
<div class="layui-input-inline" style="width:180px">
<input type="text" id="lookname" name="lookname" class="layui-input" lay-verify="required" maxlength="50" value="" placeholder="请输入值">
<input type="text" id="values" name="values" class="layui-input layui-hide">
</div>
<button class="layui-btn layui-btn-danger" style="position: absolute;top: 0;right: 6px;cursor: pointer;" onclick="deleteRule('divInputTemplate')"><i class="layui-icon">&#xe67e;</i></button>
<button class="layui-btn layui-btn-primary" style="position: absolute;top: 0;right: 6px;cursor: pointer;margin-top:40px" onclick="search(searchCout)">...</button>
</div>
</div>
<div class="layuimini-container">
<div class="layuimini-main">
<blockquote class="layui-elem-quote layui-text">
当前登录的用户{loginUser},当前登录用户的角色{loginRole},当前用户的部门{loginOrg}
</blockquote>
<div class="layui-form layuimini-form" lay-filter="adminform">
<div class="layui-form-item layui-form-text">
<label class="layui-form-label">规则备注</label>
<div class="layui-input-block">
<textarea id="Description" name="Description" class="layui-textarea" placeholder="请输入规则备注"></textarea>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">规则条件</label>
<div class="layui-input-block" style="padding-right: 70px;">
<input id="Operation" name="Operation" lay-verify="required" value="and" disabled class="layui-hide">
<button id="NF-add" class="layui-btn"><i class="layui-icon">&#xe654;</i></button>
</div>
</div>
<div id="ruledata">
</div>
<div class="layui-form-item layui-hide">
<button class="layui-btn" lay-submit id="submit" lay-filter="saveBtn">确认保存</button>
</div>
</div>
</div>
</div>
</body>