123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505 |
- /**
- *
- * 浮漂msg消息公用方法
- * 插入dom节点方式运,为了兼容 三端,采用元素js 操作 dom + css
- * @param type
- * @returns {Object|*}
- */
- var getMsgBuoyActive = {
- // 版本号
- version: '0.0.2',
- platform: '', // work_bench、wx、app、pc
- msgids: '',
- floatDOM: '',
- messageList: [],
- messageInfo: {},
- textmas: '剑鱼标讯-招标信息查询_全国招标采购信息订阅推送_专业招标大数据服务平台',
- init: function () {
- // 初始化平台计算
- this.getPlatform()
- // 限制初始化页面
- if (this.platform === 'app' || this.platform === 'wx') {
- if (this.checkNowInMobileHomePage()) {
- this.getBuoyMsgAjax()
- }
- } else {
- this.listenNotification()
- this.getBuoyMsgAjax()
- }
- },
- /**
- * 检查当前是否是 移动端首页 页面
- * @returns {boolean}
- */
- checkNowInMobileHomePage () {
- var Pages = [
- '/jyapp/jylab/mainSearch',
- '/jylab/mainSearch',
- '/jy_mobile/tabbar/home'
- ]
- return Pages.some(function (v) {
- return location.href.indexOf(v) > -1
- })
- },
- getPlatform: function () {
- this.platform = this.platformOS()
- },
- initDOMNode: function () {
- // 判断是否存在,需要先移除dom
- var oldNode = $('.msggroup')
- if (oldNode && typeof oldNode.remove === 'function') {
- oldNode.remove()
- }
- // 没有消息时退出执行
- if (!(this.messageList && this.messageList.length)) {
- return
- }
- var message = this.messageList[0]
- var textmas = this.textmas
- if (message) {
- textmas = message.buoyDetail
- this.msgids = message.id
- }
- let scanHTML = `<div class="msggroup" style="display:none;">
- <div class="msgbox">
- <div id="msg_content" class="msg_content">
- <span class="text-content">${textmas}</span>
- </div>
- </div>
- <div class="msg_close">
- </div>
- </div>`
- var scanDOM = $(scanHTML)
- this.floatDOM = scanDOM.show()
- scanDOM.find('#msg_content').html(`<span class="text-content">${textmas}</span>`)
- if (this.platform === 'pc') {
- $('#public-nav .iner').append(scanDOM)
- } else if (this.platform === 'work_bench') {
- // 插入节点
- $('.el-header > .navbar-group').append(scanDOM)
- } else {
- $('body').append(scanDOM)
- }
- // 初始化样式表
- this.createStyle()
- // 初始化监听事件
- this.addEventClick()
- // 初始化样式表style
- this.scroll()
- },
- getBuoyMsgAjax: function () {
- var _this = this
- $.ajax({
- url: '/jyapi/messageCenter/GetBuoyMsg',
- type: 'POST',
- }).done(function (res) {
- if (res && res.error_code === 0 && res.data) {
- try {
- _this.messageList = res.data
- if (res.data && res.data.length) {
- _this.messageInfo = _this.messageList[0]
- _this.initDOMNode()
- }
- } catch (error) {
- console.warn(error)
- }
- }
- })
- },
- istoReaded: function (ids, url) {
- // 消息盒子 消失
- // 效果彩蛋 ~~ 1200ms逐渐消失
- $(".msggroup").fadeOut(1200);
- $(".msggroup").fadeTo("1200", 0.6);
- $.ajax({
- type: 'POST',
- url: '/jymessageCenter/markRead',
- async: false,
- data: {
- msgId: ids
- },
- success: function (res) {
- if (res.error_code === 0 && res.data) {
- console.log(res);
- }
- }
- })
- },
- // 监听点击事件 行为
- addEventClick: function (praume) {
- var _this = this
- // 直接使用选择器进行绑定监听
- this.floatDOM.find('.msg_content').on('click', function () {
- _this.floatDOM.find('.msg_close').trigger('click')
- const ua = window.navigator.userAgent.toLocaleLowerCase()
- const isIos = /iphone|ipad|ipod/.test(ua)
- const isAndroid = /android/.test(ua)
- try {
- // 跳转链接
- switch (getMsgBuoyActive.platformOS()) {
- case 'pc':
- location.href = _this.messageInfo.pcUrl ? _this.messageInfo.pcUrl : '/swordfish/frontPage/messageCenter/sess/index'
- break;
- case 'work_bench':
- window.open(_this.messageInfo.pcUrl ? _this.messageInfo.pcUrl : '/swordfish/frontPage/messageCenter/sess/index')
- break;
- case 'wx': {
- location.href = _this.messageInfo.weChatUrl ? _this.messageInfo.weChatUrl :'/weixin/frontPage/messageCenter/sess/index'
- break;
- }
- case 'app': {
- if(isIos && _this.messageInfo.iosUrl){
- location.href = _this.messageInfo.iosUrl
- } else if(isAndroid && _this.messageInfo.androidUrl) {
- location.href = _this.messageInfo.androidUrl
- } else {
- _this.isAppH5Jump()
- }
- break;
- }
- default:
- break;
- }
- } catch (e) {
- console.log(e);
- }
- })
- // 关闭消息
- this.floatDOM.find('.msg_close').on('click', function (e) {
- getMsgBuoyActive.istoReaded(getMsgBuoyActive.msgids)
- })
- },
- isAppH5Jump: function(){
- // H5 环境支持跳转
- if (window.utilsEnv && window.utilsEnv.platformEnvs.platform === 'h5') {
- location.href = '/jy_mobile/tabbar/message'
- } else {
- try {
- // app跳转到消息中心tab
- JyObj.skipAppointTab('message')
- } catch (error) {
- console.log('error')
- }
- }
- },
- scroll: function () {
- // 可视窗口宽度 \
- let windowWidth = document.body.offsetWidth, Pc_Topstyle
- var floatDOM = this.floatDOM
- // 设置每个弹框相对位置定位style - 根据平台
- // pc 和移动端 定位盒子
- // Pc_Topstyle = getMsgBuoyActive.platformOS() === 'pc'
- // ? `width:315px;right:${Number(windowWidth - 1200)/2}px;top:80px;`
- // : `width:92%;right: 4%; bottom: 17vw;`
- switch (getMsgBuoyActive.platformOS()) {
- case 'pc':
- floatDOM.addClass('message-float-pc')
- break;
- case 'work_bench':
- Pc_Topstyle = `width:315px;right:186px;top:80px;`
- break;
- case 'app':
- floatDOM.addClass('message-float-mobile')
- Pc_Topstyle = `bottom: 8vw;`
- break;
- case 'wx':
- floatDOM.addClass('message-float-mobile')
- Pc_Topstyle = `bottom: calc(8vw + 9.33vw);`
- break;
- default:
- break;
- }
- floatDOM.show()
- floatDOM[0].style = `display:block;${Pc_Topstyle}`
- if (getMsgBuoyActive.platformOS() === 'app') {
- floatDOM.find('.msg_close')[0].style = `background: #000;`
- }
- var content = floatDOM.find('.msg_content')[0],
- box = floatDOM[0],
- contentWidth = content.offsetWidth,
- boxWidth = box.offsetWidth
- box.style.setProperty('animation', '5s')
- var _this = this
- if (!contentWidth || !boxWidth) {
- setTimeout(function () {
- _this.scroll()
- }, 200)
- return
- }
- if (contentWidth <= boxWidth) {
- // 内容宽度小于盒子宽度,停止滚动
- content.style.setProperty('animation', '5s');
- } else {
- var computedContentWidth = contentWidth * 2 + 20
- // 根据宽度设置滚动距离和动画时长,复制实现无缝滚动
- content.style.setProperty('animation', 'move ' + computedContentWidth / 50 + 's linear infinite');
- $(content).append($(".msg_content .text-content").clone())
- // // 修改@keyframes的值
- // const frame = `@Keyframes move {
- // from {
- // transform: translate(0);
- // }
- // to {
- // transform: translateX(-${contentWidth - boxWidth}px)
- // }
- // }`;
- // // 找到对应的css样式表,先删除再新增
- // let sheets = document.styleSheets;
- // for (let i = 0; i < sheets.length; ++i) {
- // const item = sheets[i];
- // if (item.cssRules[0] && item.cssRules[0].name && item.cssRules[0].name === 'move') {
- // item.deleteRule(0);
- // item.insertRule(frame, 0)
- // }
- // }
- }
- },
- // 动态创建样式==
- createStyle: function () {
- var frame = `
- @Keyframes move {
- from {
- transform: translate(0);
- }
- to {
- transform: translateX(-50%)
- }
- }
- .msggroup {
- position: absolute;
- width: 351px;
- height: 44px;
- right: 3%;
- background: linear-gradient(180deg, #E8FFFF 0%, #FFFFFF 100%);
- box-shadow: 0px 4px 16px rgb(8 31 38 / 8%);
- border-radius: 8px;
- border: 0.5px solid;
- border-image-source: linear-gradient(163deg, #1a1c1d 0%, rgba(42, 190, 209, 0) 100%);
- z-index: 7;
- line-height: 44px;
- font-size: 13px;
- padding: 0 5px;
- background-size: 100% 100%;
- background-image: url();
- background-repeat: no-repeat;
- }
- .msgbox {
- width: 100%;
- overflow: hidden;
- white-space: nowrap;
- }
- .msg_content {
- animation: move 5s linear infinite;
- display: inline-block;
- cursor: pointer;
- }
- .msg_content .text-content {
- padding: 0 10px;
- }
- .msg_close {
- position: absolute;
- width: 18px;
- height: 18px;
- right: -6px;
- top: -10px;
- cursor: pointer;
- background: #2ABED1;
- opacity: 0.8;
- /*background:url('/images/close_pc_msg.png') 0 0;
- background-size: cover;*/
- -moz-border-radius: 50px;
- -webkit-border-radius: 50px;
- border-radius: 50px;
- }
- .msg_close img {
- width:100%;
- height:100%;
- }
- .msg_close:before,
- .msg_close:after {
- content: "";
- position: absolute;
- height: 1.3px;
- width: 65%;
- top: 50%;
- left: 20%;
- margin-top: -1px;
- background: #fff;
- }
- .msg_close:before {
- -webkit-transform: rotate(45deg);
- -moz-transform: rotate(45deg);
- -ms-transform: rotate(45deg);
- -o-transform: rotate(45deg);
- transform: rotate(45deg);
- }
- .msg_close:after {
- -webkit-transform: rotate(-45deg);
- -moz-transform: rotate(-45deg);
- -ms-transform: rotate(-45deg);
- -o-transform: rotate(-45deg);
- transform: rotate(-45deg);
- }
- `
- frame += this.addPlatformStyle()
- // 创建style标签
- const style = document.createElement('style');
- style.type = 'text/css';
- style.innerHTML = frame;
- document.getElementsByTagName('head')[0].appendChild(style);
- },
- addPlatformStyle: function () {
- var text = ''
- if (this.platform === 'pc') {
- text = `
- .msggroup.message-float-pc {
- right: 0;
- bottom: -10px;
- transform: translate(0, 100%);
- }
- `
- } else if (this.platform === 'wx' || this.platform === 'app') {
- text = `
- .msggroup.message-float-mobile {
- position: fixed;
- width: calc(100% - 8vw);
- /* width:315px; */
- left: 50%;
- bottom: 0;
- z-index: 9;
- transform: translate(-50%, 0);
- }
- `
- }
- return text
- },
- // 判断平台环境,用于定位样式
- platformOS: function () {
- let ua = navigator.userAgent || window.navigator.userAgent,
- IsWeChatBrowser = ua.toLowerCase().indexOf('micromessenger') !== -1,
- androidOrIOS = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(ua),
- isAndroid = /(?:Android)/.test(ua),
- isPad = /(?:iPad|PlayBook)/.test(ua) || (isAndroid && !/(?:Mobile)/.test(ua)),
- isPhone = /(?:iPhone)/.test(ua) && !isPad,
- isPc = !isPhone && !isAndroid && !IsWeChatBrowser && !androidOrIOS,
- iswork_bench = /work-bench|dashboard|workspace/i.test(location.href)
- if (IsWeChatBrowser) {
- return 'wx'
- } else if (iswork_bench) {
- return 'work_bench'
- } else if (androidOrIOS) {
- return 'app'
- } else if (isPc) {
- return 'pc'
- } else if (isPhone) {
- return 'ios'
- } else if (isAndroid) {
- return 'Android'
- }
- },
- /**
- * @date 2023/1/4 消息通知改为 webscoket 获取并调用浏览器消息通知
- */
- listenNotification () {
- /**
- * 进行浏览器通知,判断上次通知是否与当前一致,一致则不进行重复通知
- * @param datas - 信息数据
- */
- function sendNotification (datas) {
- var waitShowMessageId = localStorage.getItem('notification-login-clear-info') || -1
- if (waitShowMessageId === datas.id) {
- return console.warn('重复消息ID,不进行重复通知')
- }
- try {
- Notification.requestPermission(function(status) {
- var notifyStatus = Notification.permission || status
- if(notifyStatus === 'granted'){
- localStorage.setItem('notification-login-clear-info', datas.id)
- var notify = new Notification(datas.title,{
- icon: '/images/t3_new.jpg',
- body: datas.show_content || datas.content || ''
- })
- // 点击时桌面消息时触发
- notify.onclick = function () {
- try {
- getMsgBuoyActive.istoReaded(datas.id)
- notify.close()
- switch (getMsgBuoyActive.platformOS()) {
- case 'pc':
- location.href = '/swordfish/frontPage/messageCenter/sess/index'
- break;
- case 'work_bench':
- window.open('/swordfish/frontPage/messageCenter/sess/index')
- break;
- }
- } catch (e) {
- console.warn(e)
- }
- }
- } else {
- Notification.requestPermission(function () {
- sendNotification(datas)
- })
- }
- })
- } catch (e) {
- console.warn('不支持通知')
- }
- }
- // 定义 scoket 信息
- var pushMessageScoket = {
- url: "ws"+(!isIE9&&"https:"==document.location.protocol?"s":"")+"://"+window.location.host,
- init: function () {
- if (typeof CommonWebScoket === 'function') {
- this._scoket = new CommonWebScoket(this.url + '/webscoket/getBuoyMsg', '', {
- ajaxReq: function() {},
- reconnect: function (commom) {
- commom.isOver = true
- commom.over()
- },
- complete: function (data, type) {
- try {
- var pushMessage = JSON.parse(data)
- if (pushMessage.id) {
- sendNotification(pushMessage)
- }
- } catch (e) {
- console.warn(e)
- }
- }
- }).init()
- }
- }
- }
- // 初始化
- pushMessageScoket.init()
- }
- }
- // 初始化
- $(function () {
- try {
- // 尝试判断是否在iframe中
- if (!goTemplateData.inIframe) {
- getMsgBuoyActive.init()
- }
- } catch (error) {
- getMsgBuoyActive.init()
- }
- })
|