/** * Created by wisestone on 2018-05-08. */ 'use strict'; define([ 'app', 'angular' ], function (app, angular) { app.controller('customFieldListController', ['$scope', '$rootScope', '$log', '$resourceProvider', '$tableProvider', '$state', '$uibModal', 'CustomField', 'SweetAlert', '$timeout', '$filter', function ($scope, $rootScope, $log, $resourceProvider, $tableProvider, $state, $uibModal, CustomField, SweetAlert, $timeout, $filter) { // 함수 $scope.fn = { initSearch : initSearch, // 검색 초기화 getPageList : getPageList, // 목록 조회 changePageRowCount : changePageRowCount, // 페이지 변경 makeTableConfigs : makeTableConfigs, // 테이블 설정 add : add, // 사용자 정의 필드 생성 makeSearchConditions : makeSearchConditions, // 사용자 정의 필드 검색 조건을 만든다. removes : removes // 삭제 }; // 변수 $scope.vm = { search : { name : "", // 사용자 정의 필드 명 customFieldTypes : [] // 사용자 정의 필드 유형 }, page : { selectedPage : 0, selectedPageRowCount : String(10) }, tableConfigs : [], responseData : { data : [] }, options : { customFieldTypes : [{ fieldKey : "INPUT", fieldValue : $filter("translate")("common.stringField") // "문자열 필드" }, { fieldKey : "MULTI_SELECT", fieldValue : $filter("translate")("common.multipleSelectionField") // "다중 선택 필드" }, { fieldKey : "SINGLE_SELECT", fieldValue : $filter("translate")("common.singleSelectionField") //"단일 선택 필드" }] } }; // 테이블 이벤트 $scope.tableEvent = { modify : modify }; // 사용자 정의 필드 목록 화면 새로 고침 $scope.$on("getCustomFieldList", function () { $scope.fn.getPageList(0); }); // 사용자 정의 필드 목록 테이블 설정 function makeTableConfigs() { $scope.vm.tableConfigs = []; $scope.vm.tableConfigs.push($tableProvider.config() .setDType("checkbox") .setHWidth("width-20-p") .setDAlign("text-center")); $scope.vm.tableConfigs.push($tableProvider.config() .setHName("common.customField") .setHWidth("bold") .setDName("name") .setDType("renderer") .setDAlign("text-center") .setDRenderer("COMMON_MODIFY")); $scope.vm.tableConfigs.push($tableProvider.config() .setHName("customField.fieldType") .setDType("renderer") .setHWidth("width-300-p bold") .setDAlign("text-center") .setDRenderer("CUSTOM_FIELD_OPTION")); } // 검색 조건 초기화 function initSearch() { $state.go($state.current, {}, {reload : true}); } // 사용자 정의 필드 검색 조건을 만든다. function makeSearchConditions() { return { name : $scope.vm.search.name, customFieldTypes : (function () { var customFieldTypes = []; angular.forEach($scope.vm.search.customFieldTypes, function (customFieldType) { customFieldTypes.push(customFieldType.fieldKey); }); return customFieldTypes; })() }; } // 사용자 정의 필드 목록 조회 function getPageList(selectedPage) { if (selectedPage < 0) { selectedPage = 0; } // 현재 페이지 정보 var currentPage = 0; // 쿠키에 선택한 페이지 정보가 없으면 기본 페이지 정보 0 을 저장 if (angular.isUndefined(selectedPage) || selectedPage === "") { currentPage = $scope.vm.page.selectedPage; } else { currentPage = selectedPage; } // 사용자 정의 필드 검색 조건을 만든다. var conditions = $scope.fn.makeSearchConditions(); CustomField.find($resourceProvider.getContent(conditions, $resourceProvider.getPageContent(currentPage, $scope.vm.page.selectedPageRowCount))).then(function (result) { if (result.data.message.status === "success") { $scope.vm.page.selectedPage = currentPage + 1; $scope.vm.responseData = result.data; } else { SweetAlert.swal($filter("translate")("issue.failedToUserDefinedFieldListLookup"), result.data.message.message, "error"); // "사용자 정의 필드 목록 조회 실패" } }); } function changePageRowCount() { $scope.fn.getPageList(0); } // 사용자 정의 필드 생성 팝업 function add() { $uibModal.open({ templateUrl : 'views/customField/customFieldAdd.html', size : "md", controller : 'customFieldAddController', backdrop : 'static' }); } // 사용자 정의 필드 수정 팝업 function modify(id) { $uibModal.open({ templateUrl : 'views/customField/customFieldModify.html', size : "md", controller : 'customFieldModifyController', backdrop : 'static', resolve : { parameter : function () { return { id : id }; } } }); } // 사용자 정의 필드 삭제 팝업 function removes() { var removeIds = []; angular.forEach($scope.vm.responseData.data, function (data) { if (data.checked) { removeIds.push(data.id); } }); if (removeIds.length < 1) { SweetAlert.swal({ title : $filter("translate")("common.checkPurgingTargets"), // 삭제 대상 확인 text : $filter("translate")("common.selectDestinationDeletion"), // 삭제 대상을 선택하세요. type : "warning" }); return; } // 삭제 알림 SweetAlert.swal({ title : $filter("translate")("customField.deleteUserDefinedFields"), // "사용자 정의 필드 삭제" text : $filter("translate")("customField.wantToDeleteSelectUserDefinedFields"), // "선택한 사용자 정의 필드를 삭제하겠습니까? 삭제된 사용자 정의 필드는 복구할 수 없습니다." type : "warning", showCancelButton : true, confirmButtonColor : "#DD6B55", confirmButtonText : $filter("translate")("common.delete"), // 삭제 cancelButtonText : $filter("translate")("common.cancel"), // 취소 closeOnConfirm : false, closeOnCancel : true }, function (isConfirm) { SweetAlert.close(); if (isConfirm) { $rootScope.spinner = true; CustomField.remove($resourceProvider.getContent( { removeIds : removeIds }, $resourceProvider.getPageContent(0, 0))).then(function (result) { if (result.data.message.status === "success") { $timeout(function () { SweetAlert.success($filter("translate")("common.deleteSucceeded"), result.data.message.message); // 삭제 성공 }, 100); $scope.fn.getPageList(0); } else { $timeout(function () { SweetAlert.error($filter("translate")("common.deleteFailed"), result.data.message.message); // 삭제 실패 }, 100); } $rootScope.spinner = false; }); } }); } $scope.fn.makeTableConfigs(); $scope.fn.getPageList(0); } ]); } );