Kaynağa Gözat

产品管理

chenlei1231 3 ay önce
ebeveyn
işleme
3d27a6c30e

+ 20 - 37
src/views/adweb/product/AdwebProduct.data.ts

@@ -6,77 +6,62 @@ import { getWeekMonthQuarterYear } from '/@/utils';
 //列表数据
 export const columns: BasicColumn[] = [
   {
-    title: '创建人',
-    align: 'center',
-    dataIndex: 'createBy',
-  },
-  {
     title: '创建日期',
     align: 'center',
     dataIndex: 'createTime',
   },
   {
-    title: '更新人',
-    align: 'center',
-    dataIndex: 'updateBy',
-  },
-  {
     title: '更新日期',
     align: 'center',
     dataIndex: 'updateTime',
   },
   {
-    title: '站点code',
+    title: '站点推送时间',
     align: 'center',
-    dataIndex: 'siteCode',
+    dataIndex: 'requestTime',
   },
   {
-    title: 'mq生产时间',
+    title: '站点名称',
     align: 'center',
-    dataIndex: 'requestTime',
+    dataIndex: 'siteCode_dictText',
   },
   {
-    title: 'wp产品ID',
+    title: '产品ID',
     align: 'center',
     dataIndex: 'productId',
   },
   {
-    title: 'wp产品类型,adwebpro or woocommerce',
+    title: '产品类型',
     align: 'center',
     dataIndex: 'productType',
   },
   {
-    title: 'wp产品操作类型, add, edit, delete',
+    title: '产品状态',
     align: 'center',
     dataIndex: 'actionType',
   },
   {
-    title: 'wp产品名称',
+    title: '产品名称',
     align: 'center',
     dataIndex: 'productName',
   },
   {
-    title: 'wp产品中文名称',
+    title: '产品中文名称',
     align: 'center',
-    dataIndex: 'productsNameZh',
+    dataIndex: 'productNameZh',
   },
   {
-    title: 'wp产品封面图',
+    title: '产品封面图',
     align: 'center',
     dataIndex: 'productImage',
   },
   {
-    title: 'wp产品图库',
-    align: 'center',
-    dataIndex: 'productGalleryImage',
-  },
-  {
-    title: 'wp产品分类',
+    title: '产品分类',
     align: 'center',
     dataIndex: 'categoryName',
   },
   {
-    title: 'wp产品作者',
+    title: '产品作者',
     align: 'center',
     dataIndex: 'authorName',
   },
@@ -90,13 +75,11 @@ export const superQuerySchema = {
   updateTime: { title: '更新日期', order: 3, view: 'datetime', type: 'string' },
   siteCode: { title: '站点code', order: 4, view: 'text', type: 'string' },
   requestTime: { title: 'mq生产时间', order: 5, view: 'text', type: 'string' },
-  productId: { title: 'wp产品ID', order: 6, view: 'number', type: 'number' },
-  productType: { title: 'wp产品类型,adwebpro or woocommerce', order: 7, view: 'text', type: 'string' },
-  actionType: { title: 'wp产品操作类型, add, edit, delete', order: 8, view: 'text', type: 'string' },
-  productName: { title: 'wp产品名称', order: 9, view: 'text', type: 'string' },
-  productsNameZh: { title: 'wp产品中文名称', order: 10, view: 'text', type: 'string' },
-  productImage: { title: 'wp产品封面图', order: 11, view: 'text', type: 'string' },
-  productGalleryImage: { title: 'wp产品图库', order: 12, view: 'text', type: 'string' },
-  categoryName: { title: 'wp产品分类', order: 13, view: 'text', type: 'string' },
-  authorName: { title: 'wp产品作者', order: 14, view: 'text', type: 'string' },
+  productId: { title: '产品ID', order: 6, view: 'number', type: 'number' },
+  productType: { title: '产品类型', order: 7, view: 'text', type: 'string' },
+  actionType: { title: '产品操状态', order: 8, view: 'text', type: 'string' },
+  productName: { title: '产品名称', order: 9, view: 'text', type: 'string' },
+  productsNameZh: { title: '产品中文名称', order: 10, view: 'text', type: 'string' },
+  categoryName: { title: '产品分类', order: 13, view: 'text', type: 'string' },
+  authorName: { title: '产品作者', order: 14, view: 'text', type: 'string' },
 };

+ 55 - 69
src/views/adweb/product/AdwebProductList.vue

@@ -5,20 +5,13 @@
       <a-form ref="formRef" @keyup.enter.native="searchQuery" :model="queryParam" :label-col="labelCol" :wrapper-col="wrapperCol">
         <a-row :gutter="24">
           <a-col :lg="6">
-            <a-form-item name="siteCode">
-              <template #label><span title="站点code">站点co</span></template>
-              <a-input placeholder="请输入站点code" v-model:value="queryParam.siteCode" allow-clear ></a-input>
-            </a-form-item>
+            <select-site ref="selectSiteRef" @set-site-info="getSiteList" select-width="100%" />
           </a-col>
           <a-col :xl="6" :lg="7" :md="8" :sm="24">
             <span style="float: left; overflow: hidden" class="table-page-search-submitButtons">
               <a-col :lg="6">
                 <a-button type="primary" preIcon="ant-design:search-outlined" @click="searchQuery">查询</a-button>
                 <a-button type="primary" preIcon="ant-design:reload-outlined" @click="searchReset" style="margin-left: 8px">重置</a-button>
-                <a @click="toggleSearchStatus = !toggleSearchStatus" style="margin-left: 8px">
-                  {{ toggleSearchStatus ? '收起' : '展开' }}
-                  <Icon :icon="toggleSearchStatus ? 'ant-design:up-outlined' : 'ant-design:down-outlined'" />
-                </a>
               </a-col>
             </span>
           </a-col>
@@ -29,34 +22,20 @@
     <BasicTable @register="registerTable" :rowSelection="rowSelection">
       <!--插槽:table标题-->
       <template #tableTitle>
-        <a-button type="primary" @click="handleAdd" preIcon="ant-design:plus-outlined"> 新增</a-button>
-        <a-button  type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"> 导出</a-button>
-        <j-upload-button  type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>
-        <a-dropdown v-if="selectedRowKeys.length > 0">
-          <template #overlay>
-            <a-menu>
-              <a-menu-item key="1" @click="batchHandleDelete">
-                <Icon icon="ant-design:delete-outlined"></Icon>
-                删除
-              </a-menu-item>
-            </a-menu>
-          </template>
-          <a-button>批量操作
-            <Icon icon="mdi:chevron-down"></Icon>
-          </a-button>
-        </a-dropdown>
+        <!--        <a-button type="primary" @click="handleAdd" preIcon="ant-design:plus-outlined"> 新增</a-button>-->
+        <a-button type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"> 导出</a-button>
+        <!--        <j-upload-button type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>-->
         <!-- 高级查询 -->
         <super-query :config="superQueryConfig" @search="handleSuperQuery" />
       </template>
       <!--操作栏-->
       <template #action="{ record }">
-        <TableAction :actions="getTableAction(record)" :dropDownActions="getDropDownAction(record)"/>
-      </template>
-      <template v-slot:bodyCell="{ column, record, index, text }">
+        <TableAction :actions="getTableAction(record)" :dropDownActions="getDropDownAction(record)" />
       </template>
+      <template #bodyCell="{ column, record, index, text }"> </template>
     </BasicTable>
     <!-- 表单区域 -->
-    <AdwebProductModal ref="registerModal" @success="handleSuccess"></AdwebProductModal>
+    <AdwebProductModal ref="registerModal" @success="handleSuccess" />
   </div>
 </template>
 
@@ -67,8 +46,9 @@
   import { columns, superQuerySchema } from './AdwebProduct.data';
   import { list, deleteOne, batchDelete, getImportUrl, getExportUrl } from './AdwebProduct.api';
   import { downloadFile } from '/@/utils/common/renderUtils';
-  import AdwebProductModal from './components/AdwebProductModal.vue'
+  import AdwebProductModal from './components/AdwebProductModal.vue';
   import { useUserStore } from '/@/store/modules/user';
+  import SelectSite from '@/components/Adweb/selectSite.vue';
 
   const formRef = ref();
   const queryParam = reactive<any>({});
@@ -81,8 +61,9 @@
       title: 'wp站点产品',
       api: list,
       columns,
-      canResize:false,
+      canResize: false,
       useSearchForm: false,
+      immediate: false, // 不直接触发,通过reload事件触发接口
       actionColumn: {
         width: 120,
         fixed: 'right',
@@ -92,21 +73,22 @@
       },
     },
     exportConfig: {
-      name: "wp站点产品",
+      name: 'wp站点产品',
       url: getExportUrl,
       params: queryParam,
     },
