app.controller('notificationCtrl', ['$scope', '$http', '$timeout', 'uiGridConstants', 'i18nService', 'toaster', function ($scope, $http, $timeout, uiGridConstants, i18nService, toaster) {
i18nService.setCurrentLang("zh-cn");
$scope.gridOptions = {
data: 'myData',
showGridFooter: true, //是否显示grid footer
//-------- 分页属性 ----------------
paginationPageSizes: [10, 20, 50, 100], //每页显示个数可选项
paginationCurrentPage: 1, //当前页码
paginationPageSize: 10, //每页显示个数
totalItems: 0,// 总数量
useExternalPagination: true,//是否使用分页按钮
//过滤
enableFiltering: true,
columnDefs: [],
//---------------api---------------------
onRegisterApi: function (gridApi) {
$scope.gridApi = gridApi;
gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
if ($scope.setPagingData) {
$scope.getPagedDataAsync(newPage, pageSize);
}
});
}
};
//查询条件
var condition = $scope.condition = {
searchKey: ""
};
function setColumnDefs() {
$scope.gridOptions.columnDefs = [
{field: 'id', displayName: '编号'},
{field: 'text', displayName: '内容'},
{field: 'startTime', displayName: '公告开始时间'},
{field: 'endTime', displayName: '公告结束时间'},
{
field: 'status', displayName: '状态',
cellTemplate: '
{{row.entity.status==0?"未运行":"正在运行"}}
'
},
{
field: 'oper', displayName: '操作',
enableFiltering: false,
enableSorting: false,
enableHiding: false,//禁止在列选择器中隐藏
enableColumnMenu: false,// 是否显示列头部菜单按钮
width: 200,
cellTemplate: '' +
'' +
'' +
'
'
}
];
var fields = $scope.gridOptions.columnDefs;
for (var index in fields) {
var item = fields[index];
if (item && item['minWidth'] == null) {
item['minWidth'] = 100;
}
}
}
function initDataGrid() {
//首次加载表格
$scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize);
}
$scope.setPagingData = function (data, curPage, pageSize) {
var pagedData = data.data.dataList;
$scope.myData = pagedData;
$scope.gridOptions.totalItems = data.data.total;
};
$scope.getPagedDataAsync = function (curPage, pageSize) {
var params = {
pageSize: pageSize,
pageIndex: curPage
};
if (condition.searchKey != "") {
params.searchKey = condition.searchKey
}
$http.get('/manager/getNotificationList', {
params: params
}).then(function (data) {
$scope.setPagingData(data.data, curPage, pageSize);
}).catch(function (data) {
toaster.pop("error", "提示", "获取数据失败");
});
};
setColumnDefs();
initDataGrid();
//事件
$scope.event = {
search: function () {
$scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize);
}
};
//编辑弹窗需要的数据
$scope.dialogName = "编辑公告";
$scope.dialogData = {};
//添加
$scope.add = function () {
//重置表单状态
$scope.noticeForm.$setPristine();
$scope.noticeForm.$setUntouched();
$scope.dialogName = "添加公告";
$scope.dialogData = {status: true};
$("#noticePanel").modal();
};
//编辑
$scope.edit = function () {
//重置表单状态
$scope.noticeForm.$setPristine();
$scope.noticeForm.$setUntouched();
$scope.dialogName = "编辑公告";
var rows = $scope.gridApi.selection.getSelectedRows();
if (rows.length == 0) {
toaster.pop("info", "提示", "请选择数据!");
return;
}
if (rows.length > 1) {
toaster.pop("info", "提示", "只能选中编辑一条数据");
return;
}
var item = rows[0];
$scope.dialogData = $.extend(true, {}, item);
$scope.dialogData.status = $scope.dialogData.status == 1 ? true : false;
$("#noticePanel").modal();
};
//打开或关闭
$scope.openOrClose = function (entity, status) {
$http({
method: 'POST',
url: '/manager/toggleNotice',
data: {id: entity.id, status: status}
}).then(function (response) {
initDataGrid();
}, function (response) {
toaster.pop("error", "提示", "操作失败!");
});
};
//删除
$scope.deleteData = function () {
var rows = $scope.gridApi.selection.getSelectedRows();
if (rows.length == 0) {
toaster.pop("info", "提示", "请选择数据!");
return;
}
var ids = [];
for (var i = 0; i < rows.length; i++) {
ids.push(rows[i].id);
}
$.confirm({
content: '确定删除?',
buttons: {
ok: {
btnClass: 'btn-red',
action: function () {
$http({
method: 'POST',
url: '/manager/deleteNotice',
data: {ids: ids}
}).then(function (response) {
initDataGrid();
}, function (response) {
toaster.pop("error", "提示", "删除失败!");
});
}
},
}
});
};
//提交表单保存
$scope.saveData = function () {
//表单未校验通过不能提交
if ($scope.noticeForm.$invalid) {
return;
}
var url = "";
if ($scope.dialogData.id == null) {
url = "/manager/addNotice";
} else {
url = "/manager/editNotice";
}
//深度克隆 避免操作原对象
var data = $.extend(true, {}, $scope.dialogData);
data.status = $scope.dialogData.status ? 1 : 0;
$http({
method: 'POST',
url: url,
data: data
}).then(function (response) {
$('#noticePanel').modal('hide');//弹窗消失
$scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize);
}, function (response) {
toaster.pop("error", "提示", "保存失败!");
});
};
$scope.startTimeOpen = false;
$scope.endTimeOpen = false;
$scope.timeChange = function (newDate, oldDate) {
$scope.startTimeOpen = false;
$scope.endTimeOpen = false;
};
}]);