index.vue 9.2 KB

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