Class: TabStudentsController
- Inherits:
-
Object
- Object
- TabStudentsController
- Defined in:
- lib/source/controllers/tab_students_controller.rb
Overview
Контроллер для вкладки со списком студентов
Instance Method Summary collapse
-
#delete_selected(current_page, per_page, selected_row) ⇒ Object
Удалить выбранного студента.
-
#initialize(view) ⇒ TabStudentsController
constructor
A new instance of TabStudentsController.
-
#on_view_created ⇒ Object
Вызывается из view после ее создания.
-
#refresh_data(page, per_page) ⇒ Object
Обновить данные в таблице студентов.
-
#show_modal_add ⇒ Object
Показать модальное окно с добавлением студента.
-
#show_modal_edit(current_page, per_page, selected_row) ⇒ Object
Показать модальное окно с изменением выделенного студента.
Constructor Details
#initialize(view) ⇒ TabStudentsController
Returns a new instance of TabStudentsController.
17 18 19 20 21 22 23 |
# File 'lib/source/controllers/tab_students_controller.rb', line 17 def initialize(view) LoggerHolder.instance.debug('TabStudentsController: init start') @view = view @data_list = DataListStudentShort.new([]) @data_list.add_listener(@view) LoggerHolder.instance.debug('TabStudentsController: init done') end |
Instance Method Details
#delete_selected(current_page, per_page, selected_row) ⇒ Object
Удалить выбранного студента
66 67 68 69 70 71 72 73 74 75 76 |
# File 'lib/source/controllers/tab_students_controller.rb', line 66 def delete_selected(current_page, per_page, selected_row) begin LoggerHolder.instance.debug('TabStudentsController: deleting selected student') student_num = (current_page - 1) * per_page + selected_row @data_list.select_element(student_num) student_id = @data_list.selected_id @student_rep.remove_student(student_id) rescue Mysql2::Error::ConnectionError => e on_db_conn_error(e) end end |
#on_view_created ⇒ Object
Вызывается из view после ее создания
28 29 30 31 32 33 34 35 |
# File 'lib/source/controllers/tab_students_controller.rb', line 28 def on_view_created begin @student_rep = StudentRepository.new(DBSourceAdapter.new) LoggerHolder.instance.debug('TabStudentsController: created student repository') rescue Mysql2::Error::ConnectionError => e on_db_conn_error(e) end end |
#refresh_data(page, per_page) ⇒ Object
Обновить данные в таблице студентов
81 82 83 84 85 86 87 88 89 |
# File 'lib/source/controllers/tab_students_controller.rb', line 81 def refresh_data(page, per_page) begin LoggerHolder.instance.debug('TabStudentsController: refreshing data...') @data_list = @student_rep.paginated_short_students(page, per_page, @data_list) @view.update_student_count(@student_rep.student_count) rescue Mysql2::Error::ConnectionError => e on_db_conn_error(e) end end |
#show_modal_add ⇒ Object
Показать модальное окно с добавлением студента
41 42 43 44 45 46 47 |
# File 'lib/source/controllers/tab_students_controller.rb', line 41 def show_modal_add LoggerHolder.instance.debug('TabStudentsController: showing modal (add)') controller = StudentInputFormControllerCreate.new(self) view = StudentInputForm.new(controller) controller.set_view(view) view.create.show end |
#show_modal_edit(current_page, per_page, selected_row) ⇒ Object
Показать модальное окно с изменением выделенного студента
52 53 54 55 56 57 58 59 60 61 |
# File 'lib/source/controllers/tab_students_controller.rb', line 52 def show_modal_edit(current_page, per_page, selected_row) LoggerHolder.instance.debug('TabStudentsController: showing modal (edit)') student_num = (current_page - 1) * per_page + selected_row @data_list.select_element(student_num) student_id = @data_list.selected_id controller = StudentInputFormControllerEdit.new(self, student_id) view = StudentInputForm.new(controller) controller.set_view(view) view.create.show end |