12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643 |
- <template>
- <el-card class="info-list-card" :class="{gray: config.gray}" v-loading="listState.loading">
- <div slot="header" class="clearfix" v-if="!config.gray">
- <span class="card-title">订阅推送</span>
- <el-button v-if="canSubmanager" @click="goManage" class="sub-manager" type="plain" icon="el-icon-jy-edit">订阅管理
- </el-button>
- </div>
- <div class="collect-list-header" style="" v-else>
- <div class="c-tab-container">
- <div class="left">
- <input @click="changeAllCheck($event)" class="has-top custom-checkbox title-text-checkbox"
- style="margin: 16px;" type="checkbox"/>
- <div class="list-title">订阅信息</div>
- </div>
- <div class="right">
- <div class="right-line">
- <div class="icon-box" :class="{active: !isTable}" @click="toggleActiveIcon('list')"><span
- class="j-icon icon-list"></span> <span class="icon-text">列表</span></div>
- <div class="icon-box" :class="{active: isTable}" @click="toggleActiveIcon('table')"><span
- class="j-icon icon-table"></span> <span class="icon-text">表格</span></div>
- </div>
- <div class="icon-box right-line" @click="onClickDataExport">
- <span class="j-icon icon-data-export"></span> <span class="icon-text">数据导出</span>
- </div>
- <div class="icon-box" @click="onClickDataCollect"><span class="j-icon icon-star"></span> <span
- class="icon-text">标讯收藏</span></div>
- </div>
- </div>
- </div>
- <div class="info-list" v-show="!isTable">
- <article-item
- class="list-item"
- v-for="(item, index) in listState.list"
- :class="{ visited: item.visited }"
- :key="index"
- :index="(listState.pageSize * (listState.pageNum - 1)) + index + 1"
- :article="item"
- :config="config"
- @onCollect="onCollect"
- @onClick="toDetail(item)"
- @changeCheck="changeCheck"
- />
- <empty v-show="showEmpty">
- <div v-if="isAllFirst && canSubmanager">
- <span>订阅关键词,接收最新招投标信息</span>
- <div class="add-key-button" @click="$router.push('/set_subscribe/config')">
- <span class="icon-chahao"></span>
- <span class="button-text">订阅关键词</span>
- </div>
- </div>
- <div v-else>
- <span>暂时无历史推送记录</span>
- </div>
- </empty>
- </div>
- <div class="info-list collect-table-list" v-show="isTable">
- <table class="table" v-show="tableList.length">
- <thead class="thead">
- <tr>
- <td width="48">序号</td>
- <td width="315" class="deep-border">项目名称</td>
- <td width="84">公告类型</td>
- <td width="73" class="deep-border">预算<br/>(万元)</td>
- <td width="181">招标单位</td>
- <td width="103" class="deep-border">开标日期</td>
- <td width="174">中标单位</td>
- <td width="76" class="deep-border">中标金额<br/>(万元)</td>
- <td width="103">发布日期</td>
- </tr>
- </thead>
- <tbody>
- <tr v-for="(item, index) in tableList" :class="{ visited: item.visited }" :key="index + '_' + item._id"
- @click="toDetail(item)">
- <td width="48">{{ index + 1 }}</td>
- <td width="315" class="tt-l" v-html="calcTitle(item, index)"></td>
- <td width="84">{{ item.type }}</td>
- <td width="73" class="tt-r">{{ calcBudget(item.budget) }}</td>
- <td width="181" class="tt-l">{{ item.buyer }}</td>
- <td width="103">{{ dateFromNow(item.bidopentime ? item.bidopentime * 1000 : null, 'yyyy-MM-dd HH:mm') }}</td>
- <td width="174" class="tt-l">{{ item.s_winner }}</td>
- <td width="76" class="tt-r">{{ item.bidamount }}</td>
- <td width="103">{{ dateFromNow(item.publishtime * 1000) }}</td>
- </tr>
- </tbody>
- </table>
- <div class="shade_table" v-show="showTableMore">
- <div class="more" data-need-bind-phone="" @click="onClickDataExport">
- 查看更多>
- </div>
- </div>
- <empty v-show="!tableList.length">
- <div>
- <span>暂时无历史推送记录</span>
- </div>
- </empty>
- </div>
- <div class="el-pagination-container" v-if="!isTable && ((listState.total > listState.pageSize) || showMore)"
- :class="showMore ? 'center' : ''">
- <el-pagination
- background
- layout="prev, pager, next, ->"
- :hide-on-single-page="true"
- :current-page="listState.pageNum"
- :page-size="listState.pageSize"
- :total="listState.total"
- @current-change="onPageChange"
- >
- </el-pagination>
- <div class="p-right" v-if="showMore && !showEmpty">
- <el-button size="mini" class="get-more" type="plain" icon="el-icon-arrow-right" @click="getMore">更多</el-button>
- </div>
- </div>
- <div class="sub-collection tags-box">
- <div class="tags-inputs">
- <div class="tag-input">
- <div class="tag-labels"></div>
- <input type="text" class="clear-input" maxlength="10" oninput="this.value=this.value.replace(/\s+/g,'')">
- <div class="tag-placeholder">新增标签回车保存</div>
- </div>
- <div class="add-tag-button">添加并使用</div>
- </div>
- <div class="tags-list clearfix"></div>
- <div class="tags-footer">
- <div class="tags-button button-confirm">确认添加</div>
- <div class="tags-button button-cancel">暂不添加</div>
- </div>
- </div>
- </el-card>
- </template>
- <script>
- import { Button, Card, Pagination } from 'element-ui'
- import Empty from '@/components/common/Empty.vue'
- import ArticleItem from '@/components/article-item/ArticleItem.vue'
- import { dateFromNow, moneyUnit, replaceKeyword } from '@/utils/'
- import { getEventTarget } from '@/utils/jq-help'
- import { mixinVisited } from '@/utils/mixins/visited'
- import { tryCallHooks } from '@jianyu/easy-inject-qiankun'
- import {
- getExportPushList,
- getExportSelectItems,
- getPushList,
- bidCollAction,
- getBidCollTagList,
- saveBidCollAddTag,
- createBidTag,
- checkBidsIsColl
- } from '@/api/modules/'
- /* eslint-disable */
- var selectDataIds = []
- export default {
- name: 'push-list',
- mixins: [mixinVisited],
- components: {
- [Pagination.name]: Pagination,
- [Card.name]: Card,
- [Button.name]: Button,
- ArticleItem,
- Empty
- },
- props: {
- showMore: {
- type: Boolean,
- default: true
- },
- subManager: {
- type: Boolean,
- default: false
- },
- config: {
- type: Object,
- default () {
- return {
- gray: false,
- table: false,
- collect: false
- }
- }
- },
- filters: {
- type: Object,
- default () {
- return {
- area: '',
- time: ''
- }
- }
- }
- },
- computed: {
- isTable () {
- return this.showIcon === 'table'
- },
- showTableMore () {
- return this.tableList.length === 10 && this.listState.total > 10
- },
- showEmpty () {
- return this.listState.list.length === 0 && this.listState.loaded
- },
- getFilters () {
- return this.filters
- },
- canSubmanager () {
- return !this.$store.state.user.info?.isSubCount
- }
- },
- data () {
- return {
- showIcon: 'list',
- isAllFirst: false,
- tableList: [],
- listState: {
- loaded: true, // 是否已经搜索过
- loading: false,
- pageNum: 1, // 当前页
- pageSize: 10, // 每页多少条数据
- total: 0, // 一共多少条数据
- list: [] // 查询请求返回的数据
- },
- nowCheckList: [],
- }
- },
- created () {
- if (!this.config.table) {
- this.doQuery(this.filters)
- }
- },
- mounted () {
- this.initCollectEvent()
- },
- methods: {
- dateFromNow,
- calcBudget (budget) {
- if (budget) {
- return moneyUnit(budget).replace('万元', '')
- } else {
- return budget
- }
- },
- calcTitle (item) {
- const {
- projectName,
- matchkeys
- } = item
- const hightLightedTitle = replaceKeyword(projectName, matchkeys, ['<span class="highlight-text">', '</span>'])
- return `${hightLightedTitle}`
- },
- async onClickDataExport () {
- this.getNewData()
- const $ = this.$querySelector.bind(this)
- let nowCheckItems = this.getCheckIds(function () {
- return $(this).attr('dataid')
- })
- nowCheckItems = selectDataIds
- let exportDataFlag = ''
- if (nowCheckItems.length) {
- //导出选择(因可以翻页多选,修改为post请求,防止穿参数过长,后跳转)
- //return location.href = `/front/dataExport/superSearchExport?selectIds=${nowCheckItems.join(',')}`
- const res = await getExportSelectItems({ selectIds: nowCheckItems.join(',') })
- if (res.error_code === 0) {
- exportDataFlag = res.data
- }
- } else {
- //导出筛选条件
- const query = {}
- if (this.getFilters && Object.keys(this.getFilters).length > 0) {
- Object.keys(this.getFilters).forEach(v => {
- if (typeof this.getFilters[v] !== 'undefined') {
- query[v] = this.getFilters[v]
- }
- })
- }
- if (query.vt === 'f') {
- query.vt = ''
- }
- const res = await getExportPushList(query)
- if (res.error_code === 0) {
- if (res.data._id) {
- exportDataFlag = res.data._id
- }
- }
- }
- if (exportDataFlag) {
- const link = `/front/dataExport/toCreateOrderPage/${exportDataFlag}`
- tryCallHooks({
- fn: () => {
- this.$BRACE.methods.open({
- route: {
- link
- }
- })
- },
- spareFn: () => {
- location.href = link
- // window.open(link)
- }
- })
- }
- },
- changeCheck (data) {
- const $ = this.$querySelector.bind(this)
- console.log(data)
- if(selectDataIds.length == 0) {
- if(data.check) {
- selectDataIds.push(data.id)
- }
- }
- selectDataIds.forEach((v, i) => {
- if(data.check) {
- if (!this.contains(selectDataIds, data.id)) {
- selectDataIds.push(data.id)
- }
- }
- })
- if(!data.check) {
- const index = selectDataIds.indexOf(data.id)
- selectDataIds.splice(index, 1)
- $('.custom-checkbox.has-top').prop('checked', false)
- }
- },
- onClickDataCollect () {
- let _this = this
- const $ = this.$querySelector.bind(this)
- let nowCheckItems = []
- this.getNewData()
- $('.custom-checkbox:not(.has-top):checked').each(function(index) {
- const tempN = $(this).attr('dataid')
- if (!_this.contains(selectDataIds, tempN)) {
- selectDataIds.push(tempN)
- }
- const haschecked = $(this).siblings('.a-i-right').find('i').hasClass('checked')
- if (haschecked) {
- selectDataIds.splice(index, 1)
- }
- })
- selectDataIds.forEach((item, index) => {
- nowCheckItems.push({
- id: item,
- index: index,
- check: $(this).parent().find('.icon-collect.checked').length > 0
- })
- })
- this.onCollect({
- list: nowCheckItems
- })
- },
- toggleActiveIcon (type) {
- this.showIcon = type
- },
- changeAllCheck (e) {
- const $ = this.$querySelector.bind(this)
- const nowStatus = $(e.target).prop('checked')
- $('.custom-checkbox:not(.has-top)').prop('checked', nowStatus)
- if(nowStatus) {
- let pageCheckId = []
- this.listState.list.forEach((v) => {
- pageCheckId.push(v._id)
- })
- if(selectDataIds.length == 0) {
- selectDataIds = pageCheckId
- } else {
- selectDataIds.concat(pageCheckId)
- }
- selectDataIds = [...new Set(selectDataIds)]
- } else {
- this.listState.list.forEach((v) => {
- selectDataIds.forEach((s, index) => {
- if(v._id == s) {
- selectDataIds.splice(index, 1)
- }
- })
- })
- }
- },
- getCheckIds (callback) {
- const arr = []
- const $ = this.$querySelector.bind(this)
- $('.custom-checkbox:not(.has-top):checked').each(function () {
- const tempN = callback.bind(this)()
- arr.push(tempN)
- })
- return arr
- },
- goManage () {
- this.$router.push('/set_subscribe/config')
- },
- // 恢复数据至第一次请求的状态(页码等)
- resetListState () {
- const state = {
- loaded: false,
- loading: false,
- pageNum: 1,
- total: 0,
- list: []
- }
- Object.assign(this.listState, state)
- },
- doQuery (filters) {
- this.resetListState()
- this.getList(filters)
- },
- async getList (filters) {
- const $ = this.$querySelector.bind(this)
- let _this = this
- const query = {
- pageNum: this.listState.pageNum,
- pageSize: this.listState.pageSize
- }
- if (query.pageNum === 1) {
- query.format = 'table'
- }
- if (this.getFilters && Object.keys(this.getFilters).length > 0) {
- Object.keys(this.getFilters).forEach(v => {
- if (typeof this.getFilters[v] !== 'undefined') {
- query[v] = this.getFilters[v]
- }
- })
- }
- if (filters && Object.keys(filters).length > 0) {
- Object.keys(filters).forEach(v => {
- if (typeof filters[v] !== 'undefined') {
- query[v] = filters[v]
- }
- })
- }
- this.listState.loading = true
- this.listState.loaded = false
- // 判断是否无筛选条件
- this.isAllFirst = false
- if (query.pageNum === 1 && query.area === '' && query.time === '') {
- this.isAllFirst = true
- }
- const res = await getPushList(query)
- this.listState.loading = false
- this.listState.loaded = true
- if (Array.isArray(res.data)) {
- res.data.forEach(item => {
- const visited = this.pathVisited(
- this.createPathItem(
- '/article/content/*.html',
- `id=${item._id}`
- )
- )
- this.$set(item, 'visited', visited)
- })
- }
- if (query.pageNum === 1) {
- this.tableList = res.data || []
- }
- if (res?.total) {
- this.listState.total = res.total
- this.listState.list = res.data || []
- this.$nextTick(() => {
- this.getCollectStatusForList()
- // 等dataid赋值完成后再获取值
- var $dom = $('.info-list-card .title-text-checkbox[name="bid-list"]')
- var selectPageNum = 0
- $dom.each(function () {
- // 回显列表选中状态
- if (!_this.contains(selectDataIds, $(this).attr('dataid'))) {
- $(this).prop('checked', false)
- }
- if (_this.contains(selectDataIds, $(this).attr('dataid'))) {
- selectPageNum++
- $(this).prop('checked', true)
- }
- // 全选复选框选中/不选中
- if (!$(this).attr('checked')) {
- $('.custom-checkbox.has-top').prop('checked', false)
- }
- if (selectPageNum >= 10) {
- $('.custom-checkbox.has-top').prop('checked', true)
- }
- })
- })
- } else {
- this.listState.total = 0
- this.listState.list = []
- }
- },
- toDetail (item) {
- const { _id, matchkeys } = item
- item.visited = true
- this.pathVisiting(
- this.createPathItem(
- '/article/content/*.html',
- `id=${_id}`
- )
- )
- let match = ''
- if (Array.isArray(matchkeys) && matchkeys.length) {
- match = matchkeys.join(' ')
- if (match) {
- match = encodeURIComponent(match)
- }
- }
- window.open(`/article/content/${_id}.html?kds=${match}`)
- },
- getNewData () {
- const $ = this.$querySelector.bind(this)
- const nowCheckItems = this.getCheckIds(function () {
- return $(this).attr('dataid')
- })
- this.nowCheckList = nowCheckItems
- if(selectDataIds.length === 0) {
- selectDataIds = nowCheckItems
- } else {
- nowCheckItems.forEach((sum, index) => {
- if (!this.contains(selectDataIds, sum)) {
- selectDataIds.push(sum)
- }
- })
- }
- },
- onPageChange (p) {
- this.getNewData()
- this.listState.pageNum = p
- this.getList()
- },
- contains(arr, ele) {
- if(arr.length == 0){
- return;
- }
- var i = arr.length;
- while (i--) {
- if (arr[i] == ele) {
- return true;
- }
- }
- return false;
- },
- getMore () {
- this.$emit('getMore')
- },
- ajaxForCollectChange (baction, binfo, callback) {
- /*
- 收藏或取消收藏ajax
- params: {
- baction: String, //用户行为:R:移除收藏;C:收藏(默认)非必填
- binfo: Array, // 招标信息数组 必填
- bid: String, // 招标信息加密后id 必填
- }
- 参数示例 (baction=R binfo数组只需要bid即可)
- */
- const params = {
- baction: baction,
- binfo: binfo
- }
- bidCollAction(params).then(r => {
- callback && callback(r)
- })
- },
- onCollect (data) {
- const $ = this.$querySelector.bind(this)
- let {
- item,
- event,
- list
- } = data
- let binfo = []
- if (list) {
- binfo = list.filter(v => !v.check).map(v => ({ bid: v.id }))
- item = {}
- event = {}
- } else {
- binfo = [{ bid: item._id }]
- }
- var _this = this
- if (binfo.length === 0) {
- return _this.$toast(list.length ? '已收藏' : '尚未选择标讯,请选择', 800)
- }
- if (item.collection) {
- // 单个取消收藏行为
- this.ajaxForCollectChange('R', binfo, function (res) {
- if (res.data) {
- item.collection = 0
- _this.$toast('已取消收藏', 800)
- } else {
- _this.$toast(res.error_msg, 1000)
- }
- })
- } else {
- // 将本次收藏的标讯id缓存起来 用于绑定标签时使用
- sessionStorage.setItem('$save-tags-binfo', JSON.stringify(binfo))
- this.ajaxForCollectChange('C', binfo, function (res) {
- if (res.data) {
- _this.$toast('收藏成功', 1500)
- if (list) {
- list.filter(v => !v.check).forEach(function (v) {
- _this.nowCheckList.forEach(function(s, i) {
- if (s === v.id) {
- _this.listState.list[i].collection = 1
- }
- })
- })
- event = {
- target: $('.info-list .list-item i.icon-collect')
- }
- } else {
- item.collection = 1
- }
- const { top, left } = _this.calcCardTopLeft(event, !!list)
- $('.tags-box').show(function () {
- window.pushListActiveTags = []
- $('.tag-labels').empty()
- $('.clear-input').val('')
- $('.tags-list').find('.tags-item').removeClass('tags-active')
- $('.tag-placeholder').show()
- }).css({
- top: top,
- right: 'unset',
- left: left
- })
- window.getUserTags()
- } else {
- if (res.error_msg.indexOf('付费') > -1) {
- _this.$toast('您的标讯收藏上限为5000条,请联系客服人员。', 1500)
- }
- }
- })
- }
- },
- calcCardTopLeft (e, batch) {
- const $ = this.$querySelector.bind(this)
- const containerWidth = this.$el.clientWidth
- const containerHeight = this.$el.clientHeight
- const cardWidth = 332
- const cardHeight = 362
- var top = parseInt($(getEventTarget(e)).position().top) + 30 + 50
- if (batch) {
- top -= 30
- }
- var left = parseInt($(getEventTarget(e)).position().left) - 300
- if (top >= containerHeight - cardHeight) {
- top = containerHeight - cardHeight
- }
- if (left >= containerWidth - cardWidth) {
- left = containerWidth - cardWidth
- }
- left += 'px'
- top += 'px'
- return {
- top,
- left
- }
- },
- initCollectEvent () {
- const _this = this
- const $ = this.$querySelector.bind(this)
- function toastFn (text, duration) {
- _this.$toast(text, duration)
- }
- // 自定义标签
- // 标签输入框事件
- $('.tags-box').click(function (e) {
- e.stopPropagation()
- })
- $('.tag-input').click(function (e) {
- e.stopPropagation()
- $(this).children('.tag-placeholder').hide()
- $(this).children('input').focus()
- })
- // 标签输入框回车事件
- $('.tag-input .clear-input').keydown(function (event) {
- event.stopPropagation()
- if (event.keyCode == 13) {
- if (!$('.tags-box').is(':hidden')) {
- $('.tags-inputs .add-tag-button').trigger('click')
- }
- }
- })
- // 标签输入框失去焦点事件
- $('.tag-input .clear-input').blur(function () {
- if ($('.tag-labels').children().length == 0 && $(this).val() == '') {
- $('.tag-placeholder').show()
- }
- })
- // 添加标签按钮事件
- $('.tags-inputs .add-tag-button').on('click', function () {
- var input = $('.tag-input .clear-input')
- if (input.val().length >= 2 && input.val().length < 11) {
- // ajax提交自定义标签
- addTagsAjax(input.val())
- }
- })
- // 点击确定按钮,绑定标签
- $('.tags-footer .button-confirm').on('click', function () {
- if (!$('.tags-box').is(':hidden')) {
- var lids = ''
- var lname = ''
- $('.tags-item.tags-active').each(function () {
- if ($(this).attr('data-id')) {
- if (lids != '') {
- lids += ','
- }
- if (lname != '') {
- lname += ','
- }
- lids += $(this).attr('data-id')
- lname += $(this).text()
- }
- })
- var params = {
- lids: lids,
- laction: 'S',
- binfo: JSON.parse(sessionStorage.getItem('$save-tags-binfo'))
- }
- // 执行保存绑定标签操作
- if (params.lids !== '') {
- saveChooseTags(params, function () {
- $('.tags-footer .button-cancel').trigger('click')
- })
- }
- }
- })
- $('.tags-footer .button-cancel').on('click', function () {
- $('.tags-box').hide(function () {
- // 标签弹框消失时 清除上次选择的标签分类
- pushListActiveTags = []
- $('.tag-labels').empty()
- $('.clear-input').val('')
- $('.tags-list').find('.tags-item').removeClass('tags-active')
- $('.tag-placeholder').show()
- })
- })
- window.pushListActiveTags = [] // 选中的自定义标签 作为全局变量使用
- // 解绑自定义标签
- function deleteInputTag (item) {
- var index = $(item).parent().attr('data-index')
- var id = $(item).parent().attr('data-id')
- pushListActiveTags.splice(index, 1)
- inputTagList()
- $('.tags-item[data-id="' + id + '"]').removeClass('tags-active')
- }
- function inputTagList () {
- var ht = ''
- $('.tag-labels').html(ht)
- pushListActiveTags.forEach(function (v, i) {
- ht += '<span class="tag-label" data-index=' + i + ' data-id="' + v.lid + '">'
- ht += '<em>' + v.lname + '</em>'
- ht += '<i class="tag-close"></i>'
- ht += '</span>'
- })
- $('.tag-labels').html(ht).off('click').on('click', '.tag-close' ,function (e) {
- const target = getEventTarget(e)
- deleteInputTag(target)
- })
- if ($('.tag-labels').children('.tag-label').length > 0) {
- $('.tag-placeholder').hide()
- }
- checkTagDisabled()
- }
- // 渲染标签列表数据
- function renderTagsList (data) {
- if (data && data.length > 0) {
- var ht = ''
- data.forEach(function (v, i) {
- ht += '<span class="tags-item" data-count=' + v.count + ' data-id=' + v.lid + '>' + v.lanme + '</span>'
- })
- $('.tags-list').html(ht)
- pushListActiveTags.forEach(function (s, j) {
- $('.tags-list .tags-item[data-id="' + s.lid + '"]').addClass('tags-active')
- })
- $('.tags-item').click(function (e) {
- e.stopPropagation()
- if ($(this).hasClass('disabled')) return
- var id = $(this).attr('data-id')
- var name = $(this).text()
- $(this).toggleClass('tags-active')
- if ($(this).hasClass('tags-active')) {
- pushListActiveTags.push({
- lid: id,
- lname: name
- })
- inputTagList()
- } else {
- var newArr = pushListActiveTags.filter(function (item) {
- return item.lid != id
- })
- pushListActiveTags = newArr
- console.log(pushListActiveTags, newArr, 'quxiao')
- inputTagList()
- }
- })
- }
- inputTagList()
- }
- // 获取用户自定义标签
- function getUserTags () {
- getBidCollTagList().then(r => {
- if (r.error_code == 0 && Array.isArray(r.data)) {
- renderTagsList(r.data.reverse())
- }
- })
- }
- window.getUserTags = getUserTags
- /*
- 保存或清除标签 ajax
- params: {
- lids: String 标签id(加密后), 非必传
- lname: String 标签名称, 非必传
- laction: String 用户行为:S添加或绑定标签;D删除标签 非必传
- binfo: Array 招标信息数组(已收藏的招标信息) 非必传
- bid: String 招标信息加密后id 必传
- }
- 1:lids为空;lname不为空;laction=”S”;binfo数组不为空->新增标签并且绑定收藏信息
- 2:lids不为空;laction=”S”;binfo数组不为空->收藏信息绑定标签
- 3:lids不为空;laction=”D”;->删除标签 并解绑收藏的信息
- */
- function saveChooseTags (params, callback) {
- saveBidCollAddTag(params).then(r => {
- if (r.data) {
- toastFn('标签绑定成功', 1000)
- callback && callback()
- }
- })
- }
- // 新增标签
- function addTagsAjax (name) {
- createBidTag({ name }).then(r => {
- if (r.data) {
- $('.tag-input .clear-input').val('')
- // 添加标签成功后 绑定标签
- if (pushListActiveTags.length < 3) {
- pushListActiveTags.push({
- lid: r.data,
- lname: name
- })
- }
- getUserTags()
- } else {
- // toastFn(r.error_msg, 1000)
- toastFn('标签已经存在,无需添加', 1000)
- }
- })
- }
- function checkTagDisabled () {
- if (pushListActiveTags.length >= 3) {
- // 禁用标签
- $('.tags-list').find('.tags-item:not(.tags-active)').addClass('disabled')
- } else {
- // 解除禁用
- $('.tags-list').find('.disabled').removeClass('disabled')
- }
- }
- getUserTags()
- },
- getCollectStatusForList () {
- const $ = this.$querySelector.bind(this)
- // 获取当前页信息流收藏状态
- function getBidIsColl () {
- var bids = ''
- var dataId = ''
- // 区分标题搜索和全文搜索收藏
- var $dom = $('.info-list-card .title-text-checkbox[name="bid-list"]')
- $dom.each(function () {
- if ($(this).attr('dataid')) {
- dataId = $(this).attr('dataid')
- if (bids != '') {
- bids += ','
- }
- bids += dataId
- }
- })
- checkBidsIsColl({ bids: bids }).then(r => {
- if (r.data) {
- var data = r.data
- $('.icon-collect').removeClass('checked')
- data.forEach(function (item, index) {
- $('.icon-collect[dataid="' + item + '"]').addClass('checked')
- })
- }
- })
- }
- getBidIsColl()
- }
- }
- }
- /* eslint-enable */
- </script>
- <style>
- .info-list-card .custom-checkbox {
- float: left;
- width: 14px;
- height: 14px;
- border: 1px solid #E0E0E0;
- border-radius: 3px;
- background-color: #fff;
- margin-right: 16px;
- cursor: pointer;
- }
- .custom-checkbox:checked {
- width: 14px;
- height: 14px;
- background: url(https://cdn-ali.jianyu360.com/images/biddingSearch/icon-checked.png) no-repeat center;
- background-size: contain;
- border: 0;
- }
- .tags-box {
- display: none;
- position: absolute;
- top: 0;
- right: 0;
- width: 332px;
- padding: 20px 16px;
- background: #FFFFFF;
- border: 1px solid #ECECEC;
- box-sizing: border-box;
- border-radius: 8px;
- box-shadow: 0px 0px 28px 0px rgba(0, 0, 0, 0.08);
- z-index: 99;
- }
- .tags-box .tags-inputs {
- position: relative;
- width: 100%;
- display: flex;
- align-items: center;
- justify-content: space-between;
- }
- .tags-box .tags-inputs .tag-input {
- width: 100%;
- padding: 0;
- min-height: 34px;
- max-height: 74px;
- overflow-y: scroll;
- display: inline-block;
- border: 1px solid #ccc;
- border-radius: 4px;
- background-color: #fff;
- cursor: text;
- text-align: left;
- }
- .tags-inputs .tag-input::-webkit-scrollbar {
- width: 8px;
- }
- .tags-inputs .tag-input::-webkit-scrollbar-thumb {
- border-radius: 4px;
- background-color: #ECECEC;
- }
- .tag-input > .tag-labels {
- display: inline;
- vertical-align: middle;
- }
- .tag-input > .clear-input {
- display: inline-block;
- padding: 0 10px;
- width: 160px;
- height: 36px;
- line-height: 1;
- background: #fff;
- border-radius: 2px;
- vertical-align: middle;
- border: none;
- background-color: transparent;
- box-shadow: none;
- box-sizing: border-box;
- font-size: 14px;
- color: #1d1d1d;
- }
- .tag-input > .tag-labels > .tag-label {
- display: inline-block;
- padding: 5px 12px;
- font-size: 14px;
- line-height: 1.2;
- margin: 5px;
- cursor: pointer;
- border: 1px solid #ECECEC;
- box-sizing: border-box;
- border-radius: 4px;
- background: #F5F6F7;
- color: #1D1D1D;
- }
- .tag-close {
- display: inline-block;
- width: 16px;
- height: 16px;
- margin-left: 8px;
- background-image: url();
- background-position: center 2px;
- background-repeat: no-repeat;
- background-size: contain;
- }
- .tag-placeholder {
- position: absolute;
- top: 12px;
- left: 16px;
- color: #bbb;
- font-size: 14px;
- }
- .tags-box .tags-list {
- margin-top: 12px;
- overflow-y: auto;
- height: 220px;
- }
- .tags-box .tags-list::-webkit-scrollbar {
- width: 8px;
- }
- .tags-box .tags-list::-webkit-scrollbar-thumb {
- border-radius: 4px;
- background-color: #ECECEC;
- }
- .tags-box .tags-list .tags-item {
- float: left;
- min-width: 44px;
- padding: 0 8px;
- margin: 10px 8px 0 0;
- height: 24px;
- line-height: 24px;
- border-radius: 4px;
- border: 1px solid #ECECEC;
- box-sizing: border-box;
- color: #1D1D1D;
- text-align: center;
- font-size: 14px;
- background: #F5F6F7;
- cursor: pointer;
- }
- .tags-item.tags-active {
- padding: 0 8px 0 24px !important;
- background: #2CB7CA url() no-repeat 6px center !important;
- color: #fff !important;
- background-size: 16px !important;
- border: 0 !important;
- }
- .tags-item.disabled {
- color: #8E8E8E !important;
- }
- .tag-label em {
- font-style: normal;
- }
- .add-tag-button {
- margin-left: 16px;
- color: #2cb7ca;
- font-size: 14px;
- line-height: 22px;
- white-space: nowrap;
- cursor: pointer;
- }
- .tags-footer {
- margin-top: 20px;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .tags-button {
- padding: 3px 17px;
- color: #1d1d1d;
- font-size: 14px;
- line-height: 22px;
- border-radius: 4px;
- border: 1px solid #e0e0e0;
- text-shadow: 0px 0px 28px 0px rgba(0, 0, 0, 0.08);
- cursor: pointer;
- }
- .button-confirm {
- margin-right: 16px;
- color: #fff;
- background: #2cb7ca;
- border-color: #2cb7ca;
- }
- .j-icon {
- display: inline-block;
- width: 20px;
- height: 20px;
- }
- .icon-list {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- .icon-box.active .icon-list {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- .icon-table {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- .icon-box.active .icon-table {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- .icon-data-export {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- /* /images/collected.png */
- .icon-star {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- .icon-star-active {
- background-image: url();
- background-repeat: no-repeat;
- background-size: contain;
- }
- .icon-hot-vip {
- display: inline-block;
- width: 42px;
- height: 20px;
- background: url() no-repeat center center;
- background-size: contain;
- }
- .icon-box {
- display: flex;
- align-items: center;
- color: #252627;
- font-size: 14px;
- }
- .icon-box .icon-text {
- margin-left: 6px;
- }
- .icon-box.active {
- color: #2abed1;
- }
- .tab-title {
- margin: 40px 0 44px;
- font-size: 24px;
- line-height: 36px;
- }
- [class*=el-icon-] {
- transition: transform .2s ease;
- }
- [class*=no-select] {
- user-select: none;
- }
- .rotate180 {
- transform: rotate(180deg);
- }
- /* selector样式定制 */
- .tag-list-container .j-button-item:not(.all) {
- border: 1px solid #ECECEC;
- background-color: #F5F6F7;
- }
- .selector-card:not(:last-of-type) {
- border-bottom: 1px dashed #ECECEC;
- }
- .other-filter .el-select {
- margin: 0 12px;
- }
- .other-filter .el-select input::placeholder {
- color: inherit;
- }
- .manage-tags {
- display: inline-block;
- position: relative;
- right: 0;
- top: 3px;
- font-size: 14px;
- height: 22px;
- line-height: 22px;
- color: #2CB7CA;
- cursor: pointer;
- }
- .collect-list-container {
- margin-top: 28px;
- }
- .collect-list-container .el-checkbox {
- margin: 16px;
- }
- .collect-list-header {
- border: 1px solid #ECECEC;
- }
- .collect-list-content,
- .collect-list-content .list {
- min-height: 400px;
- }
- .c-tab-container .left,
- .c-tab-container .right,
- .c-tab-container .right-line {
- display: flex;
- flex-direction: row;
- }
- .c-tab-container .left .custom-checkbox {
- float: unset;
- }
- .c-tab-container {
- display: flex;
- flex-direction: row;
- height: 49px;
- width: 100%;
- justify-content: space-between;
- }
- .c-tab-container .list-title {
- position: relative;
- height: 100%;
- line-height: 49px;
- text-align: center;
- color: #2abed1;
- }
- .c-tab-container .list-title::after {
- content: '';
- position: absolute;
- left: 0;
- bottom: -1px;
- width: 100%;
- height: 2px;
- background-color: #2abed1;
- }
- .c-tab-container .icon-box {
- cursor: pointer;
- }
- .c-tab-container .j-icon {
- width: 16px;
- height: 16px;
- background-position: center;
- }
- .c-tab-container .icon-box {
- padding: 0 10px;
- }
- .c-tab-container .right-line {
- position: relative;
- }
- .c-tab-container .right-line::after {
- content: '';
- position: absolute;
- margin-top: -8px;
- width: 1px;
- height: 16px;
- right: 0;
- top: 50%;
- background-color: #ECECEC;
- }
- .list-item {
- border-bottom: 1px solid #ECECEC;
- }
- .list-item:hover {
- background-color: #F5F6F7;
- box-shadow: inset 0px -1px 0px rgb(0, 0, 0, .05);
- }
- .list-index {
- margin-right: 2px;
- }
- .append-container .j-icon {
- margin: 0 16px 0 8px;
- cursor: pointer;
- }
- /* table */
- .collect-table-list table {
- width: 1199px;
- border-collapse: collapse;
- }
- .collect-table-list .thead tr {
- font-size: 14px;
- color: #888;
- background-color: #f3fbff;
- }
- .collect-table-list tbody tr:hover {
- background-color: #F5F6F7;
- box-shadow: inset 0px -1px 0px rgb(0, 0, 0, .05);
- cursor: pointer;
- }
- .collect-table-list table tr td {
- vertical-align: middle;
- text-align: center;
- line-height: 26px;
- border: 1px solid #e0e0e0;
- }
- .collect-table-list table tr td.tt-l {
- text-align: left;
- }
- .collect-table-list table tr td.tt-c {
- text-align: center;
- }
- .collect-table-list table tr td.tt-r {
- text-align: right;
- }
- .collect-table-list .thead td {
- padding: 6px 0;
- border-top: 3px solid #2cb7ca;
- }
- .collect-table-list .tbody tr {
- cursor: pointer;
- }
- .collect-table-list .thead .deep {
- border-top: 3px solid #2C90CB;
- }
- .tag-drawer .el-drawer__header {
- margin-bottom: 0;
- padding-bottom: 22px;
- font-size: 20px;
- line-height: 32px;
- border-bottom: 1px solid #ebebeb;
- /* box-shadow: 0px -1px 0px 0px rgba(0,0,0,0.05) inset; */
- }
- .tag-drawer .tag-title {
- flex: unset;
- color: #1D1D1D;
- }
- .tag-drawer .tag-count {
- margin-left: 8px;
- color: #2CB7CA;
- }
- .add-tag-confirm-button {
- height: 100%;
- color: #2CB7CA;
- white-space: nowrap;
- cursor: pointer;
- }
- .tag-drawer .add-tag-confirm-button {
- margin-left: 16px;
- }
- .tag-drawer .el-drawer__body {
- overflow-y: scroll;
- }
- .tag-drawer .tag-container {
- height: 100%;
- display: flex;
- flex-direction: column;
- }
- .tag-drawer .tag-header {
- padding: 28px 28px 20px;
- justify-content: space-between;
- }
- .tag-drawer .tag-main {
- padding: 0 20px;
- flex: 1;
- overflow-y: scroll;
- }
- .tag-drawer .tag-footer {
- padding: 0 20px;
- display: flex;
- align-items: center;
- justify-content: center;
- height: 100px;
- box-shadow: 0px -8px 8px 0px rgba(0, 0, 0, 0.05);
- }
- .tag-drawer .el-tag {
- margin: 6px;
- padding: 1px 8px;
- height: auto;
- color: #1d1d1d;
- background-color: #f5f6f7;
- border: 1px solid #ececec;
- border-radius: 5px;
- line-height: 22px;
- cursor: pointer;
- }
- .tag-drawer .el-tag:hover {
- color: #2CB7CA;
- border-color: #2CB7CA;
- }
- .tag-drawer .el-tag:hover .el-icon-close {
- color: #2CB7CA;
- background-color: transparent;
- }
- .tag-drawer .el-tag .el-icon-close {
- font-weight: 700;
- }
- .select-title {
- color: #686868;
- font-size: 14px;
- line-height: 22px;
- }
- .el-select + .select-title {
- margin-left: 14px;
- }
- .vip .selector-card-header {
- padding-right: 50px;
- }
- .selector-card-header .icon-hot-vip {
- position: absolute;
- right: 0;
- top: 6px;
- }
- .selector-card-header .s-h-title {
- font-weight: 700;
- color: #996118;
- }
- .shade_table {
- width: 1199px;
- position: absolute;
- margin-top: -150px;
- height: 150px;
- background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 1));
- }
- .shade_table .more {
- position: absolute;
- height: 35px;
- width: 120px;
- left: 50%;
- margin-left: -60px;
- bottom: 0px;
- color: #2cb7ca;
- border-radius: 5px;
- border: 1px solid #2cb7ca;
- line-height: 35px;
- text-align: center;
- cursor: pointer;
- }
- </style>
- <style lang="scss" scoped>
- @include diy-icon('edit', 20, 20);
- // card样式重置
- ::v-deep {
- .el-card__header {
- margin: 0 40px;
- padding-left: 0;
- padding-right: 0;
- }
- .el-card__body {
- padding: 20px 40px;
- }
- .get-more {
- display: flex;
- .el-icon-arrow-right {
- margin-left: 4px;
- order: 2;
- }
- }
- }
- .c-tab-container {
- }
- .sub-manager {
- display: flex;
- align-items: center;
- padding: 8px 16px;
- font-size: 14px;
- line-height: 24px;
- color: #1d1d1d;
- border-color: #E0E0E0;
- &.el-button:focus,
- &.el-button:hover {
- color: inherit;
- background-color: inherit;
- }
- }
- .info-list-card {
- position: relative;
- &.gray {
- padding: 0;
- box-shadow: unset;
- border: none;
- ::v-deep {
- .el-card__body {
- padding: 0;
- }
- }
- }
- .card-title {
- font-size: 24px;
- color: #1d1d1d;
- line-height: 36px;
- }
- .sub-manager {
- float: right;
- }
- .info-list {
- min-height: 300px;
- border-top: 1px solid transparent;
- position: relative;
- }
- .add-key-button {
- display: flex;
- align-items: center;
- justify-content: center;
- margin-top: 32px;
- padding: 8px 16px;
- color: #F7F9FA;
- border-radius: 6px;
- background-color: #2ABED1;
- cursor: pointer;
- .icon-chahao {
- margin-right: 4px;
- transform: rotate(-45deg);
- }
- .button-text {
- margin-left: 4px;
- white-space: nowrap;
- }
- }
- .icon-chahao {
- position: relative;
- display: inline-block;
- width: 14px;
- height: 14px;
- &:before,
- &:after {
- position: absolute;
- content: '';
- background-color: #fff;
- top: 50%;
- left: 50%;
- width: 14px;
- height: 2px;
- border-radius: 2px;
- }
- &:before {
- transform: translate(-50%, -50%) rotate(45deg);
- }
- &:after {
- transform: translate(-50%, -50%) rotate(-45deg);
- }
- }
- .el-pagination-container.center {
- .el-pagination {
- left: 50%;
- right: unset;
- transform: translateX(-50%);
- }
- }
- }
- </style>
|