diff --git a/src/api/qms/selectedProject/index.ts b/src/api/qms/selectedProject/index.ts
new file mode 100644
index 000000000..a32d54b55
--- /dev/null
+++ b/src/api/qms/selectedProject/index.ts
@@ -0,0 +1,57 @@
+import request from '@/config/axios'
+
+export interface SelectedProjectVO {
+ id: number
+ code: string
+ dictionaryCode: string
+ dictionaryValue: string
+ estimateCode: string
+ defectLevel: string
+ available: string
+ deletionTime: Date
+ deleterId: string
+ extraProperties: string
+ concurrencyStamp: number
+ siteId: string
+}
+
+// 查询选定集项目列表
+export const getSelectedProjectPage = async (params) => {
+ if (params.isSearch) {
+ delete params.isSearch
+ const data = {...params}
+ return await request.post({ url: '/qms/selected-project/senior', data })
+ } else {
+ return await request.get({ url: `/qms/selected-project/page`, params })
+ }
+}
+
+// 查询选定集项目详情
+export const getSelectedProject = async (id: number) => {
+ return await request.get({ url: `/qms/selected-project/get?id=` + id })
+}
+
+// 新增选定集项目
+export const createSelectedProject = async (data: SelectedProjectVO) => {
+ return await request.post({ url: `/qms/selected-project/create`, data })
+}
+
+// 修改选定集项目
+export const updateSelectedProject = async (data: SelectedProjectVO) => {
+ return await request.put({ url: `/qms/selected-project/update`, data })
+}
+
+// 删除选定集项目
+export const deleteSelectedProject = async (id: number) => {
+ return await request.delete({ url: `/qms/selected-project/delete?id=` + id })
+}
+
+// 导出选定集项目 Excel
+export const exportSelectedProject = async (params) => {
+ return await request.download({ url: `/qms/selected-project/export-excel`, params })
+}
+
+// 下载用户导入模板
+export const importTemplate = () => {
+ return request.download({ url: '/qms/selected-project/get-import-template' })
+}
\ No newline at end of file
diff --git a/src/api/qms/selectedSet/index.ts b/src/api/qms/selectedSet/index.ts
new file mode 100644
index 000000000..13c778883
--- /dev/null
+++ b/src/api/qms/selectedSet/index.ts
@@ -0,0 +1,55 @@
+import request from '@/config/axios'
+
+export interface SelectedSetVO {
+ id: number
+ code: string
+ describe: string
+ classification: string
+ available: string
+ deletionTime: Date
+ deleterId: string
+ extraProperties: string
+ concurrencyStamp: number
+ siteId: string
+}
+
+// 查询选定集列表
+export const getSelectedSetPage = async (params) => {
+ if (params.isSearch) {
+ delete params.isSearch
+ const data = {...params}
+ return await request.post({ url: '/qms/selected-set/senior', data })
+ } else {
+ return await request.get({ url: `/qms/selected-set/page`, params })
+ }
+}
+
+// 查询选定集详情
+export const getSelectedSet = async (id: number) => {
+ return await request.get({ url: `/qms/selected-set/get?id=` + id })
+}
+
+// 新增选定集
+export const createSelectedSet = async (data: SelectedSetVO) => {
+ return await request.post({ url: `/qms/selected-set/create`, data })
+}
+
+// 修改选定集
+export const updateSelectedSet = async (data: SelectedSetVO) => {
+ return await request.put({ url: `/qms/selected-set/update`, data })
+}
+
+// 删除选定集
+export const deleteSelectedSet = async (id: number) => {
+ return await request.delete({ url: `/qms/selected-set/delete?id=` + id })
+}
+
+// 导出选定集 Excel
+export const exportSelectedSet = async (params) => {
+ return await request.download({ url: `/qms/selected-set/export-excel`, params })
+}
+
+// 下载用户导入模板
+export const importTemplate = () => {
+ return request.download({ url: '/qms/selected-set/get-import-template' })
+}
\ No newline at end of file
diff --git a/src/views/qms/basicDataManage/selectedProject/index.vue b/src/views/qms/basicDataManage/selectedProject/index.vue
new file mode 100644
index 000000000..e698b0565
--- /dev/null
+++ b/src/views/qms/basicDataManage/selectedProject/index.vue
@@ -0,0 +1,244 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ row.code }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/qms/basicDataManage/selectedProject/selectedProject.data.ts b/src/views/qms/basicDataManage/selectedProject/selectedProject.data.ts
new file mode 100644
index 000000000..29d9820d7
--- /dev/null
+++ b/src/views/qms/basicDataManage/selectedProject/selectedProject.data.ts
@@ -0,0 +1,131 @@
+import type { CrudSchema } from '@/hooks/web/useCrudSchemas'
+import { dateFormatter } from '@/utils/formatTime'
+
+// 表单校验
+export const SelectedProjectRules = reactive({
+ code: [required],
+ dictionaryCode: [required],
+ dictionaryValue: [required],
+ available: [required],
+ concurrencyStamp: [required]
+})
+
+export const SelectedProject = useCrudSchemas(reactive([
+ {
+ label: 'id',
+ field: 'id',
+ sort: 'custom',
+ isForm: false
+ },
+ {
+ label: '编码',
+ field: 'code',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '字典编码',
+ field: 'dictionaryCode',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '字典项值',
+ field: 'dictionaryValue',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '评估代码',
+ field: 'estimateCode',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '缺陷级别',
+ field: 'defectLevel',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '是否可用',
+ field: 'available',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '创建时间',
+ field: 'createTime',
+ sort: 'custom',
+ formatter: dateFormatter,
+ isSearch: true,
+ search: {
+ component: 'DatePicker',
+ componentProps: {
+ valueFormat: 'YYYY-MM-DD HH:mm:ss',
+ type: 'daterange',
+ defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
+ }
+ },
+ isForm: false
+ },
+ {
+ label: '删除时间',
+ field: 'deletionTime',
+ sort: 'custom',
+ formatter: dateFormatter,
+ isSearch: true,
+ search: {
+ component: 'DatePicker',
+ componentProps: {
+ valueFormat: 'YYYY-MM-DD HH:mm:ss',
+ type: 'daterange',
+ defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
+ }
+ },
+ form: {
+ component: 'DatePicker',
+ componentProps: {
+ type: 'datetime',
+ valueFormat: 'x'
+ }
+ }
+ },
+ {
+ label: '删除者ID',
+ field: 'deleterId',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '扩展属性',
+ field: 'extraProperties',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '并发乐观锁',
+ field: 'concurrencyStamp',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'InputNumber',
+ value: 0
+ }
+ },
+ {
+ label: '地点ID',
+ field: 'siteId',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '操作',
+ field: 'action',
+ isForm: false,
+ table: {
+ width: 150,
+ fixed: 'right'
+ }
+ }
+]))
diff --git a/src/views/qms/basicDataManage/selectedSet/index.vue b/src/views/qms/basicDataManage/selectedSet/index.vue
new file mode 100644
index 000000000..4b96d3710
--- /dev/null
+++ b/src/views/qms/basicDataManage/selectedSet/index.vue
@@ -0,0 +1,244 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ row.code }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/qms/basicDataManage/selectedSet/selectedSet.data.ts b/src/views/qms/basicDataManage/selectedSet/selectedSet.data.ts
new file mode 100644
index 000000000..53ecfd8b9
--- /dev/null
+++ b/src/views/qms/basicDataManage/selectedSet/selectedSet.data.ts
@@ -0,0 +1,117 @@
+import type { CrudSchema } from '@/hooks/web/useCrudSchemas'
+import { dateFormatter } from '@/utils/formatTime'
+
+// 表单校验
+export const SelectedSetRules = reactive({
+ code: [required],
+ available: [required],
+ concurrencyStamp: [required]
+})
+
+export const SelectedSet = useCrudSchemas(reactive([
+ {
+ label: 'id',
+ field: 'id',
+ sort: 'custom',
+ isForm: false
+ },
+ {
+ label: '编码',
+ field: 'code',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '描述',
+ field: 'describe',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '分类',
+ field: 'classification',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '是否可用',
+ field: 'available',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '创建时间',
+ field: 'createTime',
+ sort: 'custom',
+ formatter: dateFormatter,
+ isSearch: true,
+ search: {
+ component: 'DatePicker',
+ componentProps: {
+ valueFormat: 'YYYY-MM-DD HH:mm:ss',
+ type: 'daterange',
+ defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
+ }
+ },
+ isForm: false
+ },
+ {
+ label: '删除时间',
+ field: 'deletionTime',
+ sort: 'custom',
+ formatter: dateFormatter,
+ isSearch: true,
+ search: {
+ component: 'DatePicker',
+ componentProps: {
+ valueFormat: 'YYYY-MM-DD HH:mm:ss',
+ type: 'daterange',
+ defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
+ }
+ },
+ form: {
+ component: 'DatePicker',
+ componentProps: {
+ type: 'datetime',
+ valueFormat: 'x'
+ }
+ }
+ },
+ {
+ label: '删除者ID',
+ field: 'deleterId',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '扩展属性',
+ field: 'extraProperties',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '并发乐观锁',
+ field: 'concurrencyStamp',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'InputNumber',
+ value: 0
+ }
+ },
+ {
+ label: '地点ID',
+ field: 'siteId',
+ sort: 'custom',
+ isSearch: true
+ },
+ {
+ label: '操作',
+ field: 'action',
+ isForm: false,
+ table: {
+ width: 150,
+ fixed: 'right'
+ }
+ }
+]))