vue3.txt 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. <template>
  2. <view class="container">
  3. <view class="search-bar">
  4. 总:{{total}}
  5. <view class="right">
  6. $if(replaceDto.ShowBtnAdd)
  7. <view class="iconfont margin-right" v-if="checkPermi(['${replaceDto.PermissionPrefix}:add'])" @click="handleAdd">新增</view>
  8. $end
  9. <view class="iconfont icon-filter icon" @click="show = true">筛选 </view>
  10. </view>
  11. </view>
  12. <u-gap height="5"></u-gap>
  13. <view class="info-item" v-for="(item,index) in dataList" :key="index">
  14. $foreach(column in genTable.Columns)
  15. $set(labelName = column.ColumnComment)
  16. $set(columnName = column.CsharpFieldFl)
  17. $if(column.IsList == true)
  18. $if(column.HtmlType == "imageUpload")
  19. <view class="info-line">
  20. <text class="label-name">${labelName}</text>
  21. <imagePreview :src="item.${columnName}"></imagePreview>
  22. </view>
  23. $elseif(column.HtmlType == "checkbox" || column.HtmlType == "select" || column.HtmlType == "radio")
  24. <view class="info-line">
  25. <text class="label-name">${labelName}</text>
  26. $if(column.HtmlType == "checkbox")
  27. <dictTag :options="$if(column.DictType != "")options.${column.DictType}$else options.${column.CsharpFieldFl}Options$end" :value="item.${columnName} ? item.${columnName}.split(',') : []" />
  28. $else
  29. <dictTag :options="$if(column.DictType != "")options.${column.DictType}$else options.${column.CsharpFieldFl}Options$end" :value="item.${columnName}" />
  30. $end
  31. </view>
  32. $else
  33. <view class="info-line">
  34. <text class="label-name">${labelName}</text>
  35. <text>{{item.${columnName}}}</text>
  36. </view>
  37. $end
  38. $end
  39. $end
  40. <view class="info-btn-wrap justify-end">
  41. $if(replaceDto.ShowBtnView)
  42. <view class="tag-item">
  43. <u-tag text="详情" plain shape="circle" type="info" icon="eye" @click="handleView(item)"
  44. v-if="checkPermi(['${replaceDto.PermissionPrefix}:query'])"></u-tag>
  45. </view>
  46. $end
  47. $if(replaceDto.ShowBtnEdit)
  48. <view class="tag-item">
  49. <u-tag text="编辑" plain shape="circle" icon="edit-pen" @click="handleEdit(item)"
  50. v-if="checkPermi(['${replaceDto.PermissionPrefix}:edit'])"></u-tag>
  51. </view>
  52. $end
  53. $if(replaceDto.ShowBtnDelete || replaceDto.ShowBtnMultiDel)
  54. <view class="tag-item">
  55. <u-tag text="删除" class="tag-item" plain shape="circle" type="error" icon="trash"
  56. v-if="checkPermi(['userinfo:delete'])" @click="handleDelete(item)"></u-tag>
  57. </view>
  58. $end
  59. </view>
  60. <u-line dashed></u-line>
  61. </view>
  62. <view class="page-footer">
  63. <u-empty mode="list" :marginTop="140" v-if="total == 0"></u-empty>
  64. <uni-pagination v-else show-icon="true" :total="total" :pageSize="queryParams.pageSize"
  65. :current="queryParams.pageNum" @change="getData"></uni-pagination>
  66. <view class="text-grey padding text-center"> 共 {{ total }}条数据 </view>
  67. </view>
  68. <u-popup :show="show" mode="bottom" @close="show = false" @open="show = true">
  69. <view class="search-form">
  70. <view class="search-title">搜索</view>
  71. <up-form labelPosition="left" :model="queryParams" labelWidth="100px" ref="uForm">
  72. <up-form-item label="排序字段" prop="sort" borderBottom>
  73. <uni-data-select v-model="queryParams.sort" :clear="true" :localdata="sortOptions"
  74. format="{label}"></uni-data-select>
  75. </up-form-item>
  76. <up-form-item label="排序方式" prop="sortType" borderBottom ref="item1">
  77. <u-radio-group v-model="queryParams.sortType">
  78. <u-radio label="升序" name="asc" :customStyle="{marginRight: '20px'}"></u-radio>
  79. <u-radio label="倒序" name="desc"></u-radio>
  80. </u-radio-group>
  81. </up-form-item>
  82. <u-gap height="30"></u-gap>
  83. $foreach(column in genTable.Columns)
  84. $set(labelName = "")
  85. $set(columnName = "")
  86. $if(column.IsQuery == true)
  87. $set(columnName = column.CsharpFieldFl)
  88. $if(column.ColumnComment != "")
  89. $set(labelName = column.ColumnComment)
  90. $else
  91. $set(labelName = column.CsharpFieldFl)
  92. $end
  93. $if(column.HtmlType == "datetime")
  94. <up-form-item label="时间查询">
  95. <uni-datetime-picker :border="false" v-model="dateRange${column.CsharpField}" type="daterange" />
  96. </up-form-item>
  97. $elseif(column.HtmlType == "radio" || column.HtmlType == "select")
  98. <up-form-item label="${labelName}" prop="${column.CsharpFieldFl}" borderBottom ref="item2">
  99. <view class="tag-wrap">
  100. <view class="tag-item">
  101. <u-tag text="全部" :plain="null != queryParams.${column.CsharpFieldFl}" name="" @click="queryParams.${column.CsharpFieldFl} = null">
  102. </u-tag>
  103. </view>
  104. <view class="tag-item" v-for="(item, index) in $if(column.DictType != "")options.${column.DictType} $else options.${column.CsharpFieldFl}Options$end" :key="index">
  105. <u-tag :text="item.label" :plain="item.value != queryParams.${column.CsharpFieldFl}" :name="item.value"
  106. @click="${column.CsharpFieldFl}Select(item)">
  107. </u-tag>
  108. </view>
  109. </view>
  110. </up-form-item>
  111. $else
  112. <up-form-item label="${labelName}" prop="${column.CsharpFieldFl}" borderBottom ref="item1">
  113. <u--input v-model="queryParams.${column.CsharpFieldFl}" border="none" placeholder="请输入${labelName}"></u--input>
  114. </up-form-item>
  115. $end
  116. $end
  117. $end
  118. </up-form>
  119. <view class="btn-group">
  120. <u-button text="重置" icon="reload" :customStyle="{marginRight: '10px'}" shape="circle" type="success"
  121. @click="resetQuery"></u-button>
  122. <u-button text="搜索" icon="search" shape="circle" type="primary" @click="handleQuery"></u-button>
  123. </view>
  124. </view>
  125. </u-popup>
  126. <u-back-top :scroll-top="scrollTop" :bottom="180"></u-back-top>
  127. </view>
  128. </template>
  129. <script setup>
  130. import {
  131. checkPermi
  132. } from '@/utils/permission.js'
  133. import {
  134. list${genTable.BusinessName},
  135. $if(replaceDto.ShowBtnDelete)
  136. del${genTable.BusinessName},
  137. $end
  138. } from '@/api/${tool.FirstLowerCase(genTable.ModuleName)}/${genTable.BusinessName.ToLower()}.js'
  139. import {
  140. getCurrentInstance,
  141. reactive,
  142. ref,
  143. toRefs
  144. } from 'vue';
  145. const {
  146. proxy
  147. } = getCurrentInstance()
  148. import {
  149. onPullDownRefresh,
  150. onShow
  151. } from '@dcloudio/uni-app'
  152. const queryParams = reactive({
  153. pageNum: 1,
  154. pageSize: 20,
  155. sort: '${genTable.Options.SortField}',
  156. sortType: '${genTable.Options.SortType}',
  157. $foreach(item in genTable.Columns)
  158. $if(item.IsQuery == true)
  159. ${item.CsharpFieldFl}: undefined,
  160. $end
  161. $end
  162. })
  163. $foreach(item in genTable.Columns)
  164. $if((item.HtmlType == "datetime" || item.HtmlType == "datePicker") && item.IsQuery == true)
  165. // ${item.ColumnComment}时间范围
  166. const dateRange${item.CsharpField} = ref([])
  167. $end
  168. $end
  169. $set(index = 0)
  170. var dictParams = [
  171. $foreach(item in dicts)
  172. $if(item.DictType != "")
  173. '${item.DictType}',
  174. $set(index = index + 1)
  175. $end
  176. $end
  177. ]
  178. $if(index > 0)
  179. proxy.getDicts(dictParams).then((response) => {
  180. response.data.forEach((element) => {
  181. state.options[element.dictType] = element.list
  182. })
  183. })
  184. $end
  185. const scrollTop = ref(0)
  186. const state = reactive({
  187. dataList: [],
  188. total: 0,
  189. show: false,
  190. loading: false,
  191. options: {
  192. $foreach(column in dicts)
  193. $if(column.HtmlType == "radio" || column.HtmlType.Contains("select") || column.HtmlType == "checkbox")
  194. //$if(column.ColumnComment != "") ${column.ColumnComment} $else ${column.CsharpFieldFl}$end选项列表 格式 eg:{ label: '标签', value: '0'}
  195. $if(column.DictType != "") ${column.DictType}$else ${column.CsharpFieldFl}Options$end: [],
  196. $end
  197. $end
  198. },
  199. // 排序集合 格式 eg:{ label: '名称', value: 'userId'}
  200. sortOptions: [
  201. $foreach(column in genTable.Columns)
  202. $if(column.IsSort)
  203. {
  204. label: '${column.ColumnComment}',
  205. value: '${column.CsharpFieldFl}'
  206. },
  207. $end
  208. $end
  209. ]
  210. })
  211. const {
  212. options,
  213. dataList,
  214. total,
  215. show,
  216. loading,
  217. sortOptions
  218. } = toRefs(state)
  219. function getList() {
  220. uni.showLoading({
  221. title: 'loading...'
  222. })
  223. state.loading = true
  224. $foreach(item in genTable.Columns)
  225. $if((item.HtmlType == "datetime" || item.HtmlType == "datePicker") && item.IsQuery == true)
  226. proxy.addDateRange(queryParams, dateRange${item.CsharpField}.value, '${item.CsharpField}');
  227. $end
  228. $end
  229. list${genTable.BusinessName}(queryParams).then(res => {
  230. if (res.code == 200) {
  231. dataList.value = [...dataList.value, ...res.data.result]
  232. total.value = res.data.totalNum;
  233. state.loaing = false
  234. }
  235. }).finally(() => {
  236. uni.hideLoading()
  237. })
  238. }
  239. $if(replaceDto.ShowBtnAdd)
  240. function handleAdd() {
  241. proxy.${tab}tab.navigateTo('./edit?opertype=1')
  242. }
  243. $end
  244. $if(replaceDto.ShowBtnEdit)
  245. function handleEdit(e) {
  246. proxy.${tab}tab.navigateTo('./edit?opertype=2&${replaceDto.FistLowerPk}=' + e.id)
  247. }
  248. $end
  249. $if(replaceDto.ShowBtnView)
  250. function handleView(e) {
  251. proxy.${tab}tab.navigateTo('./edit?opertype=3&${replaceDto.FistLowerPk}=' + e.id)
  252. }
  253. $end
  254. $if(replaceDto.ShowBtnDelete || replaceDto.ShowBtnMultiDel)
  255. function handleDelete(row) {
  256. const Ids = row.${replaceDto.FistLowerPk};
  257. proxy.${modal}modal.confirm('你确定要删除吗?').then(() => {
  258. return del${genTable.BusinessName}(Ids);
  259. })
  260. .then(() => {
  261. handleQuery()
  262. proxy.${modal}modal.msgSuccess("删除成功");
  263. })
  264. }
  265. $end
  266. function resetQuery() {
  267. proxy.${refs}refs.uForm.resetFields()
  268. $foreach(column in genTable.Columns)
  269. $if(column.HtmlType == "datetime" && column.IsQuery == true)
  270. dateRange${column.CsharpField}.value = []
  271. $end
  272. $end
  273. }
  274. function handleQuery(refresh) {
  275. queryParams.pageNum = 1;
  276. dataList.value = []
  277. state.show = false
  278. if (refresh) {
  279. uni.startPullDownRefresh();
  280. }
  281. getList()
  282. }
  283. function getData(e) {
  284. queryParams.pageNum = e.current
  285. getList()
  286. }
  287. onPullDownRefresh(() => {
  288. uni.stopPullDownRefresh()
  289. handleQuery(true)
  290. })
  291. $foreach(column in genTable.Columns)
  292. $if(column.IsQuery == true)
  293. $if(column.HtmlType == "radio" || column.HtmlType == "select")
  294. function ${column.CsharpFieldFl}Select(e) {
  295. queryParams.${column.CsharpFieldFl} = e.value
  296. }
  297. $end
  298. $end
  299. $end
  300. function onPageScroll(e) {
  301. scrollTop.value = e.scrollTop;
  302. }
  303. getList()
  304. </script>
  305. <style lang="scss" scoped>
  306. @import "@/static/scss/page.scss";
  307. </style>