index.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. <template>
  2. <div class="p-2">
  3. <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave">
  4. <div v-show="showSearch" class="mb-[10px]">
  5. <el-card shadow="hover">
  6. <el-form ref="queryFormRef" :model="queryParams" :inline="true">
  7. <el-form-item label="品牌名称" prop="brandName">
  8. <el-input v-model="queryParams.brandName" placeholder="请输入品牌名称" clearable @keyup.enter="handleQuery" />
  9. </el-form-item>
  10. <el-form-item label="品牌编号" prop="brandNo">
  11. <el-input v-model="queryParams.brandNo" placeholder="请输入品牌编号" clearable @keyup.enter="handleQuery" />
  12. </el-form-item>
  13. <el-form-item>
  14. <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
  15. <el-button icon="Refresh" @click="resetQuery">重置</el-button>
  16. </el-form-item>
  17. </el-form>
  18. </el-card>
  19. </div>
  20. </transition>
  21. <el-card shadow="never">
  22. <template #header>
  23. <el-row :gutter="10" class="mb8">
  24. <el-col :span="1.5">
  25. <el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['product:brand:add']">新增品牌</el-button>
  26. </el-col>
  27. <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
  28. </el-row>
  29. </template>
  30. <el-table v-loading="loading" border :data="brandList" @selection-change="handleSelectionChange">
  31. <el-table-column type="selection" width="55" align="center" />
  32. <el-table-column label="品牌编号" align="center" prop="brandNo" width="120" />
  33. <el-table-column label="品牌名称" align="center" prop="brandName" />
  34. <el-table-column label="是否有授权" align="center" prop="license" width="120">
  35. <template #default="scope">
  36. <span>{{ scope.row.license ? '是' : '无' }}</span>
  37. </template>
  38. </el-table-column>
  39. <el-table-column label="授权区域" align="center" prop="position" show-overflow-tooltip>
  40. <template #default="scope">
  41. <span>{{ scope.row.position || '无' }}</span>
  42. </template>
  43. </el-table-column>
  44. <el-table-column label="到期时间" align="center" prop="expireTime" width="120">
  45. <template #default="scope">
  46. <span>{{ scope.row.expireTime ? parseTime(scope.row.expireTime, '{y}-{m}-{d}') : '无' }}</span>
  47. </template>
  48. </el-table-column>
  49. <el-table-column label="操作" align="center" class-name="small-padding fixed-width" width="180">
  50. <template #default="scope">
  51. <el-tooltip content="查看" placement="top">
  52. <el-button link type="primary" icon="View" @click="handleUpdate(scope.row)" v-hasPermi="['product:brand:query']">查看</el-button>
  53. </el-tooltip>
  54. <el-tooltip content="编辑" placement="top">
  55. <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['product:brand:edit']">编辑</el-button>
  56. </el-tooltip>
  57. <el-tooltip content="删除" placement="top">
  58. <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['product:brand:remove']">删除</el-button>
  59. </el-tooltip>
  60. </template>
  61. </el-table-column>
  62. </el-table>
  63. <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
  64. </el-card>
  65. <!-- 添加或修改产品品牌信息对话框 -->
  66. <el-dialog :title="dialog.title" v-model="dialog.visible" width="500px" append-to-body>
  67. <el-form ref="brandFormRef" :model="form" :rules="rules" label-width="80px">
  68. <el-form-item label="品牌编号" prop="brandNo">
  69. <el-input v-model="form.brandNo" placeholder="请输入品牌编号" />
  70. </el-form-item>
  71. <el-form-item label="品牌中文名称" prop="brandName">
  72. <el-input v-model="form.brandName" placeholder="请输入品牌中文名称" />
  73. </el-form-item>
  74. <el-form-item label="品牌首字母缩写" prop="brandInitials">
  75. <el-input v-model="form.brandInitials" placeholder="请输入品牌首字母缩写" />
  76. </el-form-item>
  77. <el-form-item label="品牌英文名称" prop="brandEnglishName">
  78. <el-input v-model="form.brandEnglishName" placeholder="请输入品牌英文名称" />
  79. </el-form-item>
  80. <el-form-item label="推荐值" prop="recommendValue">
  81. <el-input v-model="form.recommendValue" placeholder="请输入推荐值" />
  82. </el-form-item>
  83. <el-form-item label="品牌Logo图片路径或URL" prop="brandLogo">
  84. <el-input v-model="form.brandLogo" placeholder="请输入品牌Logo图片路径或URL" />
  85. </el-form-item>
  86. <el-form-item label="品牌标题" prop="brandTitle">
  87. <el-input v-model="form.brandTitle" placeholder="请输入品牌标题" />
  88. </el-form-item>
  89. <el-form-item label="品牌大图" prop="brandBigImage">
  90. <image-upload v-model="form.brandBigImage"/>
  91. </el-form-item>
  92. <el-form-item label="品牌故事" prop="brandStory">
  93. <el-input v-model="form.brandStory" type="textarea" placeholder="请输入内容" />
  94. </el-form-item>
  95. <el-form-item label="是否显示" prop="isShow">
  96. <el-input v-model="form.isShow" placeholder="请输入是否显示" />
  97. </el-form-item>
  98. <el-form-item label="品牌注册人" prop="brandRegistrant">
  99. <el-input v-model="form.brandRegistrant" placeholder="请输入品牌注册人" />
  100. </el-form-item>
  101. <el-form-item label="许可证编号" prop="license">
  102. <el-input v-model="form.license" placeholder="请输入许可证编号" />
  103. </el-form-item>
  104. <el-form-item label="注册证书编号" prop="registrationCertificate">
  105. <el-input v-model="form.registrationCertificate" placeholder="请输入注册证书编号" />
  106. </el-form-item>
  107. <el-form-item label="证书/许可过期时间" prop="expireTime">
  108. <el-date-picker clearable
  109. v-model="form.expireTime"
  110. type="datetime"
  111. value-format="YYYY-MM-DD HH:mm:ss"
  112. placeholder="请选择证书/许可过期时间">
  113. </el-date-picker>
  114. </el-form-item>
  115. <el-form-item label="品牌描述" prop="brandDescribe">
  116. <el-input v-model="form.brandDescribe" type="textarea" placeholder="请输入内容" />
  117. </el-form-item>
  118. <el-form-item label="展示位置" prop="position">
  119. <el-input v-model="form.position" placeholder="请输入展示位置" />
  120. </el-form-item>
  121. <el-form-item label="关注度/收藏数" prop="care">
  122. <el-input v-model="form.care" placeholder="请输入关注度/收藏数" />
  123. </el-form-item>
  124. <el-form-item label="数据来源" prop="dataSource">
  125. <el-input v-model="form.dataSource" placeholder="请输入数据来源" />
  126. </el-form-item>
  127. <el-form-item label="备注" prop="remark">
  128. <el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
  129. </el-form-item>
  130. </el-form>
  131. <template #footer>
  132. <div class="dialog-footer">
  133. <el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
  134. <el-button @click="cancel">取 消</el-button>
  135. </div>
  136. </template>
  137. </el-dialog>
  138. </div>
  139. </template>
  140. <script setup name="Brand" lang="ts">
  141. import { listBrand, getBrand, delBrand, addBrand, updateBrand } from '@/api/product/brand';
  142. import { BrandVO, BrandQuery, BrandForm } from '@/api/product/brand/types';
  143. const { proxy } = getCurrentInstance() as ComponentInternalInstance;
  144. const router = useRouter();
  145. const brandList = ref<BrandVO[]>([]);
  146. const buttonLoading = ref(false);
  147. const loading = ref(true);
  148. const showSearch = ref(true);
  149. const ids = ref<Array<string | number>>([]);
  150. const single = ref(true);
  151. const multiple = ref(true);
  152. const total = ref(0);
  153. const queryFormRef = ref<ElFormInstance>();
  154. const brandFormRef = ref<ElFormInstance>();
  155. const dialog = reactive<DialogOption>({
  156. visible: false,
  157. title: ''
  158. });
  159. const initFormData: BrandForm = {
  160. id: undefined,
  161. brandNo: undefined,
  162. brandName: undefined,
  163. brandInitials: undefined,
  164. brandEnglishName: undefined,
  165. recommendValue: undefined,
  166. brandLogo: undefined,
  167. brandTitle: undefined,
  168. brandBigImage: undefined,
  169. brandStory: undefined,
  170. isShow: undefined,
  171. brandRegistrant: undefined,
  172. license: undefined,
  173. registrationCertificate: undefined,
  174. expireTime: undefined,
  175. brandDescribe: undefined,
  176. position: undefined,
  177. care: undefined,
  178. dataSource: undefined,
  179. remark: undefined,
  180. }
  181. const data = reactive<PageData<BrandForm, BrandQuery>>({
  182. form: {...initFormData},
  183. queryParams: {
  184. pageNum: 1,
  185. pageSize: 10,
  186. brandNo: undefined,
  187. brandName: undefined,
  188. brandInitials: undefined,
  189. brandEnglishName: undefined,
  190. recommendValue: undefined,
  191. brandLogo: undefined,
  192. brandTitle: undefined,
  193. brandBigImage: undefined,
  194. brandStory: undefined,
  195. isShow: undefined,
  196. brandRegistrant: undefined,
  197. license: undefined,
  198. registrationCertificate: undefined,
  199. expireTime: undefined,
  200. brandDescribe: undefined,
  201. position: undefined,
  202. care: undefined,
  203. dataSource: undefined,
  204. platformCode: undefined,
  205. params: {
  206. }
  207. },
  208. rules: {
  209. brandInitials: [
  210. { required: true, message: "品牌首字母缩写不能为空", trigger: "blur" }
  211. ],
  212. brandEnglishName: [
  213. { required: true, message: "品牌英文名称不能为空", trigger: "blur" }
  214. ],
  215. recommendValue: [
  216. { required: true, message: "推荐值不能为空", trigger: "blur" }
  217. ],
  218. brandLogo: [
  219. { required: true, message: "品牌Logo图片路径或URL不能为空", trigger: "blur" }
  220. ],
  221. brandTitle: [
  222. { required: true, message: "品牌标题不能为空", trigger: "blur" }
  223. ],
  224. brandBigImage: [
  225. { required: true, message: "品牌大图不能为空", trigger: "blur" }
  226. ],
  227. brandStory: [
  228. { required: true, message: "品牌故事不能为空", trigger: "blur" }
  229. ],
  230. isShow: [
  231. { required: true, message: "是否显示不能为空", trigger: "blur" }
  232. ],
  233. brandRegistrant: [
  234. { required: true, message: "品牌注册人不能为空", trigger: "blur" }
  235. ],
  236. license: [
  237. { required: true, message: "许可证编号不能为空", trigger: "blur" }
  238. ],
  239. registrationCertificate: [
  240. { required: true, message: "注册证书编号不能为空", trigger: "blur" }
  241. ],
  242. expireTime: [
  243. { required: true, message: "证书/许可过期时间不能为空", trigger: "blur" }
  244. ],
  245. brandDescribe: [
  246. { required: true, message: "品牌描述不能为空", trigger: "blur" }
  247. ],
  248. position: [
  249. { required: true, message: "展示位置不能为空", trigger: "blur" }
  250. ],
  251. dataSource: [
  252. { required: true, message: "数据来源不能为空", trigger: "blur" }
  253. ],
  254. remark: [
  255. { required: true, message: "备注不能为空", trigger: "blur" }
  256. ],
  257. }
  258. });
  259. const { queryParams, form, rules } = toRefs(data);
  260. /** 查询产品品牌信息列表 */
  261. const getList = async () => {
  262. loading.value = true;
  263. const res = await listBrand(queryParams.value);
  264. brandList.value = res.rows;
  265. total.value = res.total;
  266. loading.value = false;
  267. }
  268. /** 取消按钮 */
  269. const cancel = () => {
  270. reset();
  271. dialog.visible = false;
  272. }
  273. /** 表单重置 */
  274. const reset = () => {
  275. form.value = {...initFormData};
  276. brandFormRef.value?.resetFields();
  277. }
  278. /** 搜索按钮操作 */
  279. const handleQuery = () => {
  280. queryParams.value.pageNum = 1;
  281. getList();
  282. }
  283. /** 重置按钮操作 */
  284. const resetQuery = () => {
  285. queryFormRef.value?.resetFields();
  286. handleQuery();
  287. }
  288. /** 多选框选中数据 */
  289. const handleSelectionChange = (selection: BrandVO[]) => {
  290. ids.value = selection.map(item => item.id);
  291. single.value = selection.length != 1;
  292. multiple.value = !selection.length;
  293. }
  294. /** 新增按钮操作 */
  295. const handleAdd = () => {
  296. router.push({
  297. path: '/product/brand/edit',
  298. query: {
  299. type: 'add'
  300. }
  301. });
  302. }
  303. /** 修改按钮操作 */
  304. const handleUpdate = async (row?: BrandVO) => {
  305. const _id = row?.id || ids.value[0];
  306. router.push({
  307. path: '/product/brand/edit',
  308. query: {
  309. id: _id,
  310. type: 'edit'
  311. }
  312. });
  313. }
  314. /** 提交按钮 */
  315. const submitForm = () => {
  316. brandFormRef.value?.validate(async (valid: boolean) => {
  317. if (valid) {
  318. buttonLoading.value = true;
  319. if (form.value.id) {
  320. await updateBrand(form.value).finally(() => buttonLoading.value = false);
  321. } else {
  322. await addBrand(form.value).finally(() => buttonLoading.value = false);
  323. }
  324. proxy?.$modal.msgSuccess("操作成功");
  325. dialog.visible = false;
  326. await getList();
  327. }
  328. });
  329. }
  330. /** 删除按钮操作 */
  331. const handleDelete = async (row?: BrandVO) => {
  332. const _ids = row?.id || ids.value;
  333. await proxy?.$modal.confirm('是否确认删除产品品牌信息编号为"' + _ids + '"的数据项?').finally(() => loading.value = false);
  334. await delBrand(_ids);
  335. proxy?.$modal.msgSuccess("删除成功");
  336. await getList();
  337. }
  338. /** 导出按钮操作 */
  339. const handleExport = () => {
  340. proxy?.download('product/brand/export', {
  341. ...queryParams.value
  342. }, `brand_${new Date().getTime()}.xlsx`)
  343. }
  344. onMounted(() => {
  345. getList();
  346. });
  347. </script>