https://web.archive.org/web/20161130042657/http://www.xeschool.com/xe/xenote_module_admin_controller_delete

Module Admin Controller for Delete

모듈(mid)의 삭제는 모듈의 고유 식별 번호($module_srl)을 확인하고 module 테이블에서 해당 식별 번호를 삭제하는 것으로 끝난다. 여기에서는 프론트 엔드의 내용, 즉 삭제하려고 하는 모듈(mid)이 만들어 놓은 내용물에 대해서는 확인하지 않는다. 아직 프론트 엔드 프로그램을 만들지 않았기 때문이다. 우선 삭제를 원하는 모듈의 식별 번호를 확인하고 module 컨트롤러를 확장하여 example 모듈이 만들어 놓은 모듈(mid)만 삭제하는 것을 구현해 보자.

https://web.archive.org/web/20161130042657im_/http:/www.xeschool.com/xenote_page/images/module_mvc_dispExampleAdminDelete.png

  1. Delete 액션과 모듈 삭제

모듈(mid)을 삭제하기 위한 버튼은 이미 tpl/index.html 파일에 추가해 두었다. 관리자 목록에서 맨 우측 아이콘이 그것이다. 모듈(mid)을 삭제하는 액션을 module.xml 명세서에 등록한다. 모듈의 삭제 또한 컨트롤러의 도움이 필요하기 때문에 2개의 액션을 등록한다. Delete와 관련된 일이기 때문에 disp 와 proc 머릿글을 갖는 Delete 액션을 타입과 함께 설정한다.

<action name="dispExampleAdminDelete" type="view" />
<action name="procExampleAdminDelete" type="controller" />

2. example.admin.view.php

이전에 작성했던 메소드 아래에 다음의 내용을 추가하고 업로드 한다.(모듈 삭제 화면 출력 메소드만 추가해야 한다.)

제목 없는 데이터베이스

삭제 아이콘을 클릭하게 되면 모듈의 고유 식별 번호($module_srl) 번호도 URL에 붙어서 함께 따라 온다. 이것을 확인해 보고 없으면 다시 목록 보기를 위한 메소드를 실행시킬 것이고, 모듈의 정보를 확인한 후에 있다면 삭제를 위해 준비한 템플릿 파일에 보내기 전에 URL 뒤에 예쁘게 세팅해 보낸다. 모듈(mid) 삭제를 위해 준비한 템플릿은 example_admin_delete.html 이다.

3. 모듈(mid) 삭제 폼

tpl/example_admin_delete.html

제목 없는 데이터베이스

모듈의 정보($module_info)를 확인하여 폼에 미리 채워 넣는다. 모듈의 식별 번호($module_srl)는 폼에서 숨김(hidden) 타입(type)형식으로 함께 전송 된다. 모듈 입력 과정과 동일한 방법으로 폼 검사를 위해 procFilter() 함수가 실행되고 폼의 내용(this)은 상단에 임포트 해 둔 admin_delete.xml 필터로 전송 된다. 폼 필터가 회신을 받게 되면 아래에 임포트 해 둔 JS 파일에게 다음 진행 과정과 메시지의 처리를 부탁할 것이다...^^

4. 폼 필터

tpl/filter/admin_delete.xml

제목 없는 데이터베이스

모듈(mid) 삭제를 위해 필요한 정보는 모듈의 고유 식별 번호($module_srl) 1개면 충분하다. <node> 요소는 모듈 식별 번호만 확인하고 삭제를 위한 컨트롤러 함수를 호출한다. 서버로 부터의 회신 결과는 콜백함수를 통해 JS 파일에 보낸다.