-	  importConfig: {
-	    url: getImportUrl,
-	    success: handleSuccess
-	  },
+    importConfig: {
+      url: getImportUrl,
+      success: handleSuccess,
+    },
   });
-  const [registerTable, { reload, collapseAll, updateTableDataRecord, findTableDataRecord, getDataSource }, { rowSelection, selectedRowKeys }] = tableContext;
+  const [registerTable, { reload, collapseAll, updateTableDataRecord, findTableDataRecord, getDataSource }, { rowSelection, selectedRowKeys }] =
+    tableContext;
   const labelCol = reactive({
-    xs:24,
-    sm:4,
-    xl:6,
-    xxl:4
+    xs: 24,
+    sm: 4,
+    xl: 6,
+    xxl: 4,
   });
   const wrapperCol = reactive({
     xs: 24,
@@ -133,7 +115,7 @@
     registerModal.value.disableSubmit = false;
     registerModal.value.add();
   }
-  
+
   /**
    * 编辑事件
    */
@@ -141,7 +123,7 @@
     registerModal.value.disableSubmit = false;
     registerModal.value.edit(record);
   }
-   
+
   /**
    * 详情
    */
@@ -149,57 +131,58 @@
     registerModal.value.disableSubmit = true;
     registerModal.value.edit(record);
   }
