mirror of
https://github.com/LC044/WeChatMsg
synced 2025-04-19 02:08:05 +08:00
5440 lines
413 KiB
HTML
5440 lines
413 KiB
HTML
|
<!DOCTYPE html>
|
|||
|
<html lang="zh-CN">
|
|||
|
|
|||
|
<head>
|
|||
|
<meta charset="UTF-8">
|
|||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|||
|
<meta name="referrer" content="no-referrer" />
|
|||
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
|
|||
|
<style>
|
|||
|
.flatpickr-calendar {
|
|||
|
background: transparent;
|
|||
|
opacity: 0;
|
|||
|
display: none;
|
|||
|
text-align: center;
|
|||
|
visibility: hidden;
|
|||
|
padding: 0;
|
|||
|
-webkit-animation: none;
|
|||
|
animation: none;
|
|||
|
direction: ltr;
|
|||
|
border: 0;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 24px;
|
|||
|
border-radius: 5px;
|
|||
|
position: absolute;
|
|||
|
width: 307.875px;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
-ms-touch-action: manipulation;
|
|||
|
touch-action: manipulation;
|
|||
|
background: #fff;
|
|||
|
-webkit-box-shadow: 1px 0 0 #e6e6e6, -1px 0 0 #e6e6e6, 0 1px 0 #e6e6e6, 0 -1px 0 #e6e6e6, 0 3px 13px rgba(0, 0, 0, 0.08);
|
|||
|
box-shadow: 1px 0 0 #e6e6e6, -1px 0 0 #e6e6e6, 0 1px 0 #e6e6e6, 0 -1px 0 #e6e6e6, 0 3px 13px rgba(0, 0, 0, 0.08)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.open,
|
|||
|
.flatpickr-calendar.inline {
|
|||
|
opacity: 1;
|
|||
|
max-height: 640px;
|
|||
|
visibility: visible
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.open {
|
|||
|
display: inline-block;
|
|||
|
z-index: 99999
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.animate.open {
|
|||
|
-webkit-animation: fpFadeInDown 300ms cubic-bezier(.23, 1, .32, 1);
|
|||
|
animation: fpFadeInDown 300ms cubic-bezier(.23, 1, .32, 1)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.inline {
|
|||
|
display: block;
|
|||
|
position: relative;
|
|||
|
top: 2px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.static {
|
|||
|
position: absolute;
|
|||
|
top: calc(100% + 2px)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.static.open {
|
|||
|
z-index: 999;
|
|||
|
display: block
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
|
|||
|
-webkit-box-shadow: none !important;
|
|||
|
box-shadow: none !important
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
|
|||
|
-webkit-box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
|
|||
|
box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar .hasWeeks .dayContainer,
|
|||
|
.flatpickr-calendar .hasTime .dayContainer {
|
|||
|
border-bottom: 0;
|
|||
|
border-bottom-right-radius: 0;
|
|||
|
border-bottom-left-radius: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar .hasWeeks .dayContainer {
|
|||
|
border-left: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.hasTime .flatpickr-time {
|
|||
|
height: 40px;
|
|||
|
border-top: 1px solid #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
|
|||
|
height: auto
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar:before,
|
|||
|
.flatpickr-calendar:after {
|
|||
|
position: absolute;
|
|||
|
display: block;
|
|||
|
pointer-events: none;
|
|||
|
border: solid transparent;
|
|||
|
content: '';
|
|||
|
height: 0;
|
|||
|
width: 0;
|
|||
|
left: 22px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.rightMost:before,
|
|||
|
.flatpickr-calendar.arrowRight:before,
|
|||
|
.flatpickr-calendar.rightMost:after,
|
|||
|
.flatpickr-calendar.arrowRight:after {
|
|||
|
left: auto;
|
|||
|
right: 22px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowCenter:before,
|
|||
|
.flatpickr-calendar.arrowCenter:after {
|
|||
|
left: 50%;
|
|||
|
right: 50%
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar:before {
|
|||
|
border-width: 5px;
|
|||
|
margin: 0 -5px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar:after {
|
|||
|
border-width: 4px;
|
|||
|
margin: 0 -4px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowTop:before,
|
|||
|
.flatpickr-calendar.arrowTop:after {
|
|||
|
bottom: 100%
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowTop:before {
|
|||
|
border-bottom-color: #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowTop:after {
|
|||
|
border-bottom-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowBottom:before,
|
|||
|
.flatpickr-calendar.arrowBottom:after {
|
|||
|
top: 100%
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowBottom:before {
|
|||
|
border-top-color: #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar.arrowBottom:after {
|
|||
|
border-top-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-calendar:focus {
|
|||
|
outline: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-wrapper {
|
|||
|
position: relative;
|
|||
|
display: inline-block
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months {
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: flex
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-month {
|
|||
|
background: transparent;
|
|||
|
color: rgba(0, 0, 0, 0.9);
|
|||
|
fill: rgba(0, 0, 0, 0.9);
|
|||
|
height: 34px;
|
|||
|
line-height: 1;
|
|||
|
text-align: center;
|
|||
|
position: relative;
|
|||
|
-webkit-user-select: none;
|
|||
|
-moz-user-select: none;
|
|||
|
-ms-user-select: none;
|
|||
|
user-select: none;
|
|||
|
overflow: hidden;
|
|||
|
-webkit-box-flex: 1;
|
|||
|
-webkit-flex: 1;
|
|||
|
-ms-flex: 1;
|
|||
|
flex: 1
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month,
|
|||
|
.flatpickr-months .flatpickr-next-month {
|
|||
|
-webkit-user-select: none;
|
|||
|
-moz-user-select: none;
|
|||
|
-ms-user-select: none;
|
|||
|
user-select: none;
|
|||
|
text-decoration: none;
|
|||
|
cursor: pointer;
|
|||
|
position: absolute;
|
|||
|
top: 0;
|
|||
|
height: 34px;
|
|||
|
padding: 10px;
|
|||
|
z-index: 3;
|
|||
|
color: rgba(0, 0, 0, 0.9);
|
|||
|
fill: rgba(0, 0, 0, 0.9)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,
|
|||
|
.flatpickr-months .flatpickr-next-month.flatpickr-disabled {
|
|||
|
display: none
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month i,
|
|||
|
.flatpickr-months .flatpickr-next-month i {
|
|||
|
position: relative
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,
|
|||
|
.flatpickr-months .flatpickr-next-month.flatpickr-prev-month {
|
|||
|
/*
|
|||
|
/*rtl:begin:ignore*/
|
|||
|
left: 0
|
|||
|
/*
|
|||
|
/*rtl:end:ignore*/
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
/*rtl:begin:ignore*/
|
|||
|
/*
|
|||
|
/*rtl:end:ignore*/
|
|||
|
.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,
|
|||
|
.flatpickr-months .flatpickr-next-month.flatpickr-next-month {
|
|||
|
/*
|
|||
|
/*rtl:begin:ignore*/
|
|||
|
right: 0
|
|||
|
/*
|
|||
|
/*rtl:end:ignore*/
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
/*rtl:begin:ignore*/
|
|||
|
/*
|
|||
|
/*rtl:end:ignore*/
|
|||
|
.flatpickr-months .flatpickr-prev-month:hover,
|
|||
|
.flatpickr-months .flatpickr-next-month:hover {
|
|||
|
color: #959ea9
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month:hover svg,
|
|||
|
.flatpickr-months .flatpickr-next-month:hover svg {
|
|||
|
fill: #f64747
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month svg,
|
|||
|
.flatpickr-months .flatpickr-next-month svg {
|
|||
|
width: 14px;
|
|||
|
height: 14px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-months .flatpickr-prev-month svg path,
|
|||
|
.flatpickr-months .flatpickr-next-month svg path {
|
|||
|
-webkit-transition: fill .1s;
|
|||
|
transition: fill .1s;
|
|||
|
fill: inherit
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper {
|
|||
|
position: relative;
|
|||
|
height: auto
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper input,
|
|||
|
.numInputWrapper span {
|
|||
|
display: inline-block
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper input {
|
|||
|
width: 100%
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper input::-ms-clear {
|
|||
|
display: none
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper input::-webkit-outer-spin-button,
|
|||
|
.numInputWrapper input::-webkit-inner-spin-button {
|
|||
|
margin: 0;
|
|||
|
-webkit-appearance: none
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span {
|
|||
|
position: absolute;
|
|||
|
right: 0;
|
|||
|
width: 14px;
|
|||
|
padding: 0 4px 0 2px;
|
|||
|
height: 50%;
|
|||
|
line-height: 50%;
|
|||
|
opacity: 0;
|
|||
|
cursor: pointer;
|
|||
|
border: 1px solid rgba(57, 57, 57, 0.15);
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span:hover {
|
|||
|
background: rgba(0, 0, 0, 0.1)
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span:active {
|
|||
|
background: rgba(0, 0, 0, 0.2)
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span:after {
|
|||
|
display: block;
|
|||
|
content: "";
|
|||
|
position: absolute
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span.arrowUp {
|
|||
|
top: 0;
|
|||
|
border-bottom: 0
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span.arrowUp:after {
|
|||
|
border-left: 4px solid transparent;
|
|||
|
border-right: 4px solid transparent;
|
|||
|
border-bottom: 4px solid rgba(57, 57, 57, 0.6);
|
|||
|
top: 26%
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span.arrowDown {
|
|||
|
top: 50%
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span.arrowDown:after {
|
|||
|
border-left: 4px solid transparent;
|
|||
|
border-right: 4px solid transparent;
|
|||
|
border-top: 4px solid rgba(57, 57, 57, 0.6);
|
|||
|
top: 40%
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span svg {
|
|||
|
width: inherit;
|
|||
|
height: auto
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper span svg path {
|
|||
|
fill: rgba(0, 0, 0, 0.5)
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper:hover {
|
|||
|
background: rgba(0, 0, 0, 0.05)
|
|||
|
}
|
|||
|
|
|||
|
.numInputWrapper:hover span {
|
|||
|
opacity: 1
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month {
|
|||
|
font-size: 135%;
|
|||
|
line-height: inherit;
|
|||
|
font-weight: 300;
|
|||
|
color: inherit;
|
|||
|
position: absolute;
|
|||
|
width: 75%;
|
|||
|
left: 12.5%;
|
|||
|
padding: 7.48px 0 0 0;
|
|||
|
line-height: 1;
|
|||
|
height: 34px;
|
|||
|
display: inline-block;
|
|||
|
text-align: center;
|
|||
|
-webkit-transform: translate3d(0, 0, 0);
|
|||
|
transform: translate3d(0, 0, 0)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month span.cur-month {
|
|||
|
font-family: inherit;
|
|||
|
font-weight: 700;
|
|||
|
color: inherit;
|
|||
|
display: inline-block;
|
|||
|
margin-left: .5ch;
|
|||
|
padding: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month span.cur-month:hover {
|
|||
|
background: rgba(0, 0, 0, 0.05)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .numInputWrapper {
|
|||
|
width: 6ch;
|
|||
|
width: 7ch\0;
|
|||
|
display: inline-block
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .numInputWrapper span.arrowUp:after {
|
|||
|
border-bottom-color: rgba(0, 0, 0, 0.9)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
|
|||
|
border-top-color: rgba(0, 0, 0, 0.9)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month input.cur-year {
|
|||
|
background: transparent;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
color: inherit;
|
|||
|
cursor: text;
|
|||
|
padding: 0 0 0 .5ch;
|
|||
|
margin: 0;
|
|||
|
display: inline-block;
|
|||
|
font-size: inherit;
|
|||
|
font-family: inherit;
|
|||
|
font-weight: 300;
|
|||
|
line-height: inherit;
|
|||
|
height: auto;
|
|||
|
border: 0;
|
|||
|
border-radius: 0;
|
|||
|
vertical-align: initial;
|
|||
|
-webkit-appearance: textfield;
|
|||
|
-moz-appearance: textfield;
|
|||
|
appearance: textfield
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month input.cur-year:focus {
|
|||
|
outline: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month input.cur-year[disabled],
|
|||
|
.flatpickr-current-month input.cur-year[disabled]:hover {
|
|||
|
font-size: 100%;
|
|||
|
color: rgba(0, 0, 0, 0.5);
|
|||
|
background: transparent;
|
|||
|
pointer-events: none
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .flatpickr-monthDropdown-months {
|
|||
|
appearance: menulist;
|
|||
|
background: transparent;
|
|||
|
border: none;
|
|||
|
border-radius: 0;
|
|||
|
box-sizing: border-box;
|
|||
|
color: inherit;
|
|||
|
cursor: pointer;
|
|||
|
font-size: inherit;
|
|||
|
font-family: inherit;
|
|||
|
font-weight: 300;
|
|||
|
height: auto;
|
|||
|
line-height: inherit;
|
|||
|
margin: -1px 0 0 0;
|
|||
|
outline: none;
|
|||
|
padding: 0 0 0 .5ch;
|
|||
|
position: relative;
|
|||
|
vertical-align: initial;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
-webkit-appearance: menulist;
|
|||
|
-moz-appearance: menulist;
|
|||
|
width: auto
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .flatpickr-monthDropdown-months:focus,
|
|||
|
.flatpickr-current-month .flatpickr-monthDropdown-months:active {
|
|||
|
outline: none
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
|
|||
|
background: rgba(0, 0, 0, 0.05)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
|
|||
|
background-color: transparent;
|
|||
|
outline: none;
|
|||
|
padding: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-weekdays {
|
|||
|
background: transparent;
|
|||
|
text-align: center;
|
|||
|
overflow: hidden;
|
|||
|
width: 100%;
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: flex;
|
|||
|
-webkit-box-align: center;
|
|||
|
-webkit-align-items: center;
|
|||
|
-ms-flex-align: center;
|
|||
|
align-items: center;
|
|||
|
height: 28px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-weekdays .flatpickr-weekdaycontainer {
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: flex;
|
|||
|
-webkit-box-flex: 1;
|
|||
|
-webkit-flex: 1;
|
|||
|
-ms-flex: 1;
|
|||
|
flex: 1
|
|||
|
}
|
|||
|
|
|||
|
span.flatpickr-weekday {
|
|||
|
cursor: default;
|
|||
|
font-size: 90%;
|
|||
|
background: transparent;
|
|||
|
color: rgba(0, 0, 0, 0.54);
|
|||
|
line-height: 1;
|
|||
|
margin: 0;
|
|||
|
text-align: center;
|
|||
|
display: block;
|
|||
|
-webkit-box-flex: 1;
|
|||
|
-webkit-flex: 1;
|
|||
|
-ms-flex: 1;
|
|||
|
flex: 1;
|
|||
|
font-weight: bolder
|
|||
|
}
|
|||
|
|
|||
|
.dayContainer,
|
|||
|
.flatpickr-weeks {
|
|||
|
padding: 1px 0 0 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-days {
|
|||
|
position: relative;
|
|||
|
overflow: hidden;
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: flex;
|
|||
|
-webkit-box-align: start;
|
|||
|
-webkit-align-items: flex-start;
|
|||
|
-ms-flex-align: start;
|
|||
|
align-items: flex-start;
|
|||
|
width: 307.875px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-days:focus {
|
|||
|
outline: 0
|
|||
|
}
|
|||
|
|
|||
|
.dayContainer {
|
|||
|
padding: 0;
|
|||
|
outline: 0;
|
|||
|
text-align: left;
|
|||
|
width: 307.875px;
|
|||
|
min-width: 307.875px;
|
|||
|
max-width: 307.875px;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
display: inline-block;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: flex;
|
|||
|
-webkit-flex-wrap: wrap;
|
|||
|
flex-wrap: wrap;
|
|||
|
-ms-flex-wrap: wrap;
|
|||
|
-ms-flex-pack: justify;
|
|||
|
-webkit-justify-content: space-around;
|
|||
|
justify-content: space-around;
|
|||
|
-webkit-transform: translate3d(0, 0, 0);
|
|||
|
transform: translate3d(0, 0, 0);
|
|||
|
opacity: 1
|
|||
|
}
|
|||
|
|
|||
|
.dayContainer+.dayContainer {
|
|||
|
-webkit-box-shadow: -1px 0 0 #e6e6e6;
|
|||
|
box-shadow: -1px 0 0 #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day {
|
|||
|
background: none;
|
|||
|
border: 1px solid transparent;
|
|||
|
border-radius: 150px;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
color: #393939;
|
|||
|
cursor: pointer;
|
|||
|
font-weight: 400;
|
|||
|
width: 14.2857143%;
|
|||
|
-webkit-flex-basis: 14.2857143%;
|
|||
|
-ms-flex-preferred-size: 14.2857143%;
|
|||
|
flex-basis: 14.2857143%;
|
|||
|
max-width: 39px;
|
|||
|
height: 39px;
|
|||
|
line-height: 39px;
|
|||
|
margin: 0;
|
|||
|
display: inline-block;
|
|||
|
position: relative;
|
|||
|
-webkit-box-pack: center;
|
|||
|
-webkit-justify-content: center;
|
|||
|
-ms-flex-pack: center;
|
|||
|
justify-content: center;
|
|||
|
text-align: center
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.inRange,
|
|||
|
.flatpickr-day.prevMonthDay.inRange,
|
|||
|
.flatpickr-day.nextMonthDay.inRange,
|
|||
|
.flatpickr-day.today.inRange,
|
|||
|
.flatpickr-day.prevMonthDay.today.inRange,
|
|||
|
.flatpickr-day.nextMonthDay.today.inRange,
|
|||
|
.flatpickr-day:hover,
|
|||
|
.flatpickr-day.prevMonthDay:hover,
|
|||
|
.flatpickr-day.nextMonthDay:hover,
|
|||
|
.flatpickr-day:focus,
|
|||
|
.flatpickr-day.prevMonthDay:focus,
|
|||
|
.flatpickr-day.nextMonthDay:focus {
|
|||
|
cursor: pointer;
|
|||
|
outline: 0;
|
|||
|
background: #e6e6e6;
|
|||
|
border-color: #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.today {
|
|||
|
border-color: #959ea9
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.today:hover,
|
|||
|
.flatpickr-day.today:focus {
|
|||
|
border-color: #959ea9;
|
|||
|
background: #959ea9;
|
|||
|
color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.selected,
|
|||
|
.flatpickr-day.startRange,
|
|||
|
.flatpickr-day.endRange,
|
|||
|
.flatpickr-day.selected.inRange,
|
|||
|
.flatpickr-day.startRange.inRange,
|
|||
|
.flatpickr-day.endRange.inRange,
|
|||
|
.flatpickr-day.selected:focus,
|
|||
|
.flatpickr-day.startRange:focus,
|
|||
|
.flatpickr-day.endRange:focus,
|
|||
|
.flatpickr-day.selected:hover,
|
|||
|
.flatpickr-day.startRange:hover,
|
|||
|
.flatpickr-day.endRange:hover,
|
|||
|
.flatpickr-day.selected.prevMonthDay,
|
|||
|
.flatpickr-day.startRange.prevMonthDay,
|
|||
|
.flatpickr-day.endRange.prevMonthDay,
|
|||
|
.flatpickr-day.selected.nextMonthDay,
|
|||
|
.flatpickr-day.startRange.nextMonthDay,
|
|||
|
.flatpickr-day.endRange.nextMonthDay {
|
|||
|
background: #569ff7;
|
|||
|
-webkit-box-shadow: none;
|
|||
|
box-shadow: none;
|
|||
|
color: #fff;
|
|||
|
border-color: #569ff7
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.selected.startRange,
|
|||
|
.flatpickr-day.startRange.startRange,
|
|||
|
.flatpickr-day.endRange.startRange {
|
|||
|
border-radius: 50px 0 0 50px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.selected.endRange,
|
|||
|
.flatpickr-day.startRange.endRange,
|
|||
|
.flatpickr-day.endRange.endRange {
|
|||
|
border-radius: 0 50px 50px 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),
|
|||
|
.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)),
|
|||
|
.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)) {
|
|||
|
-webkit-box-shadow: -10px 0 0 #569ff7;
|
|||
|
box-shadow: -10px 0 0 #569ff7
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.selected.startRange.endRange,
|
|||
|
.flatpickr-day.startRange.startRange.endRange,
|
|||
|
.flatpickr-day.endRange.startRange.endRange {
|
|||
|
border-radius: 50px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.inRange {
|
|||
|
border-radius: 0;
|
|||
|
-webkit-box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
|
|||
|
box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.flatpickr-disabled,
|
|||
|
.flatpickr-day.flatpickr-disabled:hover,
|
|||
|
.flatpickr-day.prevMonthDay,
|
|||
|
.flatpickr-day.nextMonthDay,
|
|||
|
.flatpickr-day.notAllowed,
|
|||
|
.flatpickr-day.notAllowed.prevMonthDay,
|
|||
|
.flatpickr-day.notAllowed.nextMonthDay {
|
|||
|
color: rgba(57, 57, 57, 0.3);
|
|||
|
background: transparent;
|
|||
|
border-color: transparent;
|
|||
|
cursor: default
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.flatpickr-disabled,
|
|||
|
.flatpickr-day.flatpickr-disabled:hover {
|
|||
|
cursor: not-allowed;
|
|||
|
color: rgba(57, 57, 57, 0.1)
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.week.selected {
|
|||
|
border-radius: 0;
|
|||
|
-webkit-box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7;
|
|||
|
box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-day.hidden {
|
|||
|
visibility: hidden
|
|||
|
}
|
|||
|
|
|||
|
.rangeMode .flatpickr-day {
|
|||
|
margin-top: 1px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-weekwrapper {
|
|||
|
float: left
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-weekwrapper .flatpickr-weeks {
|
|||
|
padding: 0 12px;
|
|||
|
-webkit-box-shadow: 1px 0 0 #e6e6e6;
|
|||
|
box-shadow: 1px 0 0 #e6e6e6
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-weekwrapper .flatpickr-weekday {
|
|||
|
float: none;
|
|||
|
width: 100%;
|
|||
|
line-height: 28px
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-weekwrapper span.flatpickr-day,
|
|||
|
.flatpickr-weekwrapper span.flatpickr-day:hover {
|
|||
|
display: block;
|
|||
|
width: 100%;
|
|||
|
max-width: none;
|
|||
|
color: rgba(57, 57, 57, 0.3);
|
|||
|
background: transparent;
|
|||
|
cursor: default;
|
|||
|
border: none
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-innerContainer {
|
|||
|
display: block;
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: flex;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-rContainer {
|
|||
|
display: inline-block;
|
|||
|
padding: 0;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time {
|
|||
|
text-align: center;
|
|||
|
outline: 0;
|
|||
|
display: block;
|
|||
|
height: 0;
|
|||
|
line-height: 40px;
|
|||
|
max-height: 40px;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
overflow: hidden;
|
|||
|
display: -webkit-box;
|
|||
|
display: -webkit-flex;
|
|||
|
display: -ms-flexbox;
|
|||
|
display: flex
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time:after {
|
|||
|
content: "";
|
|||
|
display: table;
|
|||
|
clear: both
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time .numInputWrapper {
|
|||
|
-webkit-box-flex: 1;
|
|||
|
-webkit-flex: 1;
|
|||
|
-ms-flex: 1;
|
|||
|
flex: 1;
|
|||
|
width: 40%;
|
|||
|
height: 40px;
|
|||
|
float: left
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time .numInputWrapper span.arrowUp:after {
|
|||
|
border-bottom-color: #393939
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time .numInputWrapper span.arrowDown:after {
|
|||
|
border-top-color: #393939
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time.hasSeconds .numInputWrapper {
|
|||
|
width: 26%
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time.time24hr .numInputWrapper {
|
|||
|
width: 49%
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time input {
|
|||
|
background: transparent;
|
|||
|
-webkit-box-shadow: none;
|
|||
|
box-shadow: none;
|
|||
|
border: 0;
|
|||
|
border-radius: 0;
|
|||
|
text-align: center;
|
|||
|
margin: 0;
|
|||
|
padding: 0;
|
|||
|
height: inherit;
|
|||
|
line-height: inherit;
|
|||
|
color: #393939;
|
|||
|
font-size: 14px;
|
|||
|
position: relative;
|
|||
|
-webkit-box-sizing: border-box;
|
|||
|
box-sizing: border-box;
|
|||
|
-webkit-appearance: textfield;
|
|||
|
-moz-appearance: textfield;
|
|||
|
appearance: textfield
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time input.flatpickr-hour {
|
|||
|
font-weight: bold
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time input.flatpickr-minute,
|
|||
|
.flatpickr-time input.flatpickr-second {
|
|||
|
font-weight: 400
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time input:focus {
|
|||
|
outline: 0;
|
|||
|
border: 0
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time .flatpickr-time-separator,
|
|||
|
.flatpickr-time .flatpickr-am-pm {
|
|||
|
height: inherit;
|
|||
|
float: left;
|
|||
|
line-height: inherit;
|
|||
|
color: #393939;
|
|||
|
font-weight: bold;
|
|||
|
width: 2%;
|
|||
|
-webkit-user-select: none;
|
|||
|
-moz-user-select: none;
|
|||
|
-ms-user-select: none;
|
|||
|
user-select: none;
|
|||
|
-webkit-align-self: center;
|
|||
|
-ms-flex-item-align: center;
|
|||
|
align-self: center
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time .flatpickr-am-pm {
|
|||
|
outline: 0;
|
|||
|
width: 18%;
|
|||
|
cursor: pointer;
|
|||
|
text-align: center;
|
|||
|
font-weight: 400
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-time input:hover,
|
|||
|
.flatpickr-time .flatpickr-am-pm:hover,
|
|||
|
.flatpickr-time input:focus,
|
|||
|
.flatpickr-time .flatpickr-am-pm:focus {
|
|||
|
background: #eee
|
|||
|
}
|
|||
|
|
|||
|
.flatpickr-input[readonly] {
|
|||
|
cursor: pointer
|
|||
|
}
|
|||
|
|
|||
|
@-webkit-keyframes fpFadeInDown {
|
|||
|
from {
|
|||
|
opacity: 0;
|
|||
|
-webkit-transform: translate3d(0, -20px, 0);
|
|||
|
transform: translate3d(0, -20px, 0)
|
|||
|
}
|
|||
|
|
|||
|
to {
|
|||
|
opacity: 1;
|
|||
|
-webkit-transform: translate3d(0, 0, 0);
|
|||
|
transform: translate3d(0, 0, 0)
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
@keyframes fpFadeInDown {
|
|||
|
from {
|
|||
|
opacity: 0;
|
|||
|
-webkit-transform: translate3d(0, -20px, 0);
|
|||
|
transform: translate3d(0, -20px, 0)
|
|||
|
}
|
|||
|
|
|||
|
to {
|
|||
|
opacity: 1;
|
|||
|
-webkit-transform: translate3d(0, 0, 0);
|
|||
|
transform: translate3d(0, 0, 0)
|
|||
|
}
|
|||
|
}
|
|||
|
</style>
|
|||
|
<style>
|
|||
|
* {
|
|||
|
padding: 0;
|
|||
|
margin: 0;
|
|||
|
}
|
|||
|
|
|||
|
body {
|
|||
|
margin: 0;
|
|||
|
display: flex;
|
|||
|
flex-direction: row;
|
|||
|
height: 100vh;
|
|||
|
align-items: center;
|
|||
|
justify-content: center;
|
|||
|
background-color: #f5f5f5
|
|||
|
}
|
|||
|
|
|||
|
::-webkit-scrollbar {
|
|||
|
width: 10px
|
|||
|
}
|
|||
|
|
|||
|
::-webkit-scrollbar-track {
|
|||
|
border-radius: 8px
|
|||
|
}
|
|||
|
|
|||
|
::-webkit-scrollbar-thumb {
|
|||
|
border-radius: 10px;
|
|||
|
background: 0 0
|
|||
|
}
|
|||
|
|
|||
|
.page {
|
|||
|
display: flex;
|
|||
|
flex-direction: row;
|
|||
|
width: 100%;
|
|||
|
height: 100%;
|
|||
|
max-width: 1200px;
|
|||
|
box-shadow: 1px 1px 3px #ebebeb;
|
|||
|
border-radius: 5px
|
|||
|
}
|
|||
|
|
|||
|
.page .side-bar {
|
|||
|
width: 50px;
|
|||
|
border-top-left-radius: 5px;
|
|||
|
border-bottom-left-radius: 5px
|
|||
|
}
|
|||
|
|
|||
|
.page .mid-bar {
|
|||
|
width: 300px;
|
|||
|
position: relative;
|
|||
|
--left: 60%;
|
|||
|
--color: #0d5dff
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body {
|
|||
|
flex: 1;
|
|||
|
display: flex;
|
|||
|
width: 100%;
|
|||
|
flex-direction: column;
|
|||
|
background-color: #f5f5f5;
|
|||
|
border-top-right-radius: 5px;
|
|||
|
border-bottom-right-radius: 5px
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .title-bar {
|
|||
|
display: flex;
|
|||
|
flex-direction: row;
|
|||
|
justify-content: flex-start;
|
|||
|
align-items: center;
|
|||
|
padding-top: 3px
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .title-bar p {
|
|||
|
margin: 5px 25px;
|
|||
|
font-size: 18px;
|
|||
|
max-width: 180px;
|
|||
|
align-self: flex-start
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .container {
|
|||
|
flex: 1;
|
|||
|
border-top: solid 3px #f0f0f0;
|
|||
|
border-bottom: solid 3px #f0f0f0
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar,
|
|||
|
.page .main-body .nav-bar .turner-bar {
|
|||
|
display: flex;
|
|||
|
flex-direction: row;
|
|||
|
justify-content: center;
|
|||
|
align-items: center
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar {
|
|||
|
height: 50px
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar {
|
|||
|
color: #2e2e2e;
|
|||
|
font-size: 16px;
|
|||
|
user-select: none
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar .button {
|
|||
|
display: inline-block;
|
|||
|
background-color: #d6d6d6;
|
|||
|
margin-left: 20px;
|
|||
|
margin-right: 20px;
|
|||
|
padding: 10px 15px;
|
|||
|
border-radius: 5px;
|
|||
|
font-size: 14px;
|
|||
|
cursor: pointer;
|
|||
|
transition: all .2s
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar .button:hover {
|
|||
|
background-color: #ebebeb
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar p {
|
|||
|
display: inline-block;
|
|||
|
margin-left: 5px;
|
|||
|
margin-right: 5px
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar input {
|
|||
|
border: 0;
|
|||
|
resize: none;
|
|||
|
outline: 0;
|
|||
|
background: 0 0;
|
|||
|
border-bottom: solid 1px #1f1f1f;
|
|||
|
text-align: center;
|
|||
|
font-size: 18px;
|
|||
|
font-weight: 600;
|
|||
|
height: 24px;
|
|||
|
width: 50px
|
|||
|
}
|
|||
|
|
|||
|
.page .mid-bar .timeline-area,
|
|||
|
.timeline {
|
|||
|
position: relative;
|
|||
|
height: 100%;
|
|||
|
display: flex;
|
|||
|
overflow-y: auto;
|
|||
|
flex-direction: column
|
|||
|
}
|
|||
|
|
|||
|
.page .mid-bar .timeline-area {
|
|||
|
flex: 1;
|
|||
|
padding-right: 5px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-wrapper {
|
|||
|
flex: 1;
|
|||
|
overflow-y: auto;
|
|||
|
padding: 30% 0
|
|||
|
}
|
|||
|
|
|||
|
.timeline {
|
|||
|
width: 100%;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.timeline-item-year {
|
|||
|
height: 40px;
|
|||
|
position: relative;
|
|||
|
display: flex
|
|||
|
}
|
|||
|
|
|||
|
.timeline-item-month {
|
|||
|
height: 25px;
|
|||
|
display: flex
|
|||
|
}
|
|||
|
|
|||
|
.timeline::before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
left: var(--left);
|
|||
|
width: 1px;
|
|||
|
height: 600px;
|
|||
|
top: 20px;
|
|||
|
bottom: 0;
|
|||
|
background-image: linear-gradient(to bottom, rgba(144, 156, 173, .6) 60%, rgba(255, 255, 255, 0) 0%);
|
|||
|
background-position: left;
|
|||
|
background-size: 1px 5px;
|
|||
|
background-repeat: repeat-y
|
|||
|
}
|
|||
|
|
|||
|
.timeline-dot-month,
|
|||
|
.timeline-dot-year {
|
|||
|
left: var(--left);
|
|||
|
position: relative;
|
|||
|
border-radius: 50%;
|
|||
|
box-shadow: 0 0 0 1px #d8d8d8;
|
|||
|
text-align: center;
|
|||
|
top: 50%;
|
|||
|
transform: translateY(-50%);
|
|||
|
line-height: 40px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-dot-month {
|
|||
|
background: #fff;
|
|||
|
width: 7px;
|
|||
|
height: 7px;
|
|||
|
margin-left: -3px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-dot-year {
|
|||
|
width: 10px;
|
|||
|
height: 10px;
|
|||
|
background: #000;
|
|||
|
margin-left: -4.5px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-item-month.current .timeline-dot-month {
|
|||
|
width: 7px;
|
|||
|
height: 7px;
|
|||
|
background-color: var(--color);
|
|||
|
box-shadow: 0 0 4px var(--color);
|
|||
|
border: 1px solid #fff;
|
|||
|
margin-left: -3px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-item-month .timeline-right,
|
|||
|
.timeline-item-year .timeline-right {
|
|||
|
position: relative;
|
|||
|
margin: 0 0 0 calc(var(--left) + 15px);
|
|||
|
height: 40px;
|
|||
|
line-height: 40px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-item-month .timeline-right {
|
|||
|
height: 25px;
|
|||
|
line-height: 25px
|
|||
|
}
|
|||
|
|
|||
|
.timeline-right:hover {
|
|||
|
color: red
|
|||
|
}
|
|||
|
|
|||
|
.no-msg-month {
|
|||
|
color: #9e9898
|
|||
|
}
|
|||
|
|
|||
|
.hidden-month {
|
|||
|
display: none
|
|||
|
}
|
|||
|
|
|||
|
.container {
|
|||
|
display: flex;
|
|||
|
overflow: hidden;
|
|||
|
justify-content: center
|
|||
|
}
|
|||
|
|
|||
|
.container .content {
|
|||
|
width: calc(100% - 40px);
|
|||
|
padding: 20px;
|
|||
|
overflow-y: scroll;
|
|||
|
flex: 1
|
|||
|
}
|
|||
|
|
|||
|
.container .content:hover::-webkit-scrollbar-thumb {
|
|||
|
background: rgba(0, 0, 0, .1)
|
|||
|
}
|
|||
|
|
|||
|
.container .content:hover::-webkit-scrollbar-thumb:hover {
|
|||
|
background: rgba(0, 0, 0, .3)
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width:768px) {
|
|||
|
.container .content {
|
|||
|
width: calc(100% - 40px);
|
|||
|
padding: 10px;
|
|||
|
overflow-y: scroll;
|
|||
|
flex: 1
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.bubble,
|
|||
|
.chat-refer {
|
|||
|
max-width: 400px;
|
|||
|
position: relative;
|
|||
|
word-wrap: break-word;
|
|||
|
word-break: normal
|
|||
|
}
|
|||
|
|
|||
|
.bubble {
|
|||
|
white-space: pre-wrap;
|
|||
|
padding: 10px 11px;
|
|||
|
border-radius: 5px;
|
|||
|
color: #1f1f1f;
|
|||
|
font-size: 14px
|
|||
|
}
|
|||
|
|
|||
|
.chat-refer {
|
|||
|
margin-top: 5px;
|
|||
|
padding: 8px 10px;
|
|||
|
border-radius: 3px;
|
|||
|
color: #797979;
|
|||
|
font-size: 12px;
|
|||
|
background-color: #e8e8e8;
|
|||
|
display: -webkit-box;
|
|||
|
overflow: hidden;
|
|||
|
text-overflow: ellipsis;
|
|||
|
-webkit-box-orient: vertical;
|
|||
|
-webkit-line-clamp: 2; /* 这里添加 */
|
|||
|
line-clamp: 2; /* 这里添加 */
|
|||
|
white-space: normal; /* 这里添加 */
|
|||
|
}
|
|||
|
|
|||
|
.chat-refer-right {
|
|||
|
margin-right: 15px
|
|||
|
}
|
|||
|
|
|||
|
.chat-refer-left {
|
|||
|
margin-left: 15px
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble:before,
|
|||
|
.item-right .bubble:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble:before {
|
|||
|
left: -18px;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .bubble {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #9eea6a
|
|||
|
}
|
|||
|
|
|||
|
.item-right .bubble:before {
|
|||
|
border-left: 10px solid #9eea6a;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
right: -18px
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width: 768px) {
|
|||
|
.bubble {
|
|||
|
max-width: 280px;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .bubble {
|
|||
|
margin-right: 8px;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble {
|
|||
|
margin-left: 8px;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 8px solid transparent;
|
|||
|
border-top: 8px solid transparent;
|
|||
|
border-right: 8px solid #fff;
|
|||
|
border-bottom: 8px solid transparent;
|
|||
|
left: -13px;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .bubble:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 8px solid #9eea6a;
|
|||
|
border-top: 8px solid transparent;
|
|||
|
border-right: 8px solid transparent;
|
|||
|
border-bottom: 8px solid transparent;
|
|||
|
right: -13px;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.item {
|
|||
|
margin-top: 15px;
|
|||
|
display: flex;
|
|||
|
width: 100%;
|
|||
|
}
|
|||
|
|
|||
|
.item-refer {
|
|||
|
margin-top: 4px;
|
|||
|
}
|
|||
|
|
|||
|
.item.item-right {
|
|||
|
justify-content: flex-end;
|
|||
|
}
|
|||
|
|
|||
|
.item.item-center {
|
|||
|
justify-content: center;
|
|||
|
}
|
|||
|
|
|||
|
.item.item-center span {
|
|||
|
font-size: 12px;
|
|||
|
padding: 2px 4px;
|
|||
|
color: #fff;
|
|||
|
background-color: #dadada;
|
|||
|
border-radius: 3px;
|
|||
|
-moz-user-select: none;
|
|||
|
/*火狐*/
|
|||
|
-webkit-user-select: none;
|
|||
|
/*webkit浏览器*/
|
|||
|
-ms-user-select: none;
|
|||
|
/*IE10*/
|
|||
|
-khtml-user-select: none;
|
|||
|
/*早期浏览器*/
|
|||
|
user-select: none;
|
|||
|
}
|
|||
|
|
|||
|
.content-wrapper {
|
|||
|
display: flex;
|
|||
|
flex-direction: column;
|
|||
|
max-width: 50%;
|
|||
|
}
|
|||
|
|
|||
|
.content-wrapper-left {
|
|||
|
align-items: baseline;
|
|||
|
}
|
|||
|
|
|||
|
.content-wrapper-right {
|
|||
|
align-items: flex-end;
|
|||
|
}
|
|||
|
|
|||
|
.displayname {
|
|||
|
margin-left: 13px;
|
|||
|
margin-left: 13px;
|
|||
|
font-size: 13px;
|
|||
|
margin-bottom: 5px;
|
|||
|
color: darkgray;
|
|||
|
}
|
|||
|
.avatar img {
|
|||
|
width: 42px;
|
|||
|
height: 42px;
|
|||
|
border-radius: 3px;
|
|||
|
user-select: none;
|
|||
|
}
|
|||
|
|
|||
|
.chat-video video {
|
|||
|
margin-right: 18px;
|
|||
|
margin-left: 18px;
|
|||
|
max-width: 350px;
|
|||
|
}
|
|||
|
|
|||
|
.chat-audio {
|
|||
|
max-width: 400px;
|
|||
|
}
|
|||
|
|
|||
|
audio {
|
|||
|
margin-left: 9px;
|
|||
|
margin-right: 9px;
|
|||
|
}
|
|||
|
.chat-image img,
|
|||
|
.chat-file img {
|
|||
|
margin-right: 18px;
|
|||
|
margin-left: 18px;
|
|||
|
max-width: 250px;
|
|||
|
max-height: 250px;
|
|||
|
}
|
|||
|
.emoji-image img {
|
|||
|
margin-right: 18px;
|
|||
|
margin-left: 18px;
|
|||
|
max-width: 150px;
|
|||
|
max-height: 150px;
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width: 768px) {
|
|||
|
|
|||
|
.chat-image img,
|
|||
|
.chat-file img {
|
|||
|
margin-right: 8px;
|
|||
|
margin-left: 8px;
|
|||
|
max-width: 250px;
|
|||
|
/*max-height: auto;*/
|
|||
|
}
|
|||
|
.displayname {
|
|||
|
margin-left: 13px;
|
|||
|
margin-left: 13px;
|
|||
|
font-size: 10px;
|
|||
|
margin-bottom: 5px;
|
|||
|
color: darkgray;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.chat-file {
|
|||
|
max-width: 80%;
|
|||
|
width: 300px;
|
|||
|
margin-right: 20px;
|
|||
|
display: flex;
|
|||
|
flex-direction: column;
|
|||
|
padding: 10px;
|
|||
|
background-color: #fff;
|
|||
|
border-radius: 4px;
|
|||
|
cursor: pointer;
|
|||
|
/* height: 100px; */
|
|||
|
margin-left: 10px;
|
|||
|
}
|
|||
|
|
|||
|
.chat-file img {
|
|||
|
width: 50px;
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width: 768px) {
|
|||
|
.chat-file {
|
|||
|
margin-left: 8px;
|
|||
|
margin-right: 8px;
|
|||
|
}
|
|||
|
.chat-file img {
|
|||
|
width: 40px;
|
|||
|
}
|
|||
|
.chat-image img,
|
|||
|
.chat-file img {
|
|||
|
margin-right: 8px;
|
|||
|
margin-left: 8px;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio {
|
|||
|
margin: 0 10px;
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio .player-box,
|
|||
|
.chat-file .file-box {
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
cursor: pointer;
|
|||
|
/* height: 80px; */
|
|||
|
}
|
|||
|
|
|||
|
.player-box {
|
|||
|
background-color: #939AA1;
|
|||
|
border-radius: 5px;
|
|||
|
width: 300px;
|
|||
|
}
|
|||
|
|
|||
|
.player-box .cover-image {
|
|||
|
width: 80px;
|
|||
|
height: 80px;
|
|||
|
border-radius: 5px 0 0 5px;
|
|||
|
vertical-align: middle
|
|||
|
}
|
|||
|
|
|||
|
.player-box .player-info {
|
|||
|
width: 160px;
|
|||
|
margin: 0 14px;
|
|||
|
overflow: hidden;
|
|||
|
vertical-align: middle
|
|||
|
}
|
|||
|
|
|||
|
.player-box .player-info .title {
|
|||
|
font-size: 16px;
|
|||
|
color: #fff;
|
|||
|
margin-bottom: 5px;
|
|||
|
}
|
|||
|
|
|||
|
.player-box .player-info .artist {
|
|||
|
font-size: 14px;
|
|||
|
color: #cecece;
|
|||
|
}
|
|||
|
|
|||
|
.player-box .player-button {
|
|||
|
width: 16px;
|
|||
|
height: 16px;
|
|||
|
vertical-align: middle
|
|||
|
}
|
|||
|
|
|||
|
.player-original {
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
height: 20px;
|
|||
|
}
|
|||
|
|
|||
|
.player-original p {
|
|||
|
color: #b6b6b6;
|
|||
|
font-size: 12px;
|
|||
|
vertical-align: middle
|
|||
|
}
|
|||
|
|
|||
|
.player-original-img {
|
|||
|
width: 12px;
|
|||
|
height: 12px;
|
|||
|
margin: 0 5px;
|
|||
|
}
|
|||
|
|
|||
|
.chat-file .app-info {
|
|||
|
border-top: 1px solid #ede3e3;
|
|||
|
}
|
|||
|
|
|||
|
.chat-file .app-info p {
|
|||
|
margin-top: 3px;
|
|||
|
color: #888;
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio .player-controls,
|
|||
|
.chat-file .file-img {
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
}
|
|||
|
|
|||
|
.file-title{
|
|||
|
font-size: 14px;
|
|||
|
display: -webkit-box;
|
|||
|
overflow: hidden;
|
|||
|
text-overflow: ellipsis;
|
|||
|
-webkit-box-orient: vertical;
|
|||
|
}
|
|||
|
|
|||
|
.description>p {
|
|||
|
font-size: 12px;
|
|||
|
color: #BDBDBD;
|
|||
|
display: -webkit-box;
|
|||
|
overflow: hidden;
|
|||
|
text-overflow: ellipsis;
|
|||
|
-webkit-box-orient: vertical;
|
|||
|
}
|
|||
|
|
|||
|
.card-title{
|
|||
|
font-size: 14px;
|
|||
|
}
|
|||
|
|
|||
|
.file-title,
|
|||
|
.card-content>h2 {
|
|||
|
-webkit-line-clamp: 2;
|
|||
|
font: 14px sans-serif;
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width: 768px) {
|
|||
|
.file-title {
|
|||
|
font-size: 13px;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.description>p {
|
|||
|
-webkit-line-clamp: 3;
|
|||
|
margin-top: 2px;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
.chat-music-audio .flex1,
|
|||
|
.chat-file .flex1 {
|
|||
|
flex: 1;
|
|||
|
justify-content: start;
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio .flex2,
|
|||
|
.chat-file .flex2 {
|
|||
|
flex: 2;
|
|||
|
justify-content: end;
|
|||
|
}
|
|||
|
|
|||
|
.chat-file .file-info {
|
|||
|
width: 200px;
|
|||
|
/* height: 80px; */
|
|||
|
margin-left: 4px;
|
|||
|
/* margin-top: 15px; */
|
|||
|
white-space: normal;
|
|||
|
flex-basis: 200px;
|
|||
|
word-break: break-word;
|
|||
|
}
|
|||
|
|
|||
|
.chat-file .file-name,
|
|||
|
.chat-music-audio .song-title {
|
|||
|
font-weight: 700;
|
|||
|
overflow-wrap: break-word
|
|||
|
}
|
|||
|
|
|||
|
.chat-file .file-size {
|
|||
|
margin-top: 5px;
|
|||
|
color: #888
|
|||
|
}
|
|||
|
|
|||
|
.app-info {
|
|||
|
font-size: 13px;
|
|||
|
margin-left: 3px;
|
|||
|
margin-right: 3px
|
|||
|
}
|
|||
|
|
|||
|
.file-size,
|
|||
|
textarea {
|
|||
|
font-size: 12px
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio .play-button {
|
|||
|
width: 50px;
|
|||
|
height: 50px;
|
|||
|
background-color: transparent;
|
|||
|
border-radius: 50%;
|
|||
|
border: 0;
|
|||
|
outline: 0;
|
|||
|
cursor: pointer
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio .play-button.playing {
|
|||
|
background: url() no-repeat center;
|
|||
|
background-size: 18px 18px;
|
|||
|
}
|
|||
|
|
|||
|
.chat-music-audio .play-button.paused {
|
|||
|
background: url() no-repeat center;
|
|||
|
background-size: 18px 18px;
|
|||
|
}
|
|||
|
|
|||
|
.input-area {
|
|||
|
border-top: .5px solid #e0e0e0;
|
|||
|
height: 150px;
|
|||
|
display: flex;
|
|||
|
flex-flow: column;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
textarea {
|
|||
|
flex: 1;
|
|||
|
padding: 5px;
|
|||
|
border: 0;
|
|||
|
cursor: pointer;
|
|||
|
overflow-y: auto;
|
|||
|
overflow-x: hidden;
|
|||
|
outline: 0;
|
|||
|
resize: none
|
|||
|
}
|
|||
|
|
|||
|
.button-area {
|
|||
|
display: flex;
|
|||
|
height: 40px;
|
|||
|
margin-right: 10px;
|
|||
|
line-height: 40px;
|
|||
|
padding: 5px;
|
|||
|
justify-content: flex-end
|
|||
|
}
|
|||
|
|
|||
|
.button-area button,
|
|||
|
button {
|
|||
|
border: 0;
|
|||
|
border-radius: 4px;
|
|||
|
cursor: pointer
|
|||
|
}
|
|||
|
|
|||
|
.button-area button {
|
|||
|
width: 80px;
|
|||
|
outline: 0;
|
|||
|
float: right
|
|||
|
}
|
|||
|
|
|||
|
#paginationInfo,
|
|||
|
.button-row,
|
|||
|
.jump-row {
|
|||
|
display: flex;
|
|||
|
justify-content: center;
|
|||
|
align-items: center;
|
|||
|
margin-bottom: 10px
|
|||
|
}
|
|||
|
|
|||
|
button,
|
|||
|
input {
|
|||
|
font-size: 14px
|
|||
|
}
|
|||
|
|
|||
|
button {
|
|||
|
background-color: #3498db;
|
|||
|
color: #fff;
|
|||
|
margin: 0 14px;
|
|||
|
transition: background-color .3s;
|
|||
|
padding: 10px 25px
|
|||
|
}
|
|||
|
|
|||
|
button:hover {
|
|||
|
background-color: #2980b9
|
|||
|
}
|
|||
|
|
|||
|
input {
|
|||
|
padding: 8px;
|
|||
|
width: 120px;
|
|||
|
box-sizing: border-box;
|
|||
|
margin-right: 0;
|
|||
|
margin-left: 15px
|
|||
|
}
|
|||
|
|
|||
|
#paginationInfo {
|
|||
|
color: #555;
|
|||
|
font-size: 14px
|
|||
|
}
|
|||
|
|
|||
|
.card {
|
|||
|
background-color: #fff;
|
|||
|
border-radius: 10px;
|
|||
|
overflow: hidden;
|
|||
|
box-shadow: 0 4px 8px rgba(0, 0, 0, .1);
|
|||
|
max-width: 80%;
|
|||
|
width: 280px;
|
|||
|
display: flex;
|
|||
|
flex-direction: column;
|
|||
|
text-align: left;
|
|||
|
margin: 0 15px 10px 20px
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width:768px) {
|
|||
|
.card {
|
|||
|
margin: 0 8px
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.card a {
|
|||
|
text-decoration: none;
|
|||
|
color: inherit
|
|||
|
}
|
|||
|
|
|||
|
.card-content {
|
|||
|
padding: 10px;
|
|||
|
flex: 1
|
|||
|
}
|
|||
|
|
|||
|
.thumbnail {
|
|||
|
width: 50px;
|
|||
|
height: 50px;
|
|||
|
object-fit: cover
|
|||
|
}
|
|||
|
|
|||
|
.description,
|
|||
|
.link-info {
|
|||
|
display: flex;
|
|||
|
justify-content: space-between
|
|||
|
}
|
|||
|
|
|||
|
.link-info {
|
|||
|
align-items: center;
|
|||
|
justify-content: center;
|
|||
|
padding: 2px;
|
|||
|
background-color: #f0f0f0
|
|||
|
}
|
|||
|
|
|||
|
.app-logo {
|
|||
|
width: 20px;
|
|||
|
height: 20px;
|
|||
|
margin-right: 10px;
|
|||
|
border-radius: 50%
|
|||
|
}
|
|||
|
|
|||
|
.app-name {
|
|||
|
font-size: 12px;
|
|||
|
font-weight: bold;
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box {
|
|||
|
width: 200px;
|
|||
|
height: 80px;
|
|||
|
margin-left: 18px;
|
|||
|
margin-right: 18px;
|
|||
|
border-radius: 3px;
|
|||
|
padding-left: 11px;
|
|||
|
padding-right: 11px;
|
|||
|
position: relative
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box[paysubtype="1"],
|
|||
|
.transfer-box[paysubtype="1"]::before {
|
|||
|
background: #f79c46
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box[paysubtype="1"] i {
|
|||
|
background-image: url(
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box:not([paysubtype="1"]),
|
|||
|
.transfer-box:not([paysubtype="1"])::before {
|
|||
|
background: #f8e2c6
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box[paysubtype="3"] i {
|
|||
|
background-image: url(
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box[paysubtype="4"] i {
|
|||
|
background-image: url()
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box::before {
|
|||
|
content: "";
|
|||
|
width: 8px;
|
|||
|
height: 8px;
|
|||
|
position: absolute;
|
|||
|
transform: rotate(45deg);
|
|||
|
top: 18px
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box[issend="0"]::before {
|
|||
|
left: -3px
|
|||
|
}
|
|||
|
|
|||
|
.transfer-box[issend="1"]::before {
|
|||
|
left: 218px
|
|||
|
}
|
|||
|
|
|||
|
.trans-content {
|
|||
|
display: flex;
|
|||
|
height: 60px;
|
|||
|
align-items: center;
|
|||
|
position: relative
|
|||
|
}
|
|||
|
|
|||
|
.trans-content>i {
|
|||
|
display: block;
|
|||
|
width: 36px;
|
|||
|
height: 36px;
|
|||
|
background-repeat: no-repeat;
|
|||
|
background-size: cover
|
|||
|
}
|
|||
|
|
|||
|
.transfer-texts {
|
|||
|
margin-left: 7px;
|
|||
|
display: flex;
|
|||
|
align-items: flex-start;
|
|||
|
flex-direction: column
|
|||
|
}
|
|||
|
|
|||
|
.trans-bottom>span,
|
|||
|
.transfer-texts>font,
|
|||
|
.transfer-texts>span {
|
|||
|
color: #fff;
|
|||
|
font-weight: 500
|
|||
|
}
|
|||
|
|
|||
|
.transfer-texts>span {
|
|||
|
font-size: 15px
|
|||
|
}
|
|||
|
|
|||
|
.transfer-texts>font {
|
|||
|
font-size: 12px;
|
|||
|
padding-left: 2px
|
|||
|
}
|
|||
|
|
|||
|
.transfer {
|
|||
|
height: 60px
|
|||
|
}
|
|||
|
|
|||
|
.trans-bottom {
|
|||
|
height: 16px;
|
|||
|
margin-top: 1px;
|
|||
|
display: flex;
|
|||
|
align-items: center
|
|||
|
}
|
|||
|
|
|||
|
.trans-bottom>span {
|
|||
|
font-size: 10px
|
|||
|
}
|
|||
|
|
|||
|
.call i {
|
|||
|
display: inline-block;
|
|||
|
background-repeat: no-repeat;
|
|||
|
background-size: cover;
|
|||
|
vertical-align: middle;
|
|||
|
margin-right: 4px;
|
|||
|
margin-top: -2px
|
|||
|
}
|
|||
|
|
|||
|
.call[calltype='1'] i {
|
|||
|
background-image: url(
|
|||
|
}
|
|||
|
|
|||
|
.call[calltype='0'] i {
|
|||
|
background-image: url(
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width:768px) {
|
|||
|
|
|||
|
#paginationInfo,
|
|||
|
.button-row,
|
|||
|
.jump-row {
|
|||
|
display: flex;
|
|||
|
justify-content: center;
|
|||
|
align-items: center;
|
|||
|
margin-bottom: 0
|
|||
|
}
|
|||
|
|
|||
|
.chat-video video {
|
|||
|
margin-right: 8px;
|
|||
|
margin-left: 8px;
|
|||
|
max-width: 280px
|
|||
|
}
|
|||
|
|
|||
|
button {
|
|||
|
padding: 5px 10px;
|
|||
|
background-color: #3498db;
|
|||
|
color: #fff;
|
|||
|
border: 0;
|
|||
|
border-radius: 4px;
|
|||
|
cursor: pointer;
|
|||
|
margin: 0 5px;
|
|||
|
transition: background-color .3s
|
|||
|
}
|
|||
|
|
|||
|
button:hover {
|
|||
|
background-color: #2980b9
|
|||
|
}
|
|||
|
|
|||
|
input {
|
|||
|
padding: 8px;
|
|||
|
width: 120px;
|
|||
|
box-sizing: border-box;
|
|||
|
margin-right: 0;
|
|||
|
margin-left: 5px
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.call i,
|
|||
|
.system-msg>.emoji_img {
|
|||
|
width: 18px;
|
|||
|
height: 18px
|
|||
|
}
|
|||
|
|
|||
|
.emoji_img {
|
|||
|
width: 22px;
|
|||
|
height: 22px;
|
|||
|
vertical-align: middle;
|
|||
|
margin-top: -4.4px
|
|||
|
}
|
|||
|
|
|||
|
.modal {
|
|||
|
display: none;
|
|||
|
position: fixed;
|
|||
|
z-index: 9999;
|
|||
|
top: 0;
|
|||
|
left: 0;
|
|||
|
width: 100%;
|
|||
|
height: 100%;
|
|||
|
background-color: rgba(0, 0, 0, .8)
|
|||
|
}
|
|||
|
|
|||
|
.modal-image {
|
|||
|
display: block;
|
|||
|
max-width: 90%;
|
|||
|
max-height: 90%;
|
|||
|
position: absolute;
|
|||
|
top: 50%;
|
|||
|
left: 50%;
|
|||
|
transform: translate(-50%, -50%)
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width:768px) {
|
|||
|
body {
|
|||
|
display: flex;
|
|||
|
flex-direction: column;
|
|||
|
align-items: center;
|
|||
|
justify-content: center
|
|||
|
}
|
|||
|
|
|||
|
::-webkit-scrollbar {
|
|||
|
display: none
|
|||
|
}
|
|||
|
|
|||
|
.page {
|
|||
|
width: 100%;
|
|||
|
height: 100%;
|
|||
|
box-shadow: none
|
|||
|
}
|
|||
|
|
|||
|
.page .mid-bar,
|
|||
|
.page .side-bar {
|
|||
|
display: none
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body {
|
|||
|
height: 95%
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar {
|
|||
|
transform: none;
|
|||
|
font-size: 12px
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar .button {
|
|||
|
margin: 10px 5px
|
|||
|
}
|
|||
|
|
|||
|
.page .main-body .nav-bar .turner-bar input {
|
|||
|
font-size: 14px
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card,
|
|||
|
.personal-card {
|
|||
|
position: relative;
|
|||
|
width: 220px;
|
|||
|
height: 115px;
|
|||
|
border-radius: 5px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .contner {
|
|||
|
display: flex;
|
|||
|
margin: 12px 16px 5px;
|
|||
|
width: 100%;
|
|||
|
height: 68px
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner img,
|
|||
|
.personal-card .contner img {
|
|||
|
line-height: 100px;
|
|||
|
width: 50px;
|
|||
|
height: 50px;
|
|||
|
margin: 2px 0 0;
|
|||
|
border-radius: 5%;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .contner .text {
|
|||
|
width: 60%;
|
|||
|
margin-left: 10px;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .contner .text .nickname {
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
color: #000
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .contner .text .nickname img {
|
|||
|
width: 14px;
|
|||
|
height: 14px;
|
|||
|
margin: 0
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .contner .text .other {
|
|||
|
font-size: 12px;
|
|||
|
line-height: 16px;
|
|||
|
color: #9e9898
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .bottom {
|
|||
|
width: 100%;
|
|||
|
height: 30px;
|
|||
|
font-size: 12px;
|
|||
|
color: #9e9898;
|
|||
|
background-color: #fafafa;
|
|||
|
border-top: #eee 1px solid
|
|||
|
}
|
|||
|
|
|||
|
.personal-card .bottom .text {
|
|||
|
font-size: 12px;
|
|||
|
line-height: 28px;
|
|||
|
margin-left: 16px
|
|||
|
}
|
|||
|
|
|||
|
.personal-card:hover {
|
|||
|
background-color: #333
|
|||
|
}
|
|||
|
|
|||
|
.item-left .personal-card {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-left .personal-card:before,
|
|||
|
.item-right .personal-card:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent
|
|||
|
}
|
|||
|
|
|||
|
.item-left .personal-card:before {
|
|||
|
left: -18px;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .personal-card {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .personal-card:before {
|
|||
|
border-left: 10px solid #fff;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
right: -18px;
|
|||
|
top: 11px
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner {
|
|||
|
display: flex;
|
|||
|
margin: 12px 16px 5px;
|
|||
|
width: 100%;
|
|||
|
height: 68px
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner .text {
|
|||
|
width: 60%;
|
|||
|
margin-left: 10px;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner .text .nickname {
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
color: #000
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner .text .desc {
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
color: #9e9898
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner .text .desc img {
|
|||
|
width: 14px;
|
|||
|
height: 14px;
|
|||
|
margin: 0px 0px 0px 0px;
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner .text .nickname img {
|
|||
|
width: 14px;
|
|||
|
height: 14px;
|
|||
|
margin: 0px 0px 0px 0px;
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .contner .text .other {
|
|||
|
font-size: 12px;
|
|||
|
line-height: 16px;
|
|||
|
color: #9e9898;
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .bottom {
|
|||
|
width: 100%;
|
|||
|
height: 30px;
|
|||
|
/* margin-top: 6px; */
|
|||
|
font-size: 12px;
|
|||
|
color: #9e9898;
|
|||
|
background-color: #fafafa;
|
|||
|
border-top: #eeeeee 1px solid;
|
|||
|
border-radius: 0 0 5px 5px;
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card .bottom .text {
|
|||
|
font-size: 12px;
|
|||
|
line-height: 28px;
|
|||
|
margin-left: 16px;
|
|||
|
}
|
|||
|
|
|||
|
.OpenIM-card:hover {
|
|||
|
background-color: #333;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .OpenIM-card {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .OpenIM-card {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .OpenIM-card:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
left: -18px;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .OpenIM-card {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .OpenIM-card:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid #fff;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
right: -18px;
|
|||
|
top: 11px;
|
|||
|
}
|
|||
|
|
|||
|
/* 位置 */
|
|||
|
.location {
|
|||
|
position: relative;
|
|||
|
width: 220px;
|
|||
|
height: 180px;
|
|||
|
border-radius: 5px;
|
|||
|
background-color: #fff;
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
.location .poiname {
|
|||
|
width: 90%;
|
|||
|
padding: 0 16px 0 10px;
|
|||
|
margin: 5px 0 5px 0;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
}
|
|||
|
|
|||
|
.location .label {
|
|||
|
width: 100%;
|
|||
|
padding: 0 16px 0 10px;
|
|||
|
font-size: 12px;
|
|||
|
color: #9e9898;
|
|||
|
;
|
|||
|
}
|
|||
|
|
|||
|
.location .map {
|
|||
|
width: 100%;
|
|||
|
height: 120px;
|
|||
|
overflow: hidden;
|
|||
|
}
|
|||
|
|
|||
|
.custom-content-marker {
|
|||
|
position: relative;
|
|||
|
width: 25px;
|
|||
|
height: 34px;
|
|||
|
}
|
|||
|
|
|||
|
.custom-content-marker img {
|
|||
|
width: 100%;
|
|||
|
height: 100%;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .location {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .location:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
left: -18px;
|
|||
|
top: 11px;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .location {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .location:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid #fff;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
right: -18px;
|
|||
|
top: 11px;
|
|||
|
}
|
|||
|
|
|||
|
/* 合并消息 */
|
|||
|
.merge-message {
|
|||
|
position: relative;
|
|||
|
width: 220px;
|
|||
|
height: 110px;
|
|||
|
border-radius: 5px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.merge-message .title {
|
|||
|
width: 100%;
|
|||
|
margin: 10px 16px;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
color: #000;
|
|||
|
}
|
|||
|
|
|||
|
.merge-message .msg {
|
|||
|
height: 16px;
|
|||
|
margin: 4px 16px;
|
|||
|
font-size: 12px;
|
|||
|
line-height: 16px;
|
|||
|
color: #9e9898;
|
|||
|
overflow: hidden;
|
|||
|
}
|
|||
|
|
|||
|
.merge-message .bottom {
|
|||
|
width: 100%;
|
|||
|
height: 28px;
|
|||
|
margin-top: 6px;
|
|||
|
font-size: 12px;
|
|||
|
color: #9e9898;
|
|||
|
background-color: #fafafa;
|
|||
|
border-top: #eeeeee 1px solid;
|
|||
|
}
|
|||
|
|
|||
|
.merge-message .bottom .text {
|
|||
|
font-size: 12px;
|
|||
|
line-height: 28px;
|
|||
|
margin-left: 16px;
|
|||
|
}
|
|||
|
|
|||
|
.merge-message:hover {
|
|||
|
background-color: #333;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .merge-message {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-left .merge-message:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
left: -18px;
|
|||
|
top: 11px;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .merge-message {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #fff;
|
|||
|
}
|
|||
|
|
|||
|
.item-right .merge-message:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid #fff;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
right: -18px;
|
|||
|
top: 11px;
|
|||
|
}
|
|||
|
|
|||
|
.search-modal,
|
|||
|
.merge-msg-modal {
|
|||
|
display: none;
|
|||
|
position: fixed;
|
|||
|
z-index: 1;
|
|||
|
left: 0;
|
|||
|
top: 0;
|
|||
|
width: 100%;
|
|||
|
height: 100%;
|
|||
|
background-color: rgb(0, 0, 0);
|
|||
|
background-color: rgba(0, 0, 0, 0.4);
|
|||
|
}
|
|||
|
|
|||
|
.search-modal-content,
|
|||
|
.merge-msg-modal-content {
|
|||
|
background-color: #fefefe;
|
|||
|
margin: 5% auto;
|
|||
|
/* 15% 从顶部和居中 */
|
|||
|
padding: 20px;
|
|||
|
border: 1px solid #888;
|
|||
|
width: 60%;
|
|||
|
height: 80%;
|
|||
|
}
|
|||
|
|
|||
|
/* 关闭按钮 */
|
|||
|
.merge-msg-modal-content .title .close {
|
|||
|
color: #aaa;
|
|||
|
float: right;
|
|||
|
font-size: 28px;
|
|||
|
font-weight: bold;
|
|||
|
margin-top: -20px;
|
|||
|
margin-right: -10px;
|
|||
|
}
|
|||
|
|
|||
|
.merge-msg-modal-content .title .close:hover,
|
|||
|
.merge-msg-modal-content .title .close:focus {
|
|||
|
color: black;
|
|||
|
text-decoration: none;
|
|||
|
cursor: pointer;
|
|||
|
}
|
|||
|
|
|||
|
.merge-msg-modal-content .title {
|
|||
|
height: 40px;
|
|||
|
font-size: 14px;
|
|||
|
color: #9e9898;
|
|||
|
border-bottom: #eeeeee 1px solid;
|
|||
|
}
|
|||
|
|
|||
|
.modal-container {
|
|||
|
/* display: flex; */
|
|||
|
/* position: fixed; */
|
|||
|
height: 90%;
|
|||
|
overflow: hidden;
|
|||
|
overflow-y: auto;
|
|||
|
}
|
|||
|
|
|||
|
.modal-container .OnePersonmsg {
|
|||
|
display: flex;
|
|||
|
overflow: hidden;
|
|||
|
overflow-y: auto
|
|||
|
}
|
|||
|
|
|||
|
.search-modal-content .modal-container .OnePersonmsg:hover {
|
|||
|
background-color: #f0f0f0;
|
|||
|
}
|
|||
|
|
|||
|
.search-modal-content .modal-container .OnePersonmsg {
|
|||
|
cursor: pointer;
|
|||
|
}
|
|||
|
|
|||
|
.tooltip {
|
|||
|
position: absolute;
|
|||
|
background-color: black;
|
|||
|
color: white;
|
|||
|
padding: 5px;
|
|||
|
border-radius: 3px;
|
|||
|
font-size: 12px;
|
|||
|
white-space: nowrap;
|
|||
|
/* 防止提示文本换行 */
|
|||
|
display: none;
|
|||
|
/* 默认隐藏 */
|
|||
|
z-index: 2;
|
|||
|
}
|
|||
|
|
|||
|
.search-modal-content .modal-container .OnePersonmsg:hover .tooltip {
|
|||
|
visibility: visible;
|
|||
|
}
|
|||
|
|
|||
|
.OnePersonmsg .left {
|
|||
|
width: 12%;
|
|||
|
text-align: right
|
|||
|
}
|
|||
|
|
|||
|
.OnePersonmsg .right {
|
|||
|
width: 88%
|
|||
|
}
|
|||
|
|
|||
|
.OnePersonmsg .left .avatar {
|
|||
|
margin-left: 30px;
|
|||
|
margin-top: 10px
|
|||
|
}
|
|||
|
|
|||
|
.OnePersonmsg .left .avatar img {
|
|||
|
width: 36px;
|
|||
|
height: 36px;
|
|||
|
user-select: none
|
|||
|
}
|
|||
|
|
|||
|
.OnePersonmsg .right .msg-block {
|
|||
|
width: 80%;
|
|||
|
margin-left: 10px;
|
|||
|
margin-top: 10px;
|
|||
|
padding-bottom: 20px;
|
|||
|
border-bottom: #eee 1px solid
|
|||
|
}
|
|||
|
|
|||
|
.msg-block .msg-container-top {
|
|||
|
font-size: 14px;
|
|||
|
color: #9e9898;
|
|||
|
display: flex;
|
|||
|
justify-content: space-between;
|
|||
|
align-items: center
|
|||
|
}
|
|||
|
|
|||
|
.msg-block .msg-container {
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
color: #000
|
|||
|
}
|
|||
|
|
|||
|
.msg-block .msg-container img,
|
|||
|
.msg-block .msg-container video {
|
|||
|
max-width: 280px
|
|||
|
}
|
|||
|
|
|||
|
.msg-block .inner-msgMerge-card {
|
|||
|
background-color: #f4f4f4;
|
|||
|
padding-top: 10px;
|
|||
|
height: 60px
|
|||
|
}
|
|||
|
|
|||
|
.inner-msgMerge-card .desc,
|
|||
|
.inner-msgMerge-card .title {
|
|||
|
height: 20px;
|
|||
|
margin: 0 0 0 10px;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 18px;
|
|||
|
color: #000;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.inner-msgMerge-card .desc {
|
|||
|
height: 16px;
|
|||
|
font-size: 12px;
|
|||
|
line-height: 16px;
|
|||
|
color: #9e9898
|
|||
|
}
|
|||
|
|
|||
|
.modal-search-box {
|
|||
|
width: 90%;
|
|||
|
padding: 10px;
|
|||
|
margin: 10px auto;
|
|||
|
font-size: 16px;
|
|||
|
border: 1px solid #ccc;
|
|||
|
border-radius: 4px;
|
|||
|
}
|
|||
|
|
|||
|
.close-btn {
|
|||
|
color: #aaa;
|
|||
|
float: right;
|
|||
|
font-size: 28px;
|
|||
|
font-weight: bold;
|
|||
|
cursor: pointer;
|
|||
|
}
|
|||
|
|
|||
|
.close-btn:hover,
|
|||
|
.close-btn:focus {
|
|||
|
color: black;
|
|||
|
text-decoration: none;
|
|||
|
}
|
|||
|
|
|||
|
.mini-program,
|
|||
|
.video-number {
|
|||
|
position: relative;
|
|||
|
width: 220px;
|
|||
|
border-radius: 5px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.mini-program a {
|
|||
|
text-decoration: none
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .top {
|
|||
|
display: flex;
|
|||
|
margin: 0;
|
|||
|
width: 100%;
|
|||
|
height: 40px
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .top img {
|
|||
|
margin: 15px 0 0 15px;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .top .text {
|
|||
|
width: 60%;
|
|||
|
margin: 15px 0 0 10px;
|
|||
|
font-size: 12px;
|
|||
|
line-height: 20px;
|
|||
|
overflow: hidden;
|
|||
|
color: #9e9898
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .title {
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
color: #000;
|
|||
|
margin: 0 0 0 15px
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .cover,
|
|||
|
.mini-program img {
|
|||
|
width: 190px;
|
|||
|
height: 170px;
|
|||
|
margin: 10px auto;
|
|||
|
color: #9e9898
|
|||
|
}
|
|||
|
|
|||
|
.mini-program img {
|
|||
|
margin: 0 auto
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .bottom {
|
|||
|
width: 100%;
|
|||
|
height: 30px;
|
|||
|
font-size: 12px;
|
|||
|
color: #9e9898;
|
|||
|
background-color: #fafafa;
|
|||
|
border-top: #eee 1px solid;
|
|||
|
border-radius: 0 0 5px 5px
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .bottom .text {
|
|||
|
font-size: 12px;
|
|||
|
line-height: 28px;
|
|||
|
margin-left: 16px
|
|||
|
}
|
|||
|
|
|||
|
.mini-program:hover {
|
|||
|
background-color: #333
|
|||
|
}
|
|||
|
|
|||
|
.item-left .mini-program {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-left .mini-program:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
left: -18px
|
|||
|
}
|
|||
|
|
|||
|
.item-right .mini-program {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .mini-program:before {
|
|||
|
border-left: 10px solid #fff;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
right: -18px;
|
|||
|
top: 11px
|
|||
|
}
|
|||
|
|
|||
|
.video-number {
|
|||
|
width: 210px;
|
|||
|
height: 340px;
|
|||
|
background-color: #a56819;
|
|||
|
display: flex;
|
|||
|
flex-direction: column
|
|||
|
}
|
|||
|
|
|||
|
.video-number .title {
|
|||
|
width: 90%;
|
|||
|
height: 60px;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 20px;
|
|||
|
overflow: hidden;
|
|||
|
color: #333;
|
|||
|
margin: 5px auto
|
|||
|
}
|
|||
|
|
|||
|
.video-number .container {
|
|||
|
width: 210px;
|
|||
|
height: 280px;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.video-number .container .bottom {
|
|||
|
position: absolute;
|
|||
|
top: 240px;
|
|||
|
width: 100%;
|
|||
|
height: 100px;
|
|||
|
font-size: 12px;
|
|||
|
line-height: 16px;
|
|||
|
margin: auto 0 -100px;
|
|||
|
background: linear-gradient(to bottom, transparent, #000);
|
|||
|
border-radius: 0 0 5px 5px
|
|||
|
}
|
|||
|
|
|||
|
.video-number .container .bottom .author {
|
|||
|
position: absolute;
|
|||
|
width: 100%;
|
|||
|
height: 30px;
|
|||
|
margin: 0 0 0 15px;
|
|||
|
bottom: 10px;
|
|||
|
overflow: hidden
|
|||
|
}
|
|||
|
|
|||
|
.video-number .container .bottom .author img {
|
|||
|
width: 20px;
|
|||
|
height: 20px;
|
|||
|
border-radius: 50%;
|
|||
|
display: inline-block
|
|||
|
}
|
|||
|
|
|||
|
.video-number .container .bottom .author .authIcon,
|
|||
|
.video-number .container .bottom .author .logo {
|
|||
|
width: 20px;
|
|||
|
height: 20px;
|
|||
|
border-radius: 50%;
|
|||
|
display: inline-block;
|
|||
|
vertical-align: middle
|
|||
|
}
|
|||
|
|
|||
|
.mini-program .top img,
|
|||
|
.video-number .container .bottom .author .authIcon img,
|
|||
|
.video-number .container .bottom .author .logo img {
|
|||
|
width: 20px;
|
|||
|
height: 20px;
|
|||
|
border-radius: 50%
|
|||
|
}
|
|||
|
|
|||
|
.video-number .container .bottom .author .name {
|
|||
|
height: 30px;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 30px;
|
|||
|
color: #fff;
|
|||
|
margin: 0 4px;
|
|||
|
display: inline-block;
|
|||
|
vertical-align: middle
|
|||
|
}
|
|||
|
|
|||
|
.item-left .video-number {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-left .video-number:before,
|
|||
|
.item-right .mini-program:before,
|
|||
|
.item-right .video-number:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent
|
|||
|
}
|
|||
|
|
|||
|
.item-left .video-number:before {
|
|||
|
left: -18px;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .video-number {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .video-number:before {
|
|||
|
border-left: 10px solid #fff;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
right: -18px;
|
|||
|
top: 11px
|
|||
|
}
|
|||
|
|
|||
|
.bubble-audio-left,
|
|||
|
.bubble-audio-right {
|
|||
|
position: relative;
|
|||
|
min-width: 40px;
|
|||
|
max-width: 250px;
|
|||
|
border-radius: 5px;
|
|||
|
line-height: 40px
|
|||
|
}
|
|||
|
|
|||
|
.bubble-audio-left {
|
|||
|
background: url() no-repeat center left 10px;
|
|||
|
background-size: 20px;
|
|||
|
padding-left: 30px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.bubble-audio-right {
|
|||
|
background: url() no-repeat center right 10px;
|
|||
|
background-color: #9eea6a;
|
|||
|
background-size: 20px;
|
|||
|
padding-right: 30px;
|
|||
|
direction: rtl
|
|||
|
}
|
|||
|
|
|||
|
@keyframes spin {
|
|||
|
0% {
|
|||
|
transform: rotate(0deg)
|
|||
|
}
|
|||
|
|
|||
|
to {
|
|||
|
transform: rotate(360deg)
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble-audio-left {
|
|||
|
margin-left: 15px;
|
|||
|
background-color: #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble-audio-left:before,
|
|||
|
.item-right .bubble-audio-right:before {
|
|||
|
content: "";
|
|||
|
position: absolute;
|
|||
|
width: 0;
|
|||
|
height: 0;
|
|||
|
border-top: 10px solid transparent;
|
|||
|
border-bottom: 10px solid transparent;
|
|||
|
top: 11px
|
|||
|
}
|
|||
|
|
|||
|
.item-left .bubble-audio-left:before {
|
|||
|
left: -18px;
|
|||
|
border-left: 10px solid transparent;
|
|||
|
border-right: 10px solid #fff
|
|||
|
}
|
|||
|
|
|||
|
.item-right .bubble-audio-right {
|
|||
|
margin-right: 15px;
|
|||
|
background-color: #9eea6a
|
|||
|
}
|
|||
|
|
|||
|
.item-right .bubble-audio-right:before {
|
|||
|
border-left: 10px solid #9eea6a;
|
|||
|
border-right: 10px solid transparent;
|
|||
|
right: -18px
|
|||
|
}
|
|||
|
|
|||
|
.custom-menu-item {
|
|||
|
background-color: #fff;
|
|||
|
padding: 8px 12px;
|
|||
|
cursor: pointer
|
|||
|
}
|
|||
|
|
|||
|
.custom-menu-item:hover {
|
|||
|
background-color: #ddd
|
|||
|
}
|
|||
|
|
|||
|
.topnavbar-nav {
|
|||
|
display: flex;
|
|||
|
flex-wrap: wrap;
|
|||
|
align-items: center
|
|||
|
}
|
|||
|
|
|||
|
.topnavbar-nav .menu-button {
|
|||
|
max-width: 100px;
|
|||
|
height: 30px;
|
|||
|
font-size: 14px;
|
|||
|
line-height: 30px;
|
|||
|
text-align: center;
|
|||
|
background-color: #fff;
|
|||
|
padding: 0 10px;
|
|||
|
border-radius: 5px;
|
|||
|
margin: 5px 10px;
|
|||
|
cursor: pointer;
|
|||
|
overflow: hidden;
|
|||
|
z-index: 999
|
|||
|
}
|
|||
|
|
|||
|
.topnavbar-nav.show {
|
|||
|
display: flex
|
|||
|
}
|
|||
|
|
|||
|
.menu-toggle {
|
|||
|
display: none;
|
|||
|
font-size: 1.5em;
|
|||
|
cursor: pointer;
|
|||
|
align-self: flex-start
|
|||
|
}
|
|||
|
|
|||
|
@media screen and (max-width:768px) {
|
|||
|
.merge-msg-modal-content {
|
|||
|
background-color: #fefefe;
|
|||
|
margin: 5% auto;
|
|||
|
padding: 20px;
|
|||
|
border: 1px solid #888;
|
|||
|
width: 90%;
|
|||
|
height: 80%
|
|||
|
}
|
|||
|
|
|||
|
.OnePersonmsg .left .avatar {
|
|||
|
margin-left: 0;
|
|||
|
margin-top: 10px
|
|||
|
}
|
|||
|
|
|||
|
.topnavbar-nav {
|
|||
|
display: none;
|
|||
|
flex-direction: column;
|
|||
|
margin-left: auto;
|
|||
|
margin-right: -120px
|
|||
|
}
|
|||
|
|
|||
|
.topnavbar-nav,
|
|||
|
.topnavbar-nav .show {
|
|||
|
align-items: flex-start
|
|||
|
}
|
|||
|
|
|||
|
.menu-toggle {
|
|||
|
display: block;
|
|||
|
margin-left: auto;
|
|||
|
margin-right: 20px
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.loader {
|
|||
|
border: 16px solid #f3f3f3;
|
|||
|
border-top: 16px solid #dd512e;
|
|||
|
border-radius: 50%;
|
|||
|
width: 60px;
|
|||
|
height: 60px;
|
|||
|
animation: spin 2s linear infinite;
|
|||
|
position: absolute;
|
|||
|
top: 50%;
|
|||
|
left: 50%;
|
|||
|
transform: translate(-50%, -50%)
|
|||
|
}
|
|||
|
</style>
|
|||
|
<title>出错了</title>
|
|||
|
</head>
|
|||
|
|
|||
|
<body>
|
|||
|
<!-- 加载动画容器 -->
|
|||
|
<div class="loader" id="loader"></div>
|
|||
|
<div class="page" id="content" style="display: none;">
|
|||
|
<!-- <div class="side-bar"></div> -->
|
|||
|
<div class="mid-bar">
|
|||
|
<div class="timeline-area">
|
|||
|
<div class="timeline-wrapper">
|
|||
|
<div class="timeline" id="timeline">
|
|||
|
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="main-body">
|
|||
|
<div class="title-bar" id="title-bar">
|
|||
|
<p id="title">出错了</p>
|
|||
|
<div class="topnavbar-nav" id="topnavbar-nav">
|
|||
|
</div>
|
|||
|
<span class="menu-toggle" id="menu-toggle">
|
|||
|
<i class="fas fa-bars"></i>
|
|||
|
</span>
|
|||
|
</div>
|
|||
|
<div class="container">
|
|||
|
<div class="content" id="chat-container" onscroll="checkScroll()">
|
|||
|
<div class="item item-center">
|
|||
|
<span>8:16</span>
|
|||
|
</div>
|
|||
|
<div class="item item-center">
|
|||
|
<span>错误提示</span>
|
|||
|
</div>
|
|||
|
<div class="item item-left">
|
|||
|
<div class="avatar">
|
|||
|
<img
|
|||
|
src="https://blog.lc044.love/static/img/a774ab7a32635db7b4254c8ff7caaa89.Camera_XHS_16984826124131040g2sg30qo1ggopgqe05oce.webp">
|
|||
|
</div>
|
|||
|
<div class="bubble bubble-left">
|
|||
|
很抱歉,由于程序出现未知错误,您的聊天记录未能成功展示。<br />您可以关注下方微信公众号,<b>回复:联系方式</b>,获取QQ交流群群号,并在群内寻求帮助。
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="item item-left">
|
|||
|
<div class="avatar">
|
|||
|
<img
|
|||
|
src="https://blog.lc044.love/static/img/a774ab7a32635db7b4254c8ff7caaa89.Camera_XHS_16984826124131040g2sg30qo1ggopgqe05oce.webp">
|
|||
|
</div>
|
|||
|
<div class="bubble bubble-left">您可自行排查问题所在,例如只选择文本或图片,反馈时请说明哪种消息类型出现了问题!!!
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="item item-left">
|
|||
|
<div class="avatar">
|
|||
|
<img src="https://blog.lc044.love/static/img/a774ab7a32635db7b4254c8ff7caaa89.Camera_XHS_16984826124131040g2sg30qo1ggopgqe05oce.webp"
|
|||
|
loading="lazy">
|
|||
|
</div>
|
|||
|
<div class="content-wrapper content-wrapper-left">
|
|||
|
<div class="chat-image">
|
|||
|
<img src="https://blog.lc044.love/static/img/3fd32f1732a2c8f53a7eb923472b8f19.clipboard-2023-12-18.webp"
|
|||
|
onclick="showModal(this)" loading="lazy">
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="item item-right">
|
|||
|
<div class="bubble bubble-right">好的</div>
|
|||
|
<div class="avatar">
|
|||
|
<img src="https://cdn.luogu.com.cn/upload/image_hosting/rbnmv4bu.png">
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="nav-bar">
|
|||
|
<div class="turner-bar">
|
|||
|
<div class="button pre-page" onclick="prevPage()">上一页</div>
|
|||
|
<div class="navigator-line">转到第
|
|||
|
<input class="navgator" value="1" id="gotoPage" onchange="gotoPage()"></input>页,共<p
|
|||
|
id="maxPage">0</p>页
|
|||
|
</div>
|
|||
|
<div class="button next-page" onclick="nextPage()">下一页</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div id="search-modal" class="search-modal">
|
|||
|
<div class="search-modal-content" id="search-modal-content">
|
|||
|
<span class="close-btn" onclick="closeSearchModal()">×</span>
|
|||
|
<input type="text" id="searchBox" class="modal-search-box" placeholder="Type your search...">
|
|||
|
</div>
|
|||
|
|
|||
|
</div>
|
|||
|
<div id="modal" class="modal" onclick="hideModal()">
|
|||
|
<img id="modal-image" class="modal-image">
|
|||
|
</div>
|
|||
|
<script>
|
|||
|
const FileIcons = {
|
|||
|
'DOCX': '
|
|||
|
'XLS': '
|
|||
|
'CSV': '
|
|||
|
'TXT': '
|
|||
|
'ZIP': '
|
|||
|
'PPT': '
|
|||
|
'PDF': '
|
|||
|
'Default': ''
|
|||
|
}
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
/**
|
|||
|
* lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 0.7.0
|
|||
|
* Copyright (C) 2016 Oliver Nightingale
|
|||
|
* MIT Licensed
|
|||
|
* @license
|
|||
|
*/
|
|||
|
!function () { var t = function (e) { var n = new t.Index; return n.pipeline.add(t.trimmer, t.stopWordFilter, t.stemmer), e && e.call(n, n), n }; t.version = "0.7.0", t.utils = {}, t.utils.warn = function (t) { return function (e) { t.console && console.warn && console.warn(e) } }(this), t.utils.asString = function (t) { return void 0 === t || null === t ? "" : t.toString() }, t.EventEmitter = function () { this.events = {} }, t.EventEmitter.prototype.addListener = function () { var t = Array.prototype.slice.call(arguments), e = t.pop(), n = t; if ("function" != typeof e) throw new TypeError("last argument must be a function"); n.forEach(function (t) { this.hasHandler(t) || (this.events[t] = []), this.events[t].push(e) }, this) }, t.EventEmitter.prototype.removeListener = function (t, e) { if (this.hasHandler(t)) { var n = this.events[t].indexOf(e); this.events[t].splice(n, 1), this.events[t].length || delete this.events[t] } }, t.EventEmitter.prototype.emit = function (t) { if (this.hasHandler(t)) { var e = Array.prototype.slice.call(arguments, 1); this.events[t].forEach(function (t) { t.apply(void 0, e) }) } }, t.EventEmitter.prototype.hasHandler = function (t) { return t in this.events }, t.tokenizer = function (e) { return arguments.length && null != e && void 0 != e ? Array.isArray(e) ? e.map(function (e) { return t.utils.asString(e).toLowerCase() }) : e.toString().trim().toLowerCase().split(t.tokenizer.seperator) : [] }, t.tokenizer.seperator = /[\s\-]+/, t.tokenizer.load = function (t) { var e = this.registeredFunctions[t]; if (!e) throw new Error("Cannot load un-registered function: " + t); return e }, t.tokenizer.label = "default", t.tokenizer.registeredFunctions = { "default": t.tokenizer }, t.tokenizer.registerFunction = function (e, n) { n in this.registeredFunctions && t.utils.warn("Overwriting existing tokenizer: " + n), e.label = n, this.registeredFunctions[n] = e }, t.Pipeline = function () { this._stack = [] }, t.Pipeline.registeredFunctions = {}, t.Pipeline.registerFunction = function (e, n) { n in this.registeredFunctions && t.utils.warn("Overwriting existing registered function: " + n), e.label = n, t.Pipeline.registeredFunctions[e.label] = e }, t.Pipeline.warnIfFunctionNotRegistered = function (e) { var n = e.label && e.label in this.registeredFunctions; n || t.utils.warn("Function is not registered with pipeline. This may cause problems when serialising the index.\n", e) }, t.Pipeline.load = function (e) { var n = new t.Pipeline; return e.forEach(function (e) { var i = t.Pipeline.registeredFunctions[e]; if (!i) throw new Error("Cannot load un-registered function: " + e); n.add(i) }), n }, t.Pipeline.prototype.add = function () { var e = Array.prototype.slice.call(arguments); e.forEach(function (e) { t.Pipeline.warnIfFunctionNotRegistered(e), this._stack.push(e) }, this) }, t.Pipeline.prototype.after = function (e, n) { t.Pipeline.warnIfFunctionNotRegistered(n); var i = this._stack.indexOf(e); if (-1 == i) throw new Error("Cannot find existingFn"); i += 1, this._stack.splice(i, 0, n) }, t.Pipeline.prototype.before = function (e, n) { t.Pipeline.warnIfFunctionNotRegistered(n); var i = this._stack.indexOf(e); if (-1 == i) throw new Error("Cannot find existingFn"); this._stack.splice(i, 0, n) }, t.Pipeline.prototype.remove = function (t) { var e = this._stack.indexOf(t); -1 != e && this._stack.splice(e, 1) }, t.Pipeline.prototype.run = function (t) { for (var e = [], n = t.length, i = this._stack.length, r = 0; n > r; r++) { for (var o = t[r], s = 0; i > s && (o = this._stack[s](o, r, t), void 0 !== o && "" !== o); s++); void 0 !== o && "" !== o && e.push(o) } return e }, t.Pipeline.prototype.reset = function () { this._stack = [] }, t.Pipeline.prototype.toJSON = function () { return this._stack.map(function (e) { return t.Pipeline.warnIfFunctionNotRegistered(e), e.label }) }, t.Vector = function () { this._magnitude = null, this.list = void 0, this.length = 0 }, t.Vector.Node = function (t, e, n) { this.idx = t, this.val = e, this.next = n }, t.Vector.prototype.insert = function (e, n) { this.
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
/*!
|
|||
|
* Snowball JavaScript Library v0.3
|
|||
|
* http://code.google.com/p/urim/
|
|||
|
* http://snowball.tartarus.org/
|
|||
|
*
|
|||
|
* Copyright 2010, Oleg Mazko
|
|||
|
* http://www.mozilla.org/MPL/
|
|||
|
*/
|
|||
|
|
|||
|
/**
|
|||
|
* export the module via AMD, CommonJS or as a browser global
|
|||
|
* Export code from https://github.com/umdjs/umd/blob/master/returnExports.js
|
|||
|
*/
|
|||
|
; (function (root, factory) {
|
|||
|
if (typeof define === 'function' && define.amd) {
|
|||
|
// AMD. Register as an anonymous module.
|
|||
|
define(factory)
|
|||
|
} else if (typeof exports === 'object') {
|
|||
|
/**
|
|||
|
* Node. Does not work with strict CommonJS, but
|
|||
|
* only CommonJS-like environments that support module.exports,
|
|||
|
* like Node.
|
|||
|
*/
|
|||
|
module.exports = factory()
|
|||
|
} else {
|
|||
|
// Browser globals (root is window)
|
|||
|
factory()(root.lunr);
|
|||
|
}
|
|||
|
}(this, function () {
|
|||
|
/**
|
|||
|
* Just return a value to define the module export.
|
|||
|
* This example returns an object, but the module
|
|||
|
* can return a function as the exported value.
|
|||
|
*/
|
|||
|
return function (lunr) {
|
|||
|
/* provides utilities for the included stemmers */
|
|||
|
lunr.stemmerSupport = {
|
|||
|
Among: function (s, substring_i, result, method) {
|
|||
|
this.toCharArray = function (s) {
|
|||
|
var sLength = s.length, charArr = new Array(sLength);
|
|||
|
for (var i = 0; i < sLength; i++)
|
|||
|
charArr[i] = s.charCodeAt(i);
|
|||
|
return charArr;
|
|||
|
};
|
|||
|
|
|||
|
if ((!s && s != "") || (!substring_i && (substring_i != 0)) || !result)
|
|||
|
throw ("Bad Among initialisation: s:" + s + ", substring_i: "
|
|||
|
+ substring_i + ", result: " + result);
|
|||
|
this.s_size = s.length;
|
|||
|
this.s = this.toCharArray(s);
|
|||
|
this.substring_i = substring_i;
|
|||
|
this.result = result;
|
|||
|
this.method = method;
|
|||
|
},
|
|||
|
SnowballProgram: function () {
|
|||
|
var current;
|
|||
|
return {
|
|||
|
bra: 0,
|
|||
|
ket: 0,
|
|||
|
limit: 0,
|
|||
|
cursor: 0,
|
|||
|
limit_backward: 0,
|
|||
|
setCurrent: function (word) {
|
|||
|
current = word;
|
|||
|
this.cursor = 0;
|
|||
|
this.limit = word.length;
|
|||
|
this.limit_backward = 0;
|
|||
|
this.bra = this.cursor;
|
|||
|
this.ket = this.limit;
|
|||
|
},
|
|||
|
getCurrent: function () {
|
|||
|
var result = current;
|
|||
|
current = null;
|
|||
|
return result;
|
|||
|
},
|
|||
|
in_grouping: function (s, min, max) {
|
|||
|
if (this.cursor < this.limit) {
|
|||
|
var ch = current.charCodeAt(this.cursor);
|
|||
|
if (ch <= max && ch >= min) {
|
|||
|
ch -= min;
|
|||
|
if (s[ch >> 3] & (0X1 << (ch & 0X7))) {
|
|||
|
this.cursor++;
|
|||
|
return true;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
return false;
|
|||
|
},
|
|||
|
in_grouping_b: function (s, min, max) {
|
|||
|
if (this.cursor > this.limit_backward) {
|
|||
|
var ch = current.charCodeAt(this.cursor - 1);
|
|||
|
if (ch <= max && ch >= min) {
|
|||
|
ch -= min;
|
|||
|
if (s[ch >> 3] & (0X1 << (ch & 0X7))) {
|
|||
|
this.cursor--;
|
|||
|
return true;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
return false;
|
|||
|
},
|
|||
|
out_grouping: function (s, min, max) {
|
|||
|
if (this.cursor < this.limit) {
|
|||
|
var ch = current.charCodeAt(this.cursor);
|
|||
|
if (ch > max || ch < min) {
|
|||
|
this.cursor++;
|
|||
|
return true;
|
|||
|
}
|
|||
|
ch -= min;
|
|||
|
if (!(s[ch >> 3] & (0X1 << (ch & 0X7)))) {
|
|||
|
this.cursor++;
|
|||
|
return true;
|
|||
|
}
|
|||
|
}
|
|||
|
return false;
|
|||
|
},
|
|||
|
out_grouping_b: function (s, min, max) {
|
|||
|
if (this.cursor > this.limit_backward) {
|
|||
|
var ch = current.charCodeAt(this.cursor - 1);
|
|||
|
if (ch > max || ch < min) {
|
|||
|
this.cursor--;
|
|||
|
return true;
|
|||
|
}
|
|||
|
ch -= min;
|
|||
|
if (!(s[ch >> 3] & (0X1 << (ch & 0X7)))) {
|
|||
|
this.cursor--;
|
|||
|
return true;
|
|||
|
}
|
|||
|
}
|
|||
|
return false;
|
|||
|
},
|
|||
|
eq_s: function (s_size, s) {
|
|||
|
if (this.limit - this.cursor < s_size)
|
|||
|
return false;
|
|||
|
for (var i = 0; i < s_size; i++)
|
|||
|
if (current.charCodeAt(this.cursor + i) != s.charCodeAt(i))
|
|||
|
return false;
|
|||
|
this.cursor += s_size;
|
|||
|
return true;
|
|||
|
},
|
|||
|
eq_s_b: function (s_size, s) {
|
|||
|
if (this.cursor - this.limit_backward < s_size)
|
|||
|
return false;
|
|||
|
for (var i = 0; i < s_size; i++)
|
|||
|
if (current.charCodeAt(this.cursor - s_size + i) != s
|
|||
|
.charCodeAt(i))
|
|||
|
return false;
|
|||
|
this.cursor -= s_size;
|
|||
|
return true;
|
|||
|
},
|
|||
|
find_among: function (v, v_size) {
|
|||
|
var i = 0, j = v_size, c = this.cursor, l = this.limit, common_i = 0, common_j = 0, first_key_inspected = false;
|
|||
|
while (true) {
|
|||
|
var k = i + ((j - i) >> 1), diff = 0, common = common_i < common_j
|
|||
|
? common_i
|
|||
|
: common_j, w = v[k];
|
|||
|
for (var i2 = common; i2 < w.s_size; i2++) {
|
|||
|
if (c + common == l) {
|
|||
|
diff = -1;
|
|||
|
break;
|
|||
|
}
|
|||
|
diff = current.charCodeAt(c + common) - w.s[i2];
|
|||
|
if (diff)
|
|||
|
break;
|
|||
|
common++;
|
|||
|
}
|
|||
|
if (diff < 0) {
|
|||
|
j = k;
|
|||
|
common_j = common;
|
|||
|
} else {
|
|||
|
i = k;
|
|||
|
common_i = common;
|
|||
|
}
|
|||
|
if (j - i <= 1) {
|
|||
|
if (i > 0 || j == i || first_key_inspected)
|
|||
|
break;
|
|||
|
first_key_inspected = true;
|
|||
|
}
|
|||
|
}
|
|||
|
while (true) {
|
|||
|
var w = v[i];
|
|||
|
if (common_i >= w.s_size) {
|
|||
|
this.cursor = c + w.s_size;
|
|||
|
if (!w.method)
|
|||
|
return w.result;
|
|||
|
var res = w.method();
|
|||
|
this.cursor = c + w.s_size;
|
|||
|
if (res)
|
|||
|
return w.result;
|
|||
|
}
|
|||
|
i = w.substring_i;
|
|||
|
if (i < 0)
|
|||
|
return 0;
|
|||
|
}
|
|||
|
},
|
|||
|
find_among_b: function (v, v_size) {
|
|||
|
var i = 0, j = v_size, c = this.cursor, lb = this.limit_backward, common_i = 0, common_j = 0, first_key_inspected = false;
|
|||
|
while (true) {
|
|||
|
var k = i + ((j - i) >> 1), diff = 0, common = common_i < common_j
|
|||
|
? common_i
|
|||
|
: common_j, w = v[k];
|
|||
|
for (var i2 = w.s_size - 1 - common; i2 >= 0; i2--) {
|
|||
|
if (c - common == lb) {
|
|||
|
diff = -1;
|
|||
|
break;
|
|||
|
}
|
|||
|
diff = current.charCodeAt(c - 1 - common) - w.s[i2];
|
|||
|
if (diff)
|
|||
|
break;
|
|||
|
common++;
|
|||
|
}
|
|||
|
if (diff < 0) {
|
|||
|
j = k;
|
|||
|
common_j = common;
|
|||
|
} else {
|
|||
|
i = k;
|
|||
|
common_i = common;
|
|||
|
}
|
|||
|
if (j - i <= 1) {
|
|||
|
if (i > 0 || j == i || first_key_inspected)
|
|||
|
break;
|
|||
|
first_key_inspected = true;
|
|||
|
}
|
|||
|
}
|
|||
|
while (true) {
|
|||
|
var w = v[i];
|
|||
|
if (common_i >= w.s_size) {
|
|||
|
this.cursor = c - w.s_size;
|
|||
|
if (!w.method)
|
|||
|
return w.result;
|
|||
|
var res = w.method();
|
|||
|
this.cursor = c - w.s_size;
|
|||
|
if (res)
|
|||
|
return w.result;
|
|||
|
}
|
|||
|
i = w.substring_i;
|
|||
|
if (i < 0)
|
|||
|
return 0;
|
|||
|
}
|
|||
|
},
|
|||
|
replace_s: function (c_bra, c_ket, s) {
|
|||
|
var adjustment = s.length - (c_ket - c_bra), left = current
|
|||
|
.substring(0, c_bra), right = current.substring(c_ket);
|
|||
|
current = left + s + right;
|
|||
|
this.limit += adjustment;
|
|||
|
if (this.cursor >= c_ket)
|
|||
|
this.cursor += adjustment;
|
|||
|
else if (this.cursor > c_bra)
|
|||
|
this.cursor = c_bra;
|
|||
|
return adjustment;
|
|||
|
},
|
|||
|
slice_check: function () {
|
|||
|
if (this.bra < 0 || this.bra > this.ket || this.ket > this.limit
|
|||
|
|| this.limit > current.length)
|
|||
|
throw ("faulty slice operation");
|
|||
|
},
|
|||
|
slice_from: function (s) {
|
|||
|
this.slice_check();
|
|||
|
this.replace_s(this.bra, this.ket, s);
|
|||
|
},
|
|||
|
slice_del: function () {
|
|||
|
this.slice_from("");
|
|||
|
},
|
|||
|
insert: function (c_bra, c_ket, s) {
|
|||
|
var adjustment = this.replace_s(c_bra, c_ket, s);
|
|||
|
if (c_bra <= this.bra)
|
|||
|
this.bra += adjustment;
|
|||
|
if (c_bra <= this.ket)
|
|||
|
this.ket += adjustment;
|
|||
|
},
|
|||
|
slice_to: function () {
|
|||
|
this.slice_check();
|
|||
|
return current.substring(this.bra, this.ket);
|
|||
|
},
|
|||
|
eq_v_b: function (s) {
|
|||
|
return this.eq_s_b(s.length, s);
|
|||
|
}
|
|||
|
};
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
lunr.trimmerSupport = {
|
|||
|
generateTrimmer: function (wordCharacters) {
|
|||
|
var startRegex = new RegExp("^[^" + wordCharacters + "]+")
|
|||
|
var endRegex = new RegExp("[^" + wordCharacters + "]+$")
|
|||
|
|
|||
|
return function (token) {
|
|||
|
// for lunr version 2
|
|||
|
if (typeof token.update === "function") {
|
|||
|
return token.update(function (s) {
|
|||
|
return s
|
|||
|
.replace(startRegex, '')
|
|||
|
.replace(endRegex, '');
|
|||
|
})
|
|||
|
} else { // for lunr version 1
|
|||
|
return token
|
|||
|
.replace(startRegex, '')
|
|||
|
.replace(endRegex, '');
|
|||
|
}
|
|||
|
};
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}));
|
|||
|
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
/*!
|
|||
|
* Lunr languages, `Chinese` language
|
|||
|
* https://github.com/MihaiValentin/lunr-languages
|
|||
|
*
|
|||
|
* Copyright 2019, Felix Lian (repairearth)
|
|||
|
* http://www.mozilla.org/MPL/
|
|||
|
*/
|
|||
|
/*!
|
|||
|
* based on
|
|||
|
* Snowball zhvaScript Library v0.3
|
|||
|
* http://code.google.com/p/urim/
|
|||
|
* http://snowball.tartarus.org/
|
|||
|
*
|
|||
|
* Copyright 2010, Oleg Mazko
|
|||
|
* http://www.mozilla.org/MPL/
|
|||
|
*/
|
|||
|
|
|||
|
/**
|
|||
|
* export the module via AMD, CommonJS or as a browser global
|
|||
|
* Export code from https://github.com/umdjs/umd/blob/master/returnExports.js
|
|||
|
*/
|
|||
|
;
|
|||
|
(function (root, factory) {
|
|||
|
if (typeof define === 'function' && define.amd) {
|
|||
|
// AMD. Register as an anonymous module.
|
|||
|
define(factory)
|
|||
|
} else if (typeof exports === 'object') {
|
|||
|
/**
|
|||
|
* Node. Does not work with strict CommonJS, but
|
|||
|
* only CommonJS-like environments that support module.exports,
|
|||
|
* like Node.
|
|||
|
*/
|
|||
|
// module.exports = factory(require('@node-rs/jieba'))
|
|||
|
module.exports = factory()
|
|||
|
} else {
|
|||
|
// Browser globals (root is window)
|
|||
|
factory()(root.lunr);
|
|||
|
}
|
|||
|
}(this, function (Segment) {
|
|||
|
/**
|
|||
|
* Just return a value to define the module export.
|
|||
|
* This example returns an object, but the module
|
|||
|
* can return a function as the exported value.
|
|||
|
*/
|
|||
|
return function (lunr) {
|
|||
|
/* throw error if lunr is not yet included */
|
|||
|
if ('undefined' === typeof lunr) {
|
|||
|
throw new Error('Lunr is not present. Please include / require Lunr before this script.');
|
|||
|
}
|
|||
|
|
|||
|
/* throw error if lunr stemmer support is not yet included */
|
|||
|
if ('undefined' === typeof lunr.stemmerSupport) {
|
|||
|
throw new Error('Lunr stemmer support is not present. Please include / require Lunr stemmer support before this script.');
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
Chinese tokenization is trickier, since it does not
|
|||
|
take into account spaces.
|
|||
|
Since the tokenization function is represented different
|
|||
|
internally for each of the Lunr versions, this had to be done
|
|||
|
in order to try to try to pick the best way of doing this based
|
|||
|
on the Lunr version
|
|||
|
*/
|
|||
|
var isLunr2 = lunr.version[0] == "2";
|
|||
|
|
|||
|
/* register specific locale function */
|
|||
|
lunr.zh = function () {
|
|||
|
this.pipeline.reset();
|
|||
|
this.pipeline.add(
|
|||
|
lunr.zh.trimmer,
|
|||
|
lunr.zh.stopWordFilter,
|
|||
|
lunr.zh.stemmer
|
|||
|
);
|
|||
|
|
|||
|
// change the tokenizer for Chinese one
|
|||
|
if (isLunr2) { // for lunr version 2.0.0
|
|||
|
this.tokenizer = lunr.zh.tokenizer;
|
|||
|
} else {
|
|||
|
if (lunr.tokenizer) { // for lunr version 0.6.0
|
|||
|
lunr.tokenizer = lunr.zh.tokenizer;
|
|||
|
}
|
|||
|
if (this.tokenizerFn) { // for lunr version 0.7.0 -> 1.0.0
|
|||
|
this.tokenizerFn = lunr.zh.tokenizer;
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
lunr.zh.tokenizer = function (obj) {
|
|||
|
if (!arguments.length || obj == null || obj == undefined) return []
|
|||
|
if (Array.isArray(obj)) return obj.map(function (t) {
|
|||
|
return isLunr2 ? new lunr.Token(t.toLowerCase()) : t.toLowerCase()
|
|||
|
})
|
|||
|
|
|||
|
var tokens = [];
|
|||
|
try {
|
|||
|
var segmenter = new Intl.Segmenter('zh', { granularity: 'word' });
|
|||
|
var str = obj.toString().trim().toLowerCase();
|
|||
|
var segments = segmenter.segment(str)
|
|||
|
for (seg of segments) {
|
|||
|
if (seg.isWordLike) { tokens = tokens.concat(seg.segment) }
|
|||
|
}
|
|||
|
} catch (error) {
|
|||
|
console.error(error);
|
|||
|
}
|
|||
|
|
|||
|
tokens = tokens.filter(function (token) {
|
|||
|
return !!token;
|
|||
|
});
|
|||
|
|
|||
|
var fromIndex = 0
|
|||
|
|
|||
|
return tokens.map(function (token, index) {
|
|||
|
if (isLunr2) {
|
|||
|
var start = str.indexOf(token, fromIndex)
|
|||
|
|
|||
|
var tokenMetadata = {}
|
|||
|
tokenMetadata["position"] = [start, token.length]
|
|||
|
tokenMetadata["index"] = index
|
|||
|
|
|||
|
fromIndex = start
|
|||
|
|
|||
|
return new lunr.Token(token, tokenMetadata);
|
|||
|
} else {
|
|||
|
return token
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/* lunr trimmer function */
|
|||
|
lunr.zh.wordCharacters = "\\w\u4e00-\u9fa5";
|
|||
|
lunr.zh.trimmer = lunr.trimmerSupport.generateTrimmer(lunr.zh.wordCharacters);
|
|||
|
lunr.Pipeline.registerFunction(lunr.zh.trimmer, 'trimmer-zh');
|
|||
|
|
|||
|
/* lunr stemmer function */
|
|||
|
lunr.zh.stemmer = (function () {
|
|||
|
|
|||
|
/* TODO Chinese stemmer */
|
|||
|
return function (word) {
|
|||
|
return word;
|
|||
|
}
|
|||
|
})();
|
|||
|
lunr.Pipeline.registerFunction(lunr.zh.stemmer, 'stemmer-zh');
|
|||
|
|
|||
|
/* lunr stop word filter. see https://www.ranks.nl/stopwords/chinese-stopwords */
|
|||
|
lunr.zh.stopWordFilter = lunr.generateStopWordFilter(
|
|||
|
'的 一 不 在 人 有 是 为 以 于 上 他 而 后 之 来 及 了 因 下 可 到 由 这 与 也 此 但 并 个 其 已 无 小 我 们 起 最 再 今 去 好 只 又 或 很 亦 某 把 那 你 乃 它 吧 被 比 别 趁 当 从 到 得 打 凡 儿 尔 该 各 给 跟 和 何 还 即 几 既 看 据 距 靠 啦 了 另 么 每 们 嘛 拿 哪 那 您 凭 且 却 让 仍 啥 如 若 使 谁 虽 随 同 所 她 哇 嗡 往 哪 些 向 沿 哟 用 于 咱 则 怎 曾 至 致 着 诸 自'.split(' '));
|
|||
|
lunr.Pipeline.registerFunction(lunr.zh.stopWordFilter, 'stopWordFilter-zh');
|
|||
|
};
|
|||
|
}))
|
|||
|
</script>
|
|||
|
|
|||
|
<script>
|
|||
|
!function (n) { "use strict"; function t(n, t) { var r = (65535 & n) + (65535 & t); return (n >> 16) + (t >> 16) + (r >> 16) << 16 | 65535 & r } function r(n, t) { return n << t | n >>> 32 - t } function e(n, e, o, u, c, f) { return t(r(t(t(e, n), t(u, f)), c), o) } function o(n, t, r, o, u, c, f) { return e(t & r | ~t & o, n, t, u, c, f) } function u(n, t, r, o, u, c, f) { return e(t & o | r & ~o, n, t, u, c, f) } function c(n, t, r, o, u, c, f) { return e(t ^ r ^ o, n, t, u, c, f) } function f(n, t, r, o, u, c, f) { return e(r ^ (t | ~o), n, t, u, c, f) } function i(n, r) { n[r >> 5] |= 128 << r % 32, n[14 + (r + 64 >>> 9 << 4)] = r; var e, i, a, d, h, l = 1732584193, g = -271733879, v = -1732584194, m = 271733878; for (e = 0; e < n.length; e += 16)i = l, a = g, d = v, h = m, g = f(g = f(g = f(g = f(g = c(g = c(g = c(g = c(g = u(g = u(g = u(g = u(g = o(g = o(g = o(g = o(g, v = o(v, m = o(m, l = o(l, g, v, m, n[e], 7, -680876936), g, v, n[e + 1], 12, -389564586), l, g, n[e + 2], 17, 606105819), m, l, n[e + 3], 22, -1044525330), v = o(v, m = o(m, l = o(l, g, v, m, n[e + 4], 7, -176418897), g, v, n[e + 5], 12, 1200080426), l, g, n[e + 6], 17, -1473231341), m, l, n[e + 7], 22, -45705983), v = o(v, m = o(m, l = o(l, g, v, m, n[e + 8], 7, 1770035416), g, v, n[e + 9], 12, -1958414417), l, g, n[e + 10], 17, -42063), m, l, n[e + 11], 22, -1990404162), v = o(v, m = o(m, l = o(l, g, v, m, n[e + 12], 7, 1804603682), g, v, n[e + 13], 12, -40341101), l, g, n[e + 14], 17, -1502002290), m, l, n[e + 15], 22, 1236535329), v = u(v, m = u(m, l = u(l, g, v, m, n[e + 1], 5, -165796510), g, v, n[e + 6], 9, -1069501632), l, g, n[e + 11], 14, 643717713), m, l, n[e], 20, -373897302), v = u(v, m = u(m, l = u(l, g, v, m, n[e + 5], 5, -701558691), g, v, n[e + 10], 9, 38016083), l, g, n[e + 15], 14, -660478335), m, l, n[e + 4], 20, -405537848), v = u(v, m = u(m, l = u(l, g, v, m, n[e + 9], 5, 568446438), g, v, n[e + 14], 9, -1019803690), l, g, n[e + 3], 14, -187363961), m, l, n[e + 8], 20, 1163531501), v = u(v, m = u(m, l = u(l, g, v, m, n[e + 13], 5, -1444681467), g, v, n[e + 2], 9, -51403784), l, g, n[e + 7], 14, 1735328473), m, l, n[e + 12], 20, -1926607734), v = c(v, m = c(m, l = c(l, g, v, m, n[e + 5], 4, -378558), g, v, n[e + 8], 11, -2022574463), l, g, n[e + 11], 16, 1839030562), m, l, n[e + 14], 23, -35309556), v = c(v, m = c(m, l = c(l, g, v, m, n[e + 1], 4, -1530992060), g, v, n[e + 4], 11, 1272893353), l, g, n[e + 7], 16, -155497632), m, l, n[e + 10], 23, -1094730640), v = c(v, m = c(m, l = c(l, g, v, m, n[e + 13], 4, 681279174), g, v, n[e], 11, -358537222), l, g, n[e + 3], 16, -722521979), m, l, n[e + 6], 23, 76029189), v = c(v, m = c(m, l = c(l, g, v, m, n[e + 9], 4, -640364487), g, v, n[e + 12], 11, -421815835), l, g, n[e + 15], 16, 530742520), m, l, n[e + 2], 23, -995338651), v = f(v, m = f(m, l = f(l, g, v, m, n[e], 6, -198630844), g, v, n[e + 7], 10, 1126891415), l, g, n[e + 14], 15, -1416354905), m, l, n[e + 5], 21, -57434055), v = f(v, m = f(m, l = f(l, g, v, m, n[e + 12], 6, 1700485571), g, v, n[e + 3], 10, -1894986606), l, g, n[e + 10], 15, -1051523), m, l, n[e + 1], 21, -2054922799), v = f(v, m = f(m, l = f(l, g, v, m, n[e + 8], 6, 1873313359), g, v, n[e + 15], 10, -30611744), l, g, n[e + 6], 15, -1560198380), m, l, n[e + 13], 21, 1309151649), v = f(v, m = f(m, l = f(l, g, v, m, n[e + 4], 6, -145523070), g, v, n[e + 11], 10, -1120210379), l, g, n[e + 2], 15, 718787259), m, l, n[e + 9], 21, -343485551), l = t(l, i), g = t(g, a), v = t(v, d), m = t(m, h); return [l, g, v, m] } function a(n) { var t, r = "", e = 32 * n.length; for (t = 0; t < e; t += 8)r += String.fromCharCode(n[t >> 5] >>> t % 32 & 255); return r } function d(n) { var t, r = []; for (r[(n.length >> 2) - 1] = void 0, t = 0; t < r.length; t += 1)r[t] = 0; var e = 8 * n.length; for (t = 0; t < e; t += 8)r[t >> 5] |= (255 & n.charCodeAt(t / 8)) << t % 32; return r } function h(n) { return a(i(d(n), 8 * n.length)) } function l(n, t) { var r, e, o = d(n), u = [], c = []; for (u[15] = c[15] = void 0, o.length > 16 && (o = i(o, 8 * n.length)), r = 0; r < 16; r
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
/* flatpickr v4.6.13,, @license MIT */
|
|||
|
!function (e, n) { "object" == typeof exports && "undefined" != typeof module ? module.exports = n() : "function" == typeof define && define.amd ? define(n) : (e = "undefined" != typeof globalThis ? globalThis : e || self).flatpickr = n() }(this, (function () { "use strict"; var e = function () { return (e = Object.assign || function (e) { for (var n, t = 1, a = arguments.length; t < a; t++)for (var i in n = arguments[t]) Object.prototype.hasOwnProperty.call(n, i) && (e[i] = n[i]); return e }).apply(this, arguments) }; function n() { for (var e = 0, n = 0, t = arguments.length; n < t; n++)e += arguments[n].length; var a = Array(e), i = 0; for (n = 0; n < t; n++)for (var o = arguments[n], r = 0, l = o.length; r < l; r++, i++)a[i] = o[r]; return a } var t = ["onChange", "onClose", "onDayCreate", "onDestroy", "onKeyDown", "onMonthChange", "onOpen", "onParseConfig", "onReady", "onValueUpdate", "onYearChange", "onPreCalendarPosition"], a = { _disable: [], allowInput: !1, allowInvalidPreload: !1, altFormat: "F j, Y", altInput: !1, altInputClass: "form-control input", animate: "object" == typeof window && -1 === window.navigator.userAgent.indexOf("MSIE"), ariaDateFormat: "F j, Y", autoFillDefaultTime: !0, clickOpens: !0, closeOnSelect: !0, conjunction: ", ", dateFormat: "Y-m-d", defaultHour: 12, defaultMinute: 0, defaultSeconds: 0, disable: [], disableMobile: !1, enableSeconds: !1, enableTime: !1, errorHandler: function (e) { return "undefined" != typeof console && console.warn(e) }, getWeek: function (e) { var n = new Date(e.getTime()); n.setHours(0, 0, 0, 0), n.setDate(n.getDate() + 3 - (n.getDay() + 6) % 7); var t = new Date(n.getFullYear(), 0, 4); return 1 + Math.round(((n.getTime() - t.getTime()) / 864e5 - 3 + (t.getDay() + 6) % 7) / 7) }, hourIncrement: 1, ignoredFocusElements: [], inline: !1, locale: "default", minuteIncrement: 5, mode: "single", monthSelectorType: "dropdown", nextArrow: "<svg version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' viewBox='0 0 17 17'><g></g><path d='M13.207 8.472l-7.854 7.854-0.707-0.707 7.146-7.146-7.146-7.148 0.707-0.707 7.854 7.854z' /></svg>", noCalendar: !1, now: new Date, onChange: [], onClose: [], onDayCreate: [], onDestroy: [], onKeyDown: [], onMonthChange: [], onOpen: [], onParseConfig: [], onReady: [], onValueUpdate: [], onYearChange: [], onPreCalendarPosition: [], plugins: [], position: "auto", positionElement: void 0, prevArrow: "<svg version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' viewBox='0 0 17 17'><g></g><path d='M5.207 8.471l7.146 7.147-0.707 0.707-7.853-7.854 7.854-7.853 0.707 0.707-7.147 7.146z' /></svg>", shorthandCurrentMonth: !1, showMonths: 1, static: !1, time_24hr: !1, weekNumbers: !1, wrap: !1 }, i = { weekdays: { shorthand: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], longhand: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"] }, months: { shorthand: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], longhand: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"] }, daysInMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31], firstDayOfWeek: 0, ordinal: function (e) { var n = e % 100; if (n > 3 && n < 21) return "th"; switch (n % 10) { case 1: return "st"; case 2: return "nd"; case 3: return "rd"; default: return "th" } }, rangeSeparator: " to ", weekAbbreviation: "Wk", scrollTitle: "Scroll to increment", toggleTitle: "Click to toggle", amPM: ["AM", "PM"], yearAriaLabel: "Year", monthAriaLabel: "Month", hourAriaLabel: "Hour", minuteAriaLabel: "Minute", time_24hr: !1 }, o = function (e, n) { return void 0 === n && (n = 2), ("000" + e).slice(-1 * n) }, r = function (e) { return !0 === e ? 1 : 0 }; function l(e, n) { var t; return function () { var a = this, i = arguments; clearTimeout(t), t = setTimeout((function () { return e.apply(a, i) }), n) } } var c = function (e) { return e instanceof Array ? e : [e] }; function s(e, n, t) { if (!
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
const loader = document.getElementById("loader");
|
|||
|
const content = document.getElementById("content");
|
|||
|
const gender = ['未知', '男', '女'];
|
|||
|
const wxid={{wxid}};
|
|||
|
const isChatroom = wxid.endsWith("@chatroom");
|
|||
|
const avatarPaths = {{avatarPaths}};
|
|||
|
const avatarUrls = {{avatarUrls}};
|
|||
|
const chatMessages = /*注意看这是分割线*/;
|
|||
|
var timelineData = {{timelineData}};
|
|||
|
var PageTimeline = {{PageTimeline}};
|
|||
|
var server_id_Page = {{server_id_Page}};
|
|||
|
var server_id_Idx = {{server_id_Idx}};
|
|||
|
const dateDataMap = {{dateDataMap}};
|
|||
|
const AllIndex = {{AllIndex}};
|
|||
|
const ImageIndex = {{ImageIndex}};
|
|||
|
const FileIndex = {{FileIndex}};
|
|||
|
const LinkIndex = {{LinkIndex}};
|
|||
|
const MusicIndex = {{MusicIndex}};
|
|||
|
const TransferIndex = {{TransferIndex}};
|
|||
|
const MiniProgramIndex = {{MiniProgramIndex}};
|
|||
|
const VideoNumberIndex = {{VideoNumberIndex}};
|
|||
|
</script>
|
|||
|
<script type="text/javascript">
|
|||
|
window._AMapSecurityConfig = {
|
|||
|
serviceHost: "https://api.memotrace.cn/_AMapService",
|
|||
|
|
|||
|
};
|
|||
|
</script>
|
|||
|
<script type="text/javascript"
|
|||
|
src="https://webapi.amap.com/maps?v=2.0&key=b999f45a5b06a184518f744681048368"></script>
|
|||
|
<script>
|
|||
|
// const markerContent = `<div class="custom-content-marker">
|
|||
|
// <img src="./icon/location.png">`
|
|||
|
var MapID = {};
|
|||
|
</script>
|
|||
|
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/1.10.0/jquery.min.js"></script>
|
|||
|
<script>
|
|||
|
class MessageType {
|
|||
|
static Unknown = -1;
|
|||
|
static Text = "1";
|
|||
|
static Image = "3";
|
|||
|
static Audio = "34";
|
|||
|
static BusinessCard = "42";
|
|||
|
static Video = "43";
|
|||
|
static Emoji = "47";
|
|||
|
static Position = "48";
|
|||
|
static Voip = "50";
|
|||
|
static OpenIMBCard = "66";
|
|||
|
static System = "10000";
|
|||
|
static File = "25769803825"; // Use BigInt for large numbers
|
|||
|
static LinkMessage = 21474836529n;
|
|||
|
static LinkMessage2 = 292057776177n;
|
|||
|
static LinkMessage3 = 12884901937n;
|
|||
|
static LinkMessage4 = 4294967345n;
|
|||
|
static LinkMessage5 = 326417514545n;
|
|||
|
static LinkMessage6 = 17179869233n;
|
|||
|
static RedEnvelope = 8594229559345n;
|
|||
|
static Transfer = 8589934592049n;
|
|||
|
static Quote = 244813135921n;
|
|||
|
static MergedMessages = 81604378673n;
|
|||
|
static Applet = "141733920817";
|
|||
|
static Applet2 = 154618822705n;
|
|||
|
// static Applet3 = 17179869233n; // Uncomment if needed
|
|||
|
static WeChatVideo = "219043332145";
|
|||
|
static Music = "12884901937";
|
|||
|
static FavNote = 103079215153n;
|
|||
|
static Pat = 266287972401n;
|
|||
|
}
|
|||
|
|
|||
|
const menuToggle = document.getElementById("menu-toggle");
|
|||
|
const navbarNav = document.getElementById("topnavbar-nav");
|
|||
|
|
|||
|
menuToggle.addEventListener("click", () => {
|
|||
|
navbarNav.classList.toggle("show");
|
|||
|
});
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
function renderPage(page) {
|
|||
|
if (ChatMsgIndex.length !== 0) {
|
|||
|
const currentYear = PageTimeline[page]['year'];
|
|||
|
const currentMonth = PageTimeline[page]['month'];
|
|||
|
const monthName = currentMonth < 10 ? '0' + currentMonth : currentMonth;
|
|||
|
// console.log(monthName+'月');
|
|||
|
toggleMonthsDisplay(currentYear);
|
|||
|
const yearIdElement = document.getElementById(currentYear + 'year');
|
|||
|
const monthElements = yearIdElement.querySelectorAll('.timeline-item-month');
|
|||
|
let targetMonthElement = null;
|
|||
|
monthElements.forEach(monthElement => {
|
|||
|
const monthText = monthElement.querySelector('.timeline-right').textContent; // 获取月份文本内容
|
|||
|
if (monthText.includes(String(monthName) + '月')) { // 检查是否包含指定的月份
|
|||
|
targetMonthElement = monthElement; // 如果包含,则将该月份元素赋值给targetMonthElement
|
|||
|
}
|
|||
|
});
|
|||
|
// console.log(targetMonthElement);
|
|||
|
toggleCurrentMonthDisplay(targetMonthElement);
|
|||
|
}
|
|||
|
|
|||
|
const totalPages = Math.ceil(ChatMsgIndex.length / itemsPerPage);
|
|||
|
// document.getElementById('curPage').innerHTML = currentPage;
|
|||
|
document.getElementById('gotoPage').value = currentPage;
|
|||
|
document.getElementById('maxPage').innerHTML = totalPages;
|
|||
|
const container = document.getElementById('chat-container');
|
|||
|
const OnePageMessage = document.createElement('div');
|
|||
|
|
|||
|
// 计算当前页应该显示的元素范围
|
|||
|
const startIndex = (page - 1) * itemsPerPage;
|
|||
|
const endIndex = startIndex + itemsPerPage;
|
|||
|
|
|||
|
var newMapID = {};
|
|||
|
|
|||
|
function checkImageExists(url, callback) {
|
|||
|
var img = new Image();
|
|||
|
img.onload = function () {
|
|||
|
callback(true); // 图片存在
|
|||
|
};
|
|||
|
img.onerror = function () {
|
|||
|
callback(false); // 图片不存在
|
|||
|
};
|
|||
|
img.src = url;
|
|||
|
}
|
|||
|
|
|||
|
// 工具类函数
|
|||
|
function replaceEmoji(text) {
|
|||
|
if (!text) {
|
|||
|
return '';
|
|||
|
}
|
|||
|
|
|||
|
// 定义替换规则
|
|||
|
var emoji_set = new Set(['右哼哼', '礼物', '傲慢', '打脸', '流泪', '失望', '猪头', '福', '抱拳', '憨笑', '拳头', '抓狂',
|
|||
|
'闭嘴', '白眼', '嘘', '害羞', '无语', '捂脸', '弱', '骷髅', '耶', '吐舌', '爱心', '吃瓜', '發', '囧',
|
|||
|
'再见', '睡', '恐惧', '撇嘴', '尴尬', '烟花', '咖啡', '裂开', '勾引', '亲亲', '阴险', '偷笑', '得意',
|
|||
|
'凋谢', '爆竹', '玫瑰', '翻白眼', 'Emm', '旺柴', '便便', '蛋糕', '天啊', '让我看看', '嘿哈', '难过',
|
|||
|
'发呆', '難受', '庆祝', '好的', '发抖', '心碎', '抠鼻', '机智', '炸弹', '擦汗', '疑问', '脸红',
|
|||
|
'呲牙', '委屈', '汗', '苦涩', '破涕为笑', '胜利', '菜刀', '惊恐', '太阳', 'OK', '悠闲', '合十',
|
|||
|
'快哭了', '鼓掌', '拥抱', '加油加油', '转圈', 'Whimper', '坏笑', '笑脸', '生病', '吐', '调皮',
|
|||
|
'叹气', '敲打', '可怜', '发怒', '阴脸', '晕', '衰', '跳跳', '困', '社会社会', '色', '红包', '鄙视',
|
|||
|
'愉快', '加油', '皱眉', '啤酒', '咒骂', '哇', '惊讶', '握手', '大哭', '666', '奸笑', '月亮', '强',
|
|||
|
'微笑', '嘴唇']);
|
|||
|
|
|||
|
var emoji_mapping = {
|
|||
|
"愉快": "愉快",
|
|||
|
"白眼": "白眼",
|
|||
|
"傲慢": "傲慢",
|
|||
|
"困": "困",
|
|||
|
"惊恐": "惊恐",
|
|||
|
"憨笑": "憨笑",
|
|||
|
"悠闲": "悠闲",
|
|||
|
"咒骂": "咒骂",
|
|||
|
"疑问": "疑问",
|
|||
|
"嘘": "嘘",
|
|||
|
"晕": "晕",
|
|||
|
"衰": "衰",
|
|||
|
"骷髅": "骷髅",
|
|||
|
"敲打": "敲打",
|
|||
|
"Bye": "再见",
|
|||
|
"擦汗": "擦汗",
|
|||
|
"抠鼻": "抠鼻",
|
|||
|
"鼓掌": "鼓掌",
|
|||
|
"坏笑": "坏笑",
|
|||
|
"右哼哼": "右哼哼",
|
|||
|
"鄙视": "鄙视",
|
|||
|
"委屈": "委屈",
|
|||
|
"快哭了": "快哭了",
|
|||
|
"阴险": "阴险",
|
|||
|
"亲亲": "亲亲",
|
|||
|
"可怜": "可怜",
|
|||
|
"Happy": "笑脸",
|
|||
|
"Sick": "生病",
|
|||
|
"Flushed": "脸红",
|
|||
|
"Lol": "破涕为笑",
|
|||
|
"Terror": "恐惧",
|
|||
|
"LetDown": "失望",
|
|||
|
"Duh": "无语",
|
|||
|
"Hey": "嘿哈",
|
|||
|
"Facepalm": "捂脸",
|
|||
|
"Smirk": "奸笑",
|
|||
|
"Smart": "机智",
|
|||
|
"Concerned": "皱眉",
|
|||
|
"Yeah!": "耶",
|
|||
|
"Onlooker": "吃瓜",
|
|||
|
"GoForIt": "加油",
|
|||
|
"Sweats": "汗",
|
|||
|
"OMG": "天啊",
|
|||
|
"Emm": "Emm",
|
|||
|
"Respect": "社会社会",
|
|||
|
"Doge": "旺柴",
|
|||
|
"NoProb": "好的",
|
|||
|
"MyBad": "打脸",
|
|||
|
"Wow": "哇",
|
|||
|
"Boring": "翻白眼",
|
|||
|
"666": "666",
|
|||
|
"LetMeSee": "让我看看",
|
|||
|
"Sigh": "叹气",
|
|||
|
"Hurt": "苦涩",
|
|||
|
"Broken": "裂开",
|
|||
|
"嘴唇": "嘴唇",
|
|||
|
"爱心": "爱心",
|
|||
|
"心碎": "心碎",
|
|||
|
"拥抱": "拥抱",
|
|||
|
"强": "强",
|
|||
|
"弱": "弱",
|
|||
|
"握手": "握手",
|
|||
|
"胜利": "胜利",
|
|||
|
"Salute": "抱拳",
|
|||
|
"勾引": "勾引",
|
|||
|
"拳头": "拳头",
|
|||
|
"OK": "OK",
|
|||
|
"Worship": "合十",
|
|||
|
"啤酒": "啤酒",
|
|||
|
"咖啡": "咖啡",
|
|||
|
"蛋糕": "蛋糕",
|
|||
|
"玫瑰": "玫瑰",
|
|||
|
"凋谢": "凋谢",
|
|||
|
"菜刀": "菜刀",
|
|||
|
"炸弹": "炸弹",
|
|||
|
"便便": "便便",
|
|||
|
"月亮": "月亮",
|
|||
|
"太阳": "太阳",
|
|||
|
"Party": "庆祝",
|
|||
|
"gift": "礼物",
|
|||
|
"Packet": "红包",
|
|||
|
"Rich": "發",
|
|||
|
"Blessing": "福",
|
|||
|
"Fireworks": "烟花",
|
|||
|
"Firecracker": "爆竹",
|
|||
|
"猪头": "猪头",
|
|||
|
"跳跳": "跳跳",
|
|||
|
"发抖": "发抖",
|
|||
|
"转圈": "转圈",
|
|||
|
"微笑": "微笑",
|
|||
|
"撇嘴": "撇嘴",
|
|||
|
"色": "色",
|
|||
|
"发呆": "发呆",
|
|||
|
"得意": "得意",
|
|||
|
"流泪": "流泪",
|
|||
|
"害羞": "害羞",
|
|||
|
"闭嘴": "闭嘴",
|
|||
|
"睡": "睡",
|
|||
|
"大哭": "大哭",
|
|||
|
"尴尬": "尴尬",
|
|||
|
"发怒": "发怒",
|
|||
|
"调皮": "调皮",
|
|||
|
"呲牙": "呲牙",
|
|||
|
"惊讶": "惊讶",
|
|||
|
"难过": "难过",
|
|||
|
"Blush": "脸红",
|
|||
|
"抓狂": "抓狂",
|
|||
|
"吐": "吐",
|
|||
|
"偷笑": "偷笑"
|
|||
|
}
|
|||
|
|
|||
|
// 使用正则表达式匹配形如 [xxx] 的字符串
|
|||
|
return text.replace(/\[([^\]]+)\]/g, function(match, p1) {
|
|||
|
// 获取匹配的内容
|
|||
|
var emojiName = p1.trim();
|
|||
|
if (emojiName in emoji_mapping) {
|
|||
|
emojiName = emoji_mapping[emojiName];
|
|||
|
}
|
|||
|
if (emoji_set.has(emojiName)){
|
|||
|
// 如果在 emojiMap 中找到了对应的图片路径,则替换
|
|||
|
return `<img src="./emoji/${emojiName}.png" id="${emojiName}" class="emoji_img">`;
|
|||
|
}
|
|||
|
// 如果没有找到对应的图片路径,则返回原始内容
|
|||
|
return match;
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
function timestampToTime(timestamp) {
|
|||
|
let date = new Date(timestamp * 1000);
|
|||
|
let year = date.getFullYear() + '-';
|
|||
|
let month = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
|
|||
|
let day = (date.getDate() < 10 ? '0' + date.getDate() : date.getDate()) + ' ';
|
|||
|
let hour = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours()) + ':';
|
|||
|
let minute = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()) + ':';
|
|||
|
let second = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds();
|
|||
|
return year + month + day + hour + minute + second;
|
|||
|
}
|
|||
|
|
|||
|
// 生成各类标签的函数
|
|||
|
function add5MinTimeTag(message) {
|
|||
|
if (message.timestamp - lastTimeStamp > 300) {
|
|||
|
const newTimeMessage = document.createElement('div');
|
|||
|
newTimeMessage.className = "item item-center";
|
|||
|
newTimeMessage.innerHTML = `<span>${timestampToTime(message.timestamp)}</span>`;
|
|||
|
// chatContainer.appendChild(newTimeMessage);
|
|||
|
OnePageMessage.appendChild(newTimeMessage);
|
|||
|
lastTimeStamp = message.timestamp;
|
|||
|
// console.log("增加时间元素", timestampToTime(message.timestamp));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
function messageBubble(message, side) {
|
|||
|
const messageBubbleTag = document.createElement('div');
|
|||
|
messageBubbleTag.className = `bubble bubble-${side}`;
|
|||
|
messageBubbleTag.innerHTML = replaceEmoji(message.text);
|
|||
|
return messageBubbleTag;
|
|||
|
}
|
|||
|
|
|||
|
function displayNameBox(message) {
|
|||
|
const displayName = document.createElement('div');
|
|||
|
displayName.className = "displayname";
|
|||
|
displayName.innerHTML = message.display_name;
|
|||
|
return displayName;
|
|||
|
}
|
|||
|
// function checkImageExists(url, callback) {
|
|||
|
// var img = new Image();
|
|||
|
// img.onload = function () {
|
|||
|
// callback(true); // 图片存在
|
|||
|
// };
|
|||
|
// img.onerror = function () {
|
|||
|
// callback(false); // 图片不存在
|
|||
|
// };
|
|||
|
// img.src = url;
|
|||
|
// }
|
|||
|
|
|||
|
function avatarBox(message) {
|
|||
|
const avatarTag = document.createElement('div');
|
|||
|
avatarTag.className = "avatar";
|
|||
|
// var avatar_path = '';
|
|||
|
// // 使用示例
|
|||
|
// var imageUrl = avatarPaths[message.avatar_path];
|
|||
|
var imageUrl = message.avatar_src;
|
|||
|
// checkImageExists(imageUrl, function (exists) {
|
|||
|
// if (exists) {
|
|||
|
// console.log('图片存在');
|
|||
|
// } else {
|
|||
|
// imageUrl = avatarUrls[message.avatar_path]
|
|||
|
// }
|
|||
|
// avatarTag.innerHTML = `<img src="${imageUrl}" loading="lazy" />`
|
|||
|
// });
|
|||
|
avatarTag.innerHTML = `<img src="${imageUrl}" loading="lazy" />`
|
|||
|
return avatarTag;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
// function messageImgBox(message) {
|
|||
|
// const messageImgTag = document.createElement('div');
|
|||
|
// if(message.type == 47) {
|
|||
|
// messageImgTag.className = `emoji-image`;
|
|||
|
// }else{
|
|||
|
// messageImgTag.className = `chat-image`;
|
|||
|
// }
|
|||
|
// messageImgTag.innerHTML = `<img src="${message.path}" onclick="showModal(this)" loading="lazy"/>`;
|
|||
|
// return messageImgTag;
|
|||
|
// }
|
|||
|
function messageImgBox(message) {
|
|||
|
const messageImgTag = document.createElement('div');
|
|||
|
|
|||
|
if (message.type == 47) {
|
|||
|
messageImgTag.className = 'emoji-image';
|
|||
|
messageImgTag.innerHTML = `<img src="${message.path}" onclick="showModal(this)" loading="lazy"/>`;
|
|||
|
return messageImgTag;
|
|||
|
} else {
|
|||
|
messageImgTag.className = 'chat-image';
|
|||
|
}
|
|||
|
|
|||
|
const basePath = message.path; // 图片的原始路径(没有后缀名)
|
|||
|
console.log('basePath:', basePath);
|
|||
|
const extensions = ['.jpg','.png', '.jpeg', '.gif', '.bmp']; // 常见的图片后缀
|
|||
|
let imgLoaded = false;
|
|||
|
|
|||
|
// 尝试不同的后缀名
|
|||
|
extensions.forEach(extension => {
|
|||
|
const img = new Image();
|
|||
|
img.src = basePath + extension;
|
|||
|
|
|||
|
img.onload = function() {
|
|||
|
messageImgTag.innerHTML = `<img src="${img.src}" onclick="showModal(this)" loading="lazy"/>`;
|
|||
|
imgLoaded = true;
|
|||
|
};
|
|||
|
|
|||
|
img.onerror = function() {
|
|||
|
// 图片加载失败,继续尝试下一个后缀
|
|||
|
if (!imgLoaded) {
|
|||
|
// 这里可以选择在所有后缀都尝试完后进行处理
|
|||
|
}
|
|||
|
};
|
|||
|
});
|
|||
|
|
|||
|
return messageImgTag;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
function messageVideoBox(message) {
|
|||
|
const messageVideoTag = document.createElement('div');
|
|||
|
messageVideoTag.className = `chat-video`;
|
|||
|
messageVideoTag.innerHTML = `<video src="${message.path}" controls />`;
|
|||
|
return messageVideoTag;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
function messageElementReferText(message, side) {
|
|||
|
const messageElementRefer = document.createElement('div');
|
|||
|
messageElementRefer.className = `chat-refer chat-refer-${side}`;
|
|||
|
messageElementRefer.innerHTML = replaceEmoji(message.quote_text);
|
|||
|
messageElementRefer.addEventListener('contextmenu', function () {
|
|||
|
// 阻止默认的右键菜单
|
|||
|
event.preventDefault();
|
|||
|
// 创建右键菜单
|
|||
|
var contextMenu = document.createElement('div');
|
|||
|
contextMenu.className = 'custom-menu';
|
|||
|
contextMenu.style.position = 'absolute';
|
|||
|
contextMenu.style.left = event.pageX + 'px';
|
|||
|
contextMenu.style.top = event.pageY + 'px';
|
|||
|
|
|||
|
// 添加菜单项
|
|||
|
var menuItem = document.createElement('div');
|
|||
|
menuItem.className = 'custom-menu-item';
|
|||
|
menuItem.textContent = '定位到原文位置';
|
|||
|
menuItem.addEventListener('click', function () {
|
|||
|
contextMenu.remove();
|
|||
|
referId = message.quote_server_id;
|
|||
|
lastPage = currentPage;
|
|||
|
currentPage = server_id_Page[String(referId)];
|
|||
|
|
|||
|
if (lastPage != currentPage) {
|
|||
|
reachedBottom = false;
|
|||
|
reachedTop = false;
|
|||
|
renderPage(currentPage);
|
|||
|
}
|
|||
|
var targetSection = document.getElementById(referId);
|
|||
|
targetSection.scrollIntoView({ behavior: 'smooth' });
|
|||
|
});
|
|||
|
contextMenu.appendChild(menuItem);
|
|||
|
|
|||
|
// 将右键菜单添加到页面上
|
|||
|
document.body.appendChild(contextMenu);
|
|||
|
|
|||
|
// 点击页面其他地方时隐藏菜单
|
|||
|
document.addEventListener('click', function (event) {
|
|||
|
if (!contextMenu.contains(event.target)) {
|
|||
|
contextMenu.remove();
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
|
|||
|
});
|
|||
|
return messageElementRefer;
|
|||
|
}
|
|||
|
|
|||
|
function messageVoiceToTextBubble(message, side) {
|
|||
|
const messageVoiceToTextTag = document.createElement('div');
|
|||
|
messageVoiceToTextTag.className = `bubble bubble-${side}`;
|
|||
|
messageVoiceToTextTag.innerHTML = message.voice_to_text;
|
|||
|
return messageVoiceToTextTag;
|
|||
|
}
|
|||
|
|
|||
|
function messageAudioBox(message) {
|
|||
|
const messageAudioTag = document.createElement('div');
|
|||
|
if (message.is_send) {
|
|||
|
messageAudioTag.className = `bubble-audio-right`;
|
|||
|
var messageAudioTagID = message.server_id + "_audio_box";
|
|||
|
messageAudioTag.id = messageAudioTagID;
|
|||
|
var audioID = message.server_id + "_audio";
|
|||
|
AudioTag = document.createElement('audio');
|
|||
|
AudioTag.id = audioID;
|
|||
|
AudioTag.innerHTML = `<source src="${message.path}" type="audio/mpeg">`;
|
|||
|
// 根据语音时长设置气泡宽度
|
|||
|
var duration = Math.ceil(message.duration / 1000);
|
|||
|
var bubblewidth = 40 + duration * 5;
|
|||
|
if (bubblewidth < 250) {
|
|||
|
messageAudioTag.style.width = `${bubblewidth}px`;
|
|||
|
} else {
|
|||
|
messageAudioTag.style.width = `250px`;
|
|||
|
}
|
|||
|
messageAudioTag.innerHTML = `''${duration}`;
|
|||
|
messageAudioTag.appendChild(AudioTag);
|
|||
|
|
|||
|
$(function () {
|
|||
|
messageAudioTag.addEventListener('click', function () {
|
|||
|
event.stopPropagation();//防止冒泡
|
|||
|
var AudioTag = messageAudioTag.querySelector('audio');
|
|||
|
AudioTag.addEventListener('error', function () {
|
|||
|
// 文件加载错误时执行的操作
|
|||
|
alert('音频文件加载错误,文件不存在或无法访问。');
|
|||
|
});
|
|||
|
if (AudioTag !== null) {
|
|||
|
if (AudioTag.paused) {
|
|||
|
AudioTag.play();
|
|||
|
if (AudioTag.networkState === HTMLMediaElement.NETWORK_NO_SOURCE) {
|
|||
|
alert('音频文件加载错误,文件不存在或无法访问!');
|
|||
|
return;
|
|||
|
}
|
|||
|
messageAudioTag.style.background = 'url() no-repeat center right 10px';
|
|||
|
messageAudioTag.style.backgroundSize = '20px';
|
|||
|
messageAudioTag.style.backgroundColor = '#9eea6a';
|
|||
|
var checkAudioInterval = setInterval(function () {
|
|||
|
if (AudioTag.paused) {
|
|||
|
messageAudioTag.style.background = 'url() no-repeat center right 10px';
|
|||
|
messageAudioTag.style.backgroundSize = '20px';
|
|||
|
messageAudioTag.style.backgroundColor = '#9eea6a';
|
|||
|
clearInterval(checkAudioInterval);
|
|||
|
}
|
|||
|
}, 100);
|
|||
|
}
|
|||
|
else {
|
|||
|
messageAudioTag.style.background = 'url() no-repeat center right 10px';
|
|||
|
messageAudioTag.style.backgroundSize = '20px';
|
|||
|
messageAudioTag.style.backgroundColor = '#9eea6a';
|
|||
|
AudioTag.pause();
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
});
|
|||
|
|
|||
|
} else {
|
|||
|
messageAudioTag.className = `bubble-audio-left`;
|
|||
|
var messageAudioTagID = message.server_id + "_audio_box";
|
|||
|
messageAudioTag.id = messageAudioTagID;
|
|||
|
var audioID = message.server_id + "_audio";
|
|||
|
AudioTag = document.createElement('audio');
|
|||
|
AudioTag.id = audioID;
|
|||
|
AudioTag.innerHTML = `<source src="${message.path}" type="audio/mpeg">`;
|
|||
|
var duration = Math.ceil(message.duration / 1000);
|
|||
|
var bubblewidth = 40 + duration * 5;
|
|||
|
if (bubblewidth < 250) {
|
|||
|
messageAudioTag.style.width = `${bubblewidth}px`;
|
|||
|
} else {
|
|||
|
messageAudioTag.style.width = `250px`;
|
|||
|
}
|
|||
|
messageAudioTag.innerHTML = `${duration}''`;
|
|||
|
messageAudioTag.appendChild(AudioTag);
|
|||
|
|
|||
|
$(function () {
|
|||
|
//播放器控制
|
|||
|
messageAudioTag.addEventListener('click', function () {
|
|||
|
event.stopPropagation();//防止冒泡
|
|||
|
var AudioTag = messageAudioTag.querySelector('audio');
|
|||
|
if (AudioTag !== null) {
|
|||
|
if (AudioTag.paused) {
|
|||
|
AudioTag.play();
|
|||
|
if (AudioTag.networkState === HTMLMediaElement.NETWORK_NO_SOURCE) {
|
|||
|
alert('音频文件加载错误,文件不存在或无法访问!');
|
|||
|
return;
|
|||
|
}
|
|||
|
messageAudioTag.style.background = 'url() no-repeat center left 10px';
|
|||
|
messageAudioTag.style.backgroundSize = '20px';
|
|||
|
messageAudioTag.style.backgroundColor = '#fff';
|
|||
|
var checkAudioInterval = setInterval(function () {
|
|||
|
if (AudioTag.paused) {
|
|||
|
messageAudioTag.style.background = 'url() no-repeat center left 10px';
|
|||
|
messageAudioTag.style.backgroundSize = '20px';
|
|||
|
messageAudioTag.style.backgroundColor = '#fff';
|
|||
|
clearInterval(checkAudioInterval);
|
|||
|
}
|
|||
|
}, 100);
|
|||
|
}
|
|||
|
else {
|
|||
|
messageAudioTag.style.background = 'url() no-repeat center left 10px';
|
|||
|
messageAudioTag.style.backgroundSize = '20px';
|
|||
|
messageAudioTag.style.backgroundColor = '#fff';
|
|||
|
AudioTag.pause();
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
return messageAudioTag;
|
|||
|
}
|
|||
|
|
|||
|
function messageCard(message) {
|
|||
|
const messageTag = document.createElement('div');
|
|||
|
messageTag.className = `card`;
|
|||
|
messageTag.innerHTML = `<a href="${message.url}" target="_blank">
|
|||
|
<div class="card-content">
|
|||
|
<div title="${message.title}" class="card-title">${message.title}</div>
|
|||
|
${message.description ? `
|
|||
|
<div class="description">
|
|||
|
<p title="${message.description}">${message.description}</p>
|
|||
|
<img loading="lazy" class="thumbnail" src="${message.cover_url}" alt="Thumbnail" onerror="this.style.display='none';">
|
|||
|
</div>` : ''}
|
|||
|
</div>
|
|||
|
<div class="link-info">
|
|||
|
${message.app_logo ? `<img loading="lazy" class="app-logo" src="${message.app_logo}" alt="App Logo" onerror="this.style.display='none';">` : ''}
|
|||
|
${message.app_name ? `<span class="app-name">${message.app_name}</span>` : `<span class="app-name">app-name</span>`}
|
|||
|
</div>
|
|||
|
</a>`;
|
|||
|
|
|||
|
return messageTag;
|
|||
|
}
|
|||
|
|
|||
|
function getFileSize(byteSize, format = 'MB') {
|
|||
|
// 定义转换因子
|
|||
|
const units = {
|
|||
|
'B': 1,
|
|||
|
'KB': 1024,
|
|||
|
'MB': 1024 ** 2,
|
|||
|
'GB': 1024 ** 3,
|
|||
|
};
|
|||
|
|
|||
|
// 检查格式是否支持
|
|||
|
if (units.hasOwnProperty(format)) {
|
|||
|
const sizeInFormat = byteSize / units[format];
|
|||
|
return `${sizeInFormat.toFixed(2)} ${format}`;
|
|||
|
} else {
|
|||
|
throw new Error(`Unsupported format: ${format}`);
|
|||
|
}
|
|||
|
}
|
|||
|
function getFileExtension(file_type) {
|
|||
|
icon_files = {
|
|||
|
'doc': 'DOCX',
|
|||
|
'docx': 'DOCX',
|
|||
|
'xls': 'XLSX',
|
|||
|
'xlsx': 'XLSX',
|
|||
|
'csv': 'CSV',
|
|||
|
'txt': 'TXT',
|
|||
|
'zip': 'ZIP',
|
|||
|
'7z': 'ZIP',
|
|||
|
'rar': 'ZIP',
|
|||
|
'ppt':'PPT',
|
|||
|
'pptx':'PPT',
|
|||
|
'pdf': 'PDF'
|
|||
|
}
|
|||
|
return icon_files.hasOwnProperty(file_type) ? icon_files[file_type] : 'Default';
|
|||
|
// 如果没有匹配到后缀名,返回 'Default'
|
|||
|
return 'Default';
|
|||
|
}
|
|||
|
function messageFileBox(message) {
|
|||
|
const messageFileTag = document.createElement('div');
|
|||
|
messageFileTag.className = `chat-file`;
|
|||
|
messageFileTag.onclick = function (event) {
|
|||
|
if (message.path !== '') {
|
|||
|
window.open(message.path, '_blank');
|
|||
|
} else {
|
|||
|
alert("文件可能丢失、过期或不存放在该主机上")
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
messageFileTag.innerHTML = `<div class="file-box">
|
|||
|
<div class="file-info flex1">
|
|||
|
<div class="file-title" title="${message.file_name}">${message.file_name}</div>
|
|||
|
<div class="file-size">${getFileSize(message.file_size)}</div>
|
|||
|
</div>
|
|||
|
<div class="file-img flex2">
|
|||
|
<img src="${FileIcons[getFileExtension(message.file_type)]}"/>
|
|||
|
</div>
|
|||
|
</div>` +
|
|||
|
(message.app_name ? `<div class="app-info"><p>${message.app_name}</p></div>` : "");
|
|||
|
return messageFileTag;
|
|||
|
}
|
|||
|
function messageVideoAudioCall(message, side) {
|
|||
|
const message_call_box = document.createElement('div');
|
|||
|
message_call_box.className = `bubble bubble-${side} call`;
|
|||
|
message_call_box.setAttribute("calltype", message.invite_type)
|
|||
|
message_call_box.innerHTML = `<i></i><span>${message.display_content}<span>`;
|
|||
|
return message_call_box;
|
|||
|
}
|
|||
|
function messageMusicAudioBox(message) {
|
|||
|
const messageMusicAudioTag = document.createElement('div');
|
|||
|
messageMusicAudioTag.className = `chat-music-audio`;
|
|||
|
messageMusicAudioTag.dataset.link = message.url;
|
|||
|
messageMusicAudioTag.onclick = function (event) {
|
|||
|
if (!event.target.classList.contains('play-button')) {
|
|||
|
window.open(message.url, '_blank');
|
|||
|
}
|
|||
|
}
|
|||
|
if (message.title.length >= 12) {
|
|||
|
message.title = message.title.slice(0, 12) + '...'
|
|||
|
}
|
|||
|
if (message.description.length >= 10) {
|
|||
|
message.description = message.description.slice(0, 10) + '...'
|
|||
|
}
|
|||
|
messageMusicAudioTag.innerHTML = `<div class="player-box">
|
|||
|
<div>
|
|||
|
<img src="${message.cover_url}" alt="Cover Image" class="cover-image">
|
|||
|
</div>
|
|||
|
<div class="player-info">
|
|||
|
<div class="title">${message.title}</div>
|
|||
|
<div class="artist">${message.description}</div>
|
|||
|
</div>
|
|||
|
<div class="player-controls">
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="player-original">
|
|||
|
<svg class="player-original-img" t="1727442389694" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4302" width="64" height="64"><path d="M35.84 529.92c0 263.68 215.04 478.72 478.72 478.72 263.68 0 478.72-215.04 478.72-478.72C993.28 266.24 780.8 51.2 514.56 51.2 250.88 51.2 35.84 266.24 35.84 529.92z" fill="#F8C913" p-id="4303"></path><path d="M660.48 10.24c-17.92 20.48-56.32 38.4-107.52 51.2-87.04 20.48-104.96 25.6-130.56 40.96-15.36 7.68-33.28 20.48-43.52 30.72-20.48 17.92-35.84 51.2-30.72 61.44 2.56 5.12 51.2 74.24 110.08 158.72 58.88 81.92 115.2 163.84 128 181.76 12.8 17.92 20.48 33.28 20.48 33.28 0 2.56-10.24 0-20.48-2.56-40.96-12.8-112.64 0-163.84 25.6-38.4 20.48-81.92 64-99.84 99.84-20.48 40.96-23.04 97.28-7.68 135.68 15.36 40.96 48.64 74.24 92.16 97.28 33.28 17.92 40.96 17.92 84.48 20.48 35.84 2.56 56.32 0 76.8-5.12 94.72-28.16 163.84-102.4 168.96-189.44 2.56-48.64-2.56-64-66.56-176.64-99.84-174.08-189.44-332.8-189.44-335.36 0 0 17.92-2.56 40.96-5.12 66.56-2.56 120.32-35.84 148.48-89.6 12.8-23.04 12.8-30.72 12.8-79.36 0-30.72-2.56-58.88-5.12-61.44-2.56-7.68-5.12-5.12-17.92 7.68z" fill="#02B053" p-id="4304"></path></svg>
|
|||
|
<p>${message.app_name}</p>
|
|||
|
</div>
|
|||
|
`
|
|||
|
if (message.text != '') {
|
|||
|
var audio = document.createElement('audio');
|
|||
|
audio.src = message.text;
|
|||
|
messageMusicAudioTag.querySelector('.player-controls').append(audio)
|
|||
|
}
|
|||
|
;
|
|||
|
var playButton = document.createElement('button');
|
|||
|
playButton.className = 'play-button paused';
|
|||
|
playButton.onclick = function (event) {
|
|||
|
event.stopPropagation(); // 阻止点击播放按钮时触发父级的点击事件
|
|||
|
toggleAudio(event.target);
|
|||
|
};
|
|||
|
if (message.is_send) {
|
|||
|
messageMusicAudioTag.querySelector('.player-controls').append(playButton)
|
|||
|
} else {
|
|||
|
messageMusicAudioTag.querySelector('.player-controls').prepend(playButton)
|
|||
|
}
|
|||
|
return messageMusicAudioTag;
|
|||
|
}
|
|||
|
function messageTransfer(message) {
|
|||
|
const transfer_box = document.createElement("div");
|
|||
|
transfer_box.className = "transfer-box";
|
|||
|
transfer_box.setAttribute("issend", message.is_send);
|
|||
|
transfer_box.setAttribute("paysubtype", message.pay_subtype);
|
|||
|
transfer_box.innerHTML = `<div class="transfer">
|
|||
|
<div class="trans-content"><i></i>
|
|||
|
<div class="transfer-texts"><span>${message.fee_desc}</span><font>${message.text}</font></div>
|
|||
|
</div>
|
|||
|
<div class="trans-bottom"><span>聊天转账</span></div>
|
|||
|
</div>`;
|
|||
|
return transfer_box;
|
|||
|
}
|
|||
|
function personalCard(message) {
|
|||
|
const personal_card = document.createElement("div");
|
|||
|
personal_card.className = "personal-card";
|
|||
|
const contner = document.createElement("div");
|
|||
|
contner.className = "contner";
|
|||
|
contner.innerHTML = `<img src="${message.small_head_url}" alt="headimg">`
|
|||
|
const contner_text = document.createElement("div");
|
|||
|
contner_text.className = "text";
|
|||
|
if (message.sex == '男') {
|
|||
|
contner_text.innerHTML = `<div class="nickname">
|
|||
|
${message.nickname}<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1704295160809" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4268" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16"><path d="M922.344176 152.209186v-0.050575c0-0.765851-0.0867-1.517251-0.130051-2.283101-0.036125-0.67915-0.04335-1.365526-0.108375-2.037452-0.0867-0.794751-0.2312-1.553376-0.36125-2.333676-0.07225-0.455175-0.122825-0.917576-0.209525-1.379976l-0.04335-0.296226-0.050575-0.281775c-0.15895-0.794751-0.397375-1.553376-0.599676-2.333677-0.15895-0.6069-0.289-1.228251-0.469625-1.820701-0.2601-0.816426-0.585225-1.618401-0.888676-2.420377l-0.27455-0.758625-0.166175-0.455176-0.13005-0.325125c-0.354025-0.830876-0.758626-1.625626-1.163226-2.427602-0.223975-0.455175-0.41905-0.917576-0.6647-1.358301-0.4335-0.801976-0.924801-1.553376-1.401651-2.319226-0.1445-0.223975-0.267325-0.4624-0.411826-0.671926-0.0867-0.13005-0.151725-0.267325-0.238425-0.397375l-0.1156-0.1734c-0.50575-0.751401-1.062076-1.445001-1.611176-2.153052-0.30345-0.39015-0.578-0.801976-0.888676-1.184901-0.556325-0.6647-1.163226-1.293276-1.755676-1.929076-0.354025-0.382925-0.67915-0.780301-1.040401-1.141551l-0.065025-0.065025-0.01445-0.021675-0.07225-0.0578c-0.527425-0.527425-1.098201-1.004276-1.668976-1.510026-0.426275-0.3757-0.823651-0.780301-1.271601-1.148776-0.599675-0.4913-1.249926-0.932026-1.878501-1.401651-0.484075-0.36125-0.953701-0.744176-1.452226-1.083751a5.086404 5.086404 0 0 1-0.332351-0.2023l-0.53465-0.310675a26.70362 26.70362 0 0 0-1.141551-0.693601c-0.5202-0.3179-1.025951-0.657475-1.567826-0.9537-0.67915-0.368475-1.394426-0.671925-2.095252-1.004276-0.56355-0.267325-1.112651-0.570775-1.690651-0.809201-0.151725-0.07225-0.325125-0.122825-0.4913-0.180625-0.18785-0.079475-0.39015-0.137275-0.578001-0.223975l-1.018725-0.368475c-0.628575-0.223975-1.242701-0.484075-1.892952-0.693601-0.643025-0.18785-1.307726-0.325125-1.965201-0.4913-0.729726-0.195075-1.445001-0.41905-2.189177-0.563551-0.151725-0.036125-0.310675-0.036125-0.4624-0.065025l-0.426275-0.07225c-0.527425-0.10115-1.069301-0.166175-1.618402-0.238425-0.599675-0.093925-1.184901-0.21675-1.784576-0.281775a42.772031 42.772031 0 0 0-4.428928-0.223975h-0.151725l-343.079377 1.235476a43.350032 43.350032 0 0 0 0.151726 86.700063h0.151725l238.417949-0.867-156.76094 157.895265c-53.710689-42.179581-121.170564-67.467099-194.150342-67.467099l-4.219403 0.021675c-174.093728 2.290327-313.85423 145.786157-311.563903 319.858209 2.261427 171.817851 143.849855 311.592803 315.631581 311.592803l4.219403-0.0289c84.330262-1.105426 163.18397-34.983476 222.031638-95.39897 58.854893-60.415494 90.644916-140.136203 89.532265-224.452014-0.881451-67.82835-23.553517-130.613646-61.159669-181.831708l157.61349-158.747816V495.418613a43.350032 43.350032 0 0 0 86.700064 0V152.346462v-0.050575-0.086701zM577.198448 751.978551c-39.990404 41.06693-93.585494 64.085797-150.901461 64.844422l-2.890002 0.01445c-116.73441 0-212.957031-95.001595-214.495957-211.77213C207.357652 486.748607 302.352021 389.23271 420.668708 387.672109l2.890002-0.007225c116.741636 0 212.971481 94.99437 214.488732 211.779355 0.758626 57.301517-20.851365 111.474607-60.848994 152.534312z" fill="#1296db" p-id="4269"></path></svg></div>`
|
|||
|
} else if (message.sex == '女') {
|
|||
|
contner_text.innerHTML = `<div class="nickname">
|
|||
|
${message.nickname}<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1704295202245" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5558" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16"><path d="M870.69952 153.30048c-66.10688-66.10944-154.00448-102.51776-247.49696-102.51904-93.49248 0-181.3888 36.40832-247.49696 102.51648-66.11072 66.10944-102.51648 154.00576-102.51648 247.49952-0.00128 76.19968 24.19072 148.6784 68.93056 208.67584l-60.2048 60.20352L138.18496 525.94688c-19.99488-19.99488-52.41216-19.99488-72.40704 0-19.99488 19.9936-19.99488 52.41216 0 72.40704l143.72992 143.72992-55.75552 55.75552c-19.9936 19.9936-19.9936 52.41216 0 72.40576 19.99616 19.99616 52.41344 19.99488 72.40832 0l55.75424-55.75424 143.7312 143.72992c19.9936 19.99488 52.41088 19.99488 72.40576 0 19.99616-19.99488 19.99616-52.41216 0-72.40704L354.32192 742.08512l60.2048-60.20352c59.99872 44.73856 132.47616 68.93184 208.67584 68.93184 93.49248 0 181.38752-36.40832 247.49696-102.51776s102.51776-154.00576 102.51776-247.49824C973.21728 307.30496 936.80768 219.40736 870.69952 153.30048zM798.29248 575.88736c-46.76736 46.76736-108.94976 72.5248-175.08992 72.5248s-128.32128-25.75744-175.08992-72.5248c-46.76864-46.76736-72.5248-108.94976-72.5248-175.08992 0.00128-66.14272 25.75616-128.32384 72.5248-175.0912 46.76736-46.76864 108.94976-72.5248 175.08992-72.5248 66.14016 0.00128 128.32256 25.75744 175.08992 72.52608 46.76736 46.76736 72.5248 108.94848 72.5248 175.08864C870.81728 466.9376 845.0624 529.11872 798.29248 575.88736z" fill="#d81e06" p-id="5559"></path></svg></div>`
|
|||
|
} else {
|
|||
|
contner_text.innerHTML = `<div class="nickname">
|
|||
|
${message.nickname}</div>`
|
|||
|
}
|
|||
|
contner_text.innerHTML += `<div class="other">微信号: ${message.alias}</div>
|
|||
|
<div class="other">地区: ${message.province}${message.city}</div>`
|
|||
|
contner.appendChild(contner_text);
|
|||
|
personal_card.appendChild(contner);
|
|||
|
const card_bottom = document.createElement("div");
|
|||
|
card_bottom.className = "bottom";
|
|||
|
if (message.username.includes("gh_")) {
|
|||
|
card_bottom.innerHTML = `<div class="text">公众号名片</div>`
|
|||
|
} else {
|
|||
|
card_bottom.innerHTML = `<div class="text">个人名片</div>`
|
|||
|
}
|
|||
|
personal_card.appendChild(card_bottom);
|
|||
|
return personal_card;
|
|||
|
}
|
|||
|
function openIMCard(message) {
|
|||
|
const OpenIM_card = document.createElement("div");
|
|||
|
OpenIM_card.className = "OpenIM-card";
|
|||
|
const contner = document.createElement("div");
|
|||
|
contner.className = "contner";
|
|||
|
contner.innerHTML = `<img src="${message.smallheadimgurl}" alt="headimg">`
|
|||
|
const contner_text = document.createElement("div");
|
|||
|
contner_text.className = "text";
|
|||
|
if (message.sex == '男') {
|
|||
|
contner_text.innerHTML = `<div class="nickname">
|
|||
|
${message.nickname}<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1704295160809" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4268" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16"><path d="M922.344176 152.209186v-0.050575c0-0.765851-0.0867-1.517251-0.130051-2.283101-0.036125-0.67915-0.04335-1.365526-0.108375-2.037452-0.0867-0.794751-0.2312-1.553376-0.36125-2.333676-0.07225-0.455175-0.122825-0.917576-0.209525-1.379976l-0.04335-0.296226-0.050575-0.281775c-0.15895-0.794751-0.397375-1.553376-0.599676-2.333677-0.15895-0.6069-0.289-1.228251-0.469625-1.820701-0.2601-0.816426-0.585225-1.618401-0.888676-2.420377l-0.27455-0.758625-0.166175-0.455176-0.13005-0.325125c-0.354025-0.830876-0.758626-1.625626-1.163226-2.427602-0.223975-0.455175-0.41905-0.917576-0.6647-1.358301-0.4335-0.801976-0.924801-1.553376-1.401651-2.319226-0.1445-0.223975-0.267325-0.4624-0.411826-0.671926-0.0867-0.13005-0.151725-0.267325-0.238425-0.397375l-0.1156-0.1734c-0.50575-0.751401-1.062076-1.445001-1.611176-2.153052-0.30345-0.39015-0.578-0.801976-0.888676-1.184901-0.556325-0.6647-1.163226-1.293276-1.755676-1.929076-0.354025-0.382925-0.67915-0.780301-1.040401-1.141551l-0.065025-0.065025-0.01445-0.021675-0.07225-0.0578c-0.527425-0.527425-1.098201-1.004276-1.668976-1.510026-0.426275-0.3757-0.823651-0.780301-1.271601-1.148776-0.599675-0.4913-1.249926-0.932026-1.878501-1.401651-0.484075-0.36125-0.953701-0.744176-1.452226-1.083751a5.086404 5.086404 0 0 1-0.332351-0.2023l-0.53465-0.310675a26.70362 26.70362 0 0 0-1.141551-0.693601c-0.5202-0.3179-1.025951-0.657475-1.567826-0.9537-0.67915-0.368475-1.394426-0.671925-2.095252-1.004276-0.56355-0.267325-1.112651-0.570775-1.690651-0.809201-0.151725-0.07225-0.325125-0.122825-0.4913-0.180625-0.18785-0.079475-0.39015-0.137275-0.578001-0.223975l-1.018725-0.368475c-0.628575-0.223975-1.242701-0.484075-1.892952-0.693601-0.643025-0.18785-1.307726-0.325125-1.965201-0.4913-0.729726-0.195075-1.445001-0.41905-2.189177-0.563551-0.151725-0.036125-0.310675-0.036125-0.4624-0.065025l-0.426275-0.07225c-0.527425-0.10115-1.069301-0.166175-1.618402-0.238425-0.599675-0.093925-1.184901-0.21675-1.784576-0.281775a42.772031 42.772031 0 0 0-4.428928-0.223975h-0.151725l-343.079377 1.235476a43.350032 43.350032 0 0 0 0.151726 86.700063h0.151725l238.417949-0.867-156.76094 157.895265c-53.710689-42.179581-121.170564-67.467099-194.150342-67.467099l-4.219403 0.021675c-174.093728 2.290327-313.85423 145.786157-311.563903 319.858209 2.261427 171.817851 143.849855 311.592803 315.631581 311.592803l4.219403-0.0289c84.330262-1.105426 163.18397-34.983476 222.031638-95.39897 58.854893-60.415494 90.644916-140.136203 89.532265-224.452014-0.881451-67.82835-23.553517-130.613646-61.159669-181.831708l157.61349-158.747816V495.418613a43.350032 43.350032 0 0 0 86.700064 0V152.346462v-0.050575-0.086701zM577.198448 751.978551c-39.990404 41.06693-93.585494 64.085797-150.901461 64.844422l-2.890002 0.01445c-116.73441 0-212.957031-95.001595-214.495957-211.77213C207.357652 486.748607 302.352021 389.23271 420.668708 387.672109l2.890002-0.007225c116.741636 0 212.971481 94.99437 214.488732 211.779355 0.758626 57.301517-20.851365 111.474607-60.848994 152.534312z" fill="#1296db" p-id="4269"></path></svg></div>`
|
|||
|
} else if (message.sex == '女') {
|
|||
|
contner_text.innerHTML = `<div class="nickname">
|
|||
|
${message.nickname}<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1704295202245" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5558" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16"><path d="M870.69952 153.30048c-66.10688-66.10944-154.00448-102.51776-247.49696-102.51904-93.49248 0-181.3888 36.40832-247.49696 102.51648-66.11072 66.10944-102.51648 154.00576-102.51648 247.49952-0.00128 76.19968 24.19072 148.6784 68.93056 208.67584l-60.2048 60.20352L138.18496 525.94688c-19.99488-19.99488-52.41216-19.99488-72.40704 0-19.99488 19.9936-19.99488 52.41216 0 72.40704l143.72992 143.72992-55.75552 55.75552c-19.9936 19.9936-19.9936 52.41216 0 72.40576 19.99616 19.99616 52.41344 19.99488 72.40832 0l55.75424-55.75424 143.7312 143.72992c19.9936 19.99488 52.41088 19.99488 72.40576 0 19.99616-19.99488 19.99616-52.41216 0-72.40704L354.32192 742.08512l60.2048-60.20352c59.99872 44.73856 132.47616 68.93184 208.67584 68.93184 93.49248 0 181.38752-36.40832 247.49696-102.51776s102.51776-154.00576 102.51776-247.49824C973.21728 307.30496 936.80768 219.40736 870.69952 153.30048zM798.29248 575.88736c-46.76736 46.76736-108.94976 72.5248-175.08992 72.5248s-128.32128-25.75744-175.08992-72.5248c-46.76864-46.76736-72.5248-108.94976-72.5248-175.08992 0.00128-66.14272 25.75616-128.32384 72.5248-175.0912 46.76736-46.76864 108.94976-72.5248 175.08992-72.5248 66.14016 0.00128 128.32256 25.75744 175.08992 72.52608 46.76736 46.76736 72.5248 108.94848 72.5248 175.08864C870.81728 466.9376 845.0624 529.11872 798.29248 575.88736z" fill="#d81e06" p-id="5559"></path></svg></div>`
|
|||
|
} else {
|
|||
|
contner_text.innerHTML = `<div class="nickname">
|
|||
|
${message.nickname}</div>`
|
|||
|
}
|
|||
|
contner_text.innerHTML += `<div class="desc"><img src="${message.open_im_desc_icon}">${message.open_im_desc}</div>`
|
|||
|
contner.appendChild(contner_text);
|
|||
|
OpenIM_card.appendChild(contner);
|
|||
|
const card_bottom = document.createElement("div");
|
|||
|
card_bottom.className = "bottom";
|
|||
|
card_bottom.innerHTML = `<div class="text">企业微信名片</div>`
|
|||
|
OpenIM_card.appendChild(card_bottom);
|
|||
|
return OpenIM_card;
|
|||
|
}
|
|||
|
|
|||
|
function messageLocation(message, newMapID) {
|
|||
|
const Location = document.createElement("div");
|
|||
|
Location.className = "location";
|
|||
|
Location.innerHTML = `<div class="poiname">${message.poiname}</div>
|
|||
|
<div class="label">${message.label}</div>
|
|||
|
`
|
|||
|
const map_box = document.createElement("div");
|
|||
|
map_box.className = "map";
|
|||
|
map_box.id = "map" + message.timestamp;
|
|||
|
Location.appendChild(map_box);
|
|||
|
|
|||
|
newMapID["map" + message.timestamp] = [message.x, message.y, message.label, message.scale]
|
|||
|
|
|||
|
return Location;
|
|||
|
}
|
|||
|
|
|||
|
function loadMap(MapID) {
|
|||
|
// 点标记显示内容,HTML要素字符串
|
|||
|
var markerContent = '' +
|
|||
|
'<div class="custom-content-marker">' +
|
|||
|
' <img src="https://a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-red.png">' +
|
|||
|
'</div>';
|
|||
|
// 遍历MapID
|
|||
|
for (var key in MapID) {
|
|||
|
var map = new AMap.Map(key, {
|
|||
|
resizeEnable: true,
|
|||
|
center: [MapID[key][1], MapID[key][0]],
|
|||
|
zoom: MapID[key][3]
|
|||
|
});
|
|||
|
const position = new AMap.LngLat(MapID[key][1], MapID[key][0]); //Marker 经纬度
|
|||
|
|
|||
|
const marker = new AMap.Marker({
|
|||
|
position: position,
|
|||
|
// content: 'label', //将 html 传给 content
|
|||
|
// icon: "https://a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-red.png",
|
|||
|
content: markerContent,
|
|||
|
title: MapID[key][2],
|
|||
|
offset: new AMap.Pixel(-13, -30), //以 icon 的 [center bottom] 为原点
|
|||
|
});
|
|||
|
map.add(marker);
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
function messageMergeCard(message, zindex=1, index=0) {
|
|||
|
const messageMergeCardTag = document.createElement('div');
|
|||
|
messageMergeCardTag.className = `merge-message`;
|
|||
|
console.log("mergeMessage", message);
|
|||
|
if (message.description && message.description !== null) {
|
|||
|
const splitResults = message.description.split("\n");
|
|||
|
const firstTwoItems = splitResults.slice(0, 2);
|
|||
|
|
|||
|
messageMergeCardTag.innerHTML = `<div class="title">${message.title}</div>
|
|||
|
<div class="msg">${firstTwoItems[0]}</div>
|
|||
|
<div class="msg">${firstTwoItems[1]}</div>`;
|
|||
|
} else {
|
|||
|
messageMergeCardTag.innerHTML = `<div class="title">${message.title}</div>
|
|||
|
<div class="msg"></div>
|
|||
|
<div class="msg"></div>`;
|
|||
|
}
|
|||
|
const bottomTag = document.createElement('div');
|
|||
|
bottomTag.className = `bottom`;
|
|||
|
bottomTag.innerHTML = `<div class="text">聊天记录</div>`;
|
|||
|
messageMergeCardTag.appendChild(bottomTag);
|
|||
|
|
|||
|
messageMergeCardTag.addEventListener('click', function () {
|
|||
|
modalID = `${message.server_id}-${zindex}-${index}Modal`;
|
|||
|
var modal = document.getElementById(modalID);
|
|||
|
modal.style.display = "block";
|
|||
|
|
|||
|
var span = modal.querySelector('.close');
|
|||
|
|
|||
|
span.onclick = function () {
|
|||
|
modal.style.display = "none";
|
|||
|
}
|
|||
|
});
|
|||
|
return messageMergeCardTag;
|
|||
|
}
|
|||
|
|
|||
|
function innermessageMergeCard(message, zindex=1, index=0, parent_server_id=0) {
|
|||
|
const innerMsgMerge_card = document.createElement("div")
|
|||
|
innerMsgMerge_card.className = "inner-msgMerge-card"
|
|||
|
if (message.description && message.description !== null) {
|
|||
|
const splitResults = message.description.split("\n");
|
|||
|
const firstTwoItems = splitResults.slice(0, 2);
|
|||
|
innerMsgMerge_card.innerHTML = `<div class="title">${message.title}</div>
|
|||
|
<div class="desc">${firstTwoItems[0]}</div>
|
|||
|
<div class="desc">${firstTwoItems[1]}</div>`
|
|||
|
} else {
|
|||
|
innerMsgMerge_card.innerHTML = `<div class="title">${message.title}</div>
|
|||
|
<div class="desc"></div>
|
|||
|
<div class="desc"></div>`
|
|||
|
}
|
|||
|
|
|||
|
innerMsgMerge_card.addEventListener('click', function () {
|
|||
|
modalID = `${parent_server_id}-${zindex}-${index}Modal`;
|
|||
|
var modal = document.getElementById(modalID);
|
|||
|
modal.style.display = "block";
|
|||
|
|
|||
|
var span = modal.querySelector('.close');
|
|||
|
|
|||
|
span.onclick = function () {
|
|||
|
modal.style.display = "none";
|
|||
|
}
|
|||
|
});
|
|||
|
return innerMsgMerge_card
|
|||
|
}
|
|||
|
|
|||
|
function messageMergeModaltitle(message) {
|
|||
|
const messageMergeModaltitle = document.createElement('div');
|
|||
|
messageMergeModaltitle.className = `title`;
|
|||
|
if (message.title) {
|
|||
|
messageMergeModaltitle.innerHTML = `<span class="close">×</span>
|
|||
|
<div class="title">${message.title}</div>`;
|
|||
|
} else {
|
|||
|
messageMergeModaltitle.innerHTML = `<span class="close">×</span>
|
|||
|
<div class="title">${message.description}</div>`;
|
|||
|
}
|
|||
|
return messageMergeModaltitle;
|
|||
|
}
|
|||
|
|
|||
|
function messageMergeModal(message, messageContent, zindex, index=0, parent_server_id=0) {
|
|||
|
var message_MergeModal = document.createElement('div');
|
|||
|
message_MergeModal.className = `merge-msg-modal`;
|
|||
|
message_MergeModal.style.zIndex = zindex;
|
|||
|
if (parent_server_id == 0) {
|
|||
|
parent_server_id = message.server_id;
|
|||
|
}
|
|||
|
message_MergeModal.id = `${parent_server_id}-${zindex}-${index}Modal`;
|
|||
|
// if (message.server_id) {
|
|||
|
// message_MergeModal.id = `${message.server_id}-${zindex}-${index}Modal`;
|
|||
|
// } else {
|
|||
|
// message_MergeModal.id = `${message.dataid}Modal`;
|
|||
|
// }
|
|||
|
|
|||
|
var ModalContent = document.createElement('div');
|
|||
|
ModalContent.className = `merge-msg-modal-content`;
|
|||
|
ModalContent.appendChild(messageMergeModaltitle(message));
|
|||
|
|
|||
|
var ModalContainer = document.createElement('div');
|
|||
|
ModalContainer.className = `modal-container`;
|
|||
|
|
|||
|
if (message.messages.length == 0) {
|
|||
|
var OnePersonMsg = document.createElement('div');
|
|||
|
OnePersonMsg.className = `OnePersonmsg`;
|
|||
|
OnePersonMsg.innerHTML = `<div class="left">
|
|||
|
<div class="avatar"><img src="" loading="lazy"></div>
|
|||
|
</div>
|
|||
|
`;
|
|||
|
|
|||
|
var OnePersonMsgRight = document.createElement('div');
|
|||
|
OnePersonMsgRight.className = `right`;
|
|||
|
OnePersonMsg.appendChild(OnePersonMsgRight);
|
|||
|
ModalContainer.appendChild(OnePersonMsg);
|
|||
|
ModalContent.appendChild(ModalContainer);
|
|||
|
message_MergeModal.appendChild(ModalContent);
|
|||
|
return message_MergeModal;
|
|||
|
}
|
|||
|
|
|||
|
var OnePersonMsg = document.createElement('div');
|
|||
|
OnePersonMsg.className = `OnePersonmsg`;
|
|||
|
OnePersonMsg.innerHTML = `<div class="left">
|
|||
|
<div class="avatar"><img src="${message.messages[0].avatar_src}" loading="lazy"></div>
|
|||
|
</div>
|
|||
|
`;
|
|||
|
|
|||
|
var OnePersonMsgRight = document.createElement('div');
|
|||
|
OnePersonMsgRight.className = `right`;
|
|||
|
|
|||
|
|
|||
|
var lastsrcname = message.messages[0].display_name;
|
|||
|
// 遍历message.recorditem
|
|||
|
for (let i = 0; i < message.messages.length; i++) {
|
|||
|
var record = message.messages[i];
|
|||
|
var currentsrcname = record.display_name;
|
|||
|
if (currentsrcname != lastsrcname) {
|
|||
|
OnePersonMsg.appendChild(OnePersonMsgRight);
|
|||
|
ModalContainer.appendChild(OnePersonMsg);
|
|||
|
lastsrcname = currentsrcname;
|
|||
|
var OnePersonMsg = document.createElement('div');
|
|||
|
OnePersonMsg.className = `OnePersonmsg`;
|
|||
|
OnePersonMsg.innerHTML = `<div class="left">
|
|||
|
<div class="avatar"><img src="${record.avatar_src}" loading="lazy"></div>
|
|||
|
</div>
|
|||
|
`;
|
|||
|
var OnePersonMsgRight = document.createElement('div');
|
|||
|
OnePersonMsgRight.className = `right`;
|
|||
|
}
|
|||
|
const recordItem = document.createElement('div');
|
|||
|
recordItem.className = `msg-block`;
|
|||
|
// console.log("type:",record.type);
|
|||
|
if (record.type == MessageType.Text || record.type == MessageType.Audio) {
|
|||
|
// console.log(record.datadesc)
|
|||
|
// 文本消息
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>
|
|||
|
<div class="msg-container">${record.text}</div>`;
|
|||
|
} else if (record.type == MessageType.MergedMessages) {
|
|||
|
// 嵌套合并消息
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>`;
|
|||
|
recordItem.appendChild(innermessageMergeCard(record, zindex + 1, i, parent_server_id));
|
|||
|
// messageContent.appendChild(messageMergeModal(record, messageContent));
|
|||
|
messageContent.insertBefore(messageMergeModal(record, messageContent, zindex + 1, i, parent_server_id), messageContent.firstChild);
|
|||
|
} else if (record.type == MessageType.Video) {
|
|||
|
// 视频消息
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>
|
|||
|
<div class="msg-container"><video src="${record.path}" controls=""></video></div>`;
|
|||
|
} else if (record.type == MessageType.Image || record.type == MessageType.Emoji) {
|
|||
|
// 文件消息
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>`;
|
|||
|
recordItem.appendChild(messageImgBox(record));
|
|||
|
|
|||
|
} else if (record.type == MessageType.File) {
|
|||
|
// 文件消息
|
|||
|
record.icon_path = getFileIcon(record.datafmt)
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>`;
|
|||
|
recordItem.appendChild(messageFileBox(record));
|
|||
|
} else if (record.type == MessageType.Position) {
|
|||
|
// 文件消息
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>`;
|
|||
|
recordItem.appendChild(messageLocation(record, newMapID));
|
|||
|
} else if (record.type == MessageType.LinkMessage) {
|
|||
|
// 文件消息
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
|||
|
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>`;
|
|||
|
recordItem.appendChild(messageCard(record));
|
|||
|
}
|
|||
|
OnePersonMsgRight.appendChild(recordItem);
|
|||
|
}
|
|||
|
|
|||
|
OnePersonMsg.appendChild(OnePersonMsgRight);
|
|||
|
ModalContainer.appendChild(OnePersonMsg);
|
|||
|
ModalContent.appendChild(ModalContainer);
|
|||
|
message_MergeModal.appendChild(ModalContent);
|
|||
|
|
|||
|
function getFileIcon(datafmt) {
|
|||
|
icon_files = {
|
|||
|
'DOCX': ['doc', 'docx'],
|
|||
|
'XLS': ['xls', 'xlsx'],
|
|||
|
'CSV': ['csv'],
|
|||
|
'TXT': ['txt'],
|
|||
|
'ZIP': ['zip', '7z', 'rar'],
|
|||
|
'PPT': ['ppt', 'pptx'],
|
|||
|
'PDF': ['pdf'],
|
|||
|
}
|
|||
|
|
|||
|
for (var key in icon_files) {
|
|||
|
if (icon_files[key].includes(datafmt)) {
|
|||
|
return key
|
|||
|
}
|
|||
|
}
|
|||
|
return 'Default'
|
|||
|
}
|
|||
|
|
|||
|
return message_MergeModal;
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
function messageMiniProgram(message) {
|
|||
|
const message_MiniProgram = document.createElement('div');
|
|||
|
message_MiniProgram.className = `mini-program`;
|
|||
|
|
|||
|
message_MiniProgram.innerHTML = `<a href="${message.url}" target="_blank">
|
|||
|
<div class="top">
|
|||
|
<img src='${message.app_logo}' alt='logo'>
|
|||
|
<div class='text'>${message.app_name}</div>
|
|||
|
</div>
|
|||
|
<div class="title">${message.title}</div>
|
|||
|
<div class="cover"><img src='${message.cover_url}' onerror="this.style.display='none';"></div>
|
|||
|
<div class="bottom"><div class="text">小程序</div></div>
|
|||
|
</a>`;
|
|||
|
return message_MiniProgram;
|
|||
|
}
|
|||
|
|
|||
|
function messageVideoNumber(message) {
|
|||
|
const message_VideoNumber = document.createElement('div');
|
|||
|
message_VideoNumber.className = `video-number`;
|
|||
|
const message_VideoNumber_title = document.createElement('div');
|
|||
|
message_VideoNumber_title.className = `title`;
|
|||
|
const message_VideoNumber_container = document.createElement('div');
|
|||
|
message_VideoNumber_container.className = `container`;
|
|||
|
message_VideoNumber_container.style.backgroundImage = `url(${message.cover_url})`;
|
|||
|
message_VideoNumber_container.style.backgroundSize = "cover";
|
|||
|
message_VideoNumber_container.style.backgroundRepeat = "no-repeat";
|
|||
|
message_VideoNumber_title.innerHTML = replaceEmoji(message.title);
|
|||
|
message_VideoNumber_container.innerHTML = `
|
|||
|
<div class="bottom">
|
|||
|
<div class="author">
|
|||
|
<div class="logo"><img src='${message.publisher_avatar}' onerror="this.style.display='none';"></div>
|
|||
|
<div class="name">${message.publisher_nickname}</div>
|
|||
|
<div class="authIcon"><img src='${message.authIconUrl}' onerror="this.style.display='none';"></div>
|
|||
|
</div>
|
|||
|
</div>`;
|
|||
|
|
|||
|
message_VideoNumber.appendChild(message_VideoNumber_title);
|
|||
|
message_VideoNumber.appendChild(message_VideoNumber_container);
|
|||
|
|
|||
|
return message_VideoNumber;
|
|||
|
}
|
|||
|
|
|||
|
// 从数据列表中取出对应范围的元素并添加到容器中
|
|||
|
for (let i = startIndex; i < endIndex && i < ChatMsgIndex.length; i++) {
|
|||
|
const message = chatMessages[ChatMsgIndex[i]];
|
|||
|
console.log(message.type);
|
|||
|
console.log(message);
|
|||
|
add5MinTimeTag(message);
|
|||
|
const messageElement = document.createElement('div'); // 下面那俩的合体
|
|||
|
const avatarTag = avatarBox(message); // 头像
|
|||
|
const messageContent = document.createElement('div'); // 除了avatar之外的所有
|
|||
|
messageElement.setAttribute('id', message.server_id);
|
|||
|
const side = message.is_send ? "right" : "left";
|
|||
|
if (isChatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
if (message.type == MessageType.Text && is_valid_data(message.server_id, message.token)) {
|
|||
|
// displayname 和 bubble
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
messageContent.appendChild(messageBubble(message, side));
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.System) {
|
|||
|
messageElement.className = "item item-center";
|
|||
|
messageElement.innerHTML = `<span class="system-msg">${replaceEmoji(message.text.replace('\\"', '"'))}</span>`;
|
|||
|
} else if ((message.type == MessageType.Image || message.type == MessageType.Emoji)&& is_valid_data(message.server_id, message.token)) {
|
|||
|
// displayname 和 img
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
|
|||
|
messageContent.appendChild(messageImgBox(message));
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.Video && is_valid_data(message.server_id, message.token)) {
|
|||
|
// displayname 和 video
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
|
|||
|
messageContent.appendChild(messageVideoBox(message));
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.File) {
|
|||
|
console.log('file');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
messageContent.appendChild(messageFileBox(message));
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.Transfer) {
|
|||
|
console.log('Transfer');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageTransfer(message));
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.LinkMessage) {
|
|||
|
console.log('LinkMessage');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageCard(message));
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.Music) {
|
|||
|
console.log('LinkMessage');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageMusicAudioBox(message));
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.Applet) {
|
|||
|
console.log('LinkMessage');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageMiniProgram(message));
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.MergedMessages) {
|
|||
|
console.log('MergedMessages');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageMergeCard(message));
|
|||
|
// messageContent.appendChild(messageMergeModal(message, messageContent));
|
|||
|
messageContent.insertBefore(messageMergeModal(message, messageContent, 1), messageContent.firstChild);
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.Quote) {
|
|||
|
console.log('Quote');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageBubble(message, side));
|
|||
|
if (message.quote_text) {
|
|||
|
messageContent.appendChild(messageElementReferText(message, side));
|
|||
|
}
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.WeChatVideo) {
|
|||
|
console.log('WeChatVideo');
|
|||
|
// displayname 和 file
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageVideoNumber(message));
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == 49 && is_valid_data(message.server_id, message.token)) {
|
|||
|
if (message.sub_type == 57) {
|
|||
|
// displayname 和 bubble 和 refer
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageBubble(message, side));
|
|||
|
if (message.refer_text) {
|
|||
|
messageContent.appendChild(messageElementReferText(message, side));
|
|||
|
}
|
|||
|
|
|||
|
} else if (message.sub_type == 3 || message.sub_type == 76) {
|
|||
|
// music share
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageMusicAudioBox(message));
|
|||
|
} else if (message.sub_type == 5) {
|
|||
|
// displayname 和 card
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageCard(message));
|
|||
|
} else if (message.sub_type == 2000) {
|
|||
|
// displayname 和 messageTransfer
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageTransfer(message));
|
|||
|
} else if (message.sub_type == 19) {
|
|||
|
// displayname 和 messageMergeCard
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageMergeCard(message));
|
|||
|
// messageContent.appendChild(messageMergeModal(message, messageContent));
|
|||
|
messageContent.insertBefore(messageMergeModal(message, messageContent, 1), messageContent.firstChild);
|
|||
|
|
|||
|
} else if (message.sub_type == 33 || message.sub_type == 36) {
|
|||
|
// 小程序
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageMiniProgram(message));
|
|||
|
} else if (message.sub_type == 51) {
|
|||
|
// 视频号
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
if (message.is_chatroom && !message.is_send) {
|
|||
|
messageContent.appendChild(displayNameBox(message));
|
|||
|
}
|
|||
|
messageContent.appendChild(messageVideoNumber(message));
|
|||
|
}
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == 34 && is_valid_data(message.server_id, message.token)) {
|
|||
|
// displayname 和 转的文字 和 audio
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
|
|||
|
messageContent.appendChild(messageAudioBox(message));
|
|||
|
if (message.voice_to_text) {
|
|||
|
messageContent.appendChild(messageVoiceToTextBubble(message, side));
|
|||
|
}
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.Voip && is_valid_data(message.server_id, message.token)) {
|
|||
|
// displayname 和 转的文字 和 audio
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
|
|||
|
messageContent.appendChild(messageVideoAudioCall(message, side));
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == MessageType.BusinessCard) {
|
|||
|
// 个人名片
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
|
|||
|
messageContent.appendChild(MessageType.is_open_im?openIMCard(message):personalCard(message));
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
} else if (message.type == 48 && is_valid_data(message.server_id, message.token)) {
|
|||
|
// 定位
|
|||
|
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
|||
|
|
|||
|
messageContent.appendChild(messageLocation(message, newMapID));
|
|||
|
|
|||
|
// 整合
|
|||
|
messageElement.className = `item item-${side}`;
|
|||
|
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
|||
|
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
|||
|
}
|
|||
|
OnePageMessage.appendChild(messageElement);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
if (!reachedBottom && !reachedTop) {
|
|||
|
container.innerHTML = ''; // 清空容器
|
|||
|
lastScrollTop = 10;
|
|||
|
lastTimeStamp = 0;
|
|||
|
|
|||
|
chatContainer.appendChild(OnePageMessage);
|
|||
|
document.querySelector("#chat-container").scrollTop = lastScrollTop;
|
|||
|
|
|||
|
MapID = newMapID;
|
|||
|
} else if (reachedBottom) {
|
|||
|
|
|||
|
reachedBottom = false;
|
|||
|
|
|||
|
chatContainer.appendChild(OnePageMessage);
|
|||
|
document.querySelector("#chat-container").scrollTop = lastScrollTop;
|
|||
|
|
|||
|
Object.assign(MapID, newMapID);
|
|||
|
}
|
|||
|
else if (reachedTop) {
|
|||
|
lastTimeStamp = 0;
|
|||
|
reachedTop = false;
|
|||
|
var existingElement = chatContainer.firstChild; // 获取原有内容的第一个元素
|
|||
|
chatContainer.insertBefore(OnePageMessage, existingElement);
|
|||
|
|
|||
|
var targetSection = document.getElementById(String(endIndex));
|
|||
|
targetSection.scrollIntoView({ behavior: 'smooth' });
|
|||
|
Object.assign(MapID, newMapID);
|
|||
|
}
|
|||
|
// chatContainer.appendChild(OnePageMessage);
|
|||
|
// document.querySelector("#chat-container").scrollTop = lastScrollTop;
|
|||
|
// console.log("渲染完成"+lastScrollTop);
|
|||
|
updatePaginationInfo();
|
|||
|
refreshMediaListener();
|
|||
|
loadMap(MapID);
|
|||
|
}
|
|||
|
</script>
|
|||
|
<script>
|
|||
|
const chatContainer = document.getElementById('chat-container');
|
|||
|
|
|||
|
function checkEnter(event) {
|
|||
|
if (event.keyCode === 13) {
|
|||
|
gotoPage();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
var showID = 'All';
|
|||
|
// 在title-bar下添加menu-button
|
|||
|
const menuItems = [['全部', 'All'], ['图片和视频', 'Image'], ['文件', 'File'], ['链接', 'Link'], ['音乐和音频', 'Music'], ['交易', 'Transfer'], ['小程序', 'MiniProgram'], ['视频号', 'VideoNumber'], ['日期', 'Date'], ['搜索', 'Search']];
|
|||
|
for (let i = 0; i < menuItems.length; i++) {
|
|||
|
const menuItem = document.createElement('div');
|
|||
|
menuItem.classList.add('menu-button');
|
|||
|
menuItem.innerHTML = menuItems[i][0];
|
|||
|
menuItems[i][0] === '全部' ? menuItem.style.backgroundColor = '#aed18d' : menuItem.style.backgroundColor = '#fff';
|
|||
|
if (menuItems[i][0] === '日期') {
|
|||
|
menuItem.id = 'datepicker';
|
|||
|
}
|
|||
|
menuItem.addEventListener('click', function () {
|
|||
|
navbarNav.classList.toggle("show");
|
|||
|
// 清除所有menuItem背景颜色
|
|||
|
for (let j = 0; j < menuItems.length; j++) {
|
|||
|
document.getElementsByClassName('menu-button')[j].style.backgroundColor = '#fff';
|
|||
|
}
|
|||
|
menuItem.style.backgroundColor = '#aed18d';
|
|||
|
showID = menuItems[i][1];
|
|||
|
if (showID === 'All') {
|
|||
|
ChatMsgIndex = AllIndex;
|
|||
|
resetTimeline()
|
|||
|
|
|||
|
}
|
|||
|
else if (showID === 'Image') {
|
|||
|
ChatMsgIndex = ImageIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'File') {
|
|||
|
ChatMsgIndex = FileIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'Link') {
|
|||
|
ChatMsgIndex = LinkIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'Music') {
|
|||
|
ChatMsgIndex = MusicIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'Transfer') {
|
|||
|
ChatMsgIndex = TransferIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'MiniProgram') {
|
|||
|
ChatMsgIndex = MiniProgramIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'VideoNumber') {
|
|||
|
ChatMsgIndex = VideoNumberIndex;
|
|||
|
resetTimeline()
|
|||
|
}
|
|||
|
else if (showID === 'Search') {
|
|||
|
openSearchModal();
|
|||
|
}
|
|||
|
|
|||
|
reachedBottom = false;
|
|||
|
reachedTop = false;
|
|||
|
if (showID !== 'Date' && showID !== 'Search') {
|
|||
|
renderPage(1);
|
|||
|
}
|
|||
|
|
|||
|
});
|
|||
|
const titleTag = document.getElementById('topnavbar-nav');
|
|||
|
titleTag.appendChild(menuItem);
|
|||
|
}
|
|||
|
|
|||
|
const itemsPerPage = 100; // 每页显示的元素个数
|
|||
|
let currentPage = 1; // 当前页
|
|||
|
var reachedBottom = false; // 到达底部的标记
|
|||
|
var reachedTop = false; // 到达顶部的标记
|
|||
|
var lastScrollTop = 10;
|
|||
|
var lastTimeStamp = 0;
|
|||
|
|
|||
|
// search init
|
|||
|
|
|||
|
var idx = lunr(function () {
|
|||
|
this.use(lunr.zh);
|
|||
|
this.ref('server_id')
|
|||
|
this.field('text')
|
|||
|
|
|||
|
chatMessages.forEach(function (doc) {
|
|||
|
this.add(doc);
|
|||
|
}, this);
|
|||
|
});
|
|||
|
var missingDates = [];
|
|||
|
var today = new Date();
|
|||
|
var startDate = today;
|
|||
|
var endDate = today;
|
|||
|
if (chatMessages.length !== 0) {
|
|||
|
var startDate = new Date(chatMessages[0].timestamp * 1000);
|
|||
|
var endDate = new Date(chatMessages[chatMessages.length - 1].timestamp * 1000);
|
|||
|
|
|||
|
for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) {
|
|||
|
var dateStr = d.toISOString().split('T')[0];
|
|||
|
if (!dateDataMap[dateStr]) {
|
|||
|
missingDates.push(dateStr);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
var input = document.querySelector("#datepicker");
|
|||
|
var fp = flatpickr(input, {
|
|||
|
disable: missingDates,
|
|||
|
minDate: startDate.toISOString().split('T')[0],
|
|||
|
maxDate: endDate.toISOString().split('T')[0],
|
|||
|
dateFormat: "Y-m-d",
|
|||
|
onChange: function (selectedDates, dateStr, instance) {
|
|||
|
ChatMsgIndex = AllIndex;
|
|||
|
resetTimeline();
|
|||
|
var selectedDate = selectedDates[0];
|
|||
|
referId = dateDataMap[dateStr][1];
|
|||
|
lastPage = currentPage;
|
|||
|
currentPage = dateDataMap[dateStr][0];
|
|||
|
|
|||
|
if (lastPage != currentPage) {
|
|||
|
reachedBottom = false;
|
|||
|
reachedTop = false;
|
|||
|
renderPage(currentPage);
|
|||
|
}
|
|||
|
|
|||
|
var targetSection = document.getElementById(referId);
|
|||
|
targetSection.scrollIntoView({ block: 'start' });
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
ChatMsgIndex = AllIndex;
|
|||
|
var years = Object.keys(timelineData);
|
|||
|
function resetTimeline() {
|
|||
|
timelineData = {};
|
|||
|
PageTimeline = {};
|
|||
|
MsgSvrID_Page = {};
|
|||
|
for (let i = 0; i < ChatMsgIndex.length; i++) {
|
|||
|
const message = chatMessages[ChatMsgIndex[i]];
|
|||
|
const date = new Date(message.timestamp * 1000);
|
|||
|
const month = date.getMonth() + 1;
|
|||
|
const year = date.getFullYear();
|
|||
|
const curpage = Math.ceil((i + 1) / itemsPerPage);
|
|||
|
|
|||
|
MsgSvrID_Page[message.server_id] = curpage;
|
|||
|
|
|||
|
if (!timelineData[year]) {
|
|||
|
timelineData[year] = {};
|
|||
|
}
|
|||
|
if (!timelineData[year][month]) {
|
|||
|
timelineData[year][month] = [];
|
|||
|
timelineData[year][month].push(curpage);
|
|||
|
timelineData[year][month].push(message.MsgSvrID);
|
|||
|
}
|
|||
|
|
|||
|
if (!PageTimeline[curpage]) {
|
|||
|
PageTimeline[curpage] = {};
|
|||
|
PageTimeline[curpage]['year'] = year;
|
|||
|
PageTimeline[curpage]['month'] = month;
|
|||
|
}
|
|||
|
}
|
|||
|
years = Object.keys(timelineData);
|
|||
|
if (ChatMsgIndex.length !== 0)
|
|||
|
initialTimeline()
|
|||
|
currentPage = 1
|
|||
|
}
|
|||
|
|
|||
|
function initialTimeline() {
|
|||
|
var initialYear = years[0];
|
|||
|
var currentYear = initialYear;
|
|||
|
var initialMonths = Object.keys(timelineData[initialYear]);
|
|||
|
var initialMonth = initialMonths[0];
|
|||
|
const timeline = document.getElementById('timeline');
|
|||
|
timeline.innerHTML = '';
|
|||
|
for (let year of years) {
|
|||
|
const currentMonths = Object.keys(timelineData[year]);
|
|||
|
const yearIdElement = document.createElement('div');
|
|||
|
yearIdElement.setAttribute('id', String(year) + 'year');
|
|||
|
const yearElement = document.createElement('div');
|
|||
|
yearElement.classList.add('timeline-item-year');
|
|||
|
yearElement.innerHTML = `
|
|||
|
<div class="timeline-dot-year"></div>
|
|||
|
<div class="timeline-right">${year}</div>
|
|||
|
`;
|
|||
|
|
|||
|
// 点击年份,显示该年份的月份
|
|||
|
yearElement.addEventListener('click', function () {
|
|||
|
currentYear = year;
|
|||
|
toggleMonthsDisplay(String(year));
|
|||
|
});
|
|||
|
|
|||
|
yearIdElement.appendChild(yearElement);
|
|||
|
|
|||
|
for (let month = 1; month <= 12; month++) {
|
|||
|
const monthName = month < 10 ? '0' + month : month;
|
|||
|
const monthElement = document.createElement('div');
|
|||
|
monthElement.classList.add('timeline-item-month');
|
|||
|
|
|||
|
if (currentMonths.includes(String(month))) {
|
|||
|
// 有消息的月份,添加点击事件
|
|||
|
monthElement.addEventListener('click', function () {
|
|||
|
// toggleCurrentMonthDisplay(monthElement);
|
|||
|
var parentElement = monthElement.parentElement;
|
|||
|
var parentId = parentElement.id;
|
|||
|
var parentyear = parentId.match(/\d+/)[0];
|
|||
|
|
|||
|
var lastpage = currentPage
|
|||
|
currentPage = timelineData[parentyear][month][0];
|
|||
|
currentId = timelineData[parentyear][month][1];
|
|||
|
|
|||
|
if (lastpage !== currentPage)
|
|||
|
renderPage(currentPage);
|
|||
|
|
|||
|
var targetSection = document.getElementById(currentId);
|
|||
|
// 别删
|
|||
|
console.log(targetSection);
|
|||
|
targetSection.scrollIntoView({ block: 'start' });
|
|||
|
|
|||
|
toggleCurrentMonthDisplay(monthElement);
|
|||
|
toggleMonthsDisplay(parentyear);
|
|||
|
|
|||
|
});
|
|||
|
}
|
|||
|
else {
|
|||
|
// 没有消息的月份,字体颜色变灰
|
|||
|
monthElement.classList.add('no-msg-month');
|
|||
|
}
|
|||
|
if (year === initialYear) {
|
|||
|
if (String(month) === initialMonth) {
|
|||
|
monthElement.classList.add('current');
|
|||
|
}
|
|||
|
}
|
|||
|
else {
|
|||
|
monthElement.classList.add('hidden-month');
|
|||
|
}
|
|||
|
|
|||
|
monthElement.innerHTML = `
|
|||
|
<div class="timeline-dot-month"></div>
|
|||
|
<div class="timeline-right">${monthName}月</div>
|
|||
|
`;
|
|||
|
yearIdElement.appendChild(monthElement);
|
|||
|
}
|
|||
|
timeline.appendChild(yearIdElement);
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
function toggleMonthsDisplay(year) {
|
|||
|
// 遍历所有月份,给没有hidden-month类的元素添加hidden-month类
|
|||
|
const AllmonthElements = document.querySelectorAll('.timeline-item-month');
|
|||
|
AllmonthElements.forEach(monthElement => {
|
|||
|
// 如果该月份元素没有 hidden-month 类,则添加该类
|
|||
|
if (!monthElement.classList.contains('hidden-month')) {
|
|||
|
monthElement.classList.add('hidden-month');
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
const yearIdElement = document.getElementById(year + 'year');
|
|||
|
const monthElements = yearIdElement.querySelectorAll('.timeline-item-month');
|
|||
|
// const months = yearElement.children;
|
|||
|
monthElements.forEach(monthElement => {
|
|||
|
// 删除 .hidden-month 类属性
|
|||
|
monthElement.classList.remove('hidden-month');
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
function toggleCurrentMonthDisplay(monthElement) {
|
|||
|
lastmonthElement = document.querySelectorAll('.current');
|
|||
|
lastmonthElement[0].classList.remove('current');
|
|||
|
monthElement.classList.add('current');
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
if (chatMessages.length !== 0)
|
|||
|
initialTimeline()
|
|||
|
loader.style.display = "none";
|
|||
|
content.style.display = "flex"; // 显示内容
|
|||
|
function prevPage() {
|
|||
|
if (currentPage > 1) {
|
|||
|
currentPage--;
|
|||
|
reachedBottom = false;
|
|||
|
renderPage(currentPage);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
function nextPage() {
|
|||
|
const totalPages = Math.ceil(ChatMsgIndex.length / itemsPerPage);
|
|||
|
if (currentPage < totalPages) {
|
|||
|
reachedTop = false;
|
|||
|
currentPage++;
|
|||
|
renderPage(currentPage);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
function updatePaginationInfo() {
|
|||
|
const totalPages = Math.ceil(ChatMsgIndex.length / itemsPerPage);
|
|||
|
const paginationInfo = document.getElementById('gotoPage');
|
|||
|
paginationInfo.value = `${currentPage}`;
|
|||
|
}
|
|||
|
|
|||
|
function gotoPage() {
|
|||
|
const totalPages = Math.ceil(chatMessages.length / itemsPerPage);
|
|||
|
const inputElement = document.getElementById('gotoPage');
|
|||
|
const targetPage = parseInt(inputElement.value);
|
|||
|
|
|||
|
if (targetPage >= 1 && targetPage <= totalPages) {
|
|||
|
currentPage = targetPage;
|
|||
|
renderPage(currentPage);
|
|||
|
} else {
|
|||
|
alert('请输入有效的页码');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
function checkScroll() {
|
|||
|
var chatContainer = document.getElementById("chat-container");
|
|||
|
|
|||
|
// 检查滚动条是否滑到底部
|
|||
|
if (chatContainer.scrollHeight - chatContainer.scrollTop - 10 <= chatContainer.clientHeight) {
|
|||
|
// 如果滚动条在底部
|
|||
|
if (!reachedBottom) {
|
|||
|
// 设置标记并返回
|
|||
|
reachedBottom = true;
|
|||
|
lastScrollTop = chatContainer.scrollTop;
|
|||
|
}
|
|||
|
if (reachedBottom) {
|
|||
|
nextPage();
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
if (chatContainer.scrollTop < 5) {
|
|||
|
reachedTop = true;
|
|||
|
prevPage();
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// 初始化页面
|
|||
|
renderPage(currentPage);
|
|||
|
|
|||
|
function refreshMediaListener() {
|
|||
|
const audioTags = document.querySelectorAll('audio');
|
|||
|
const videoTags = document.querySelectorAll('video');
|
|||
|
|
|||
|
audioTags.forEach(audio => {
|
|||
|
audio.addEventListener('play', function () {
|
|||
|
pauseOtherMedia(audio);
|
|||
|
});
|
|||
|
});
|
|||
|
videoTags.forEach(video => {
|
|||
|
video.addEventListener('play', function () {
|
|||
|
pauseOtherMedia(video);
|
|||
|
});
|
|||
|
});
|
|||
|
|
|||
|
function pauseOtherMedia(currentMedia) {
|
|||
|
const audioTags = document.querySelectorAll('audio');
|
|||
|
const videoTags = document.querySelectorAll('video');
|
|||
|
audioTags.forEach(media => {
|
|||
|
if (media !== currentMedia && !media.paused) {
|
|||
|
media.pause();
|
|||
|
}
|
|||
|
});
|
|||
|
videoTags.forEach(media => {
|
|||
|
if (media !== currentMedia && !media.paused) {
|
|||
|
media.pause();
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
refreshMediaListener();
|
|||
|
|
|||
|
function showModal(image) {
|
|||
|
var modal = document.getElementById("modal");
|
|||
|
var modalImage = document.getElementById("modal-image");
|
|||
|
modal.style.display = "block";
|
|||
|
modalImage.src = image.src;
|
|||
|
// console.log(image.src);
|
|||
|
}
|
|||
|
|
|||
|
function is_valid_data(content, key) {
|
|||
|
return true;
|
|||
|
key_ = md5('sNZaKe6&YhpCVvB@3R:7:^5b!mZk|f"SEx3YITEQX4|$7gC-IMHGbGjUAO6Q' + content + 'v@:L7IyXYsY7u!yc~N+lA59AjBH$sMe:kj"];1VhGbN<aDMLCza0qdv`wa)~w_;').toString();
|
|||
|
return key_ === key;
|
|||
|
}
|
|||
|
|
|||
|
function hideModal() {
|
|||
|
var modal = document.getElementById("modal");
|
|||
|
modal.style.display = "none";
|
|||
|
}
|
|||
|
|
|||
|
function toggleAudio(buttonElm) {
|
|||
|
var audioPlayer = buttonElm.parentNode;
|
|||
|
var audio = audioPlayer.querySelector('audio');
|
|||
|
if (audio == null) {
|
|||
|
alert("该音频已失效或无法直接播放,有需要请点击音频链接查看")
|
|||
|
} else {
|
|||
|
if (audio.paused) {
|
|||
|
audio.play();
|
|||
|
buttonElm.classList.remove('paused');
|
|||
|
buttonElm.classList.add('playing');
|
|||
|
} else {
|
|||
|
audio.pause();
|
|||
|
buttonElm.classList.remove('playing');
|
|||
|
buttonElm.classList.add('paused');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
function openSearchModal() {
|
|||
|
document.getElementById("search-modal").style.display = "block";
|
|||
|
}
|
|||
|
|
|||
|
function closeSearchModal() {
|
|||
|
document.getElementById("search-modal").style.display = "none";
|
|||
|
}
|
|||
|
|
|||
|
function checkImageExists(url, callback) {
|
|||
|
var img = new Image();
|
|||
|
img.onload = function () {
|
|||
|
callback(true); // 图片存在
|
|||
|
};
|
|||
|
img.onerror = function () {
|
|||
|
callback(false); // 图片不存在
|
|||
|
};
|
|||
|
img.src = url;
|
|||
|
}
|
|||
|
|
|||
|
function avatarBox(message) {
|
|||
|
const avatarTag = document.createElement('div');
|
|||
|
avatarTag.className = "avatar";
|
|||
|
var avatar_path = '';
|
|||
|
// 使用示例
|
|||
|
// var imageUrl = avatarPaths[message.avatar_path];
|
|||
|
// checkImageExists(imageUrl, function (exists) {
|
|||
|
// if (exists) {
|
|||
|
// console.log('图片存在');
|
|||
|
// } else {
|
|||
|
// imageUrl = avatarUrls[message.avatar_path]
|
|||
|
// }
|
|||
|
// avatarTag.innerHTML = `<img src="${imageUrl}" loading="lazy" />`
|
|||
|
// });
|
|||
|
|
|||
|
var imageUrl = message.avatar_src;
|
|||
|
avatarTag.innerHTML = `<img src="${imageUrl}" loading="lazy" />`
|
|||
|
|
|||
|
return avatarTag;
|
|||
|
}
|
|||
|
|
|||
|
function renderResults(ID) {
|
|||
|
var message = chatMessages[ID["idx"]];
|
|||
|
// console.log(message.text)
|
|||
|
// avatarurl = avatarUrl(message);
|
|||
|
const date = new Date(message.timestamp * 1000);
|
|||
|
var dateStr = date.toISOString().split('T')[0];
|
|||
|
var displayname = ''
|
|||
|
if (message.display_name) {
|
|||
|
displayname = message.display_name;
|
|||
|
}
|
|||
|
if (message.type == MessageType.Text || message.type == MessageType.Text2 || message.type == MessageType.Quote) {
|
|||
|
var OnePersonMsg = document.createElement('div');
|
|||
|
OnePersonMsg.className = `OnePersonmsg`;
|
|||
|
OnePersonMsg.innerHTML = `<div class="left">`;
|
|||
|
const avatarTag = avatarBox(message);
|
|||
|
OnePersonMsg.appendChild(avatarTag);
|
|||
|
|
|||
|
var OnePersonMsgRight = document.createElement('div');
|
|||
|
OnePersonMsgRight.className = `right`;
|
|||
|
const recordItem = document.createElement('div');
|
|||
|
recordItem.className = `msg-block`;
|
|||
|
recordItem.innerHTML = `<div class="msg-container-top"><span>${displayname}</span>
|
|||
|
<span style="font-size: 12px;">${dateStr}</span></div>
|
|||
|
<div class="msg-container">${message.text}</div>`;
|
|||
|
OnePersonMsgRight.appendChild(recordItem);
|
|||
|
OnePersonMsg.appendChild(OnePersonMsgRight);
|
|||
|
const tooltip = document.createElement('div');
|
|||
|
tooltip.className = `tooltip`;
|
|||
|
tooltip.innerHTML = `双击跳转到该消息`;
|
|||
|
OnePersonMsg.appendChild(tooltip);
|
|||
|
OnePersonMsg.addEventListener('dblclick', function () {
|
|||
|
console.log('双击了消息')
|
|||
|
// 阻止默认的右键菜单
|
|||
|
event.preventDefault();
|
|||
|
closeSearchModal();
|
|||
|
referId = ID["server_id"];
|
|||
|
lastPage = currentPage;
|
|||
|
ChatMsgIndex = AllIndex;
|
|||
|
resetTimeline();
|
|||
|
currentPage = server_id_Page[String(referId)];
|
|||
|
reachedBottom = false;
|
|||
|
reachedTop = false;
|
|||
|
renderPage(currentPage);
|
|||
|
|
|||
|
var targetSection = document.getElementById(referId);
|
|||
|
targetSection.scrollIntoView({ block: 'start' });
|
|||
|
});
|
|||
|
return OnePersonMsg
|
|||
|
}
|
|||
|
else {
|
|||
|
return null;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
function getSearchResults() {
|
|||
|
document.getElementById('searchBox').addEventListener('input', function () {
|
|||
|
const query = document.getElementById('searchBox').value;
|
|||
|
console.log(query);
|
|||
|
const results = idx.search(query);
|
|||
|
if (results.length > 0) {
|
|||
|
|
|||
|
}
|
|||
|
const SearchMContent = document.getElementById('search-modal-content');
|
|||
|
var oldmodalContainer = SearchMContent.querySelector('.modal-container');
|
|||
|
if (oldmodalContainer) {
|
|||
|
oldmodalContainer.remove();
|
|||
|
}
|
|||
|
// 获取modal-container
|
|||
|
const modalContainer = document.createElement('div');
|
|||
|
modalContainer.className = `modal-container`;
|
|||
|
modalContainer.id = 'modal-container';
|
|||
|
const IDresults = [];
|
|||
|
results.forEach(result => {
|
|||
|
IDresults.push({ "idx": server_id_Idx[result.ref], "server_id": result.ref });
|
|||
|
});
|
|||
|
IDresults.sort((a, b) => a["idx"] - b["idx"]);
|
|||
|
IDresults.forEach(ID => {
|
|||
|
// console.log(chatMessages[ID].text);
|
|||
|
var OnePersonMsg = renderResults(ID)
|
|||
|
if (OnePersonMsg) {
|
|||
|
modalContainer.appendChild(OnePersonMsg);
|
|||
|
}
|
|||
|
});
|
|||
|
SearchMContent.appendChild(modalContainer);
|
|||
|
|
|||
|
<!-- 添加提示信息 -->
|
|||
|
|
|||
|
document.getElementById('modal-container').querySelectorAll('.OnePersonmsg').forEach(element => {
|
|||
|
console.log('添加提示信息');
|
|||
|
const tooltip = element.querySelector('.tooltip');
|
|||
|
// console.log(tooltip);
|
|||
|
|
|||
|
// 显示提示文本
|
|||
|
element.addEventListener('mouseover', () => {
|
|||
|
tooltip.style.display = 'block';
|
|||
|
});
|
|||
|
|
|||
|
// 隐藏提示文本
|
|||
|
element.addEventListener('mouseout', () => {
|
|||
|
tooltip.style.display = 'none';
|
|||
|
});
|
|||
|
|
|||
|
// 更新提示文本位置
|
|||
|
element.addEventListener('mousemove', (event) => {
|
|||
|
const xOffset = 10;
|
|||
|
const yOffset = 20;
|
|||
|
tooltip.style.left = (event.pageX + xOffset) + 'px';
|
|||
|
tooltip.style.top = (event.pageY + yOffset) + 'px';
|
|||
|
});
|
|||
|
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
getSearchResults();
|
|||
|
</script>
|
|||
|
</body>
|
|||
|
|
|||
|
</html>
|