'use strict';
/**
* controller for User Profile Example
*/
app.controller('moonTaskListCtrl', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm_schedule", "api_bpm_data","api_doc_data","api_user_data","api_wechatfile","FileUploader","api_bpm_domain","$http","$stateParams","api_task_export", function($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm_schedule, api_bpm_data,api_doc_data,api_user_data,api_wechatfile,FileUploader,api_bpm_domain,$http,$stateParams,api_task_export) {
$scope.langs = i18nService.getAllLangs();
$scope.lang = 'zh-cn';
i18nService.setCurrentLang($scope.lang);
var loginUser = $rootScope.user;
$scope.personListData={};//责任人下拉框列表数据
$scope.personData={};//责任人下拉数据
$scope.stateData={};//状态下拉数据
$scope.stateListData={};//状态下拉框列表数据
//ui-grid设置
$scope.gridOptions = {};
$scope.gridOptions.data = 'myData';
$scope.gridOptions.enableColumnResizing = true;
$scope.gridOptions.enableFiltering = true;
$scope.gridOptions.enableGridMenu = false;
$scope.gridOptions.enableSelectAll = false;
$scope.gridOptions.enableRowSelection = true;
$scope.gridOptions.showGridFooter = true;
$scope.gridOptions.showColumnFooter = false;
$scope.gridOptions.fastWatch = true;
$scope.gridOptions.useExternalFiltering = true;
$scope.gridOptions.useExternalPagination = true;
$scope.gridOptions.paginationPageSizes = [10, 20, 50, 100];
$scope.gridOptions.paginationPageSize = 10;
$scope.gridOptions.multiSelect = true;
// 状态下拉框数据
$scope.stateListData2 = {};
$scope.getStateData2=function(){
var data={
"key":'task_month_state',
"type":'list'
}
api_wechatfile.getDictionary(data).then(function(res){
angular.forEach(res,function(v,i){
$scope.stateListData2[v.value] = v.id;
})
$scope.stateListData=res;
})
}
$scope.getStateData2();
// $scope.gridOptions.rowTemplate = '
";
$scope.gridOptions.rowIdentity = function(row) {
return row.id;
};
$scope.gridOptions.getRowIdentity = function(row) {
return row.id;
};
$scope.transferColor = function(item) {
var color = "icon iconfont icon-zhengchang greenfont";
if (item && item.colourInfo) {
if (item.colourInfo.id == 1) {
color = "icon iconfont icon-yiyuqi redfont";
} else if (item.colourInfo.id == 2) {
color = "iconfont icon-yuqixinxiu yellofont";
}
} else {
// color = "white";
}
return color;
}
$scope.transfertip = function(item) {
var tip = "正常";
if (item && item.colourInfo) {
if (item.colourInfo.id == 1) {
tip = "逾期";
} else if (item.colourInfo.id == 2) {
tip = "即将逾期";
}
} else {
// color = "white";
}
return tip;
}
$scope.gridOptions.columnDefs = [
{
name: 'item',
displayName: '序号',
width: '5%',
cellTemplate: '' +
'
{{row.entity.item}}
' +
'
',
enableFiltering: false
},
{
name: 'taskDescribe',
displayName: '任务描述',
width: '25%',
enableFiltering: false
},
{
name: 'liableShowName',
displayName: '责任人',
width: '10%',
enableFiltering: false
},
{
name: 'strStartTime',
displayName: '开始时间',
width: '15%',
enableFiltering: false,
cellTemplate: '' +
'
{{row.entity.strStartTime}}
' +
'
',
},
{
name: 'strEndTime',
displayName: '结束时间',
width: '15%',
enableFiltering: false
},
{
name: 'priority.name',
displayName: '优先级',
width: '6%',
enableFiltering: false
},
{
name: 'state.name',
displayName: '状态',
width: '6%',
enableFiltering: false
},
{
name: 'strUpdateTime3',
displayName: '操作',
enableFiltering: false,
cellTemplate: '' +
'
编辑' +
'
分配' +
'
反馈' +
'
任务总结' +
'
查看' +
'
'
}
];
// 导出
$scope.export=function(){
$http({
url: api_task_export.taskExport("exportTask", 2018).getRequestedUrl(),
method: 'GET',
// data: JSON.stringify(filadata),
headers: {
// 'Content-type': 'application/xls',
'Accept': '*/*'
},
responseType: 'arraybuffer'
}).success(function (data, status, headers, config) {
// $scope.ldloading.zoom_in = false;
var file = new Blob([data], {
type: 'application/vnd.ms-excel'
});
//trick to download store a file having its URL
var fileURL = URL.createObjectURL(file);
var a = document.createElement('a');
a.href = fileURL;
a.target = '_blank';
a.download = '任务列表.xls';
document.body.appendChild(a);
a.click();
}).error(function (data, status, headers, config) {
// $scope.ldloading.zoom_in = false;
});
}
// 双击
$scope.onDblClick=function(data){
console.log(data);
var toData={
model:{taskMonth:data}
}
$state.go('app.task.editTask',{"formKey":"taskSee","model":JSON.stringify(toData)})
}
// 查看
$scope.see=function(data){
console.log(data);
var toData={
model:{taskMonth:data}
}
$state.go('app.task.editTask',{"formKey":"taskSee","model":JSON.stringify(toData)})
}
// 任务总结
$scope.summary=function(data){
var toData={
model:{taskMonth:data}
}
$state.go('app.task.editTask',{"formKey":"taskSummary","model":JSON.stringify(toData)})
}
//反馈
$scope.feedback=function(data){
console.log(data);
var toData={
model:{taskMonth:data}
}
$state.go('app.task.editTask',{"formKey":"taskFeedback","model":JSON.stringify(toData)})
}
//分配
$scope.distribution=function(data){
console.log(data);
var toData={
model:{taskMonth:data}
}
$state.go('app.task.editTask',{"formKey":"taskDistribution","model":JSON.stringify(toData)})
}
// 编辑
$scope.edit=function(data){
console.log(data);
var toData={
model:{taskMonth:data}
}
$state.go('app.task.editTask',{"formKey":"taskEdit","model":JSON.stringify(toData)})
}
$scope.selected = {
items: []
}
$scope.editted = {
items: []
}
//grid控制器
$scope.gridOptions.onRegisterApi = function(gridApi) {
//分页控制
gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
// var filterData = JSON.parse(sessionStorage.inspectListParameter);
$scope.jry_filterdata.idx = newPage - 1;
$scope.jry_filterdata.sum = pageSize;
$scope.refreshData('expand-right', $scope.jry_filterdata);
});
}
$scope.jry_filterdata={
'idx':0,
'sum':10,
'taskMonth':{
'userid':loginUser.id,
'role':loginUser.role
}
}
// 责任人下拉框数据
$scope.getPersonData=function(){
var data={
"idx":0,
"sum":1000
}
api_user_data.fetchDataList("user",data).then(function(res){
$scope.personListData=res.list;
})
}
$scope.getPersonData();
// 搜索
$scope.search=function(){
if($scope.personData.data){
// console.log($scope.personData);
$scope.jry_filterdata.taskMonth['liableid']=$scope.personData.data.id
}
if($scope.stateData.data){
$scope.jry_filterdata.taskMonth['state']={id:$scope.stateData.data.id}
}
if($scope.jry_filterdata.taskMonth.strStartTime){
$scope.jry_filterdata.taskMonth.strStartTime = moment(new Date($scope.jry_filterdata.taskMonth.strStartTime).getTime()).format('YYYY-MM-DD HH:mm:ss');
}
if($scope.jry_filterdata.taskMonth.strEndTime){
$scope.jry_filterdata.taskMonth.strEndTime = moment(new Date($scope.jry_filterdata.taskMonth.strEndTime).getTime()).format('YYYY-MM-DD HH:mm:ss');
}
$scope.refreshData('expand-right', $scope.jry_filterdata);
}
//重置
$scope.clean=function(){
delete $scope.jry_filterdata.taskMonth.liableid;
delete $scope.jry_filterdata.taskMonth.state;
delete $scope.jry_filterdata.taskMonth.strStartTime;
delete $scope.jry_filterdata.taskMonth.strEndTime;
$scope.personData={};
$scope.stateData={};
$scope.refreshData('expand-right', $scope.jry_filterdata);
}
//时间控件
$scope.open = function ($event) {
$event.preventDefault();
$event.stopPropagation();
$scope.opened = !$scope.opened;
};
$scope.endOpen = function ($event) {
$event.preventDefault();
$event.stopPropagation();
$scope.startOpened = false;
$scope.endOpened = !$scope.endOpened;
};
$scope.startOpen = function ($event) {
$event.preventDefault();
$event.stopPropagation();
$scope.endOpened = false;
$scope.startOpened = !$scope.startOpened;
};
$scope.ldloading = {};
$scope.refreshData = function(style, filterData) {
$scope.ldloading[style.replace('-', '_')] = true;
if (angular.isUndefined(filterData)) {
filterData = defaultFilterData;
}
$scope.myData = [];
var liableName=[];
$scope.memoryfilterData = filterData;
api_doc_data.fetchDataList('taskMonth',filterData).then(function(data) {
var myData = Restangular.stripRestangular(data);
$scope.gridOptions.totalItems = myData.totalNum;
if (angular.isArray(myData.list)) {
$scope.myData = myData.list;
for (var i = 0; i < $scope.myData.length; i++) {
//添加序号
$scope.myData[i]['item'] = i + 1 + filterData.idx * filterData.sum;
// $scope.myData[i].startTime=moment($scope.myData[i].startTime).format('YYYY-MM-DD HH:mm:ss');
// $scope.myData[i].endTime=moment($scope.myData[i].endTime).format('YYYY-MM-DD HH:mm:ss');
for(var j=0;j<$scope.myData[i].liable.length;j++){
liableName.push($scope.myData[i].liable[j].name);
$scope.myData[i]['liableShowName']=liableName.join('、');
}
liableName=[];
}
console.log($scope.myData);
$scope.ldloading[style.replace('-', '_')] = false;
}
else {
$scope.ldloading[style.replace('-', '_')] = false;
SweetAlert.swal({
title: "数据为空",
text: myData.data,
type: "warning"
});
}
}, function() {
$scope.ldloading[style.replace('-', '_')] = false;
});
};
$scope.refreshData('expand-right', $scope.jry_filterdata);
}]);