mngListDeleted.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. <template>
  2. <div>
  3. <div class="inner--headers">
  4. <h2>{{ pageId }}</h2>
  5. <div class="bread--crumbs--wrap">
  6. <span>홈</span>
  7. <span>관리자 관리</span>
  8. <span>{{ pageId }}</span>
  9. </div>
  10. </div>
  11. <div class="search--modules">
  12. <div class="form--cont--filter">
  13. <v-select
  14. v-model="filter"
  15. :items="filderArr"
  16. variant="outlined"
  17. class="custom-select"
  18. >
  19. </v-select>
  20. </div>
  21. <div class="form--cont--text">
  22. <v-text-field
  23. v-model="searchModel"
  24. class="custom-input mini"
  25. style="width: 100%"
  26. placeholder="검색어를 입력하세요"
  27. ></v-text-field>
  28. </div>
  29. <v-btn
  30. class="custom-btn btn-blue mini sch--btn"
  31. @click="fnSearch(searchModel, filter)"
  32. >검색</v-btn
  33. >
  34. </div>
  35. <div class="data--list--wrap">
  36. <div class="btn--actions--wrap">
  37. <div class="left--sections">
  38. </div>
  39. <div class="right--sections">
  40. <v-btn class="custom-btn mini btn-white" @click="fnDelEvt">선택 삭제</v-btn>
  41. <v-btn class="custom-btn mini btn-reg ml--10" @click="fnResEvt"
  42. >선택 복원</v-btn
  43. >
  44. </div>
  45. </div>
  46. <div class="tbl-wrapper">
  47. <div class="tbl-wrap">
  48. <!-- ag grid -->
  49. <ag-grid-vue
  50. style="width: 100%; height: calc(10 * 2.94rem)"
  51. class="ag-theme-quartz"
  52. :gridOptions="gridOptions"
  53. :rowData="tblItems"
  54. rowSelection="multiple"
  55. :paginationPageSize="pageObj.pageSize"
  56. :suppressPaginationPanel="true"
  57. @grid-ready="onGridReady"
  58. >
  59. </ag-grid-vue>
  60. <!-- 페이징 -->
  61. <div class="ag-grid-custom-pagenations">
  62. <pagination @chg_page="chgPage" :pageObj="pageObj"></pagination>
  63. </div>
  64. </div>
  65. </div>
  66. </div>
  67. </div>
  68. </template>
  69. <script setup>
  70. import { AgGridVue } from "ag-grid-vue3";
  71. import pagination from "../components/common/pagination.vue";
  72. /************************************************************************
  73. | 레이아웃
  74. ************************************************************************/
  75. definePageMeta({
  76. layout: "default",
  77. });
  78. /************************************************************************
  79. | PROPS
  80. ************************************************************************/
  81. const props = defineProps({
  82. propsData: {
  83. type: Object,
  84. default: () => {},
  85. },
  86. });
  87. /************************************************************************
  88. | 스토어
  89. ************************************************************************/
  90. const useDtStore = useDetailStore();
  91. /************************************************************************
  92. | 전역
  93. ************************************************************************/
  94. const searchModel = ref("");
  95. const filter = ref("");
  96. const filderArr = ref([
  97. { title: "선택하세요", value: "" },
  98. { title: "이름", value: "name" },
  99. { title: "아이디", value: "id" },
  100. ]);
  101. const { $toast, $log, $dayjs, $eventBus } = useNuxtApp();
  102. const router = useRouter();
  103. const pageId = ref("삭제 관리자 리스트");
  104. let pageObj = ref({
  105. page: 1, // 현재 페이지
  106. pageMaxNumSize: 10, // 페이지 숫자 최대 표현 개수
  107. pageSize: 10, // 테이블 조회 데이터 개수
  108. totalCnt: 0, // 전체 페이지
  109. });
  110. const tblItems = ref([]); // stat 데이터
  111. /* eslint-disable */
  112. /* prettier-ignore */
  113. pageObj.value.totalCnt = tblItems.value.length;
  114. const remToPx = () => parseFloat(getComputedStyle(document.documentElement).fontSize);
  115. const rowHeightRem = 2.65; // 원하는 rem 값
  116. const rowHeightPx = rowHeightRem * remToPx();
  117. const gridApi = shallowRef();
  118. // gridOption
  119. const gridOptions = {
  120. columnDefs: [
  121. { checkboxSelection: true, headerCheckboxSelection: true, width: 0 },
  122. {
  123. headerName: "No",
  124. valueGetter: (params) => params.api.getDisplayedRowCount() - params.node.rowIndex,
  125. sortable: false,
  126. width: 70,
  127. },
  128. // { headerName: "번호", field: "NO", sortable: false },
  129. { headerName: "아이디", field: "ID", sortable: false },
  130. { headerName: "이름", field: "NAME", sortable: false },
  131. { headerName: "이메일", field: "EMAIL", sortable: false },
  132. { headerName: "상태",
  133. field: "STATUS",
  134. sortable: false,
  135. width: 140,
  136. cellRenderer: (params) => {
  137. return params.value == 0 ? '사용중' : params.value == 1 ? '정지' : '삭제';
  138. }
  139. },
  140. { headerName: "삭제일", field: "REGDATE", sortable: false, width: 140 },
  141. // {
  142. // headerName: "알림 메일 수신 여부",
  143. // field: "mail_recp_yn",
  144. // sortable: false,
  145. // width: 130,
  146. // },
  147. ],
  148. rowData: tblItems.value, // 테이블 데이터
  149. autoSizeStrategy: {
  150. type: "fitGridWidth", // width맞춤
  151. },
  152. suppressMovableColumns: true,
  153. headerHeight: rowHeightPx,
  154. rowHeight: rowHeightPx,
  155. pagination: true,
  156. suppressPaginationPanel: true, // 하단 default 페이징 컨트롤 숨김
  157. //rowSelection: {
  158. // checkboxes: true,
  159. // headerCheckbox: true,
  160. // enableClickSelection: false,
  161. // mode: "multiRow",
  162. //},
  163. };
  164. /************************************************************************
  165. | 함수(METHODS)
  166. ************************************************************************/
  167. const onGridReady = (__PARAMS) => {
  168. gridApi.value = __PARAMS.api;
  169. };
  170. const chgPage = (__PAGE) => {
  171. pageObj.value.page = __PAGE;
  172. gridApi.value.paginationGoToPage(__PAGE - 1);
  173. };
  174. // const detailLocated = (__EVENT) => {
  175. // router.push({
  176. // path: "/view/mng/mngAdd",
  177. // });
  178. // useDtStore.adminInfo.adminId = __EVENT.data.ID;
  179. // useDtStore.adminInfo.pageType = "U";
  180. // };
  181. const adminListGet = () => {
  182. let _req = {
  183. _size: 1000,
  184. _index: 0,
  185. status: "-1",
  186. };
  187. useAxios()
  188. .post("/mng/list", _req)
  189. .then((res) => {
  190. _req._size = res.data.length;
  191. tblItems.value = res.data;
  192. pageObj.value.totalCnt = tblItems.value.length;
  193. });
  194. };
  195. const fnSearch = (__KEYWORD, __FILTER) => {
  196. let _req = {
  197. _size: 1000,
  198. _index: 0,
  199. filter: __FILTER,
  200. keyword: __KEYWORD,
  201. status: "-1"
  202. };
  203. useAxios()
  204. .post("/mng/search", _req)
  205. .then((res) => {
  206. _req._size = res.data.length;
  207. tblItems.value = res.data;
  208. pageObj.value.totalCnt = tblItems.value.length;
  209. })
  210. .catch((error) => {});
  211. };
  212. const fnRestore = async (idArr) => {
  213. if (!idArr.length) return;
  214. for (const id of idArr) {
  215. await useAxios().post(`mng/stupdate/${id}`);
  216. }
  217. window.location.reload();
  218. };
  219. const fnResEvt = () => {
  220. const selected = gridApi.value.getSelectedRows();
  221. if(selected.length === 0){
  222. let param = {
  223. id: pageId,
  224. title: "관리자 복원",
  225. content: "복원할 관리자를 선택하세요.",
  226. yes: {
  227. text: "확인",
  228. isProc: false,
  229. },
  230. };
  231. $eventBus.emit("OPEN_CONFIRM_POP_UP", param);
  232. } else{
  233. let param = {
  234. id: pageId,
  235. title: "관리자 복원",
  236. content: "복원하시겠습니까?",
  237. yes: {
  238. text: "확인",
  239. isProc: true,
  240. event: "FN_RESTORE",
  241. param: selected,
  242. },
  243. no: {
  244. text: "취소",
  245. isProc: false,
  246. },
  247. };
  248. $eventBus.emit("OPEN_CONFIRM_POP_UP", param);
  249. }
  250. };
  251. const fnDelete = async (idArr) => {
  252. if (!idArr.length) return;
  253. for (const id of idArr) {
  254. await useAxios().post(`mng/delete/${id}`);
  255. }
  256. window.location.reload();
  257. };
  258. const fnDelEvt = () => {
  259. const selected = gridApi.value.getSelectedRows();
  260. if(selected.length === 0){
  261. let param = {
  262. id: pageId,
  263. title: "관리자 삭제",
  264. content: "삭제할 관리자를 선택하세요.",
  265. yes: {
  266. text: "확인",
  267. isProc: false,
  268. },
  269. };
  270. $eventBus.emit("OPEN_CONFIRM_POP_UP", param);
  271. } else{
  272. let param = {
  273. id: pageId,
  274. title: "관리자 삭제",
  275. content: "삭제하시겠습니까?",
  276. yes: {
  277. text: "확인",
  278. isProc: true,
  279. event: "FN_DELETE",
  280. param: selected,
  281. },
  282. no: {
  283. text: "취소",
  284. isProc: false,
  285. },
  286. };
  287. $eventBus.emit("OPEN_CONFIRM_POP_UP", param);
  288. }
  289. };
  290. /************************************************************************
  291. | 팝업 이벤트버스 정의
  292. ************************************************************************/
  293. $eventBus.off("FN_RESTORE");
  294. $eventBus.on("FN_RESTORE", (selected) => {
  295. const idList = selected.map(row => row.ID);
  296. fnRestore(idList);
  297. });
  298. $eventBus.off("FN_DELETE");
  299. $eventBus.on("FN_DELETE", (selected) => {
  300. const idList = selected.map(row => row.ID);
  301. fnDelete(idList);
  302. });
  303. /************************************************************************
  304. | WATCH
  305. ************************************************************************/
  306. watch(
  307. () => props,
  308. () => {
  309. searchObj.value = props.propsData;
  310. fnGetStat();
  311. },
  312. { deep: true }
  313. );
  314. onMounted(() => {
  315. adminListGet();
  316. });
  317. </script>