| @@ -55,7 +55,8 @@ | |||
| {{/* <a class="item" href="{{AppSubUrl}}/explore/data_analysis">{{.i18n.Tr "explore.data_analysis"}}</a> */}} | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageHome}} | |||
| @@ -97,6 +98,7 @@ | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageExplore}} | |||
| @@ -52,7 +52,8 @@ | |||
| {{/* <a class="item" href="{{AppSubUrl}}/explore/data_analysis">{{.i18n.Tr "explore.data_analysis"}}</a> */}} | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageHome}} | |||
| @@ -92,6 +93,7 @@ | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageExplore}} | |||
| @@ -44,7 +44,8 @@ | |||
| {{/* <a class="item" href="{{AppSubUrl}}/explore/data_analysis">{{.i18n.Tr "explore.data_analysis"}}</a> */}} | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageHome}} | |||
| @@ -85,6 +86,7 @@ | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageExplore}} | |||
| @@ -54,7 +54,8 @@ | |||
| {{/* <a class="item" href="{{AppSubUrl}}/explore/data_analysis">{{.i18n.Tr "explore.data_analysis"}}</a> */}} | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageHome}} | |||
| @@ -95,6 +96,7 @@ | |||
| <a class="item" href="{{AppSubUrl}}/kanban/index.html" target="_blank" rel="opener">{{.i18n.Tr "explore.data_analysis"}}</a> | |||
| {{end}} | |||
| <a class="item" href="{{AppSubUrl}}/OpenI">{{.i18n.Tr "custom.head.openi.repo"}}</a> | |||
| <a class="item" href="{{AppSubUrl}}/tech/tech_view">2030科技项目</a> | |||
| </div> | |||
| </div> | |||
| {{else if .IsLandingPageExplore}} | |||
| @@ -0,0 +1,5 @@ | |||
| {{template "base/head_home" .}} | |||
| <link rel="stylesheet" href="{{StaticUrlPrefix}}/css/vp-tech-adminview.css?v={{MD5 AppVer}}" /> | |||
| <div id="__vue-root"></div> | |||
| <script src="{{StaticUrlPrefix}}/js/vp-tech-adminview.js?v={{MD5 AppVer}}"></script> | |||
| {{template "base/footer" .}} | |||
| @@ -0,0 +1,5 @@ | |||
| {{template "base/head_home" .}} | |||
| <link rel="stylesheet" href="{{StaticUrlPrefix}}/css/vp-tech-create.css?v={{MD5 AppVer}}" /> | |||
| <div id="__vue-root"></div> | |||
| <script src="{{StaticUrlPrefix}}/js/vp-tech-create.js?v={{MD5 AppVer}}"></script> | |||
| {{template "base/footer" .}} | |||
| @@ -0,0 +1,5 @@ | |||
| {{template "base/head_home" .}} | |||
| <link rel="stylesheet" href="{{StaticUrlPrefix}}/css/vp-tech-repoview.css?v={{MD5 AppVer}}" /> | |||
| <div id="__vue-root"></div> | |||
| <script src="{{StaticUrlPrefix}}/js/vp-tech-repoview.js?v={{MD5 AppVer}}"></script> | |||
| {{template "base/footer" .}} | |||
| @@ -0,0 +1,5 @@ | |||
| {{template "base/head_home" .}} | |||
| <link rel="stylesheet" href="{{StaticUrlPrefix}}/css/vp-tech-techview.css?v={{MD5 AppVer}}" /> | |||
| <div id="__vue-root"></div> | |||
| <script src="{{StaticUrlPrefix}}/js/vp-tech-techview.js?v={{MD5 AppVer}}"></script> | |||
| {{template "base/footer" .}} | |||
| @@ -0,0 +1,153 @@ | |||
| /* 科技项目汇聚功能相关 */ | |||
| import service from '../service'; | |||
| // 新建申请页面科技项目查询接口 no-项目编号,name-科技项目名称,institution-参与单位 | |||
| export const getTechs = (params) => { | |||
| return service({ | |||
| url: '/api/v1/tech', | |||
| method: 'get', | |||
| params: params, | |||
| }); | |||
| } | |||
| // 新建启智项目申请页面提交 url-启智项目地址,no-项目立项编号,institution-贡献单位,多个单位用逗号分隔 | |||
| export const setOpenIApply = (data) => { | |||
| return service({ | |||
| url: '/api/v1/tech/openi', | |||
| method: 'post', | |||
| data: data, | |||
| }); | |||
| } | |||
| // 新建启智项目申请页面提交 | |||
| // url-启智项目地址,uid-启智项目uid,repo_name-启智项目名称,topics-关键词,description-简介, | |||
| // no-项目立项编号,institution-贡献单位,多个单位用逗号分隔 | |||
| export const setNoOpenIApply = (data) => { | |||
| return service({ | |||
| url: '/api/v1/tech/no_openi', | |||
| method: 'post', | |||
| data: data, | |||
| }); | |||
| } | |||
| // 新建非启智项目申请页面项目路径可选的用户和组织 | |||
| // 返回 [{id:用户ID,name:用户名字,rel_avatar_link:用户图像地址,short_name:用户短名称},...] | |||
| export const getCreateRepoUser = () => { | |||
| return service({ | |||
| url: '/api/v1/create_repo/user', | |||
| method: 'get', | |||
| params: {}, | |||
| }); | |||
| } | |||
| // 项目过滤信息列表-筛选信息 type=0查询科技项目页, type=1查询启智项目页 | |||
| // 返回 {type_name:项目类型的名称, 字符串数组,institution_name:参与单位的名称,字符串数组,execute_year:执行年份,字符串数组, | |||
| // apply_year:申请年份,字符串数组,topic-关键词,字符串数组,project_name:科技项目名称,字符串数组} | |||
| export const getTechFilterInfo = (params) => { | |||
| return service({ | |||
| url: '/api/v1/tech/filter', | |||
| method: 'get', | |||
| params: { | |||
| type: params.type, | |||
| }, | |||
| }); | |||
| } | |||
| // 按科技项目页查询功能 | |||
| // 输入 name-科技项目名称,模糊匹配,type_name-项目类型的名称,精确匹配,institution_name-参与单位的名称,精确匹配,execute_year-执行年份,精确匹配,apply_year-申请年份,精确匹配,page,pageSize,sort | |||
| // 返回 {"total":10,"data":[{}]} | |||
| // data: {id:科技项目id,project_name:科技项目名称,institution:承担单位,all_institution:参与单位,apply_year:申报年份,execute_period:执行周期,repo_numer:项目成果数,repo:[]项目信息数组} | |||
| export const getTechSearch = (params) => { | |||
| return service({ | |||
| url: '/api/v1/tech/search', | |||
| method: 'get', | |||
| params: params, | |||
| }); | |||
| } | |||
| // 按启智项目页查询功能 | |||
| // 输入 name-项目名称,模糊匹配,tech_name-科技项目名称,精确匹配,institution_name-参与单位的名称,精确匹配,topic-关键词,精确匹配,page,pageSize,sort | |||
| // 返回 {"total":10,"data":[{}]} | |||
| // data: {id:项目id,owner_id:项目拥有者id,name:项目名称,alias:项目别名,topics:关键词 字符串数组,description:项目简介,updated_unix:最后更新时间,institution:贡献单位} | |||
| export const getTechOpenISearch = (params) => { | |||
| return service({ | |||
| url: '/api/v1/tech/repo_search', | |||
| method: 'get', | |||
| params: params, | |||
| }); | |||
| } | |||
| // 后台管理项目列表 | |||
| // 输入 page,pageSize | |||
| // 返回 {"total":10,"data":[{}]} | |||
| // data: {id:记录的id,name:启智项目名称,owner_name:启智项目拥有者名称,tech_name:科技项目名称,tech_number:科技项目编号,institution:项目承担单位, | |||
| // execute_period:执行周期,contact:联系人,contact_phone:联系电话,contact_email:联系邮件,apply_user:申请账号,status:状态} | |||
| export const getTechAdminList = (params) => { | |||
| return service({ | |||
| url: '/api/v1/tech/admin', | |||
| method: 'get', | |||
| params: params, | |||
| }); | |||
| } | |||
| // 后台管理项目列表交互(显示或隐藏) | |||
| // 输入 type-show/hide,id:[1,2,3] | |||
| // 返回 { code:0, message:"" } | |||
| export const setTechAdminOperation = (data) => { | |||
| return service({ | |||
| url: `/api/v1/tech/admin/action/${data.type}`, | |||
| method: 'post', | |||
| data: data.id, | |||
| }); | |||
| } | |||
| // 后台管理科技项目编号基本信息导入功能(科技项目管理员有权限) | |||
| // 输入 form file | |||
| export const setTechImportExcel = () => { | |||
| return service({ | |||
| url: `/api/v1/tech/basic`, | |||
| method: 'post', | |||
| data: {}, | |||
| }); | |||
| } | |||
| // 增加科技项目管理员(管理员才有权限) | |||
| // 输入 name:['111', '222'] | |||
| // 返回 { code:0, message:"" } | |||
| export const setTechAdminAdd = (data) => { | |||
| return service({ | |||
| url: '/api/v1/tech/admin_add', | |||
| method: 'post', | |||
| data: data, | |||
| }); | |||
| } | |||
| // 判断是否是科技项目管理员 | |||
| // 输入 name:['111', '222'] | |||
| export const getIsTechAdmin = () => { | |||
| return service({ | |||
| url: '/api/v1/tech/is_admin', | |||
| method: 'get', | |||
| params: {}, | |||
| }); | |||
| } | |||
| // ========================================================= | |||
| // 搜索Topics q-topic | |||
| // 返回 {topics: [{id,repo_count,topic_name,created,updated}]} | |||
| export const getTopics = (params) => { | |||
| return service({ | |||
| url: '/api/v1/topics/search', | |||
| method: 'get', | |||
| params: params, | |||
| }); | |||
| } | |||
| // 检测 repo name q:名称, owner:所属者 | |||
| export const getCheckRepoName = (params) => { | |||
| return service({ | |||
| url: '/repo/check_name', | |||
| method: 'get', | |||
| params: params, | |||
| }); | |||
| } | |||
| @@ -0,0 +1,211 @@ | |||
| <template> | |||
| <div> | |||
| <div class="ui container"> | |||
| <div class="top-container"> | |||
| <el-checkbox class="check-toggle" v-model="allChecked" @change="allSelectChange">全选/全不选</el-checkbox> | |||
| <el-button class="btn-agree">批量同意展示</el-button> | |||
| <el-button class="btn-cancel">批量取消展示</el-button> | |||
| </div> | |||
| <div class="table-container"> | |||
| <div class="table-title">2030科技项目管理</div> | |||
| <div class="table-wrap"> | |||
| <el-table ref="tableRef" border :data="tableData" style="width:100%;" v-loading="loading" stripe row-key="id"> | |||
| <el-table-column label="" align="center" header-align="center" width="40" fixed> | |||
| <template slot-scope="scope"> | |||
| <el-checkbox v-model="scope.row.checked" @change="rowSelectChange(scope.row)"></el-checkbox> | |||
| </template> | |||
| </el-table-column> | |||
| <el-table-column prop="name" label="启智项目名称" align="center" header-align="center" fixed></el-table-column> | |||
| <el-table-column prop="tech_name" label="科技项目名称" align="center" header-align="center" | |||
| fixed></el-table-column> | |||
| <el-table-column prop="status" label="展示状态" align="center" header-align="center" fixed></el-table-column> | |||
| <el-table-column prop="tech_number" label="项目立项编号" align="center" header-align="center"></el-table-column> | |||
| <el-table-column prop="institution" label="项目承担单位" align="center" header-align="center"></el-table-column> | |||
| <el-table-column prop="execute_period" label="执行周期" align="center" header-align="center"></el-table-column> | |||
| <el-table-column prop="contact" label="联系人" align="center" header-align="center"></el-table-column> | |||
| <el-table-column prop="contact_phone" label="电话" align="center" header-align="center"></el-table-column> | |||
| <el-table-column prop="apply_user" label="申请账号" align="center" header-align="center"></el-table-column> | |||
| <el-table-column prop="" label="操作" align="center" header-align="center" fixed="right"></el-table-column> | |||
| </el-table> | |||
| </div> | |||
| <div class="center"> | |||
| <el-pagination ref="paginationRef" background @current-change="currentChange" @size-change="sizeChange" | |||
| :current-page.sync="page" :page-sizes="pageSizes" :page-size.sync="pageSize" | |||
| layout="total, sizes, prev, pager, next, jumper" :total="total"> | |||
| </el-pagination> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import { getTechAdminList, setTechAdminOperation } from '~/apis/modules/tech'; | |||
| export default { | |||
| data() { | |||
| return { | |||
| allChecked: false, | |||
| loading: false, | |||
| tableData: [], | |||
| page: 1, | |||
| pageSizes: [15, 30, 50, 100], | |||
| pageSize: 50, | |||
| total: 0, | |||
| }; | |||
| }, | |||
| components: {}, | |||
| methods: { | |||
| getData() { | |||
| this.loading = true; | |||
| getTechAdminList({ | |||
| page: this.page, | |||
| pageSize: this.pageSize, | |||
| }).then(res => { | |||
| this.loading = false; | |||
| const { total, data } = res.data; | |||
| this.tableData = data.map((item, index) => { | |||
| return { | |||
| checked: false, | |||
| id: 'id' + Math.random(), | |||
| ...item, | |||
| } | |||
| }); | |||
| this.total = total; | |||
| }).catch(err => { | |||
| this.loading = false; | |||
| console.log(err); | |||
| }); | |||
| }, | |||
| allSelectChange() { | |||
| for (let i = 0, iLen = this.tableData.length; i < iLen; i++) { | |||
| this.tableData[i].checked = this.allChecked; | |||
| } | |||
| this.tableData.splice(1, 0); | |||
| }, | |||
| rowSelectChange(row) { | |||
| if (row.checked == false) { | |||
| this.allChecked = false; | |||
| } else { | |||
| if (this.tableData.filter((item) => item.checked).length == this.tableData.length) { | |||
| this.allChecked = true; | |||
| } | |||
| } | |||
| this.tableData.splice(1, 0); | |||
| }, | |||
| currentChange(page) { | |||
| this.page = page; | |||
| this.getData(); | |||
| }, | |||
| sizeChange(pageSize) { | |||
| this.pageSize = pageSize; | |||
| this.getData(); | |||
| }, | |||
| }, | |||
| beforeMount() { | |||
| }, | |||
| mounted() { | |||
| this.tableData = new Array(15).fill(0).map((item, index) => { | |||
| return { | |||
| id: '记录的id-' + index, | |||
| name: '启智项目名称-' + index, | |||
| owner_name: '启智项目拥有者名称-' + index, | |||
| tech_name: '科技项目名称-' + index, | |||
| tech_number: '科技项目编号-' + index, | |||
| institution: '项目承担单位-' + index, | |||
| execute_period: '执行周期-' + index, | |||
| contact: '联系人-' + index, | |||
| contact_phone: '联系电话-' + index, | |||
| contact_email: '联系邮件-' + index, | |||
| apply_user: '申请账号-' + index, | |||
| status: '状态-' + index, | |||
| } | |||
| }); | |||
| this.total = this.tableData.length; | |||
| }, | |||
| beforeDestroy() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .top-container { | |||
| display: flex; | |||
| align-items: center; | |||
| margin: 15px 0; | |||
| .check-toggle { | |||
| margin-right: 20px; | |||
| } | |||
| .btn-agree { | |||
| margin-right: 10px; | |||
| background: rgb(50, 145, 248); | |||
| color: rgb(255, 255, 255); | |||
| &:hover { | |||
| opacity: 0.9; | |||
| } | |||
| &:active { | |||
| opacity: 0.8; | |||
| } | |||
| } | |||
| .btn-cancel { | |||
| margin-right: 10px; | |||
| background: rgb(250, 140, 22); | |||
| color: rgb(255, 255, 255); | |||
| &:hover { | |||
| opacity: 0.9; | |||
| } | |||
| &:active { | |||
| opacity: 0.8; | |||
| } | |||
| } | |||
| } | |||
| .table-container { | |||
| .table-title { | |||
| height: 43px; | |||
| font-size: 16px; | |||
| font-weight: 700; | |||
| padding: 15px; | |||
| color: rgb(16, 16, 16); | |||
| border-color: rgb(212, 212, 213); | |||
| border-width: 1px; | |||
| border-style: solid; | |||
| border-radius: 5px 5px 0px 0px; | |||
| background: rgb(240, 240, 240); | |||
| display: flex; | |||
| align-items: center; | |||
| } | |||
| .table-wrap { | |||
| margin-bottom: 12px; | |||
| overflow-x: auto; | |||
| /deep/ .el-table__header { | |||
| th { | |||
| background: rgb(249, 249, 249); | |||
| font-size: 12px; | |||
| color: rgb(136, 136, 136); | |||
| font-weight: normal; | |||
| } | |||
| } | |||
| /deep/ .el-table__body { | |||
| td { | |||
| font-size: 12px; | |||
| } | |||
| } | |||
| /deep/ .el-radio__label { | |||
| display: none; | |||
| } | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,17 @@ | |||
| import Vue from 'vue'; | |||
| import ElementUI from 'element-ui'; | |||
| import 'element-ui/lib/theme-chalk/index.css'; | |||
| import localeEn from 'element-ui/lib/locale/lang/en'; | |||
| import localeZh from 'element-ui/lib/locale/lang/zh-CN'; | |||
| import { i18n, lang } from '~/langs'; | |||
| import App from './index.vue'; | |||
| Vue.use(ElementUI, { | |||
| locale: lang === 'zh-CN' ? localeZh : localeEn, | |||
| size: 'small', | |||
| }); | |||
| new Vue({ | |||
| i18n, | |||
| render: (h) => h(App), | |||
| }).$mount('#__vue-root'); | |||
| @@ -0,0 +1,277 @@ | |||
| <template> | |||
| <div> | |||
| <div class="filter-main" v-show="!showSecond"> | |||
| <div class="filter-c" v-for="(item, index) in mainData"> | |||
| <div class="filter-title">{{ item.title }}</div> | |||
| <div class="filter-item-c"> | |||
| <div class="filter-item" v-for="(_item, _index) in item.showData" @click="changeFilter(item, _item)" | |||
| :style="conds[item.key] == _item ? { backgroundColor: item.focusBgColor, color: item.focusColor } : { backgroundColor: item.bgColor, color: item.color }"> | |||
| {{ _item }} | |||
| </div> | |||
| </div> | |||
| <div class="filter-view-more-c" v-if="item.data.length > item.showMaxLen"> | |||
| <span class="filter-view-more" @click="goMore(item)"> | |||
| <i class="el-icon-arrow-down"></i><span>展开更多</span> | |||
| </span> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| <div class="filter-second" v-show="showSecond"> | |||
| <div class="filter-second-hd"> | |||
| <span class="filter-second-go-back" @click="goBack()"> | |||
| <i class="el-icon-back"></i><span>返回上一级</span> | |||
| </span> | |||
| </div> | |||
| <div class="filter-title">{{ secondData.title }}</div> | |||
| <div class="filter-item-c"> | |||
| <div class="filter-item" v-for="(_item, _index) in secondData.data" @click="changeFilter(secondData, _item)" | |||
| :style="conds[secondData.key] == _item ? { backgroundColor: secondData.focusBgColor, color: secondData.focusColor } : { backgroundColor: secondData.bgColor, color: secondData.color }"> | |||
| {{ _item }} | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import { getTechFilterInfo } from '~/apis/modules/tech'; | |||
| export default { | |||
| name: "Filters", | |||
| props: { | |||
| type: { type: Number, default: -1 }, // 0-tech_view, 1-repo_view | |||
| condition: { type: Object, default: () => ({}) }, | |||
| }, | |||
| components: {}, | |||
| data() { | |||
| return { | |||
| list_tech: [{ | |||
| title: '项目类型', | |||
| key: 'type_name', | |||
| bgColor: 'rgb(237, 234, 251)', | |||
| color: 'rgb(100, 59, 159)', | |||
| focusBgColor: 'rgb(100, 59, 159)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 6, | |||
| }, { | |||
| title: '项目参与单位', | |||
| key: 'institution_name', | |||
| bgColor: 'rgb(234, 241, 251)', | |||
| color: 'rgb(18, 76, 157)', | |||
| focusBgColor: 'rgb(18, 76, 157)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 10, | |||
| }, { | |||
| title: '执行周期包含年份', | |||
| key: 'execute_year', | |||
| bgColor: 'rgb(225, 242, 234)', | |||
| color: 'rgb(8, 96, 96)', | |||
| focusBgColor: 'rgb(8, 96, 96)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 10, | |||
| }, { | |||
| title: '申报年份', | |||
| key: 'apply_year', | |||
| bgColor: 'rgb(231, 249, 222)', | |||
| color: 'rgb(55, 94, 2)', | |||
| focusBgColor: 'rgb(55, 94, 2)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 10, | |||
| }], | |||
| list_repo: [{ | |||
| title: '关键词', | |||
| key: 'topic', | |||
| bgColor: 'rgb(234, 250, 251)', | |||
| color: 'rgb(0, 167, 132)', | |||
| focusBgColor: 'rgb(0, 167, 132)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 10, | |||
| }, { | |||
| title: '所属科技项目', | |||
| key: 'project_name', | |||
| bgColor: 'rgb(234, 245, 251)', | |||
| color: 'rgb(8, 0, 148)', | |||
| focusBgColor: 'rgb(8, 0, 148)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 10, | |||
| }, { | |||
| title: '成果贡献单位', | |||
| key: 'institution_name', | |||
| bgColor: 'rgb(234, 241, 251)', | |||
| color: 'rgb(18, 76, 157)', | |||
| focusBgColor: 'rgb(18, 76, 157)', | |||
| focusColor: 'rgb(255, 255, 255)', | |||
| data: [], | |||
| showData: [], | |||
| showMaxLen: 10, | |||
| }, | |||
| ], | |||
| conds: { | |||
| type_name: '', | |||
| institution_name: '', | |||
| execute_year: '', | |||
| apply_year: '', | |||
| topic: '', | |||
| project_name: '', | |||
| }, | |||
| mainData: [], | |||
| showSecond: false, | |||
| secondData: {}, | |||
| }; | |||
| }, | |||
| methods: { | |||
| goMore(item) { | |||
| this.secondData = item; | |||
| this.showSecond = true; | |||
| }, | |||
| goBack() { | |||
| this.showSecond = false; | |||
| }, | |||
| changeFilter(item, _item) { | |||
| const value = this.conds[item.key] == _item ? '' : _item; | |||
| this.$emit('changeCondition', { | |||
| [item.key]: value | |||
| }); | |||
| } | |||
| }, | |||
| watch: { | |||
| condition: { | |||
| handler(newVal) { | |||
| console.log('Filters:watch:condition', newVal); | |||
| this.conds.type_name = newVal.type_name || ''; | |||
| this.conds.institution_name = newVal.institution_name || ''; | |||
| this.conds.execute_year = newVal.execute_year || ''; | |||
| this.conds.apply_year = newVal.apply_year || ''; | |||
| this.conds.topic = newVal.topic || ''; | |||
| this.conds.project_name = newVal.project_name || ''; | |||
| }, | |||
| immediate: true, | |||
| deep: true, | |||
| }, | |||
| }, | |||
| beforeMount() { | |||
| if (this.type == 0) { | |||
| this.mainData = this.list_tech; | |||
| } else if (this.type == 1) { | |||
| this.mainData = this.list_repo; | |||
| } | |||
| const data = { | |||
| type_name: ['基础前沿', '应用示范研究', '重大共性关键技术', '其他', '基础前沿1', '基础前沿2', '基础前沿3', '基础前沿4', '基础前沿5'], | |||
| institution_name: ['北京大学', '北京工业大学', '北京航空航天大学', '北京交通大学', '清华大学'], | |||
| execute_year: ['2019', '2020', '2021', '2022', '2023'], | |||
| apply_year: ['2018', '2019', '2020', '2021', '2022'], | |||
| topic: ['数据库', '操作系统', '云计算', '大数据', '数据可视化', '其他'], | |||
| project_name: ['新一代神经网络模型', '小样本条件下的自适应机器学习理论', '面向复杂数据处理的新型神经网络模型'], | |||
| } | |||
| for (let i = 0, iLen = this.mainData.length; i < iLen; i++) { | |||
| const filterItem = this.mainData[i]; | |||
| const key = filterItem.key; | |||
| const max = filterItem.showMaxLen; | |||
| if (data[key]) { | |||
| filterItem.data = data[key]; | |||
| filterItem.showData = data[key].slice(0, max); | |||
| if (this.conds[key] && filterItem.showData.indexOf(this.conds[key]) < 0) { | |||
| filterItem.showData.push(this.conds[key]); | |||
| } | |||
| } | |||
| } | |||
| return; | |||
| getTechFilterInfo({ | |||
| type: this.type, | |||
| }).then(res => { | |||
| console.log(res); | |||
| }).catch(err => { | |||
| console.log(err); | |||
| }); | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .filter-c { | |||
| margin-bottom: 32px; | |||
| .filter-title { | |||
| font-size: 18px; | |||
| color: rgb(16, 16, 16); | |||
| margin: 14px 0; | |||
| } | |||
| .filter-item-c { | |||
| display: flex; | |||
| flex-wrap: wrap; | |||
| .filter-item { | |||
| border-radius: 3px; | |||
| padding: 3px 10px; | |||
| margin-right: 10px; | |||
| margin-bottom: 10px; | |||
| cursor: pointer; | |||
| } | |||
| } | |||
| .filter-view-more-c { | |||
| margin-top: 6px; | |||
| .filter-view-more { | |||
| color: rgb(50, 145, 248); | |||
| font-size: 14px; | |||
| cursor: pointer; | |||
| i { | |||
| margin-right: 4px; | |||
| } | |||
| } | |||
| } | |||
| } | |||
| .filter-second { | |||
| .filter-second-hd { | |||
| margin: 14px 0 24px 0; | |||
| .filter-second-go-back { | |||
| color: rgb(50, 145, 248); | |||
| font-size: 14px; | |||
| cursor: pointer; | |||
| i { | |||
| margin-right: 4px; | |||
| } | |||
| } | |||
| } | |||
| .filter-title { | |||
| font-size: 18px; | |||
| color: rgb(16, 16, 16); | |||
| margin: 14px 0; | |||
| } | |||
| .filter-item-c { | |||
| display: flex; | |||
| flex-wrap: wrap; | |||
| .filter-item { | |||
| border-radius: 3px; | |||
| padding: 3px 10px; | |||
| margin-right: 10px; | |||
| margin-bottom: 10px; | |||
| cursor: pointer; | |||
| } | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,157 @@ | |||
| <template> | |||
| <div class="item"> | |||
| <div class="title-c"> | |||
| <div class="avatar-c"> | |||
| <img v-if="data.RelAvatarLink" class="avatar" :src="data.RelAvatarLink" /> | |||
| <img v-else class="avatar" :avatar="data.OwnerName" /> | |||
| </div> | |||
| <div class="title"> | |||
| <span>{{ data.Alias }}</span> | |||
| </div> | |||
| </div> | |||
| <div class="descr"> | |||
| {{ data.Description }} | |||
| </div> | |||
| <div class="topics"> | |||
| <a v-for="(item, index) in data.Topics" :key="index" class="topic" | |||
| :href="`/explore/repos?q=&topic=${item.topic}&sort=hot`">{{ item }}</a> | |||
| </div> | |||
| <div class="footer"> | |||
| <div class="contractor">鹏城实验室</div> | |||
| <div class="update-time"> | |||
| <span>{{ $t('repos.updated') }}</span> | |||
| <el-tooltip effect="dark" :content="dateFormat(data.UpdatedUnix)" placement="top-start"> | |||
| <span>{{ calcFromNow(data.UpdatedUnix) }}</span> | |||
| </el-tooltip> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import dayjs from 'dayjs'; | |||
| import { lang } from '~/langs'; | |||
| import { timeSinceUnix } from '~/utils'; | |||
| export default { | |||
| name: "PrjResultsItem", | |||
| props: { | |||
| data: { type: Object, default: () => ({}) }, | |||
| }, | |||
| components: {}, | |||
| data() { | |||
| return { | |||
| }; | |||
| }, | |||
| methods: { | |||
| calcFromNow(unix) { | |||
| return timeSinceUnix(unix, Date.now() / 1000); | |||
| }, | |||
| dateFormat(unix) { | |||
| return lang == 'zh-CN' ? dayjs(unix * 1000).format('YYYY年MM月DD日 HH时mm分ss秒') : | |||
| dayjs(unix * 1000).format('ddd, D MMM YYYY HH:mm:ss [CST]'); | |||
| } | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .item { | |||
| border-color: rgb(232, 224, 236); | |||
| border-width: 1px; | |||
| border-style: solid; | |||
| box-shadow: rgba(168, 157, 226, 0.2) 0px 5px 10px 0px; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(-0.01900000000000005%2C%200.997%2C%20-0.12862587255310284%2C%20-0.01900000000000005%2C%200.995%2C%200.014)%22%3E%3Cstop%20stop-color%3D%22%23f2edf5%22%20stop-opacity%3D%221%22%20offset%3D%220.01%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ffffff%22%20stop-opacity%3D%221%22%20offset%3D%220.31%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| overflow: hidden; | |||
| padding: 15px; | |||
| } | |||
| .title-c { | |||
| display: flex; | |||
| align-items: center; | |||
| .avatar-c { | |||
| height: 28px; | |||
| width: 28px; | |||
| margin-right: 6px; | |||
| img { | |||
| border-radius: 100%; | |||
| height: 100%; | |||
| width: 100%; | |||
| } | |||
| } | |||
| .title { | |||
| flex: 1; | |||
| overflow: hidden; | |||
| text-overflow: ellipsis; | |||
| white-space: nowrap; | |||
| span { | |||
| color: rgb(16, 16, 16); | |||
| font-size: 16px; | |||
| font-weight: 400; | |||
| } | |||
| } | |||
| } | |||
| .descr { | |||
| height: 40px; | |||
| margin-top: 8px; | |||
| font-size: 12px; | |||
| font-weight: 300; | |||
| color: rgb(136, 136, 136); | |||
| text-overflow: ellipsis; | |||
| word-break: break-all; | |||
| display: -webkit-box; | |||
| -webkit-box-orient: vertical; | |||
| -webkit-line-clamp: 2; | |||
| max-height: 41px; | |||
| overflow: hidden; | |||
| } | |||
| .topics { | |||
| overflow: hidden; | |||
| text-overflow: ellipsis; | |||
| white-space: nowrap; | |||
| margin-top: 5px; | |||
| height: 20px; | |||
| .topic { | |||
| color: rgba(16, 16, 16, 0.8); | |||
| border-radius: 4px; | |||
| font-size: 12px; | |||
| background: rgba(232, 232, 232, 0.6); | |||
| padding: 2px 6px; | |||
| margin-right: 8px; | |||
| } | |||
| } | |||
| .footer { | |||
| margin-top: 12px; | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: space-between; | |||
| height: 20px; | |||
| .contractor { | |||
| font-size: 14px; | |||
| font-weight: 400; | |||
| color: rgba(0, 40, 192, 0.73); | |||
| overflow: hidden; | |||
| text-overflow: ellipsis; | |||
| white-space: nowrap; | |||
| } | |||
| .update-time { | |||
| text-align: right; | |||
| min-width: 140px; | |||
| font-size: 12px; | |||
| font-weight: 300; | |||
| color: rgb(136, 136, 136); | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,888 @@ | |||
| <template> | |||
| <div class="list-container"> | |||
| <div class="list-item-container" style="min-height:540px;" v-loading="loading"> | |||
| <div class="item-container" v-for="(item, index) in list" :key="item.ID"> | |||
| <PrjResultsItem :data="item"></PrjResultsItem> | |||
| </div> | |||
| <div v-show="(!list.length && !loading)" class="no-data">{{ $t('repos.noReposfound') }}</div> | |||
| </div> | |||
| <div class="center"> | |||
| <el-pagination ref="paginationRef" background @current-change="currentChange" @size-change="sizeChange" | |||
| :current-page.sync="iPage" :page-sizes="iPageSizes" :page-size.sync="iPageSize" | |||
| layout="total, sizes, prev, pager, next, jumper" :total="total"> | |||
| </el-pagination> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import PrjResultsItem from './PrjResultsItem.vue'; | |||
| import LetterAvatar from '~/utils/letteravatar'; | |||
| export default { | |||
| name: "PrjResultsList", | |||
| props: { | |||
| q: { type: String, default: '' }, | |||
| page: { type: Number, default: 1 }, | |||
| pageSize: { type: Number, default: 15 }, | |||
| pageSizes: { type: Array, default: () => [15, 30, 50] } | |||
| }, | |||
| components: { PrjResultsItem }, | |||
| data() { | |||
| return { | |||
| loading: false, | |||
| list: [ | |||
| { | |||
| "ID": 4781, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "msadapter", | |||
| "Name": "MSAdapter", | |||
| "Alias": "MSAdapter", | |||
| "NumWatches": 3, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "MindSpore对PyTorch接口的支持工具", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1669691488, | |||
| "UpdatedUnix": 1670839285, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "/user/avatar/wjtest1207/-1?18", | |||
| "UserName": "wjtest1207", | |||
| "Email": "wjtest1207@163.com", | |||
| "CommitCnt": 1 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 501, | |||
| "OwnerID": 224, | |||
| "OwnerName": "OpenIOSSG", | |||
| "LowerName": "promote", | |||
| "Name": "promote", | |||
| "Alias": "promote", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1642470476, | |||
| "UpdatedUnix": 1670256276, | |||
| "PrimaryLanguage": { | |||
| "ID": 724, | |||
| "RepoID": 501, | |||
| "CommitID": "2fd3316bcf89250f80b0d1f6a05cb2c69fdb2845", | |||
| "IsPrimary": true, | |||
| "Language": "Markdown", | |||
| "Percentage": 100, | |||
| "Color": "#cccccc", | |||
| "CreatedUnix": 1642470477 | |||
| }, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 696, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "octopus", | |||
| "Name": "octopus", | |||
| "Alias": "octopus", | |||
| "NumWatches": 3, | |||
| "NumStars": 1, | |||
| "NumForks": 0, | |||
| "Description": "面向多计算场景的一站式融合计算平台", | |||
| "Topics": [ | |||
| "openi", | |||
| "deep-learning", | |||
| "golang" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647933529, | |||
| "UpdatedUnix": 1670899396, | |||
| "PrimaryLanguage": { | |||
| "ID": 1018, | |||
| "RepoID": 696, | |||
| "CommitID": "70699543cc3bf19f70ee7b126b27b752b0577469", | |||
| "IsPrimary": true, | |||
| "Language": "CSS", | |||
| "Percentage": 36.5, | |||
| "Color": "#563d7c", | |||
| "CreatedUnix": 1647933538 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/696-c9d9105eba8ad76589b65edff1588bc5", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "2522636547@qq.com", | |||
| "CommitCnt": 253 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "835952234@qq.com", | |||
| "CommitCnt": 203 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "linfj@pcl.ac.cn", | |||
| "CommitCnt": 174 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "hackmong@163.com", | |||
| "CommitCnt": 121 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "liaowsh@pcl.ac.cn", | |||
| "CommitCnt": 114 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "/user/avatar/liwei_test/-1?25", | |||
| "UserName": "liwei_test", | |||
| "Email": "liw03@pcl.ac.cn", | |||
| "CommitCnt": 88 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 697, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "paddle", | |||
| "Name": "Paddle", | |||
| "Alias": "Paddle", | |||
| "NumWatches": 3, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "PaddlePaddle (PArallel Distributed Deep LEarning) 是一个简单易用、高效灵活、可扩展的深度学习平台,最初由百度科学家和工程师共同开发,目的是将深度学习技术应用到百度的众多产品中。", | |||
| "Topics": [ | |||
| "ai开发工具", | |||
| "deep-learning" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647933857, | |||
| "UpdatedUnix": 1670838791, | |||
| "PrimaryLanguage": { | |||
| "ID": 1021, | |||
| "RepoID": 697, | |||
| "CommitID": "c46e661dfd4dca4ccb2d8bb83225d2dcb0bff52c", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 45.9, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1647933890 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/697-c50e829c78c6c3168605586c750887e4", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "yuyang18@baidu.com", | |||
| "CommitCnt": 2039 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "luotao02@baidu.com", | |||
| "CommitCnt": 1101 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "fengjiayi@baidu.com", | |||
| "CommitCnt": 864 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "qiaolongfei@baidu.com", | |||
| "CommitCnt": 1456 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "tangjian03@baidu.com", | |||
| "CommitCnt": 730 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "panxin.grad@gmail.com", | |||
| "CommitCnt": 678 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 702, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "tensorlayerx", | |||
| "Name": "TensorLayerX", | |||
| "Alias": "TensorLayerX", | |||
| "NumWatches": 3, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "TensorLayer3.0一款兼容多深度学习框架后端的深度学习库, 目前可以用TensorFlow、MindSpore、PaddlePaddle作为后端计算引擎。", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "pytorch", | |||
| "标签aaa", | |||
| "paddlepaddle", | |||
| "test-abcdefghijklmno测-试-123456", | |||
| "tensorflow", | |||
| "mindspore", | |||
| "高层次库", | |||
| "深度学习", | |||
| "支持多计算后端" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647935532, | |||
| "UpdatedUnix": 1671012469, | |||
| "PrimaryLanguage": { | |||
| "ID": 1039, | |||
| "RepoID": 702, | |||
| "CommitID": "6eafa9118008338521d3d085d70627b37ccba51d", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 99.6, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1647935549 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/702-a18a6669062a1a24aea776744c003f34", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "dhsig552@163.com", | |||
| "CommitCnt": 1598 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "luo.mai.cs@gmail.com", | |||
| "CommitCnt": 203 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "37874862+warshallrho@users.noreply.github.com", | |||
| "CommitCnt": 130 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "jingqing.zhang15@imperial.ac.uk", | |||
| "CommitCnt": 129 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "rundi_wu@pku.edu.cn", | |||
| "CommitCnt": 159 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "lg4869@outlook.com", | |||
| "CommitCnt": 67 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4780, | |||
| "OwnerID": 218, | |||
| "OwnerName": "PCL-Platform.Intelligence", | |||
| "LowerName": "pcl_pangu", | |||
| "Name": "pcl_pangu", | |||
| "Alias": "pcl_pangu", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "鹏程·盘古SDK 上线!集成了鹏程·盘古alpha模型、增强版Evolution模型、多语言mPangu模型,欢迎测试和使用。希望鹏程·盘古模型的可持续学习与应用生态快速发展!", | |||
| "Topics": [ | |||
| "大模型" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1669691367, | |||
| "UpdatedUnix": 1670921009, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "/repo-avatars/4780-5b45386c19f3e34b4749e6dde7dc3181", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "/user/avatar/wjtest1207/-1?40", | |||
| "UserName": "wjtest1207", | |||
| "Email": "wjtest1207@163.com", | |||
| "CommitCnt": 1 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4405, | |||
| "OwnerID": 585, | |||
| "OwnerName": "arXiv_Computation_and_Language_2019", | |||
| "LowerName": "paddlenlp", | |||
| "Name": "PaddleNLP", | |||
| "Alias": "PaddleNLP", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1667453897, | |||
| "UpdatedUnix": 1670256902, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4127, | |||
| "OwnerID": 507, | |||
| "OwnerName": "international_conference_on_machine_learning", | |||
| "LowerName": "fairseq", | |||
| "Name": "fairseq", | |||
| "Alias": "fairseq", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1667442805, | |||
| "UpdatedUnix": 1670256623, | |||
| "PrimaryLanguage": { | |||
| "ID": 6206, | |||
| "RepoID": 4127, | |||
| "CommitID": "b8ac3fa6cc95f9dc97085232d4faf125e5bcd2e7", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 97.8, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1667443078 | |||
| }, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": true, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 2176, | |||
| "OwnerID": 536, | |||
| "OwnerName": "openi_paper", | |||
| "LowerName": "paddledetection", | |||
| "Name": "PaddleDetection", | |||
| "Alias": "PaddleDetection", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1666872337, | |||
| "UpdatedUnix": 1670257237, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4619, | |||
| "OwnerID": 536, | |||
| "OwnerName": "openi_paper", | |||
| "LowerName": "fairseq", | |||
| "Name": "fairseq", | |||
| "Alias": "fairseq", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1667461670, | |||
| "UpdatedUnix": 1670256376, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 598, | |||
| "OwnerID": 251, | |||
| "OwnerName": "PCL_AutoML", | |||
| "LowerName": "xbbo", | |||
| "Name": "XBBO", | |||
| "Alias": "XBBO", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "超参搜索(黑盒优化)框架", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "自动机器学习", | |||
| "优化", | |||
| "超参搜索" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1645065667, | |||
| "UpdatedUnix": 1671012526, | |||
| "PrimaryLanguage": { | |||
| "ID": 842, | |||
| "RepoID": 598, | |||
| "CommitID": "bb089a69ce3541246a948c08bd37e31ab23e439c", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 98.7, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1645065672 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/598-5c870fdbde9a0457989616263b77c63c", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "isleizhang@outlook.com", | |||
| "CommitCnt": 103 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "mathcoder.zl@gmail.com", | |||
| "CommitCnt": 10 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 999, | |||
| "OwnerID": 431, | |||
| "OwnerName": "GAMMALab", | |||
| "LowerName": "openhgnn", | |||
| "Name": "OpenHGNN", | |||
| "Alias": "OpenHGNN", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 2, | |||
| "Description": "OpenHGNN是由北邮GAMMA Lab开发的基于PyTorch和DGL的开源异质图神经网络工具包。", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "pytorch", | |||
| "dgl", | |||
| "heterogeneous", | |||
| "异质图", | |||
| "gnn", | |||
| "图神经网络" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1659322878, | |||
| "UpdatedUnix": 1671012520, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "/user/avatar/wjtest001/-1?56", | |||
| "UserName": "wjtest001", | |||
| "Email": "towangjing@yeah.net", | |||
| "CommitCnt": 1 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 703, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "apulis-ai-platform", | |||
| "Name": "Apulis-AI-Platform", | |||
| "Alias": "Apulis-AI-Platform", | |||
| "NumWatches": 3, | |||
| "NumStars": 2, | |||
| "NumForks": 0, | |||
| "Description": "依瞳人工智能平台旨在为不同行业的用户提供基于深度学习的端到端解决方案,使用户可以用最快的速度、最少的时间开始高性能的深度学习工作,从而大幅节省研究成本、提高研发效率,同时可为中小企业解决私有云难建成、成本高等问题。 平台融合了Tensorflow、PyTorch、MindSpore等开源深度学习框架,提供了模型训练、超参调优、集群状态监控等开发环境,方便AI开发者快速搭建人工智能开发环境,开展AI开发应用。在监控模块基础上搭建预警模块,自动将平台异常通知管理员,提升平台的预警效率及安全性能。", | |||
| "Topics": [ | |||
| "ai开发工具", | |||
| "openi-paper" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647935724, | |||
| "UpdatedUnix": 1671012418, | |||
| "PrimaryLanguage": { | |||
| "ID": 1054, | |||
| "RepoID": 703, | |||
| "CommitID": "18a76ed026dfa5a1e71a74f3518e9ba6f830d77f", | |||
| "IsPrimary": true, | |||
| "Language": "JavaScript", | |||
| "Percentage": 57.4, | |||
| "Color": "#f1e05a", | |||
| "CreatedUnix": 1647935738 | |||
| }, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "869071540@qq.com", | |||
| "CommitCnt": 1103 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "jinlmsft@hotmail.com", | |||
| "CommitCnt": 745 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "hongzhi.li@microsoft.com", | |||
| "CommitCnt": 504 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "xjhan1995@gmail.com", | |||
| "CommitCnt": 399 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "hongzhili@users.noreply.github.com", | |||
| "CommitCnt": 377 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "xudifsd@gmail.com", | |||
| "CommitCnt": 251 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 695, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "cubeai", | |||
| "Name": "cubeai", | |||
| "Alias": "cubeai", | |||
| "NumWatches": 3, | |||
| "NumStars": 3, | |||
| "NumForks": 0, | |||
| "Description": "CubeAI智立方是中国联通研究院自主研发的集AI模型自动化服务封装、发布、共享、部署和能力开放等功能于一体的开源AI算能服务平台,其核心作用在于打通AI模型开发至实际生产应用之间的壁垒,加速AI创新和应用进程,促进AI应用从设计、开发直到部署、运营整个生命周期的自动化快速迭代和演进。", | |||
| "Topics": [ | |||
| "ai开发工具", | |||
| "openi", | |||
| "ai模型服务化", | |||
| "ai模型共享", | |||
| "ai模型部署", | |||
| "ai能力开放" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647933184, | |||
| "UpdatedUnix": 1670838880, | |||
| "PrimaryLanguage": { | |||
| "ID": 1006, | |||
| "RepoID": 695, | |||
| "CommitID": "09e1a0146612cff32fb01881707c831414494599", | |||
| "IsPrimary": true, | |||
| "Language": "Shell", | |||
| "Percentage": 96.8, | |||
| "Color": "#89e051", | |||
| "CreatedUnix": 1647933187 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/695-5d57aff010bceee7d1634ea64ca6a298", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "huolongshe@126.com", | |||
| "CommitCnt": 15 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 595, | |||
| "OwnerID": 251, | |||
| "OwnerName": "PCL_AutoML", | |||
| "LowerName": "xnas", | |||
| "Name": "XNAS", | |||
| "Alias": "XNAS", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "神经网络结构搜索框架", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "自动机器学习", | |||
| "automl", | |||
| "神经网络结构搜索" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1645065509, | |||
| "UpdatedUnix": 1671012496, | |||
| "PrimaryLanguage": { | |||
| "ID": 838, | |||
| "RepoID": 595, | |||
| "CommitID": "2c54ceb09b255cbcabd67f3c39fc777c4b2403f4", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 100, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1645065513 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/595-4284a9fbc95ba42b7753910d8fcd1828", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "zhengxiawu@126.com", | |||
| "CommitCnt": 262 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "sdut_snow@163.com", | |||
| "CommitCnt": 66 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "1004463561@qq.com", | |||
| "CommitCnt": 31 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "thrase@163.com", | |||
| "CommitCnt": 23 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "shaokunzhang529@gmail.com", | |||
| "CommitCnt": 24 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "51071696+WOODchen7@users.noreply.github.com", | |||
| "CommitCnt": 7 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| } | |||
| ], | |||
| iPageSizes: [15, 30, 50], | |||
| iPageSize: 15, | |||
| iPage: 1, | |||
| total: 0, | |||
| }; | |||
| }, | |||
| methods: { | |||
| getListData() { | |||
| return; | |||
| this.loading = true; | |||
| getReposListData({ | |||
| q: this.q || '', | |||
| topic: this.topic || '', | |||
| sort: this.sort || 'mostpopular', | |||
| pageSize: this.iPageSize || 15, | |||
| page: this.iPage || 1, | |||
| }).then(res => { | |||
| res = res.data; | |||
| this.loading = false; | |||
| if (res.Code == 0) { | |||
| const list = res.Data.Repos || []; | |||
| this.list = list.map((item) => { | |||
| item.Contributors = (item.Contributors || []).map((_item) => { | |||
| return { | |||
| ..._item, | |||
| bgColor: this.randomColor(_item.Email[0].toLocaleUpperCase()), | |||
| } | |||
| }); | |||
| const contributors = item.Contributors || []; | |||
| return { | |||
| ...item, | |||
| NameShow: this.handlerSearchStr(item.Alias, this.q), | |||
| DescriptionShow: this.handlerSearchStr(item.Description, this.q), | |||
| TopicsShow: (item.Topics || []).map((_item) => { | |||
| return { | |||
| topic: _item, | |||
| topicShow: this.handlerSearchStr(_item, this.q) | |||
| } | |||
| }), | |||
| } | |||
| }); | |||
| this.total = res.Data.Total; | |||
| this.iPage = this.iPage; | |||
| this.iPageSize = this.iPageSize; | |||
| this.$nextTick(() => { | |||
| LetterAvatar.transform(); | |||
| }); | |||
| } else { | |||
| this.list = []; | |||
| this.total = 0; | |||
| this.iPage = this.iPage; | |||
| this.iPageSize = this.iPageSize; | |||
| } | |||
| }).catch(err => { | |||
| console.log(err); | |||
| this.loading = false; | |||
| this.list = []; | |||
| this.total = 0; | |||
| this.iPage = this.iPage; | |||
| this.iPageSize = this.iPageSize; | |||
| }); | |||
| }, | |||
| search() { | |||
| this.getListData(); | |||
| }, | |||
| currentChange(page) { | |||
| this.iPage = page; | |||
| this.$emit('current-change', { | |||
| page: this.iPage, | |||
| pageSize: this.iPageSize, | |||
| }); | |||
| }, | |||
| sizeChange(pageSize) { | |||
| this.iPageSize = pageSize; | |||
| this.$emit('size-change', { | |||
| page: this.iPage, | |||
| pageSize: this.iPageSize, | |||
| }); | |||
| }, | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .list-container { | |||
| .list-item-container { | |||
| display: flex; | |||
| flex-wrap: wrap; | |||
| .item-container { | |||
| width: 50%; | |||
| padding: 12px; | |||
| } | |||
| } | |||
| } | |||
| .center { | |||
| text-align: center; | |||
| } | |||
| .no-data { | |||
| height: 60px; | |||
| display: flex; | |||
| justify-content: center; | |||
| align-items: center; | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,243 @@ | |||
| <template> | |||
| <div class="item"> | |||
| <div class="header"> | |||
| <div class="header-l"> | |||
| <div class="title">小样本条件下的自适应机器学习理论与模型研究</div> | |||
| <div class="prj-type">应用示范研究</div> | |||
| </div> | |||
| <div class="header-r"> | |||
| <a href=""> | |||
| <span>更多成果</span> | |||
| <i class="el-icon-arrow-right"></i> | |||
| </a> | |||
| </div> | |||
| </div> | |||
| <div class="content"> | |||
| <div class="item-l-c"> | |||
| <div class="row"> | |||
| <span class="tit">负责单位:</span> | |||
| <span class="val">鹏城实验室</span> | |||
| </div> | |||
| <div class="row"> | |||
| <span class="tit">参与单位:</span> | |||
| <span class="val">大连理工大学、北京理工大学、北京理工大学、北京理工大学、北京理工大学、北京理工大学</span> | |||
| </div> | |||
| <div class="row"> | |||
| <span class="tit">申报年份:</span> | |||
| <span class="val">2018</span> | |||
| </div> | |||
| <div class="row"> | |||
| <span class="tit">执行周期:</span> | |||
| <span class="val">2019 - 2023</span> | |||
| </div> | |||
| <div class="row"> | |||
| <span class="tit">项目成果数:</span> | |||
| <span class="val">10</span> | |||
| </div> | |||
| </div> | |||
| <div class="item-r-c"> | |||
| <a class="repo-item-c" href="javascript:;" v-for="(item, index) in [1, 2]"> | |||
| <div class="repo-item"> | |||
| <div class="repo-hd"> | |||
| <div class="repo-avatar"> | |||
| <img v-if="data.RelAvatarLink" class="avatar" :src="data.RelAvatarLink" /> | |||
| <img v-else class="avatar" :avatar="data.OwnerName" /> | |||
| </div> | |||
| <div class="repo-tit">面向服务的群智化生态化软件开发支撑平台(aiforge)</div> | |||
| </div> | |||
| <div class="repo-content"> | |||
| <div class="repo-descr"> | |||
| 本项目是群体化方法与技术的开源实现案例,在基于Gitea的基础上,进一步支持社交化的协同开发、协同学习、协同研究等群体创新实践服务,特别是针对新一代人工智能技术特点,重点支持项目管理、git代码管理、大数据集存储管理与智能计算平台接入。 | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </a> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import dayjs from 'dayjs'; | |||
| import { lang } from '~/langs'; | |||
| import { timeSinceUnix } from '~/utils'; | |||
| export default { | |||
| name: "SciAndTechPrjItem", | |||
| props: { | |||
| data: { type: Object, default: () => ({}) }, | |||
| }, | |||
| components: {}, | |||
| data() { | |||
| return { | |||
| }; | |||
| }, | |||
| methods: { | |||
| calcFromNow(unix) { | |||
| return timeSinceUnix(unix, Date.now() / 1000); | |||
| }, | |||
| dateFormat(unix) { | |||
| return lang == 'zh-CN' ? dayjs(unix * 1000).format('YYYY年MM月DD日 HH时mm分ss秒') : | |||
| dayjs(unix * 1000).format('ddd, D MMM YYYY HH:mm:ss [CST]'); | |||
| } | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .item { | |||
| border-color: rgb(232, 224, 236); | |||
| border-width: 1px; | |||
| border-style: solid; | |||
| box-shadow: rgba(168, 157, 226, 0.2) 0px 5px 10px 0px; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(-0.01900000000000005%2C%200.997%2C%20-0.12862587255310284%2C%20-0.01900000000000005%2C%200.995%2C%200.014)%22%3E%3Cstop%20stop-color%3D%22%23f2edf5%22%20stop-opacity%3D%221%22%20offset%3D%220.01%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ffffff%22%20stop-opacity%3D%221%22%20offset%3D%220.31%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| overflow: hidden; | |||
| padding: 15px; | |||
| .header { | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: space-between; | |||
| .header-l { | |||
| display: flex; | |||
| align-items: center; | |||
| .title { | |||
| color: rgb(16, 16, 16); | |||
| font-size: 18px; | |||
| font-weight: bold; | |||
| overflow: hidden; | |||
| text-overflow: ellipsis; | |||
| white-space: nowrap; | |||
| max-width: 800px; | |||
| } | |||
| .prj-type { | |||
| margin-left: 14px; | |||
| font-size: 12px; | |||
| font-weight: 400; | |||
| color: rgb(100, 59, 159); | |||
| background: rgb(237, 234, 251); | |||
| padding: 2px 5px; | |||
| border-radius: 4px; | |||
| } | |||
| } | |||
| .header-r { | |||
| display: flex; | |||
| align-items: baseline; | |||
| text-align: right; | |||
| color: rgb(50, 145, 248); | |||
| font-size: 12px; | |||
| width: 80px; | |||
| justify-content: flex-end; | |||
| i { | |||
| margin-left: 1px; | |||
| } | |||
| } | |||
| } | |||
| .content { | |||
| display: flex; | |||
| margin-top: 10px; | |||
| .item-l-c { | |||
| flex: 1; | |||
| .row { | |||
| display: flex; | |||
| font-size: 14px; | |||
| color: rgb(16, 16, 16); | |||
| margin: 8px 0; | |||
| font-weight: 400; | |||
| .tit { | |||
| color: rgba(136, 136, 136, 1); | |||
| } | |||
| .val { | |||
| flex: 1; | |||
| width: 0; | |||
| overflow: hidden; | |||
| text-overflow: ellipsis; | |||
| white-space: nowrap; | |||
| } | |||
| &:last-child { | |||
| margin-bottom: 0; | |||
| } | |||
| } | |||
| } | |||
| .item-r-c { | |||
| flex: 2; | |||
| margin-left: 10px; | |||
| display: flex; | |||
| .repo-item-c { | |||
| display: block; | |||
| flex: 1; | |||
| margin: 10px; | |||
| padding: 20px; | |||
| border-color: rgba(157, 197, 226, 0.4); | |||
| border-width: 1px; | |||
| border-style: solid; | |||
| border-radius: 5px; | |||
| box-shadow: rgba(157, 197, 226, 0.2) 0px 5px 10px 0px; | |||
| background: rgb(255, 255, 255); | |||
| width: 0; | |||
| .repo-item { | |||
| .repo-hd { | |||
| display: flex; | |||
| align-items: center; | |||
| .repo-avatar { | |||
| width: 28px; | |||
| height: 28px; | |||
| img { | |||
| width: 100%; | |||
| height: 100%; | |||
| border-radius: 100%; | |||
| } | |||
| } | |||
| .repo-tit { | |||
| flex: 1; | |||
| margin-left: 8px; | |||
| width: 0; | |||
| font-size: 14px; | |||
| color: rgb(50, 145, 248); | |||
| overflow: hidden; | |||
| text-overflow: ellipsis; | |||
| white-space: nowrap; | |||
| } | |||
| } | |||
| .repo-content { | |||
| margin-top: 10px; | |||
| .repo-descr { | |||
| width: 100%; | |||
| font-size: 12px; | |||
| color: rgb(136, 136, 136); | |||
| text-overflow: ellipsis; | |||
| word-break: break-all; | |||
| display: -webkit-box; | |||
| -webkit-box-orient: vertical; | |||
| -webkit-line-clamp: 2; | |||
| max-height: 41px; | |||
| overflow: hidden; | |||
| } | |||
| } | |||
| } | |||
| } | |||
| } | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,885 @@ | |||
| <template> | |||
| <div class="list-container"> | |||
| <div class="list-item-container" style="min-height:540px;" v-loading="loading"> | |||
| <div class="item-container" v-for="(item, index) in list" :key="item.ID"> | |||
| <SciAndTechPrjItem :data="item"></SciAndTechPrjItem> | |||
| </div> | |||
| <div v-show="(!list.length && !loading)" class="no-data">{{ $t('repos.noReposfound') }}</div> | |||
| </div> | |||
| <div class="center"> | |||
| <el-pagination ref="paginationRef" background @current-change="currentChange" @size-change="sizeChange" | |||
| :current-page.sync="iPage" :page-sizes="iPageSizes" :page-size.sync="iPageSize" | |||
| layout="total, sizes, prev, pager, next, jumper" :total="total"> | |||
| </el-pagination> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import SciAndTechPrjItem from './SciAndTechPrjItem.vue'; | |||
| import LetterAvatar from '~/utils/letteravatar'; | |||
| export default { | |||
| name: "SciAndTechPrjList", | |||
| props: { | |||
| q: { type: String, default: '' }, | |||
| page: { type: Number, default: 1 }, | |||
| pageSize: { type: Number, default: 15 }, | |||
| pageSizes: { type: Array, default: () => [15, 30, 50] } | |||
| }, | |||
| components: { SciAndTechPrjItem }, | |||
| data() { | |||
| return { | |||
| loading: false, | |||
| list: [ | |||
| { | |||
| "ID": 4781, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "msadapter", | |||
| "Name": "MSAdapter", | |||
| "Alias": "MSAdapter", | |||
| "NumWatches": 3, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "MindSpore对PyTorch接口的支持工具", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1669691488, | |||
| "UpdatedUnix": 1670839285, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "/user/avatar/wjtest1207/-1?18", | |||
| "UserName": "wjtest1207", | |||
| "Email": "wjtest1207@163.com", | |||
| "CommitCnt": 1 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 501, | |||
| "OwnerID": 224, | |||
| "OwnerName": "OpenIOSSG", | |||
| "LowerName": "promote", | |||
| "Name": "promote", | |||
| "Alias": "promote", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1642470476, | |||
| "UpdatedUnix": 1670256276, | |||
| "PrimaryLanguage": { | |||
| "ID": 724, | |||
| "RepoID": 501, | |||
| "CommitID": "2fd3316bcf89250f80b0d1f6a05cb2c69fdb2845", | |||
| "IsPrimary": true, | |||
| "Language": "Markdown", | |||
| "Percentage": 100, | |||
| "Color": "#cccccc", | |||
| "CreatedUnix": 1642470477 | |||
| }, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 696, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "octopus", | |||
| "Name": "octopus", | |||
| "Alias": "octopus", | |||
| "NumWatches": 3, | |||
| "NumStars": 1, | |||
| "NumForks": 0, | |||
| "Description": "面向多计算场景的一站式融合计算平台", | |||
| "Topics": [ | |||
| "openi", | |||
| "deep-learning", | |||
| "golang" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647933529, | |||
| "UpdatedUnix": 1670899396, | |||
| "PrimaryLanguage": { | |||
| "ID": 1018, | |||
| "RepoID": 696, | |||
| "CommitID": "70699543cc3bf19f70ee7b126b27b752b0577469", | |||
| "IsPrimary": true, | |||
| "Language": "CSS", | |||
| "Percentage": 36.5, | |||
| "Color": "#563d7c", | |||
| "CreatedUnix": 1647933538 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/696-c9d9105eba8ad76589b65edff1588bc5", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "2522636547@qq.com", | |||
| "CommitCnt": 253 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "835952234@qq.com", | |||
| "CommitCnt": 203 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "linfj@pcl.ac.cn", | |||
| "CommitCnt": 174 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "hackmong@163.com", | |||
| "CommitCnt": 121 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "liaowsh@pcl.ac.cn", | |||
| "CommitCnt": 114 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "/user/avatar/liwei_test/-1?25", | |||
| "UserName": "liwei_test", | |||
| "Email": "liw03@pcl.ac.cn", | |||
| "CommitCnt": 88 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 697, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "paddle", | |||
| "Name": "Paddle", | |||
| "Alias": "Paddle", | |||
| "NumWatches": 3, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "PaddlePaddle (PArallel Distributed Deep LEarning) 是一个简单易用、高效灵活、可扩展的深度学习平台,最初由百度科学家和工程师共同开发,目的是将深度学习技术应用到百度的众多产品中。", | |||
| "Topics": [ | |||
| "ai开发工具", | |||
| "deep-learning" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647933857, | |||
| "UpdatedUnix": 1670838791, | |||
| "PrimaryLanguage": { | |||
| "ID": 1021, | |||
| "RepoID": 697, | |||
| "CommitID": "c46e661dfd4dca4ccb2d8bb83225d2dcb0bff52c", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 45.9, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1647933890 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/697-c50e829c78c6c3168605586c750887e4", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "yuyang18@baidu.com", | |||
| "CommitCnt": 2039 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "luotao02@baidu.com", | |||
| "CommitCnt": 1101 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "fengjiayi@baidu.com", | |||
| "CommitCnt": 864 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "qiaolongfei@baidu.com", | |||
| "CommitCnt": 1456 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "tangjian03@baidu.com", | |||
| "CommitCnt": 730 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "panxin.grad@gmail.com", | |||
| "CommitCnt": 678 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 702, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "tensorlayerx", | |||
| "Name": "TensorLayerX", | |||
| "Alias": "TensorLayerX", | |||
| "NumWatches": 3, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "TensorLayer3.0一款兼容多深度学习框架后端的深度学习库, 目前可以用TensorFlow、MindSpore、PaddlePaddle作为后端计算引擎。", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "pytorch", | |||
| "标签aaa", | |||
| "paddlepaddle", | |||
| "test-abcdefghijklmno测-试-123456", | |||
| "tensorflow", | |||
| "mindspore", | |||
| "高层次库", | |||
| "深度学习", | |||
| "支持多计算后端" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647935532, | |||
| "UpdatedUnix": 1671012469, | |||
| "PrimaryLanguage": { | |||
| "ID": 1039, | |||
| "RepoID": 702, | |||
| "CommitID": "6eafa9118008338521d3d085d70627b37ccba51d", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 99.6, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1647935549 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/702-a18a6669062a1a24aea776744c003f34", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "dhsig552@163.com", | |||
| "CommitCnt": 1598 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "luo.mai.cs@gmail.com", | |||
| "CommitCnt": 203 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "37874862+warshallrho@users.noreply.github.com", | |||
| "CommitCnt": 130 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "jingqing.zhang15@imperial.ac.uk", | |||
| "CommitCnt": 129 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "rundi_wu@pku.edu.cn", | |||
| "CommitCnt": 159 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "lg4869@outlook.com", | |||
| "CommitCnt": 67 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4780, | |||
| "OwnerID": 218, | |||
| "OwnerName": "PCL-Platform.Intelligence", | |||
| "LowerName": "pcl_pangu", | |||
| "Name": "pcl_pangu", | |||
| "Alias": "pcl_pangu", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "鹏程·盘古SDK 上线!集成了鹏程·盘古alpha模型、增强版Evolution模型、多语言mPangu模型,欢迎测试和使用。希望鹏程·盘古模型的可持续学习与应用生态快速发展!", | |||
| "Topics": [ | |||
| "大模型" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1669691367, | |||
| "UpdatedUnix": 1670921009, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "/repo-avatars/4780-5b45386c19f3e34b4749e6dde7dc3181", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "/user/avatar/wjtest1207/-1?40", | |||
| "UserName": "wjtest1207", | |||
| "Email": "wjtest1207@163.com", | |||
| "CommitCnt": 1 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4405, | |||
| "OwnerID": 585, | |||
| "OwnerName": "arXiv_Computation_and_Language_2019", | |||
| "LowerName": "paddlenlp", | |||
| "Name": "PaddleNLP", | |||
| "Alias": "PaddleNLP", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1667453897, | |||
| "UpdatedUnix": 1670256902, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4127, | |||
| "OwnerID": 507, | |||
| "OwnerName": "international_conference_on_machine_learning", | |||
| "LowerName": "fairseq", | |||
| "Name": "fairseq", | |||
| "Alias": "fairseq", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1667442805, | |||
| "UpdatedUnix": 1670256623, | |||
| "PrimaryLanguage": { | |||
| "ID": 6206, | |||
| "RepoID": 4127, | |||
| "CommitID": "b8ac3fa6cc95f9dc97085232d4faf125e5bcd2e7", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 97.8, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1667443078 | |||
| }, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": true, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 2176, | |||
| "OwnerID": 536, | |||
| "OwnerName": "openi_paper", | |||
| "LowerName": "paddledetection", | |||
| "Name": "PaddleDetection", | |||
| "Alias": "PaddleDetection", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1666872337, | |||
| "UpdatedUnix": 1670257237, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 4619, | |||
| "OwnerID": 536, | |||
| "OwnerName": "openi_paper", | |||
| "LowerName": "fairseq", | |||
| "Name": "fairseq", | |||
| "Alias": "fairseq", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "", | |||
| "Topics": null, | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1667461670, | |||
| "UpdatedUnix": 1670256376, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 598, | |||
| "OwnerID": 251, | |||
| "OwnerName": "PCL_AutoML", | |||
| "LowerName": "xbbo", | |||
| "Name": "XBBO", | |||
| "Alias": "XBBO", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "超参搜索(黑盒优化)框架", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "自动机器学习", | |||
| "优化", | |||
| "超参搜索" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1645065667, | |||
| "UpdatedUnix": 1671012526, | |||
| "PrimaryLanguage": { | |||
| "ID": 842, | |||
| "RepoID": 598, | |||
| "CommitID": "bb089a69ce3541246a948c08bd37e31ab23e439c", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 98.7, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1645065672 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/598-5c870fdbde9a0457989616263b77c63c", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "isleizhang@outlook.com", | |||
| "CommitCnt": 103 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "mathcoder.zl@gmail.com", | |||
| "CommitCnt": 10 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 999, | |||
| "OwnerID": 431, | |||
| "OwnerName": "GAMMALab", | |||
| "LowerName": "openhgnn", | |||
| "Name": "OpenHGNN", | |||
| "Alias": "OpenHGNN", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 2, | |||
| "Description": "OpenHGNN是由北邮GAMMA Lab开发的基于PyTorch和DGL的开源异质图神经网络工具包。", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "pytorch", | |||
| "dgl", | |||
| "heterogeneous", | |||
| "异质图", | |||
| "gnn", | |||
| "图神经网络" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1659322878, | |||
| "UpdatedUnix": 1671012520, | |||
| "PrimaryLanguage": null, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "/user/avatar/wjtest001/-1?56", | |||
| "UserName": "wjtest001", | |||
| "Email": "towangjing@yeah.net", | |||
| "CommitCnt": 1 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 703, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "apulis-ai-platform", | |||
| "Name": "Apulis-AI-Platform", | |||
| "Alias": "Apulis-AI-Platform", | |||
| "NumWatches": 3, | |||
| "NumStars": 2, | |||
| "NumForks": 0, | |||
| "Description": "依瞳人工智能平台旨在为不同行业的用户提供基于深度学习的端到端解决方案,使用户可以用最快的速度、最少的时间开始高性能的深度学习工作,从而大幅节省研究成本、提高研发效率,同时可为中小企业解决私有云难建成、成本高等问题。 平台融合了Tensorflow、PyTorch、MindSpore等开源深度学习框架,提供了模型训练、超参调优、集群状态监控等开发环境,方便AI开发者快速搭建人工智能开发环境,开展AI开发应用。在监控模块基础上搭建预警模块,自动将平台异常通知管理员,提升平台的预警效率及安全性能。", | |||
| "Topics": [ | |||
| "ai开发工具", | |||
| "openi-paper" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647935724, | |||
| "UpdatedUnix": 1671012418, | |||
| "PrimaryLanguage": { | |||
| "ID": 1054, | |||
| "RepoID": 703, | |||
| "CommitID": "18a76ed026dfa5a1e71a74f3518e9ba6f830d77f", | |||
| "IsPrimary": true, | |||
| "Language": "JavaScript", | |||
| "Percentage": 57.4, | |||
| "Color": "#f1e05a", | |||
| "CreatedUnix": 1647935738 | |||
| }, | |||
| "RelAvatarLink": "", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "869071540@qq.com", | |||
| "CommitCnt": 1103 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "jinlmsft@hotmail.com", | |||
| "CommitCnt": 745 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "hongzhi.li@microsoft.com", | |||
| "CommitCnt": 504 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "xjhan1995@gmail.com", | |||
| "CommitCnt": 399 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "hongzhili@users.noreply.github.com", | |||
| "CommitCnt": 377 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "xudifsd@gmail.com", | |||
| "CommitCnt": 251 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 695, | |||
| "OwnerID": 679, | |||
| "OwnerName": "OpenI", | |||
| "LowerName": "cubeai", | |||
| "Name": "cubeai", | |||
| "Alias": "cubeai", | |||
| "NumWatches": 3, | |||
| "NumStars": 3, | |||
| "NumForks": 0, | |||
| "Description": "CubeAI智立方是中国联通研究院自主研发的集AI模型自动化服务封装、发布、共享、部署和能力开放等功能于一体的开源AI算能服务平台,其核心作用在于打通AI模型开发至实际生产应用之间的壁垒,加速AI创新和应用进程,促进AI应用从设计、开发直到部署、运营整个生命周期的自动化快速迭代和演进。", | |||
| "Topics": [ | |||
| "ai开发工具", | |||
| "openi", | |||
| "ai模型服务化", | |||
| "ai模型共享", | |||
| "ai模型部署", | |||
| "ai能力开放" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1647933184, | |||
| "UpdatedUnix": 1670838880, | |||
| "PrimaryLanguage": { | |||
| "ID": 1006, | |||
| "RepoID": 695, | |||
| "CommitID": "09e1a0146612cff32fb01881707c831414494599", | |||
| "IsPrimary": true, | |||
| "Language": "Shell", | |||
| "Percentage": 96.8, | |||
| "Color": "#89e051", | |||
| "CreatedUnix": 1647933187 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/695-5d57aff010bceee7d1634ea64ca6a298", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "huolongshe@126.com", | |||
| "CommitCnt": 15 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| }, | |||
| { | |||
| "ID": 595, | |||
| "OwnerID": 251, | |||
| "OwnerName": "PCL_AutoML", | |||
| "LowerName": "xnas", | |||
| "Name": "XNAS", | |||
| "Alias": "XNAS", | |||
| "NumWatches": 1, | |||
| "NumStars": 0, | |||
| "NumForks": 0, | |||
| "Description": "神经网络结构搜索框架", | |||
| "Topics": [ | |||
| "openi-paper", | |||
| "自动机器学习", | |||
| "automl", | |||
| "神经网络结构搜索" | |||
| ], | |||
| "AiTaskCnt": 0, | |||
| "ModelCnt": 0, | |||
| "DatasetCnt": 0, | |||
| "CreatedUnix": 1645065509, | |||
| "UpdatedUnix": 1671012496, | |||
| "PrimaryLanguage": { | |||
| "ID": 838, | |||
| "RepoID": 595, | |||
| "CommitID": "2c54ceb09b255cbcabd67f3c39fc777c4b2403f4", | |||
| "IsPrimary": true, | |||
| "Language": "Python", | |||
| "Percentage": 100, | |||
| "Color": "#3572A5", | |||
| "CreatedUnix": 1645065513 | |||
| }, | |||
| "RelAvatarLink": "/repo-avatars/595-4284a9fbc95ba42b7753910d8fcd1828", | |||
| "Contributors": [ | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "zhengxiawu@126.com", | |||
| "CommitCnt": 262 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "sdut_snow@163.com", | |||
| "CommitCnt": 66 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "1004463561@qq.com", | |||
| "CommitCnt": 31 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "thrase@163.com", | |||
| "CommitCnt": 23 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "shaokunzhang529@gmail.com", | |||
| "CommitCnt": 24 | |||
| }, | |||
| { | |||
| "RelAvatarLink": "", | |||
| "UserName": "", | |||
| "Email": "51071696+WOODchen7@users.noreply.github.com", | |||
| "CommitCnt": 7 | |||
| } | |||
| ], | |||
| "IsPrivate": false, | |||
| "IsFork": false, | |||
| "IsMirror": false, | |||
| "IsOwnerPrivate": false, | |||
| "IsArchived": false | |||
| } | |||
| ], | |||
| iPageSizes: [15, 30, 50], | |||
| iPageSize: 15, | |||
| iPage: 1, | |||
| total: 0, | |||
| }; | |||
| }, | |||
| methods: { | |||
| getListData() { | |||
| return; | |||
| this.loading = true; | |||
| getReposListData({ | |||
| q: this.q || '', | |||
| topic: this.topic || '', | |||
| sort: this.sort || 'mostpopular', | |||
| pageSize: this.iPageSize || 15, | |||
| page: this.iPage || 1, | |||
| }).then(res => { | |||
| res = res.data; | |||
| this.loading = false; | |||
| if (res.Code == 0) { | |||
| const list = res.Data.Repos || []; | |||
| this.list = list.map((item) => { | |||
| item.Contributors = (item.Contributors || []).map((_item) => { | |||
| return { | |||
| ..._item, | |||
| bgColor: this.randomColor(_item.Email[0].toLocaleUpperCase()), | |||
| } | |||
| }); | |||
| const contributors = item.Contributors || []; | |||
| return { | |||
| ...item, | |||
| NameShow: this.handlerSearchStr(item.Alias, this.q), | |||
| DescriptionShow: this.handlerSearchStr(item.Description, this.q), | |||
| TopicsShow: (item.Topics || []).map((_item) => { | |||
| return { | |||
| topic: _item, | |||
| topicShow: this.handlerSearchStr(_item, this.q) | |||
| } | |||
| }), | |||
| } | |||
| }); | |||
| this.total = res.Data.Total; | |||
| this.iPage = this.iPage; | |||
| this.iPageSize = this.iPageSize; | |||
| this.$nextTick(() => { | |||
| LetterAvatar.transform(); | |||
| }); | |||
| } else { | |||
| this.list = []; | |||
| this.total = 0; | |||
| this.iPage = this.iPage; | |||
| this.iPageSize = this.iPageSize; | |||
| } | |||
| }).catch(err => { | |||
| console.log(err); | |||
| this.loading = false; | |||
| this.list = []; | |||
| this.total = 0; | |||
| this.iPage = this.iPage; | |||
| this.iPageSize = this.iPageSize; | |||
| }); | |||
| }, | |||
| search() { | |||
| this.getListData(); | |||
| }, | |||
| currentChange(page) { | |||
| this.iPage = page; | |||
| this.$emit('current-change', { | |||
| page: this.iPage, | |||
| pageSize: this.iPageSize, | |||
| }); | |||
| }, | |||
| sizeChange(pageSize) { | |||
| this.iPageSize = pageSize; | |||
| this.$emit('size-change', { | |||
| page: this.iPage, | |||
| pageSize: this.iPageSize, | |||
| }); | |||
| }, | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .list-container { | |||
| .list-item-container { | |||
| .item-container { | |||
| width: 100%; | |||
| padding: 12px; | |||
| } | |||
| } | |||
| } | |||
| .center { | |||
| text-align: center; | |||
| } | |||
| .no-data { | |||
| height: 60px; | |||
| display: flex; | |||
| justify-content: center; | |||
| align-items: center; | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,179 @@ | |||
| <template> | |||
| <div class="search-bar"> | |||
| <div class="search-bar-l"> | |||
| <div class="search-c"> | |||
| <div class="search-input-c"> | |||
| <input type="text" :placeholder="serchPlaceHolder" v-model="keyword" @keyup.enter.native="search"> | |||
| </div> | |||
| <div class="search-btn" @click="search">搜索</div> | |||
| </div> | |||
| <el-button class="apply-btn" type="primary" icon="el-icon-plus" size="medium" @click="apply">申请展示项目</el-button> | |||
| <el-button class="apply-btn" type="primary" icon="el-icon-s-management" size="medium" v-if="isTechAdmin" | |||
| @click="manage">管理展示项目</el-button> | |||
| <div class="openi-link-c"> | |||
| <a class="openi-link" href="">OpenI启智社区开源指南</a> | |||
| </div> | |||
| </div> | |||
| <div class="sort-c"> | |||
| <el-select class="select" size="medium" v-model="sortType" @change="changeSort" placeholder="排序" clearable> | |||
| <el-option v-for="item in sortList" :key="item.k" :label="item.v" :value="item.k" /> | |||
| </el-select> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import { getIsTechAdmin } from '~/apis/modules/tech'; | |||
| export default { | |||
| name: "SearchBar", | |||
| props: { | |||
| condition: { type: Object, default: () => ({}) }, | |||
| }, | |||
| components: {}, | |||
| data() { | |||
| return { | |||
| keyword: '', | |||
| serchPlaceHolder: '搜索项目名称/简介', | |||
| sortType: '', | |||
| sortList: [{ | |||
| k: '1', | |||
| v: '最近更新', | |||
| }, { | |||
| k: '2', | |||
| v: '项目成果数', | |||
| }], | |||
| isTechAdmin: true, | |||
| }; | |||
| }, | |||
| methods: { | |||
| search() { | |||
| this.$emit('changeCondition', { | |||
| q: this.keyword.trim() | |||
| }); | |||
| }, | |||
| apply() { | |||
| window.location.href = '/tech/new'; | |||
| }, | |||
| manage() { | |||
| window.location.href = '/tech/admin_view'; | |||
| }, | |||
| changeSort() { | |||
| this.$emit('changeCondition', { | |||
| sort: this.sortType | |||
| }); | |||
| } | |||
| }, | |||
| watch: { | |||
| condition: { | |||
| handler(newVal) { | |||
| console.log('searchBar:watch:condition', newVal); | |||
| this.keyword = newVal.q; | |||
| this.sortType = newVal.sort; | |||
| }, | |||
| immediate: true, | |||
| deep: true, | |||
| }, | |||
| }, | |||
| beforeMount() { | |||
| getIsTechAdmin().then(res => { | |||
| console.log(res); | |||
| }).catch(err => { | |||
| console.log(err); | |||
| }); | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .search-bar { | |||
| margin: 30px 0; | |||
| display: flex; | |||
| justify-content: space-between; | |||
| .search-bar-l { | |||
| display: flex; | |||
| .search-c { | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: center; | |||
| margin-right: 20px; | |||
| .search-input-c { | |||
| width: 268px; | |||
| height: 40px; | |||
| border-color: rgba(0, 61, 192, 0.73); | |||
| border-width: 2px; | |||
| border-style: solid; | |||
| font-size: 14px; | |||
| line-height: 20px; | |||
| padding: 8px; | |||
| display: flex; | |||
| color: rgb(136, 136, 136); | |||
| align-items: center; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(6.123233995736766e-17%2C%201%2C%20-0.014005111865831027%2C%206.123233995736766e-17%2C%200.5%2C%200)%22%3E%3Cstop%20stop-color%3D%22%23e2d1ea%22%20stop-opacity%3D%221%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ffffff%22%20stop-opacity%3D%221%22%20offset%3D%220.3%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| input { | |||
| width: 100%; | |||
| border: none; | |||
| outline: none; | |||
| } | |||
| } | |||
| .search-btn { | |||
| height: 40px; | |||
| font-size: 14px; | |||
| line-height: 20px; | |||
| padding: 0px; | |||
| display: flex; | |||
| color: rgb(255, 255, 255); | |||
| align-items: center; | |||
| text-align: center; | |||
| justify-content: center; | |||
| padding: 0 20px; | |||
| cursor: pointer; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(-1.1800000000000002%2C%200.9499999999999998%2C%20-0.23749999999999996%2C%20-1.1800000000000002%2C%201.024%2C%200.047)%22%3E%3Cstop%20stop-color%3D%22%23bbd2f2%22%20stop-opacity%3D%221%22%20offset%3D%220.02%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23003dc0%22%20stop-opacity%3D%220.73%22%20offset%3D%221%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| } | |||
| } | |||
| .apply-btn { | |||
| margin-left: 20px; | |||
| border-color: rgb(31, 1, 115); | |||
| border-width: 1px; | |||
| border-style: solid; | |||
| border-radius: 6px; | |||
| font-size: 14px; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(6.123233995736766e-17%2C%201%2C%20-0.08281144868278038%2C%206.123233995736766e-17%2C%200.5%2C%200)%22%3E%3Cstop%20stop-color%3D%22%233291f8%22%20stop-opacity%3D%221%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23060075%22%20stop-opacity%3D%220.73%22%20offset%3D%221%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| &:hover { | |||
| opacity: 0.9; | |||
| } | |||
| &:active { | |||
| opacity: 0.8; | |||
| } | |||
| } | |||
| .openi-link-c { | |||
| margin-left: 20px; | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: center; | |||
| .openi-link { | |||
| text-decoration: underline; | |||
| color: rgb(50, 145, 248); | |||
| } | |||
| } | |||
| } | |||
| .sort-c { | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: center; | |||
| justify-self: flex-end; | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,141 @@ | |||
| <template> | |||
| <div> | |||
| <div class="bg-container"> | |||
| <div class="bg"> | |||
| <div class="bg-01"></div> | |||
| <div class="bg-02"></div> | |||
| <div class="bg-03"></div> | |||
| <div class="bg-04"></div> | |||
| </div> | |||
| <div class="title-c"> | |||
| <div class="title-main">科技创新2030</div> | |||
| <div class="title-second">新一代人工智能重大项目成果展示</div> | |||
| </div> | |||
| <div class="menu"> | |||
| <TopMenu :menu="menu"></TopMenu> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import TopMenu from './TopMenu.vue'; | |||
| export default { | |||
| name: "TopHeader", | |||
| props: { | |||
| menu: { type: Number, default: -1 }, | |||
| }, | |||
| components: { | |||
| TopMenu | |||
| }, | |||
| data() { | |||
| return { | |||
| list: [], | |||
| }; | |||
| }, | |||
| methods: {}, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .bg-container { | |||
| height: 200px; | |||
| width: 100%; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(0.9059999999999998%2C%20-0.8390000000000001%2C%200.016184413580246918%2C%200.9059999999999998%2C%20-0.183%2C%200.683)%22%3E%3Cstop%20stop-color%3D%22%233bb6fe%22%20stop-opacity%3D%221%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%232250cf%22%20stop-opacity%3D%221%22%20offset%3D%220.61%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%237c23b4%22%20stop-opacity%3D%221%22%20offset%3D%220.99%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| overflow: hidden; | |||
| position: relative; | |||
| .bg { | |||
| position: absolute; | |||
| width: 100%; | |||
| height: 100%; | |||
| left: 67%; | |||
| top: 23%; | |||
| .bg-01 { | |||
| position: absolute; | |||
| top: -296.85px; | |||
| left: -100.21px; | |||
| width: 11.52px; | |||
| height: 430.36px; | |||
| transform: rotate(46deg); | |||
| border-radius: 45px; | |||
| display: flex; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(2.6570000000000005%2C%20-1.366%2C%201906.3802884596842%2C%202.6570000000000005%2C%20-0.714%2C%201.313)%22%3E%3Cstop%20stop-color%3D%22%2315cf16%22%20stop-opacity%3D%221%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ed6bc9%22%20stop-opacity%3D%220%22%20offset%3D%221%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| } | |||
| .bg-02 { | |||
| position: absolute; | |||
| top: -130.68px; | |||
| left: -213.01px; | |||
| width: 3.64px; | |||
| height: 430.36px; | |||
| transform: rotate(46deg); | |||
| border-radius: 45px; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(2.6570000000000005%2C%20-1.366%2C%2019094.65120710059%2C%202.6570000000000005%2C%20-0.714%2C%201.313)%22%3E%3Cstop%20stop-color%3D%22%23ffffff%22%20stop-opacity%3D%221%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ed6bc9%22%20stop-opacity%3D%220%22%20offset%3D%221%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| } | |||
| .bg-03 { | |||
| position: absolute; | |||
| top: -178.07px; | |||
| left: -50.045px; | |||
| width: 111.15px; | |||
| height: 306.28px; | |||
| transform: rotate(46deg); | |||
| border-radius: 63px; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(2.6570000000000005%2C%20-1.366%2C%2010.372156049382713%2C%202.6570000000000005%2C%20-0.714%2C%201.313)%22%3E%3Cstop%20stop-color%3D%22%23f8da77%22%20stop-opacity%3D%221%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ed6bc9%22%20stop-opacity%3D%220%22%20offset%3D%221%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| } | |||
| .bg-04 { | |||
| position: absolute; | |||
| top: -218.72px; | |||
| left: 239.81px; | |||
| width: 20.38px; | |||
| height: 306.28px; | |||
| transform: rotate(46deg); | |||
| border-radius: 45px; | |||
| background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%221%22%20x1%3D%220%22%20x2%3D%221%22%20y1%3D%220%22%20y2%3D%220%22%20gradientTransform%3D%22matrix(2.6570000000000005%2C%20-1.366%2C%20308.5173674049777%2C%202.6570000000000005%2C%20-0.714%2C%201.313)%22%3E%3Cstop%20stop-color%3D%22%2377f8f8%22%20stop-opacity%3D%220.6%22%20offset%3D%220%22%3E%3C%2Fstop%3E%3Cstop%20stop-color%3D%22%23ed6bc9%22%20stop-opacity%3D%220%22%20offset%3D%221%22%3E%3C%2Fstop%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20fill%3D%22url(%231)%22%3E%3C%2Frect%3E%3C%2Fsvg%3E"); | |||
| } | |||
| } | |||
| .title-c { | |||
| position: absolute; | |||
| top: 0; | |||
| left: 0; | |||
| width: 100%; | |||
| height: 100%; | |||
| z-index: 1; | |||
| .title-main { | |||
| text-align: center; | |||
| color: rgba(255, 230, 21, 1); | |||
| font-weight: 700; | |||
| text-shadow: rgb(34 7 94) 0px 2px 6px; | |||
| line-height: 39px; | |||
| font-size: 28px; | |||
| margin: 26px 0 4px; | |||
| } | |||
| .title-second { | |||
| text-align: center; | |||
| font-weight: 700; | |||
| text-shadow: rgb(34 7 94) 0px 2px 6px; | |||
| color: rgb(255, 255, 255); | |||
| font-size: 36px; | |||
| font-weight: 500; | |||
| line-height: 50px; | |||
| } | |||
| } | |||
| .menu { | |||
| position: absolute; | |||
| bottom: 0; | |||
| height: 40px; | |||
| width: 100%; | |||
| z-index: 2; | |||
| padding: 0 140px; | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,99 @@ | |||
| <template> | |||
| <div class="container ui" style="padding:0 75px;"> | |||
| <div class="menu"> | |||
| <div class="menu-l"> | |||
| <div class="menu-item" v-for="(item, index) in list" :key="index" :class="focusIndex == index ? 'focused' : ''" | |||
| @click="changeMenu(item, index)"> | |||
| {{ item.title }} | |||
| </div> | |||
| </div> | |||
| <div class="menu-r"></div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| export default { | |||
| name: "TopMenu", | |||
| props: { | |||
| menu: { type: Number, default: -1 }, | |||
| }, | |||
| components: {}, | |||
| data() { | |||
| return { | |||
| focusIndex: 0, | |||
| list: [{ | |||
| key: 'tech_view', | |||
| title: '按科技项目查看', | |||
| url: '/tech/tech_view', | |||
| }, { | |||
| key: 'repo_view', | |||
| title: '按项目成果查看', | |||
| url: '/tech/repo_view', | |||
| },/* { | |||
| key: '', | |||
| title: '我申请的项目', | |||
| url: '', | |||
| }*/], | |||
| }; | |||
| }, | |||
| methods: { | |||
| changeMenu(item, index) { | |||
| if (this.focusIndex == index) return; | |||
| this.focusIndex = index; | |||
| window.location.href = item.url; | |||
| } | |||
| }, | |||
| beforeMount() { | |||
| this.focusIndex = this.menu; | |||
| }, | |||
| mounted() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .menu { | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: space-between; | |||
| .menu-l { | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: flex-start; | |||
| } | |||
| .menu-r { | |||
| display: flex; | |||
| align-items: center; | |||
| justify-content: flex-end; | |||
| } | |||
| .menu-item { | |||
| display: flex; | |||
| border-color: rgb(187, 187, 187); | |||
| border-width: 1px 1px 0px 0px; | |||
| border-style: solid; | |||
| font-size: 14px; | |||
| line-height: 20px; | |||
| color: rgba(255, 255, 255, 0.7); | |||
| align-items: center; | |||
| text-align: center; | |||
| justify-content: center; | |||
| background: rgba(104, 50, 165, 0.2); | |||
| height: 40px; | |||
| width: 178px; | |||
| cursor: pointer; | |||
| &:first-child { | |||
| border-left-width: 1px; | |||
| } | |||
| &.focused { | |||
| cursor: default; | |||
| color: rgb(255, 255, 255); | |||
| background: rgba(249, 249, 249, 0.2); | |||
| } | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,470 @@ | |||
| <template> | |||
| <div> | |||
| <TopHeader :menu="-1"></TopHeader> | |||
| <div class="ui container"> | |||
| <div class="title">您申请的项目将在2030科技项目页面展示</div> | |||
| <div class="form-c" v-show="!selectTechPrj"> | |||
| <div class="form-wrap"> | |||
| <div class="form-header">申请展示项目</div> | |||
| <div class="form-content"> | |||
| <div class="form-row"> | |||
| <div class="row-label required">申请项目存放于</div> | |||
| <div class="row-content"> | |||
| <el-radio v-model="form.type" label="openi" @input="changeType()">启智社区</el-radio> | |||
| <el-radio v-model="form.type" label="no-openi" @input="changeType()">非启智社区</el-radio> | |||
| </div> | |||
| </div> | |||
| <div class="form-row"> | |||
| <div class="row-label required">现项目地址</div> | |||
| <div class="row-content"> | |||
| <el-input size="medium" v-model="form.url" @input="changeUrl" | |||
| placeholder='请输入现有项目的 HTTP(s) 或 Git " clone" URL,如:https://openi.pcl.ac.cn/OpenI/aiforge'></el-input> | |||
| </div> | |||
| </div> | |||
| <div v-show="form.type == 'no-openi'"> | |||
| <div class="form-row" :class="form.alias_err ? 'form-row-err' : ''"> | |||
| <div class="row-label required baseline">启智项目名称</div> | |||
| <div class="row-content"> | |||
| <div> | |||
| <el-input size="medium" v-model="form.repo_alias" @input="changeAlias"></el-input> | |||
| </div> | |||
| <div class="tips"> | |||
| 请输入中文、字母、数字和-_ .,最多100个字符。 | |||
| </div> | |||
| </div> | |||
| </div> | |||
| <div class="form-row" :class="form.name_err ? 'form-row-err' : ''"> | |||
| <div class="row-label required baseline">启智项目路径</div> | |||
| <div class="row-content"> | |||
| <div class="reop-url-c"> | |||
| <el-select size="medium" v-model="form.uid"></el-select> | |||
| <span style="margin: 0 8px;font-size:22px;"> / </span> | |||
| <el-input size="medium" v-model="form.repo_name" @input="changeRepoName"></el-input> | |||
| </div> | |||
| <div class="tips"> | |||
| 启智项目地址:<span class="openi-repo-url">{{ form.repo_url }}</span> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| <div class="form-row"> | |||
| <div class="row-label">关键词</div> | |||
| <div class="row-content"> | |||
| <el-select style="width:100%" size="medium" v-model="form.topics" multiple filterable remote | |||
| allow-create default-first-option placeholder="请选择标签" :remote-method="searchTopics" | |||
| :loading="form.topicLoading"> | |||
| <el-option v-for="item in topicsList" :key="item.value" :label="item.label" :value="item.value"> | |||
| </el-option> | |||
| </el-select> | |||
| </div> | |||
| </div> | |||
| <div class="form-row"> | |||
| <div class="row-label baseline">项目简介</div> | |||
| <div class="row-content"> | |||
| <el-input size="medium" type="textarea" :rows="3" placeholder="请输入项目简介(长度不超过255)" :maxLength="255" | |||
| v-model="form.description"></el-input> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| <div class="form-row"> | |||
| <div class="row-label required">科技项目</div> | |||
| <div class="row-content"> | |||
| <el-input placeholder="请选择科技项目" size="medium" v-model="form.tech_show" :readonly="true"> | |||
| <el-button size="medium" slot="append" @click="goSelectTechPrj">选择科技项目</el-button> | |||
| </el-input> | |||
| </div> | |||
| </div> | |||
| <div class="form-row"> | |||
| <div class="row-label required">成果贡献单位</div> | |||
| <div class="row-content"> | |||
| <el-select style="width:100%" size="medium" v-model="form.institution" multiple> | |||
| <el-option v-for="item in institutionList" :key="item.key" :label="item.value" | |||
| :value="item.value"></el-option> | |||
| </el-select> | |||
| </div> | |||
| </div> | |||
| <div class="form-btn-group"> | |||
| <el-button size="medium" type="primary" class="btn confirm-btn" @click="submit">提交申请</el-button> | |||
| <el-button size="medium" class="btn" @click="cancel">{{ $t('cancel') }}</el-button> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| <div class="form-select-tech-prj" v-show="selectTechPrj"> | |||
| <div class="form-wrap"> | |||
| <div class="form-header">选择科技项目</div> | |||
| <div class="form-content"> | |||
| <div class="form-row"> | |||
| <div class="row-label required">请输入科技项目</div> | |||
| <div class="row-content"> | |||
| <el-input placeholder="请输入内容" size="medium" v-model="form.tech_search_keyword" | |||
| @keyup.enter.native="searchTechList" class="input-with-select"> | |||
| <el-select v-model="form.tech_search_sel" style="width:142px" size="medium" slot="prepend" | |||
| placeholder="请选择"> | |||
| <el-option label="项目立项编号" value="0"></el-option> | |||
| <el-option label="参与单位" value="1"></el-option> | |||
| <el-option label="项目名称" value="2"></el-option> | |||
| </el-select> | |||
| <el-button size="medium" slot="append" icon="el-icon-search" @click="searchTechList"></el-button> | |||
| </el-input> | |||
| </div> | |||
| </div> | |||
| <div class="form-table"> | |||
| <div style="margin: 0 20px 30px 20px"> | |||
| <el-table ref="tableRef" border :data="tableData" style="width:100%" v-loading="loading" stripe> | |||
| <el-table-column prop="no" label="项目立项编号" align="center" header-align="center" | |||
| width="120"></el-table-column> | |||
| <el-table-column prop="name" label="科技项目名称" align="center" header-align="center" | |||
| width="150"></el-table-column> | |||
| <el-table-column prop="unit" label="项目承担单位" align="center" header-align="center" | |||
| width="150"></el-table-column> | |||
| <el-table-column prop="allunit" label="所有参与单位" align="center" header-align="center"></el-table-column> | |||
| <el-table-column width="100" label="操作" align="center" header-align="center"> | |||
| <template slot-scope="scope"> | |||
| <el-button type="primary">选择</el-button> | |||
| </template> | |||
| </el-table-column> | |||
| </el-table> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import TopHeader from '../components/TopHeader.vue'; | |||
| import { getTechs, setOpenIApply, setNoOpenIApply, getCreateRepoUser, getCheckRepoName, getTopics } from '~/apis/modules/tech'; | |||
| export default { | |||
| data() { | |||
| return { | |||
| form: { | |||
| type: 'openi', | |||
| url: '', | |||
| repo_alias: '', | |||
| alias_err: false, | |||
| uid: '', | |||
| repo_name: '', | |||
| name_err: false, | |||
| repo_url: '', | |||
| topics: [], | |||
| topicLoading: false, | |||
| description: '', | |||
| tech_search_sel: '0', | |||
| tech_search_keyword: '', | |||
| tech_show: '', | |||
| institution: [], | |||
| }, | |||
| selectTechPrj: false, | |||
| loading: false, | |||
| tableData: [{ | |||
| selected: '0', | |||
| no: 'xxxxxxxxxx1', | |||
| name: 'Name NameName', | |||
| unit: '项目承担单位项目承担单位1', | |||
| allunit: '所有参与单位1、所有参与单位、所有参与单位、所有参与单位、所有参与单位', | |||
| }, { | |||
| selected: '0', | |||
| no: 'xxxxxxxxxx2', | |||
| name: 'Name NameName2', | |||
| unit: '项目承担单位项目承担单位2', | |||
| allunit: '所有参与单位2、所有参与单位、所有参与单位', | |||
| }], | |||
| topicsList: [], | |||
| institutionList: [], | |||
| }; | |||
| }, | |||
| components: { | |||
| TopHeader, | |||
| }, | |||
| methods: { | |||
| resetData() { | |||
| this.form.url = ''; | |||
| this.form.repo_alias = ''; | |||
| this.form.alias_err = false; | |||
| this.form.uid = ''; | |||
| this.form.repo_name = ''; | |||
| this.form.repo_url = ''; | |||
| this.form.name_err = false; | |||
| this.form.topics = []; | |||
| this.form.topicLoading = false; | |||
| this.form.description = ''; | |||
| this.form.tech_search_sel = '0'; | |||
| this.form.tech_search_keyword = ''; | |||
| this.form.tech_show = ''; | |||
| this.form.institution = []; | |||
| this.tableData = []; | |||
| this.topicsList = []; | |||
| }, | |||
| changeType() { | |||
| this.resetData(); | |||
| }, | |||
| checkRepoAlias() { | |||
| const reg = /^[\u4E00-\u9FA5A-Za-z0-9_.-]{1,100}$/; | |||
| const res = reg.test(this.form.repo_alias); | |||
| this.form.alias_err = !res; | |||
| return res; | |||
| }, | |||
| checkRepoName() { | |||
| const reg = /^[A-Za-z0-9_.-]{1,100}$/; | |||
| const res = reg.test(this.form.repo_name); | |||
| this.form.name_err = !res; | |||
| return res; | |||
| }, | |||
| changeUrl() { | |||
| if (this.form.type == 'openi') return; | |||
| const owner = 'Itx003'; | |||
| const urlAdd = location.href.split("/")[0] + "//" + location.href.split("/")[2]; | |||
| const repoValue = this.form.url.match(/^(.*\/)?((.+?)(\.git)?)$/)[3]; | |||
| this.form.repo_alias = repoValue; | |||
| getCheckRepoName({ owner: 'Itx003', q: repoValue }).then(res => { | |||
| const repo_name = res.data.name; | |||
| this.form.repo_name = repo_name; | |||
| this.form.repo_url = `${urlAdd}/${owner}/${repo_name}.git`; | |||
| }).catch(err => { | |||
| console.log(err); | |||
| this.form.repo_name = ''; | |||
| this.form.repo_url = ''; | |||
| }); | |||
| }, | |||
| changeAlias() { | |||
| const owner = 'Itx003'; | |||
| const aliasValue = this.form.repo_alias; | |||
| const urlAdd = location.href.split("/")[0] + "//" + location.href.split("/")[2]; | |||
| if (aliasValue && this.checkRepoAlias()) { | |||
| getCheckRepoName({ owner: 'Itx003', q: aliasValue }).then(res => { | |||
| const repo_name = res.data.name; | |||
| this.form.repo_name = repo_name; | |||
| this.form.repo_url = `${urlAdd}/${owner}/${repo_name}.git`; | |||
| }).catch(err => { | |||
| console.log(err); | |||
| this.form.repo_name = ''; | |||
| this.form.repo_url = ''; | |||
| }); | |||
| } else { | |||
| this.form.repo_name = ''; | |||
| this.form.repo_url = ''; | |||
| } | |||
| }, | |||
| changeRepoName() { | |||
| const owner = 'Itx003'; | |||
| const repo_name = this.form.repo_name; | |||
| const urlAdd = location.href.split("/")[0] + "//" + location.href.split("/")[2]; | |||
| if (this.checkRepoName()) { | |||
| this.form.repo_url = `${urlAdd}/${owner}/${repo_name}.git`; | |||
| } else { | |||
| this.form.repo_url = ''; | |||
| } | |||
| }, | |||
| searchTopics(query) { | |||
| if (query !== '') { | |||
| this.form.topicLoading = true; | |||
| getTopics({ q: query }).then(res => { | |||
| this.form.topicLoading = false; | |||
| const topics = res.data.topics || []; | |||
| this.topicsList = topics.map(item => { | |||
| return { | |||
| value: item.topic_name, | |||
| label: item.topic_name, | |||
| } | |||
| }); | |||
| }).catch(err => { | |||
| this.topicsList = []; | |||
| }); | |||
| } else { | |||
| this.topicsList = []; | |||
| } | |||
| }, | |||
| goSelectTechPrj() { | |||
| this.selectTechPrj = true; | |||
| }, | |||
| searchTechList() { | |||
| getTechs({ | |||
| no: this.form.tech_search_sel == '0' ? this.form.tech_search_keyword : '', | |||
| institution: this.form.tech_search_sel == '1' ? this.form.tech_search_keyword : '', | |||
| name: this.form.tech_search_sel == '2' ? this.form.tech_search_keyword : '', | |||
| }).then(res => { | |||
| console.log(res); | |||
| }).catch(err => { | |||
| console.log(err); | |||
| }) | |||
| }, | |||
| changeTableSelect(row) { | |||
| for (let i = 0, iLen = this.tableData.length; i < iLen; i++) { | |||
| this.tableData[i].selected = '0'; | |||
| } | |||
| row.selected = '1'; | |||
| this.$refs.tableRef.setCurrentRow(row); | |||
| }, | |||
| submit() { | |||
| console.log(this.form); | |||
| }, | |||
| cancel() { | |||
| window.history.back(); | |||
| } | |||
| }, | |||
| beforeMount() { | |||
| getCreateRepoUser().then(res => { | |||
| console.log(res); | |||
| }).catch(err => { | |||
| console.log(err); | |||
| }); | |||
| }, | |||
| mounted() { | |||
| }, | |||
| beforeDestroy() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .title { | |||
| text-align: center; | |||
| margin: 30px 0; | |||
| font-size: 14px; | |||
| color: rgb(16, 16, 16); | |||
| } | |||
| .form-c, | |||
| .form-select-tech-prj { | |||
| display: flex; | |||
| justify-content: center; | |||
| .form-wrap { | |||
| width: 1000px; | |||
| background: rgb(255, 255, 255); | |||
| border-color: rgb(212, 212, 213); | |||
| border-width: 1px; | |||
| border-style: solid; | |||
| border-radius: 5px; | |||
| box-sizing: border-box; | |||
| .form-header { | |||
| height: 45px; | |||
| background: rgb(240, 240, 240); | |||
| border-bottom: 1px solid rgb(212, 212, 213); | |||
| color: rgb(16, 16, 16); | |||
| padding-left: 16px; | |||
| font-size: 16px; | |||
| font-weight: 700; | |||
| display: flex; | |||
| align-items: center; | |||
| } | |||
| .form-content { | |||
| margin-top: 40px; | |||
| .form-row { | |||
| display: flex; | |||
| align-items: center; | |||
| width: 80%; | |||
| margin: 20px auto; | |||
| padding-right: 50px; | |||
| .row-label { | |||
| flex: 2; | |||
| text-align: right; | |||
| margin-right: 24px; | |||
| position: relative; | |||
| &.required { | |||
| &::after { | |||
| position: absolute; | |||
| top: -2px; | |||
| right: -10px; | |||
| content: '*'; | |||
| color: #db2828; | |||
| } | |||
| } | |||
| &.baseline { | |||
| align-self: baseline; | |||
| margin-top: 11px; | |||
| } | |||
| } | |||
| .row-content { | |||
| flex: 9; | |||
| .tips { | |||
| margin-top: 4px; | |||
| font-size: 14px; | |||
| color: rgb(136, 136, 136); | |||
| } | |||
| } | |||
| .reop-url-c { | |||
| display: flex; | |||
| align-items: center; | |||
| } | |||
| .openi-repo-url { | |||
| color: rgba(16, 16, 16, 1); | |||
| } | |||
| &.form-row-err { | |||
| .row-label { | |||
| color: #9f3a38; | |||
| } | |||
| /deep/ .el-input__inner:not([readonly="readonly"]) { | |||
| color: #9f3a38; | |||
| background: #fff6f6; | |||
| border-color: #e0b4b4; | |||
| } | |||
| } | |||
| } | |||
| .form-table { | |||
| margin-top: 30px; | |||
| margin-bottom: 30px; | |||
| /deep/ .el-table__header { | |||
| th { | |||
| background: rgb(249, 249, 249); | |||
| font-size: 12px; | |||
| color: rgb(136, 136, 136); | |||
| font-weight: normal; | |||
| } | |||
| } | |||
| /deep/ .el-table__body { | |||
| td { | |||
| font-size: 12px; | |||
| } | |||
| } | |||
| /deep/ .el-radio__label { | |||
| display: none; | |||
| } | |||
| } | |||
| .form-btn-group { | |||
| display: flex; | |||
| justify-content: center; | |||
| align-items: center; | |||
| margin: 30px 0 40px; | |||
| } | |||
| } | |||
| } | |||
| } | |||
| .btn { | |||
| color: rgb(2, 0, 4); | |||
| background-color: rgb(194, 199, 204); | |||
| border-color: rgb(194, 199, 204); | |||
| &.confirm-btn { | |||
| color: #fff; | |||
| background-color: rgb(56, 158, 13); | |||
| border-color: rgb(56, 158, 13); | |||
| margin-right: 20px; | |||
| } | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,17 @@ | |||
| import Vue from 'vue'; | |||
| import ElementUI from 'element-ui'; | |||
| import 'element-ui/lib/theme-chalk/index.css'; | |||
| import localeEn from 'element-ui/lib/locale/lang/en'; | |||
| import localeZh from 'element-ui/lib/locale/lang/zh-CN'; | |||
| import { i18n, lang } from '~/langs'; | |||
| import App from './index.vue'; | |||
| Vue.use(ElementUI, { | |||
| locale: lang === 'zh-CN' ? localeZh : localeEn, | |||
| size: 'small', | |||
| }); | |||
| new Vue({ | |||
| i18n, | |||
| render: (h) => h(App), | |||
| }).$mount('#__vue-root'); | |||
| @@ -0,0 +1,92 @@ | |||
| <template> | |||
| <div> | |||
| <TopHeader :menu="1"></TopHeader> | |||
| <div class="ui container"> | |||
| <SearchBar :condition="condition" @changeCondition="changeCondition"></SearchBar> | |||
| <div class="conent-c"> | |||
| <div class="filter-c"> | |||
| <Filters :type="1" :condition="condition" @changeCondition="changeCondition"></Filters> | |||
| </div> | |||
| <div class="result-c"> | |||
| <PrjResultsList ref="resultListRef" :condition="condition"></PrjResultsList> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import TopHeader from '../components/TopHeader.vue'; | |||
| import SearchBar from '../components/SearchBar.vue'; | |||
| import Filters from '../components/Filters.vue'; | |||
| import PrjResultsList from '../components/PrjResultsList.vue'; | |||
| import { getUrlSearchParams } from '~/utils'; | |||
| export default { | |||
| data() { | |||
| return { | |||
| condition: { | |||
| q: '', // 搜索框 | |||
| topic: '', // 关键词 | |||
| project_name: '', // 项目类型 | |||
| institution_name: '', // 成果贡献单位 | |||
| page: '', | |||
| pageSize: '', | |||
| sort: '', | |||
| }, | |||
| pageSizes: [15, 30, 50, 100], | |||
| }; | |||
| }, | |||
| components: { | |||
| TopHeader, | |||
| SearchBar, | |||
| Filters, | |||
| PrjResultsList | |||
| }, | |||
| methods: { | |||
| changeCondition(params) { | |||
| this.condition = { | |||
| ...this.condition, | |||
| ...params, | |||
| }; | |||
| window.location.href = `/tech/repo_view?` + `q=${encodeURIComponent(this.condition.q.trim())}` + | |||
| `&topic=${encodeURIComponent(this.condition.topic)}` + | |||
| `&project_name=${encodeURIComponent(this.condition.project_name)}` + | |||
| `&institution_name=${encodeURIComponent(this.condition.institution_name)}` + | |||
| `&page=${encodeURIComponent(this.condition.page)}` + | |||
| `&pageSize=${encodeURIComponent(this.condition.pageSize)}` + | |||
| `&sort=${encodeURIComponent(this.condition.sort)}`; | |||
| }, | |||
| }, | |||
| beforeMount() { | |||
| const urlParams = getUrlSearchParams(); | |||
| this.condition.q = urlParams.q || ''; | |||
| this.condition.topic = urlParams.topic || ''; | |||
| this.condition.project_name = urlParams.project_name || ''; | |||
| this.condition.institution_name = urlParams.institution_name || ''; | |||
| this.condition.sort = urlParams.sort || ''; | |||
| this.condition.page = Number(urlParams.page) || 1; | |||
| this.condition.pageSize = this.pageSizes.indexOf(Number(urlParams.pageSize)) >= 0 ? Number(urlParams.pageSize) : 15; | |||
| }, | |||
| mounted() { }, | |||
| beforeDestroy() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .conent-c { | |||
| display: flex; | |||
| } | |||
| .filter-c { | |||
| flex: 1; | |||
| padding-left: 12px; | |||
| } | |||
| .result-c { | |||
| margin-left: 10px; | |||
| flex: 3; | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,17 @@ | |||
| import Vue from 'vue'; | |||
| import ElementUI from 'element-ui'; | |||
| import 'element-ui/lib/theme-chalk/index.css'; | |||
| import localeEn from 'element-ui/lib/locale/lang/en'; | |||
| import localeZh from 'element-ui/lib/locale/lang/zh-CN'; | |||
| import { i18n, lang } from '~/langs'; | |||
| import App from './index.vue'; | |||
| Vue.use(ElementUI, { | |||
| locale: lang === 'zh-CN' ? localeZh : localeEn, | |||
| size: 'small', | |||
| }); | |||
| new Vue({ | |||
| i18n, | |||
| render: (h) => h(App), | |||
| }).$mount('#__vue-root'); | |||
| @@ -0,0 +1,93 @@ | |||
| <template> | |||
| <div> | |||
| <TopHeader :menu="0"></TopHeader> | |||
| <div class="ui container"> | |||
| <SearchBar :condition="condition" @changeCondition="changeCondition"></SearchBar> | |||
| <div class="conent-c"> | |||
| <div class="filter-c"> | |||
| <Filters :type="0" :condition="condition" @changeCondition="changeCondition"></Filters> | |||
| </div> | |||
| <div class="result-c"> | |||
| <SciAndTechPrjList ref="resultListRef" :condition="condition"></SciAndTechPrjList> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </template> | |||
| <script> | |||
| import TopHeader from '../components/TopHeader.vue'; | |||
| import SearchBar from '../components/SearchBar.vue'; | |||
| import Filters from '../components/Filters.vue'; | |||
| import SciAndTechPrjList from '../components/SciAndTechPrjList.vue'; | |||
| import { getUrlSearchParams } from '~/utils'; | |||
| export default { | |||
| data() { | |||
| return { | |||
| condition: { | |||
| q: '', // 搜索框 | |||
| type_name: '', // 项目类型 | |||
| institution_name: '', // 项目参与单位 | |||
| execute_year: '', // 执行周期包含年份 | |||
| apply_year: '', | |||
| page: '', | |||
| pageSize: '', | |||
| sort: '', | |||
| }, | |||
| pageSizes: [15, 30, 50, 100], | |||
| }; | |||
| }, | |||
| components: { | |||
| TopHeader, | |||
| SearchBar, | |||
| Filters, | |||
| SciAndTechPrjList | |||
| }, | |||
| methods: { | |||
| changeCondition(params) { | |||
| this.condition = { | |||
| ...this.condition, | |||
| ...params, | |||
| }; | |||
| window.location.href = `/tech/tech_view?` + `q=${encodeURIComponent(this.condition.q.trim())}` + | |||
| `&type_name=${encodeURIComponent(this.condition.type_name)}` + | |||
| `&institution_name=${encodeURIComponent(this.condition.institution_name)}` + | |||
| `&execute_year=${encodeURIComponent(this.condition.execute_year)}` + | |||
| `&apply_year=${encodeURIComponent(this.condition.apply_year)}` + | |||
| `&page=${encodeURIComponent(this.condition.page)}` + | |||
| `&pageSize=${encodeURIComponent(this.condition.pageSize)}` + | |||
| `&sort=${encodeURIComponent(this.condition.sort)}`; | |||
| }, | |||
| }, | |||
| beforeMount() { | |||
| const urlParams = getUrlSearchParams(); | |||
| this.condition.q = urlParams.q || ''; | |||
| this.condition.type_name = urlParams.type_name || ''; | |||
| this.condition.institution_name = urlParams.institution_name || ''; | |||
| this.condition.execute_year = urlParams.execute_year || ''; | |||
| this.condition.apply_year = urlParams.apply_year || ''; | |||
| this.condition.sort = urlParams.sort || ''; | |||
| this.condition.page = Number(urlParams.page) || 1; | |||
| this.condition.pageSize = this.pageSizes.indexOf(Number(urlParams.pageSize)) >= 0 ? Number(urlParams.pageSize) : 15; | |||
| }, | |||
| mounted() { }, | |||
| beforeDestroy() { }, | |||
| }; | |||
| </script> | |||
| <style scoped lang="less"> | |||
| .conent-c { | |||
| display: flex; | |||
| } | |||
| .filter-c { | |||
| flex: 1; | |||
| padding-left: 12px; | |||
| } | |||
| .result-c { | |||
| margin-left: 10px; | |||
| flex: 3; | |||
| } | |||
| </style> | |||
| @@ -0,0 +1,17 @@ | |||
| import Vue from 'vue'; | |||
| import ElementUI from 'element-ui'; | |||
| import 'element-ui/lib/theme-chalk/index.css'; | |||
| import localeEn from 'element-ui/lib/locale/lang/en'; | |||
| import localeZh from 'element-ui/lib/locale/lang/zh-CN'; | |||
| import { i18n, lang } from '~/langs'; | |||
| import App from './index.vue'; | |||
| Vue.use(ElementUI, { | |||
| locale: lang === 'zh-CN' ? localeZh : localeEn, | |||
| size: 'small', | |||
| }); | |||
| new Vue({ | |||
| i18n, | |||
| render: (h) => h(App), | |||
| }).$mount('#__vue-root'); | |||