diff --git a/src/views/admin/IssueInfo/IssueInfo.api.ts b/src/views/admin/IssueInfo/IssueInfo.api.ts
new file mode 100644
index 0000000..a8ae7dc
--- /dev/null
+++ b/src/views/admin/IssueInfo/IssueInfo.api.ts
@@ -0,0 +1,72 @@
+import { defHttp } from '/@/utils/http/axios';
+import { useMessage } from "/@/hooks/web/useMessage";
+
+const { createConfirm } = useMessage();
+
+enum Api {
+ list = '/admin/issueInfo/list',
+ save='/admin/issueInfo/add',
+ edit='/admin/issueInfo/edit',
+ deleteOne = '/admin/issueInfo/delete',
+ deleteBatch = '/admin/issueInfo/deleteBatch',
+ importExcel = '/admin/issueInfo/importExcel',
+ exportXls = '/admin/issueInfo/exportXls',
+}
+
+/**
+ * 导出api
+ * @param params
+ */
+export const getExportUrl = Api.exportXls;
+
+/**
+ * 导入api
+ */
+export const getImportUrl = Api.importExcel;
+
+/**
+ * 列表接口
+ * @param params
+ */
+export const list = (params) => defHttp.get({ url: Api.list, params });
+
+/**
+ * 删除单个
+ * @param params
+ * @param handleSuccess
+ */
+export const deleteOne = (params,handleSuccess) => {
+ return defHttp.delete({url: Api.deleteOne, params}, {joinParamsToUrl: true}).then(() => {
+ handleSuccess();
+ });
+}
+
+/**
+ * 批量删除
+ * @param params
+ * @param handleSuccess
+ */
+export const batchDelete = (params, handleSuccess) => {
+ createConfirm({
+ iconType: 'warning',
+ title: '确认删除',
+ content: '是否删除选中数据',
+ okText: '确认',
+ cancelText: '取消',
+ onOk: () => {
+ return defHttp.delete({url: Api.deleteBatch, data: params}, {joinParamsToUrl: true}).then(() => {
+ handleSuccess();
+ });
+ }
+ });
+}
+
+/**
+ * 保存或者更新
+ * @param params
+ * @param isUpdate
+ */
+export const saveOrUpdate = (params, isUpdate) => {
+ let url = isUpdate ? Api.edit : Api.save;
+ return defHttp.post({ url: url, params }, { isTransformResponse: false });
+}
diff --git a/src/views/admin/IssueInfo/IssueInfo.data.ts b/src/views/admin/IssueInfo/IssueInfo.data.ts
new file mode 100644
index 0000000..5e48745
--- /dev/null
+++ b/src/views/admin/IssueInfo/IssueInfo.data.ts
@@ -0,0 +1,32 @@
+import {BasicColumn} from '/@/components/Table';
+import {FormSchema} from '/@/components/Table';
+import { rules} from '/@/utils/helper/validator';
+import { render } from '/@/utils/common/renderUtils';
+import { getWeekMonthQuarterYear } from '/@/utils';
+//列表数据
+export const columns: BasicColumn[] = [
+ {
+ title: '创建日期',
+ align: "center",
+ dataIndex: 'createTime',
+ width: 180,
+ },
+ {
+ title: '发版类型',
+ align: "center",
+ dataIndex: 'issueType_dictText',
+ width: 180,
+ },
+ {
+ title: '发版内容',
+ align: "center",
+ dataIndex: 'content',
+ },
+];
+
+// 高级查询数据
+export const superQuerySchema = {
+ createTime: {title: '创建日期',order: 0,view: 'datetime', type: 'string',},
+ issueType: {title: '发版类型',order: 1,view: 'radio', type: 'string',dictCode: 'issue_type',},
+ content: {title: '发版内容',order: 2,view: 'umeditor', type: 'string',},
+};
diff --git a/src/views/admin/IssueInfo/IssueInfoList.vue b/src/views/admin/IssueInfo/IssueInfoList.vue
new file mode 100644
index 0000000..2653a62
--- /dev/null
+++ b/src/views/admin/IssueInfo/IssueInfoList.vue
@@ -0,0 +1,234 @@
+
+
+
+
+
+
+ 新增
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 发版内容
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/admin/IssueInfo/components/IssueInfoForm.vue b/src/views/admin/IssueInfo/components/IssueInfoForm.vue
new file mode 100644
index 0000000..d0da7b3
--- /dev/null
+++ b/src/views/admin/IssueInfo/components/IssueInfoForm.vue
@@ -0,0 +1,155 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/admin/IssueInfo/components/IssueInfoModal.vue b/src/views/admin/IssueInfo/components/IssueInfoModal.vue
new file mode 100644
index 0000000..c82f6c7
--- /dev/null
+++ b/src/views/admin/IssueInfo/components/IssueInfoModal.vue
@@ -0,0 +1,77 @@
+
+
+
+
+
+
+
+
+
+