data_table.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package builder
  2. import (
  3. "fmt"
  4. "html"
  5. "math"
  6. "strconv"
  7. "golang-fave/engine/wrapper"
  8. )
  9. type DataTableRow struct {
  10. DBField string
  11. DBExp string
  12. NameInTable string
  13. Classes string
  14. CallBack func(values *[]string) string
  15. }
  16. func DataTable(wrap *wrapper.Wrapper, table string, order_by string, order_way string, data *[]DataTableRow, action func(values *[]string) string, pagination_url string) string {
  17. var num int
  18. err := wrap.DB.QueryRow("SELECT COUNT(*) FROM `" + table + "`;").Scan(&num)
  19. if err != nil {
  20. return ""
  21. }
  22. pear_page := 10
  23. max_pages := int(math.Ceil(float64(num) / float64(pear_page)))
  24. curr_page := 1
  25. p := wrap.R.URL.Query().Get("p")
  26. if p != "" {
  27. pi, err := strconv.Atoi(p)
  28. if err != nil {
  29. curr_page = 1
  30. } else {
  31. if pi < 1 {
  32. curr_page = 1
  33. } else if pi > max_pages {
  34. curr_page = max_pages
  35. } else {
  36. curr_page = pi
  37. }
  38. }
  39. }
  40. limit_offset := curr_page*pear_page - pear_page
  41. result := `<table id="cp-table-` + table + `" class="table data-table table-striped table-bordered table-hover table_` + table + `">`
  42. result += `<thead>`
  43. result += `<tr>`
  44. sql := "SELECT"
  45. for i, column := range *data {
  46. if column.NameInTable != "" {
  47. classes := column.Classes
  48. if classes != "" {
  49. classes = " " + classes
  50. }
  51. result += `<th scope="col" class="col_` + column.DBField + classes + `">` + html.EscapeString(column.NameInTable) + `</th>`
  52. }
  53. if column.DBExp == "" {
  54. sql += " `" + column.DBField + "`"
  55. } else {
  56. sql += " " + column.DBExp + " as `" + column.DBField + "`"
  57. }
  58. if i+1 < len(*data) {
  59. sql += ","
  60. }
  61. }
  62. sql += " FROM `" + table + "` ORDER BY `" + order_by + "` " + order_way + " LIMIT ?, ?;"
  63. if action != nil {
  64. result += `<th scope="col" class="col_action">&nbsp;</th>`
  65. }
  66. result += `</tr>`
  67. result += `</thead>`
  68. result += `<tbody>`
  69. if num > 0 {
  70. rows, err := wrap.DB.Query(sql, limit_offset, pear_page)
  71. if err == nil {
  72. values := make([]string, len(*data))
  73. scan := make([]interface{}, len(values))
  74. for i := range values {
  75. scan[i] = &values[i]
  76. }
  77. for rows.Next() {
  78. err = rows.Scan(scan...)
  79. if err == nil {
  80. result += `<tr>`
  81. for i, val := range values {
  82. if (*data)[i].NameInTable != "" {
  83. classes := (*data)[i].Classes
  84. if classes != "" {
  85. classes = " " + classes
  86. }
  87. if (*data)[i].CallBack == nil {
  88. result += `<td class="col_` + (*data)[i].DBField + classes + `">` + html.EscapeString(string(val)) + `</td>`
  89. } else {
  90. result += `<td class="col_` + (*data)[i].DBField + classes + `">` + (*data)[i].CallBack(&values) + `</td>`
  91. }
  92. }
  93. }
  94. if action != nil {
  95. result += `<td class="col_action">` + action(&values) + `</td>`
  96. }
  97. result += `</tr>`
  98. }
  99. }
  100. }
  101. } else {
  102. result += `<tr><td colspan="50">No any data found</td></tr>`
  103. }
  104. result += `</tbody></table>`
  105. // Show page navigation only if pages more then one
  106. if max_pages > 1 {
  107. result += `<nav>`
  108. result += `<ul class="pagination" style="margin-bottom:0px;">`
  109. class := ""
  110. if curr_page <= 1 {
  111. class = " disabled"
  112. }
  113. result += `<li class="page-item` + class + `">`
  114. result += `<a class="page-link" href="` + pagination_url + `?p=` + fmt.Sprintf("%d", curr_page-1) + `" aria-label="Previous">`
  115. result += `<span aria-hidden="true">&laquo;</span>`
  116. result += `<span class="sr-only">Previous</span>`
  117. result += `</a>`
  118. result += `</li>`
  119. for i := 1; i <= max_pages; i++ {
  120. class = ""
  121. if i == curr_page {
  122. class = " active"
  123. }
  124. result += `<li class="page-item` + class + `">`
  125. result += `<a class="page-link" href="` + pagination_url + `?p=` + fmt.Sprintf("%d", i) + `">` + fmt.Sprintf("%d", i) + `</a>`
  126. result += `</li>`
  127. }
  128. class = ""
  129. if curr_page >= max_pages {
  130. class = " disabled"
  131. }
  132. result += `<li class="page-item` + class + `">`
  133. result += `<a class="page-link" href="` + pagination_url + `?p=` + fmt.Sprintf("%d", curr_page+1) + `" aria-label="Next">`
  134. result += `<span aria-hidden="true">&raquo;</span>`
  135. result += `<span class="sr-only">Next</span>`
  136. result += `</a>`
  137. result += `</li>`
  138. result += `</ul>`
  139. result += `</nav>`
  140. }
  141. return result
  142. }