classes.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. // 初始化表格参数配置
  5. Table.api.init({
  6. extend: {
  7. index_url: 'unishop/classes/index' + location.search,
  8. add_url: 'unishop/classes/add',
  9. edit_url: 'unishop/classes/edit',
  10. del_url: 'unishop/classes/del',
  11. multi_url: 'unishop/classes/multi',
  12. table: 'classes',
  13. }
  14. });
  15. var table = $("#table");
  16. // 初始化表格
  17. table.bootstrapTable({
  18. url: $.fn.bootstrapTable.defaults.extend.index_url,
  19. pk: 'id',
  20. sortName: 'id',
  21. columns: [
  22. [
  23. {checkbox: true},
  24. {field: 'id', title: __('Id')},
  25. // {field: 'grade_id', title: __('Grade_id')},
  26. {field: 'name', title: __('Name')},
  27. {field: 'grade.name', title: __('Grade.name')},
  28. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  29. ]
  30. ]
  31. });
  32. // 为表格绑定事件
  33. Table.api.bindevent(table);
  34. },
  35. add: function () {
  36. Controller.api.bindevent();
  37. $("#c-area_id").on("cp:updated", function() {
  38. var citypicker = $(this).data("citypicker");
  39. var code = citypicker.getCode("district");
  40. $("#c-area_id").val(code);
  41. $("#c-school_id").val("");
  42. $("#c-school_id_text").val("");
  43. $("#c-grade_id").val("");
  44. $("#c-grade_id_text").val("");
  45. $("#c-name").val("");
  46. });
  47. $("#c-school_id").on("change", function() {
  48. $("#c-grade_id").val("");
  49. $("#c-grade_id_text").val("");
  50. $("#c-name").val("");
  51. });
  52. $("#c-grade_id").on("change", function() {
  53. $("#c-name").val("");
  54. });
  55. $("#c-school_id").data("params", function (obj) {
  56. return {custom: {area_id: $("#c-area_id").val()}};
  57. });
  58. $("#c-grade_id").data("params", function (obj) {
  59. return {custom: {school_id: $("#c-school_id").val()}};
  60. });
  61. },
  62. edit: function () {
  63. Controller.api.bindevent();
  64. $("#c-area_id").on("cp:updated", function() {
  65. var citypicker = $(this).data("citypicker");
  66. var code = citypicker.getCode("district");
  67. $("#c-area_id").val(code);
  68. $("#areaid").val(code);
  69. $("#c-school_id").val("");
  70. $("#c-school_id_text").val("");
  71. $("#c-grade_id").val("");
  72. $("#c-grade_id_text").val("");
  73. $("#c-name").val("");
  74. });
  75. $("#c-school_id").on("change", function() {
  76. $("#c-grade_id").val("");
  77. $("#c-grade_id_text").val("");
  78. $("#c-name").val("");
  79. });
  80. $("#c-grade_id").on("change", function() {
  81. $("#c-name").val("");
  82. });
  83. $("#c-school_id").data("params", function (obj) {
  84. return {custom: {area_id: $("#areaid").val()}};
  85. });
  86. $("#c-grade_id").data("params", function (obj) {
  87. return {custom: {school_id: $("#c-school_id").val()}};
  88. });
  89. },
  90. api: {
  91. bindevent: function () {
  92. Form.api.bindevent($("form[role=form]"));
  93. }
  94. }
  95. };
  96. return Controller;
  97. });