-   
+
   /**
    * 删除事件
    */
   async function handleDelete(record) {
     await deleteOne({ id: record.id }, handleSuccess);
   }
-   
+
   /**
    * 批量删除事件
    */
   async function batchHandleDelete() {
     await batchDelete({ ids: selectedRowKeys.value }, handleSuccess);
   }
-   
+
   /**
    * 成功回调
    */
   function handleSuccess() {
     (selectedRowKeys.value = []) && reload();
   }
-   
+
   /**
    * 操作栏
    */
   function getTableAction(record) {
     return [
       {
-        label: '编辑',
-        onClick: handleEdit.bind(null, record),
+        label: '详情',
+        onClick: handleDetail.bind(null, record),
       },
     ];
   }
-   
+
   /**
    * 下拉操作栏
    */
   function getDropDownAction(record) {
     return [
-      {
-        label: '详情',
-        onClick: handleDetail.bind(null, record),
-      }, {
-        label: '删除',
-        popConfirm: {
-          title: '是否确认删除',
-          confirm: handleDelete.bind(null, record),
-          placement: 'topLeft',
-        }
-      }
-    ]
+      // {
+      //   label: '详情',
+      //   onClick: handleDetail.bind(null, record),
+      // },
+      // {
+      //   label: '删除',
+      //   popConfirm: {
+      //     title: '是否确认删除',
+      //     confirm: handleDelete.bind(null, record),
+      //     placement: 'topLeft',
+      //   },
+      // },
+    ];
   }
 
   /**
@@ -208,7 +191,7 @@
   function searchQuery() {
     reload();
   }
-  
+
   /**
    * 重置
    */
@@ -218,10 +201,12 @@
     //刷新数据
     reload();
   }
-  
-
 
+  function getSiteList(selectedSiteInfo: any) {
+    queryParam.siteCode = selectedSiteInfo.code;
 
+    reload();
+  }
 </script>
 
 <style lang="less" scoped>
@@ -232,19 +217,20 @@
       margin-bottom: 24px;
       white-space: nowrap;
     }
-    .query-group-cust{
+    .query-group-cust {
       min-width: 100px !important;
     }
-    .query-group-split-cust{
+    .query-group-split-cust {
       width: 30px;
       display: inline-block;
-      text-align: center
+      text-align: center;
     }
-    .ant-form-item:not(.ant-form-item-with-help){
+    .ant-form-item:not(.ant-form-item-with-help) {
       margin-bottom: 16px;
       height: 32px;
     }
-    :deep(.ant-picker),:deep(.ant-input-number){
+    :deep(.ant-picker),
+    :deep(.ant-input-number) {
       width: 100%;
     }
   }