mirror of
https://github.com/LC044/WeChatMsg
synced 2025-04-11 17:28:01 +08:00
5435 lines
409 KiB
HTML
5435 lines
409 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._magnitude = void 0; var i = this.list; if (!i) return this.list = new t.Vector.Node(e, n, i), this.length++; if (e < i.idx) return this.list = new t.Vector.Node(e, n, i), this.length++; for (var r = i, o = i.next; void 0 != o;) { if (e < o.idx) return r.next = new t.Vector.Node(e, n, o), this.length++; r = o, o = o.next } return r.next = new t.Vector.Node(e, n, o), this.length++ }, t.Vector.prototype.magnitude = function () { if (this._magnitude) return this._magnitude; for (var t, e = this.list, n = 0; e;)t = e.val, n += t * t, e = e.next; return this._magnitude = Math.sqrt(n) }, t.Vector.prototype.dot = function (t) { for (var e = this.list, n = t.list, i = 0; e && n;)e.idx < n.idx ? e = e.next : e.idx > n.idx ? n = n.next : (i += e.val * n.val, e = e.next, n = n.next); return i }, t.Vector.prototype.similarity = function (t) { return this.dot(t) / (this.magnitude() * t.magnitude()) }, t.SortedSet = function () { this.length = 0, this.elements = [] }, t.SortedSet.load = function (t) { var e = new this; return e.elements = t, e.length = t.length, e }, t.SortedSet.prototype.add = function () { var t, e; for (t = 0; t < arguments.length; t++)e = arguments[t], ~this.indexOf(e) || this.elements.splice(this.locationFor(e), 0, e); this.length = this.elements.length }, t.SortedSet.prototype.toArray = function () { return this.elements.slice() }, t.SortedSet.prototype.map = function (t, e) { return this.elements.map(t, e) }, t.SortedSet.prototype.forEach = function (t, e) { return this.elements.forEach(t, e) }, t.SortedSet.prototype.indexOf = function (t) { for (var e = 0, n = this.elements.length, i = n - e, r = e + Math.floor(i / 2), o = this.elements[r]; i > 1;) { if (o === t) return r; t > o && (e = r), o > t && (n = r), i = n - e, r = e + Math.floor(i / 2), o = this.elements[r] } return o === t ? r : -1 }, t.SortedSet.prototype.locationFor = function (t) { for (var e = 0, n = this.elements.length, i = n - e, r = e + Math.floor(i / 2), o = this.elements[r]; i > 1;)t > o && (e = r), o > t && (n = r), i = n - e, r = e + Math.floor(i / 2), o = this.elements[r]; return o > t ? r : t > o ? r + 1 : void 0 }, t.SortedSet.prototype.intersect = function (e) { for (var n = new t.SortedSet, i = 0, r = 0, o = this.length, s = e.length, a = this.elements, h = e.elements; ;) { if (i > o - 1 || r > s - 1) break; a[i] !== h[r] ? a[i] < h[r] ? i++ : a[i] > h[r] && r++ : (n.add(a[i]), i++, r++) } return n }, t.SortedSet.prototype.clone = function () { var e = new t.SortedSet; return e.elements = this.toArray(), e.length = e.elements.length, e }, t.SortedSet.prototype.union = function (t) { var e, n, i; this.length >= t.length ? (e = this, n = t) : (e = t, n = this), i = e.clone(); for (var r = 0, o = n.toArray(); r < o.length; r++)i.add(o[r]); return i }, t.SortedSet.prototype.toJSON = function () { return this.toArray() }, t.Index = function () { this._fields = [], this._ref = "id", this.pipeline = new t.Pipeline, this.documentStore = new t.Store, this.tokenStore = new t.TokenStore, this.corpusTokens = new t.SortedSet, this.eventEmitter = new t.EventEmitter, this.tokenizerFn = t.tokenizer, this._idfCache = {}, this.on("add", "remove", "update", function () { this._idfCache = {} }.bind(this)) }, t.Index.prototype.on = function () { var t = Array.prototype.slice.call(arguments); return this.eventEmitter.addListener.apply(this.eventEmitter, t) }, t.Index.prototype.off = function (t, e) { return this.eventEmitter.removeListener(t, e) }, t.Index.load = function (e) { e.version !== t.version && t.utils.warn("version mismatch: current " + t.version + " importing " + e.version); var n = new this; return n._fields = e.fields, n._ref = e.ref, n.tokenizer = t.tokenizer.load(e.tokenizer), n.documentStore = t.Store.load(e.documentStore), n.tokenStore = t.TokenStore.load(e.tokenStore), n.corpusTokens = t.SortedSet.load(e.corpusTokens), n.pipeline = t.Pipeline.load(e.pipeline), n }, t.Index.prototype.field = function (t, e) { var e = e || {}, n = { name: t, boost: e.boost || 1 }; return this._fields.push(n), this }, t.Index.prototype.ref = function (t) { return this._ref = t, this }, t.Index.prototype.tokenizer = function (e) { var n = e.label && e.label in t.tokenizer.registeredFunctions; return n || t.utils.warn("Function is not a registered tokenizer. This may cause problems when serialising the index"), this.tokenizerFn = e, this }, t.Index.prototype.add = function (e, n) { var i = {}, r = new t.SortedSet, o = e[this._ref], n = void 0 === n ? !0 : n; this._fields.forEach(function (t) { var n = this.pipeline.run(this.tokenizerFn(e[t.name])); i[t.name] = n; for (var o = 0; o < n.length; o++) { var s = n[o]; r.add(s), this.corpusTokens.add(s) } }, this), this.documentStore.set(o, r); for (var s = 0; s < r.length; s++) { for (var a = r.elements[s], h = 0, u = 0; u < this._fields.length; u++) { var l = this._fields[u], c = i[l.name], f = c.length; if (f) { for (var d = 0, p = 0; f > p; p++)c[p] === a && d++; h += d / f * l.boost } } this.tokenStore.add(a, { ref: o, tf: h }) } n && this.eventEmitter.emit("add", e, this) }, t.Index.prototype.remove = function (t, e) { var n = t[this._ref], e = void 0 === e ? !0 : e; if (this.documentStore.has(n)) { var i = this.documentStore.get(n); this.documentStore.remove(n), i.forEach(function (t) { this.tokenStore.remove(t, n) }, this), e && this.eventEmitter.emit("remove", t, this) } }, t.Index.prototype.update = function (t, e) { var e = void 0 === e ? !0 : e; this.remove(t, !1), this.add(t, !1), e && this.eventEmitter.emit("update", t, this) }, t.Index.prototype.idf = function (t) { var e = "@" + t; if (Object.prototype.hasOwnProperty.call(this._idfCache, e)) return this._idfCache[e]; var n = this.tokenStore.count(t), i = 1; return n > 0 && (i = 1 + Math.log(this.documentStore.length / n)), this._idfCache[e] = i }, t.Index.prototype.search = function (e) { var n = this.pipeline.run(this.tokenizerFn(e)), i = new t.Vector, r = [], o = this._fields.reduce(function (t, e) { return t + e.boost }, 0), s = n.some(function (t) { return this.tokenStore.has(t) }, this); if (!s) return []; n.forEach(function (e, n, s) { var a = 1 / s.length * this._fields.length * o, h = this, u = this.tokenStore.expand(e).reduce(function (n, r) { var o = h.corpusTokens.indexOf(r), s = h.idf(r), u = 1, l = new t.SortedSet; if (r !== e) { var c = Math.max(3, r.length - e.length); u = 1 / Math.log(c) } o > -1 && i.insert(o, a * s * u); for (var f = h.tokenStore.get(r), d = Object.keys(f), p = d.length, v = 0; p > v; v++)l.add(f[d[v]].ref); return n.union(l) }, new t.SortedSet); r.push(u) }, this); var a = r.reduce(function (t, e) { return t.intersect(e) }); return a.map(function (t) { return { ref: t, score: i.similarity(this.documentVector(t)) } }, this).sort(function (t, e) { return e.score - t.score }) }, t.Index.prototype.documentVector = function (e) { for (var n = this.documentStore.get(e), i = n.length, r = new t.Vector, o = 0; i > o; o++) { var s = n.elements[o], a = this.tokenStore.get(s)[e].tf, h = this.idf(s); r.insert(this.corpusTokens.indexOf(s), a * h) } return r }, t.Index.prototype.toJSON = function () { return { version: t.version, fields: this._fields, ref: this._ref, tokenizer: this.tokenizerFn.label, documentStore: this.documentStore.toJSON(), tokenStore: this.tokenStore.toJSON(), corpusTokens: this.corpusTokens.toJSON(), pipeline: this.pipeline.toJSON() } }, t.Index.prototype.use = function (t) { var e = Array.prototype.slice.call(arguments, 1); e.unshift(this), t.apply(this, e) }, t.Store = function () { this.store = {}, this.length = 0 }, t.Store.load = function (e) { var n = new this; return n.length = e.length, n.store = Object.keys(e.store).reduce(function (n, i) { return n[i] = t.SortedSet.load(e.store[i]), n }, {}), n }, t.Store.prototype.set = function (t, e) { this.has(t) || this.length++, this.store[t] = e }, t.Store.prototype.get = function (t) { return this.store[t] }, t.Store.prototype.has = function (t) { return t in this.store }, t.Store.prototype.remove = function (t) { this.has(t) && (delete this.store[t], this.length--) }, t.Store.prototype.toJSON = function () { return { store: this.store, length: this.length } }, t.stemmer = function () { var t = { ational: "ate", tional: "tion", enci: "ence", anci: "ance", izer: "ize", bli: "ble", alli: "al", entli: "ent", eli: "e", ousli: "ous", ization: "ize", ation: "ate", ator: "ate", alism: "al", iveness: "ive", fulness: "ful", ousness: "ous", aliti: "al", iviti: "ive", biliti: "ble", logi: "log" }, e = { icate: "ic", ative: "", alize: "al", iciti: "ic", ical: "ic", ful: "", ness: "" }, n = "[^aeiou]", i = "[aeiouy]", r = n + "[^aeiouy]*", o = i + "[aeiou]*", s = "^(" + r + ")?" + o + r, a = "^(" + r + ")?" + o + r + "(" + o + ")?$", h = "^(" + r + ")?" + o + r + o + r, u = "^(" + r + ")?" + i, l = new RegExp(s), c = new RegExp(h), f = new RegExp(a), d = new RegExp(u), p = /^(.+?)(ss|i)es$/, v = /^(.+?)([^s])s$/, g = /^(.+?)eed$/, m = /^(.+?)(ed|ing)$/, y = /.$/, S = /(at|bl|iz)$/, w = new RegExp("([^aeiouylsz])\\1$"), k = new RegExp("^" + r + i + "[^aeiouwxy]$"), x = /^(.+?[^aeiou])y$/, b = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/, E = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/, F = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/, _ = /^(.+?)(s|t)(ion)$/, z = /^(.+?)e$/, O = /ll$/, P = new RegExp("^" + r + i + "[^aeiouwxy]$"), T = function (n) { var i, r, o, s, a, h, u; if (n.length < 3) return n; if (o = n.substr(0, 1), "y" == o && (n = o.toUpperCase() + n.substr(1)), s = p, a = v, s.test(n) ? n = n.replace(s, "$1$2") : a.test(n) && (n = n.replace(a, "$1$2")), s = g, a = m, s.test(n)) { var T = s.exec(n); s = l, s.test(T[1]) && (s = y, n = n.replace(s, "")) } else if (a.test(n)) { var T = a.exec(n); i = T[1], a = d, a.test(i) && (n = i, a = S, h = w, u = k, a.test(n) ? n += "e" : h.test(n) ? (s = y, n = n.replace(s, "")) : u.test(n) && (n += "e")) } if (s = x, s.test(n)) { var T = s.exec(n); i = T[1], n = i + "i" } if (s = b, s.test(n)) { var T = s.exec(n); i = T[1], r = T[2], s = l, s.test(i) && (n = i + t[r]) } if (s = E, s.test(n)) { var T = s.exec(n); i = T[1], r = T[2], s = l, s.test(i) && (n = i + e[r]) } if (s = F, a = _, s.test(n)) { var T = s.exec(n); i = T[1], s = c, s.test(i) && (n = i) } else if (a.test(n)) { var T = a.exec(n); i = T[1] + T[2], a = c, a.test(i) && (n = i) } if (s = z, s.test(n)) { var T = s.exec(n); i = T[1], s = c, a = f, h = P, (s.test(i) || a.test(i) && !h.test(i)) && (n = i) } return s = O, a = c, s.test(n) && a.test(n) && (s = y, n = n.replace(s, "")), "y" == o && (n = o.toLowerCase() + n.substr(1)), n }; return T }(), t.Pipeline.registerFunction(t.stemmer, "stemmer"), t.generateStopWordFilter = function (t) { var e = t.reduce(function (t, e) { return t[e] = e, t }, {}); return function (t) { return t && e[t] !== t ? t : void 0 } }, t.stopWordFilter = t.generateStopWordFilter(["a", "able", "about", "across", "after", "all", "almost", "also", "am", "among", "an", "and", "any", "are", "as", "at", "be", "because", "been", "but", "by", "can", "cannot", "could", "dear", "did", "do", "does", "either", "else", "ever", "every", "for", "from", "get", "got", "had", "has", "have", "he", "her", "hers", "him", "his", "how", "however", "i", "if", "in", "into", "is", "it", "its", "just", "least", "let", "like", "likely", "may", "me", "might", "most", "must", "my", "neither", "no", "nor", "not", "of", "off", "often", "on", "only", "or", "other", "our", "own", "rather", "said", "say", "says", "she", "should", "since", "so", "some", "than", "that", "the", "their", "them", "then", "there", "these", "they", "this", "tis", "to", "too", "twas", "us", "wants", "was", "we", "were", "what", "when", "where", "which", "while", "who", "whom", "why", "will", "with", "would", "yet", "you", "your"]), t.Pipeline.registerFunction(t.stopWordFilter, "stopWordFilter"), t.trimmer = function (t) { return t.replace(/^\W+/, "").replace(/\W+$/, "") }, t.Pipeline.registerFunction(t.trimmer, "trimmer"), t.TokenStore = function () { this.root = { docs: {} }, this.length = 0 }, t.TokenStore.load = function (t) { var e = new this; return e.root = t.root, e.length = t.length, e }, t.TokenStore.prototype.add = function (t, e, n) { var n = n || this.root, i = t.charAt(0), r = t.slice(1); return i in n || (n[i] = { docs: {} }), 0 === r.length ? (n[i].docs[e.ref] = e, void (this.length += 1)) : this.add(r, e, n[i]) }, t.TokenStore.prototype.has = function (t) { if (!t) return !1; for (var e = this.root, n = 0; n < t.length; n++) { if (!e[t.charAt(n)]) return !1; e = e[t.charAt(n)] } return !0 }, t.TokenStore.prototype.getNode = function (t) { if (!t) return {}; for (var e = this.root, n = 0; n < t.length; n++) { if (!e[t.charAt(n)]) return {}; e = e[t.charAt(n)] } return e }, t.TokenStore.prototype.get = function (t, e) { return this.getNode(t, e).docs || {} }, t.TokenStore.prototype.count = function (t, e) { return Object.keys(this.get(t, e)).length }, t.TokenStore.prototype.remove = function (t, e) { if (t) { for (var n = this.root, i = 0; i < t.length; i++) { if (!(t.charAt(i) in n)) return; n = n[t.charAt(i)] } delete n.docs[e] } }, t.TokenStore.prototype.expand = function (t, e) { var n = this.getNode(t), i = n.docs || {}, e = e || []; return Object.keys(i).length && e.push(t), Object.keys(n).forEach(function (n) { "docs" !== n && e.concat(this.expand(t + n, e)) }, this), e }, t.TokenStore.prototype.toJSON = function () { return { root: this.root, length: this.length } }, function (t, e) { "function" == typeof define && define.amd ? define(e) : "object" == typeof exports ? module.exports = e() : t.lunr = e() }(this, function () { return t }) }();
|
||
</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 += 1)u[r] = 909522486 ^ o[r], c[r] = 1549556828 ^ o[r]; return e = i(u.concat(d(t)), 512 + 8 * t.length), a(i(c.concat(e), 640)) } function g(n) { var t, r, e = ""; for (r = 0; r < n.length; r += 1)t = n.charCodeAt(r), e += "0123456789abcdef".charAt(t >>> 4 & 15) + "0123456789abcdef".charAt(15 & t); return e } function v(n) { return unescape(encodeURIComponent(n)) } function m(n) { return h(v(n)) } function p(n) { return g(m(n)) } function s(n, t) { return l(v(n), v(t)) } function C(n, t) { return g(s(n, t)) } function A(n, t, r) { return t ? r ? s(t, n) : C(t, n) : r ? m(n) : p(n) } "function" == typeof define && define.amd ? define(function () { return A }) : "object" == typeof module && module.exports ? module.exports = A : n.md5 = A }(this);
|
||
</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 (!0 === t) return e.classList.add(n); e.classList.remove(n) } function d(e, n, t) { var a = window.document.createElement(e); return n = n || "", t = t || "", a.className = n, void 0 !== t && (a.textContent = t), a } function u(e) { for (; e.firstChild;)e.removeChild(e.firstChild) } function f(e, n) { return n(e) ? e : e.parentNode ? f(e.parentNode, n) : void 0 } function m(e, n) { var t = d("div", "numInputWrapper"), a = d("input", "numInput " + e), i = d("span", "arrowUp"), o = d("span", "arrowDown"); if (-1 === navigator.userAgent.indexOf("MSIE 9.0") ? a.type = "number" : (a.type = "text", a.pattern = "\\d*"), void 0 !== n) for (var r in n) a.setAttribute(r, n[r]); return t.appendChild(a), t.appendChild(i), t.appendChild(o), t } function g(e) { try { return "function" == typeof e.composedPath ? e.composedPath()[0] : e.target } catch (n) { return e.target } } var p = function () { }, h = function (e, n, t) { return t.months[n ? "shorthand" : "longhand"][e] }, v = { D: p, F: function (e, n, t) { e.setMonth(t.months.longhand.indexOf(n)) }, G: function (e, n) { e.setHours((e.getHours() >= 12 ? 12 : 0) + parseFloat(n)) }, H: function (e, n) { e.setHours(parseFloat(n)) }, J: function (e, n) { e.setDate(parseFloat(n)) }, K: function (e, n, t) { e.setHours(e.getHours() % 12 + 12 * r(new RegExp(t.amPM[1], "i").test(n))) }, M: function (e, n, t) { e.setMonth(t.months.shorthand.indexOf(n)) }, S: function (e, n) { e.setSeconds(parseFloat(n)) }, U: function (e, n) { return new Date(1e3 * parseFloat(n)) }, W: function (e, n, t) { var a = parseInt(n), i = new Date(e.getFullYear(), 0, 2 + 7 * (a - 1), 0, 0, 0, 0); return i.setDate(i.getDate() - i.getDay() + t.firstDayOfWeek), i }, Y: function (e, n) { e.setFullYear(parseFloat(n)) }, Z: function (e, n) { return new Date(n) }, d: function (e, n) { e.setDate(parseFloat(n)) }, h: function (e, n) { e.setHours((e.getHours() >= 12 ? 12 : 0) + parseFloat(n)) }, i: function (e, n) { e.setMinutes(parseFloat(n)) }, j: function (e, n) { e.setDate(parseFloat(n)) }, l: p, m: function (e, n) { e.setMonth(parseFloat(n) - 1) }, n: function (e, n) { e.setMonth(parseFloat(n) - 1) }, s: function (e, n) { e.setSeconds(parseFloat(n)) }, u: function (e, n) { return new Date(parseFloat(n)) }, w: p, y: function (e, n) { e.setFullYear(2e3 + parseFloat(n)) } }, D = { D: "", F: "", G: "(\\d\\d|\\d)", H: "(\\d\\d|\\d)", J: "(\\d\\d|\\d)\\w+", K: "", M: "", S: "(\\d\\d|\\d)", U: "(.+)", W: "(\\d\\d|\\d)", Y: "(\\d{4})", Z: "(.+)", d: "(\\d\\d|\\d)", h: "(\\d\\d|\\d)", i: "(\\d\\d|\\d)", j: "(\\d\\d|\\d)", l: "", m: "(\\d\\d|\\d)", n: "(\\d\\d|\\d)", s: "(\\d\\d|\\d)", u: "(.+)", w: "(\\d\\d|\\d)", y: "(\\d{2})" }, w = { Z: function (e) { return e.toISOString() }, D: function (e, n, t) { return n.weekdays.shorthand[w.w(e, n, t)] }, F: function (e, n, t) { return h(w.n(e, n, t) - 1, !1, n) }, G: function (e, n, t) { return o(w.h(e, n, t)) }, H: function (e) { return o(e.getHours()) }, J: function (e, n) { return void 0 !== n.ordinal ? e.getDate() + n.ordinal(e.getDate()) : e.getDate() }, K: function (e, n) { return n.amPM[r(e.getHours() > 11)] }, M: function (e, n) { return h(e.getMonth(), !0, n) }, S: function (e) { return o(e.getSeconds()) }, U: function (e) { return e.getTime() / 1e3 }, W: function (e, n, t) { return t.getWeek(e) }, Y: function (e) { return o(e.getFullYear(), 4) }, d: function (e) { return o(e.getDate()) }, h: function (e) { return e.getHours() % 12 ? e.getHours() % 12 : 12 }, i: function (e) { return o(e.getMinutes()) }, j: function (e) { return e.getDate() }, l: function (e, n) { return n.weekdays.longhand[e.getDay()] }, m: function (e) { return o(e.getMonth() + 1) }, n: function (e) { return e.getMonth() + 1 }, s: function (e) { return e.getSeconds() }, u: function (e) { return e.getTime() }, w: function (e) { return e.getDay() }, y: function (e) { return String(e.getFullYear()).substring(2) } }, b = function (e) { var n = e.config, t = void 0 === n ? a : n, o = e.l10n, r = void 0 === o ? i : o, l = e.isMobile, c = void 0 !== l && l; return function (e, n, a) { var i = a || r; return void 0 === t.formatDate || c ? n.split("").map((function (n, a, o) { return w[n] && "\\" !== o[a - 1] ? w[n](e, i, t) : "\\" !== n ? n : "" })).join("") : t.formatDate(e, n, i) } }, C = function (e) { var n = e.config, t = void 0 === n ? a : n, o = e.l10n, r = void 0 === o ? i : o; return function (e, n, i, o) { if (0 === e || e) { var l, c = o || r, s = e; if (e instanceof Date) l = new Date(e.getTime()); else if ("string" != typeof e && void 0 !== e.toFixed) l = new Date(e); else if ("string" == typeof e) { var d = n || (t || a).dateFormat, u = String(e).trim(); if ("today" === u) l = new Date, i = !0; else if (t && t.parseDate) l = t.parseDate(e, d); else if (/Z$/.test(u) || /GMT$/.test(u)) l = new Date(e); else { for (var f = void 0, m = [], g = 0, p = 0, h = ""; g < d.length; g++) { var w = d[g], b = "\\" === w, C = "\\" === d[g - 1] || b; if (D[w] && !C) { h += D[w]; var M = new RegExp(h).exec(e); M && (f = !0) && m["Y" !== w ? "push" : "unshift"]({ fn: v[w], val: M[++p] }) } else b || (h += ".") } l = t && t.noCalendar ? new Date((new Date).setHours(0, 0, 0, 0)) : new Date((new Date).getFullYear(), 0, 1, 0, 0, 0, 0), m.forEach((function (e) { var n = e.fn, t = e.val; return l = n(l, t, c) || l })), l = f ? l : void 0 } } if (l instanceof Date && !isNaN(l.getTime())) return !0 === i && l.setHours(0, 0, 0, 0), l; t.errorHandler(new Error("Invalid date provided: " + s)) } } }; function M(e, n, t) { return void 0 === t && (t = !0), !1 !== t ? new Date(e.getTime()).setHours(0, 0, 0, 0) - new Date(n.getTime()).setHours(0, 0, 0, 0) : e.getTime() - n.getTime() } var y = function (e, n, t) { return 3600 * e + 60 * n + t }, x = 864e5; function E(e) { var n = e.defaultHour, t = e.defaultMinute, a = e.defaultSeconds; if (void 0 !== e.minDate) { var i = e.minDate.getHours(), o = e.minDate.getMinutes(), r = e.minDate.getSeconds(); n < i && (n = i), n === i && t < o && (t = o), n === i && t === o && a < r && (a = e.minDate.getSeconds()) } if (void 0 !== e.maxDate) { var l = e.maxDate.getHours(), c = e.maxDate.getMinutes(); (n = Math.min(n, l)) === l && (t = Math.min(c, t)), n === l && t === c && (a = e.maxDate.getSeconds()) } return { hours: n, minutes: t, seconds: a } } "function" != typeof Object.assign && (Object.assign = function (e) { for (var n = [], t = 1; t < arguments.length; t++)n[t - 1] = arguments[t]; if (!e) throw TypeError("Cannot convert undefined or null to object"); for (var a = function (n) { n && Object.keys(n).forEach((function (t) { return e[t] = n[t] })) }, i = 0, o = n; i < o.length; i++) { var r = o[i]; a(r) } return e }); function k(p, v) { var w = { config: e(e({}, a), I.defaultConfig), l10n: i }; function k() { var e; return (null === (e = w.calendarContainer) || void 0 === e ? void 0 : e.getRootNode()).activeElement || document.activeElement } function T(e) { return e.bind(w) } function S() { var e = w.config; !1 === e.weekNumbers && 1 === e.showMonths || !0 !== e.noCalendar && window.requestAnimationFrame((function () { if (void 0 !== w.calendarContainer && (w.calendarContainer.style.visibility = "hidden", w.calendarContainer.style.display = "block"), void 0 !== w.daysContainer) { var n = (w.days.offsetWidth + 1) * e.showMonths; w.daysContainer.style.width = n + "px", w.calendarContainer.style.width = n + (void 0 !== w.weekWrapper ? w.weekWrapper.offsetWidth : 0) + "px", w.calendarContainer.style.removeProperty("visibility"), w.calendarContainer.style.removeProperty("display") } })) } function _(e) { if (0 === w.selectedDates.length) { var n = void 0 === w.config.minDate || M(new Date, w.config.minDate) >= 0 ? new Date : new Date(w.config.minDate.getTime()), t = E(w.config); n.setHours(t.hours, t.minutes, t.seconds, n.getMilliseconds()), w.selectedDates = [n], w.latestSelectedDateObj = n } void 0 !== e && "blur" !== e.type && function (e) { e.preventDefault(); var n = "keydown" === e.type, t = g(e), a = t; void 0 !== w.amPM && t === w.amPM && (w.amPM.textContent = w.l10n.amPM[r(w.amPM.textContent === w.l10n.amPM[0])]); var i = parseFloat(a.getAttribute("min")), l = parseFloat(a.getAttribute("max")), c = parseFloat(a.getAttribute("step")), s = parseInt(a.value, 10), d = e.delta || (n ? 38 === e.which ? 1 : -1 : 0), u = s + c * d; if (void 0 !== a.value && 2 === a.value.length) { var f = a === w.hourElement, m = a === w.minuteElement; u < i ? (u = l + u + r(!f) + (r(f) && r(!w.amPM)), m && L(void 0, -1, w.hourElement)) : u > l && (u = a === w.hourElement ? u - l - r(!w.amPM) : i, m && L(void 0, 1, w.hourElement)), w.amPM && f && (1 === c ? u + s === 23 : Math.abs(u - s) > c) && (w.amPM.textContent = w.l10n.amPM[r(w.amPM.textContent === w.l10n.amPM[0])]), a.value = o(u) } }(e); var a = w._input.value; O(), ye(), w._input.value !== a && w._debouncedChange() } function O() { if (void 0 !== w.hourElement && void 0 !== w.minuteElement) { var e, n, t = (parseInt(w.hourElement.value.slice(-2), 10) || 0) % 24, a = (parseInt(w.minuteElement.value, 10) || 0) % 60, i = void 0 !== w.secondElement ? (parseInt(w.secondElement.value, 10) || 0) % 60 : 0; void 0 !== w.amPM && (e = t, n = w.amPM.textContent, t = e % 12 + 12 * r(n === w.l10n.amPM[1])); var o = void 0 !== w.config.minTime || w.config.minDate && w.minDateHasTime && w.latestSelectedDateObj && 0 === M(w.latestSelectedDateObj, w.config.minDate, !0), l = void 0 !== w.config.maxTime || w.config.maxDate && w.maxDateHasTime && w.latestSelectedDateObj && 0 === M(w.latestSelectedDateObj, w.config.maxDate, !0); if (void 0 !== w.config.maxTime && void 0 !== w.config.minTime && w.config.minTime > w.config.maxTime) { var c = y(w.config.minTime.getHours(), w.config.minTime.getMinutes(), w.config.minTime.getSeconds()), s = y(w.config.maxTime.getHours(), w.config.maxTime.getMinutes(), w.config.maxTime.getSeconds()), d = y(t, a, i); if (d > s && d < c) { var u = function (e) { var n = Math.floor(e / 3600), t = (e - 3600 * n) / 60; return [n, t, e - 3600 * n - 60 * t] }(c); t = u[0], a = u[1], i = u[2] } } else { if (l) { var f = void 0 !== w.config.maxTime ? w.config.maxTime : w.config.maxDate; (t = Math.min(t, f.getHours())) === f.getHours() && (a = Math.min(a, f.getMinutes())), a === f.getMinutes() && (i = Math.min(i, f.getSeconds())) } if (o) { var m = void 0 !== w.config.minTime ? w.config.minTime : w.config.minDate; (t = Math.max(t, m.getHours())) === m.getHours() && a < m.getMinutes() && (a = m.getMinutes()), a === m.getMinutes() && (i = Math.max(i, m.getSeconds())) } } A(t, a, i) } } function F(e) { var n = e || w.latestSelectedDateObj; n && n instanceof Date && A(n.getHours(), n.getMinutes(), n.getSeconds()) } function A(e, n, t) { void 0 !== w.latestSelectedDateObj && w.latestSelectedDateObj.setHours(e % 24, n, t || 0, 0), w.hourElement && w.minuteElement && !w.isMobile && (w.hourElement.value = o(w.config.time_24hr ? e : (12 + e) % 12 + 12 * r(e % 12 == 0)), w.minuteElement.value = o(n), void 0 !== w.amPM && (w.amPM.textContent = w.l10n.amPM[r(e >= 12)]), void 0 !== w.secondElement && (w.secondElement.value = o(t))) } function N(e) { var n = g(e), t = parseInt(n.value) + (e.delta || 0); (t / 1e3 > 1 || "Enter" === e.key && !/[^\d]/.test(t.toString())) && ee(t) } function P(e, n, t, a) { return n instanceof Array ? n.forEach((function (n) { return P(e, n, t, a) })) : e instanceof Array ? e.forEach((function (e) { return P(e, n, t, a) })) : (e.addEventListener(n, t, a), void w._handlers.push({ remove: function () { return e.removeEventListener(n, t, a) } })) } function Y() { De("onChange") } function j(e, n) { var t = void 0 !== e ? w.parseDate(e) : w.latestSelectedDateObj || (w.config.minDate && w.config.minDate > w.now ? w.config.minDate : w.config.maxDate && w.config.maxDate < w.now ? w.config.maxDate : w.now), a = w.currentYear, i = w.currentMonth; try { void 0 !== t && (w.currentYear = t.getFullYear(), w.currentMonth = t.getMonth()) } catch (e) { e.message = "Invalid date supplied: " + t, w.config.errorHandler(e) } n && w.currentYear !== a && (De("onYearChange"), q()), !n || w.currentYear === a && w.currentMonth === i || De("onMonthChange"), w.redraw() } function H(e) { var n = g(e); ~n.className.indexOf("arrow") && L(e, n.classList.contains("arrowUp") ? 1 : -1) } function L(e, n, t) { var a = e && g(e), i = t || a && a.parentNode && a.parentNode.firstChild, o = we("increment"); o.delta = n, i && i.dispatchEvent(o) } function R(e, n, t, a) { var i = ne(n, !0), o = d("span", e, n.getDate().toString()); return o.dateObj = n, o.$i = a, o.setAttribute("aria-label", w.formatDate(n, w.config.ariaDateFormat)), -1 === e.indexOf("hidden") && 0 === M(n, w.now) && (w.todayDateElem = o, o.classList.add("today"), o.setAttribute("aria-current", "date")), i ? (o.tabIndex = -1, be(n) && (o.classList.add("selected"), w.selectedDateElem = o, "range" === w.config.mode && (s(o, "startRange", w.selectedDates[0] && 0 === M(n, w.selectedDates[0], !0)), s(o, "endRange", w.selectedDates[1] && 0 === M(n, w.selectedDates[1], !0)), "nextMonthDay" === e && o.classList.add("inRange")))) : o.classList.add("flatpickr-disabled"), "range" === w.config.mode && function (e) { return !("range" !== w.config.mode || w.selectedDates.length < 2) && (M(e, w.selectedDates[0]) >= 0 && M(e, w.selectedDates[1]) <= 0) }(n) && !be(n) && o.classList.add("inRange"), w.weekNumbers && 1 === w.config.showMonths && "prevMonthDay" !== e && a % 7 == 6 && w.weekNumbers.insertAdjacentHTML("beforeend", "<span class='flatpickr-day'>" + w.config.getWeek(n) + "</span>"), De("onDayCreate", o), o } function W(e) { e.focus(), "range" === w.config.mode && oe(e) } function B(e) { for (var n = e > 0 ? 0 : w.config.showMonths - 1, t = e > 0 ? w.config.showMonths : -1, a = n; a != t; a += e)for (var i = w.daysContainer.children[a], o = e > 0 ? 0 : i.children.length - 1, r = e > 0 ? i.children.length : -1, l = o; l != r; l += e) { var c = i.children[l]; if (-1 === c.className.indexOf("hidden") && ne(c.dateObj)) return c } } function J(e, n) { var t = k(), a = te(t || document.body), i = void 0 !== e ? e : a ? t : void 0 !== w.selectedDateElem && te(w.selectedDateElem) ? w.selectedDateElem : void 0 !== w.todayDateElem && te(w.todayDateElem) ? w.todayDateElem : B(n > 0 ? 1 : -1); void 0 === i ? w._input.focus() : a ? function (e, n) { for (var t = -1 === e.className.indexOf("Month") ? e.dateObj.getMonth() : w.currentMonth, a = n > 0 ? w.config.showMonths : -1, i = n > 0 ? 1 : -1, o = t - w.currentMonth; o != a; o += i)for (var r = w.daysContainer.children[o], l = t - w.currentMonth === o ? e.$i + n : n < 0 ? r.children.length - 1 : 0, c = r.children.length, s = l; s >= 0 && s < c && s != (n > 0 ? c : -1); s += i) { var d = r.children[s]; if (-1 === d.className.indexOf("hidden") && ne(d.dateObj) && Math.abs(e.$i - s) >= Math.abs(n)) return W(d) } w.changeMonth(i), J(B(i), 0) }(i, n) : W(i) } function K(e, n) { for (var t = (new Date(e, n, 1).getDay() - w.l10n.firstDayOfWeek + 7) % 7, a = w.utils.getDaysInMonth((n - 1 + 12) % 12, e), i = w.utils.getDaysInMonth(n, e), o = window.document.createDocumentFragment(), r = w.config.showMonths > 1, l = r ? "prevMonthDay hidden" : "prevMonthDay", c = r ? "nextMonthDay hidden" : "nextMonthDay", s = a + 1 - t, u = 0; s <= a; s++, u++)o.appendChild(R("flatpickr-day " + l, new Date(e, n - 1, s), 0, u)); for (s = 1; s <= i; s++, u++)o.appendChild(R("flatpickr-day", new Date(e, n, s), 0, u)); for (var f = i + 1; f <= 42 - t && (1 === w.config.showMonths || u % 7 != 0); f++, u++)o.appendChild(R("flatpickr-day " + c, new Date(e, n + 1, f % i), 0, u)); var m = d("div", "dayContainer"); return m.appendChild(o), m } function U() { if (void 0 !== w.daysContainer) { u(w.daysContainer), w.weekNumbers && u(w.weekNumbers); for (var e = document.createDocumentFragment(), n = 0; n < w.config.showMonths; n++) { var t = new Date(w.currentYear, w.currentMonth, 1); t.setMonth(w.currentMonth + n), e.appendChild(K(t.getFullYear(), t.getMonth())) } w.daysContainer.appendChild(e), w.days = w.daysContainer.firstChild, "range" === w.config.mode && 1 === w.selectedDates.length && oe() } } function q() { if (!(w.config.showMonths > 1 || "dropdown" !== w.config.monthSelectorType)) { var e = function (e) { return !(void 0 !== w.config.minDate && w.currentYear === w.config.minDate.getFullYear() && e < w.config.minDate.getMonth()) && !(void 0 !== w.config.maxDate && w.currentYear === w.config.maxDate.getFullYear() && e > w.config.maxDate.getMonth()) }; w.monthsDropdownContainer.tabIndex = -1, w.monthsDropdownContainer.innerHTML = ""; for (var n = 0; n < 12; n++)if (e(n)) { var t = d("option", "flatpickr-monthDropdown-month"); t.value = new Date(w.currentYear, n).getMonth().toString(), t.textContent = h(n, w.config.shorthandCurrentMonth, w.l10n), t.tabIndex = -1, w.currentMonth === n && (t.selected = !0), w.monthsDropdownContainer.appendChild(t) } } } function $() { var e, n = d("div", "flatpickr-month"), t = window.document.createDocumentFragment(); w.config.showMonths > 1 || "static" === w.config.monthSelectorType ? e = d("span", "cur-month") : (w.monthsDropdownContainer = d("select", "flatpickr-monthDropdown-months"), w.monthsDropdownContainer.setAttribute("aria-label", w.l10n.monthAriaLabel), P(w.monthsDropdownContainer, "change", (function (e) { var n = g(e), t = parseInt(n.value, 10); w.changeMonth(t - w.currentMonth), De("onMonthChange") })), q(), e = w.monthsDropdownContainer); var a = m("cur-year", { tabindex: "-1" }), i = a.getElementsByTagName("input")[0]; i.setAttribute("aria-label", w.l10n.yearAriaLabel), w.config.minDate && i.setAttribute("min", w.config.minDate.getFullYear().toString()), w.config.maxDate && (i.setAttribute("max", w.config.maxDate.getFullYear().toString()), i.disabled = !!w.config.minDate && w.config.minDate.getFullYear() === w.config.maxDate.getFullYear()); var o = d("div", "flatpickr-current-month"); return o.appendChild(e), o.appendChild(a), t.appendChild(o), n.appendChild(t), { container: n, yearElement: i, monthElement: e } } function V() { u(w.monthNav), w.monthNav.appendChild(w.prevMonthNav), w.config.showMonths && (w.yearElements = [], w.monthElements = []); for (var e = w.config.showMonths; e--;) { var n = $(); w.yearElements.push(n.yearElement), w.monthElements.push(n.monthElement), w.monthNav.appendChild(n.container) } w.monthNav.appendChild(w.nextMonthNav) } function z() { w.weekdayContainer ? u(w.weekdayContainer) : w.weekdayContainer = d("div", "flatpickr-weekdays"); for (var e = w.config.showMonths; e--;) { var n = d("div", "flatpickr-weekdaycontainer"); w.weekdayContainer.appendChild(n) } return G(), w.weekdayContainer } function G() { if (w.weekdayContainer) { var e = w.l10n.firstDayOfWeek, t = n(w.l10n.weekdays.shorthand); e > 0 && e < t.length && (t = n(t.splice(e, t.length), t.splice(0, e))); for (var a = w.config.showMonths; a--;)w.weekdayContainer.children[a].innerHTML = "\n <span class='flatpickr-weekday'>\n " + t.join("</span><span class='flatpickr-weekday'>") + "\n </span>\n " } } function Z(e, n) { void 0 === n && (n = !0); var t = n ? e : e - w.currentMonth; t < 0 && !0 === w._hidePrevMonthArrow || t > 0 && !0 === w._hideNextMonthArrow || (w.currentMonth += t, (w.currentMonth < 0 || w.currentMonth > 11) && (w.currentYear += w.currentMonth > 11 ? 1 : -1, w.currentMonth = (w.currentMonth + 12) % 12, De("onYearChange"), q()), U(), De("onMonthChange"), Ce()) } function Q(e) { return w.calendarContainer.contains(e) } function X(e) { if (w.isOpen && !w.config.inline) { var n = g(e), t = Q(n), a = !(n === w.input || n === w.altInput || w.element.contains(n) || e.path && e.path.indexOf && (~e.path.indexOf(w.input) || ~e.path.indexOf(w.altInput))) && !t && !Q(e.relatedTarget), i = !w.config.ignoredFocusElements.some((function (e) { return e.contains(n) })); a && i && (w.config.allowInput && w.setDate(w._input.value, !1, w.config.altInput ? w.config.altFormat : w.config.dateFormat), void 0 !== w.timeContainer && void 0 !== w.minuteElement && void 0 !== w.hourElement && "" !== w.input.value && void 0 !== w.input.value && _(), w.close(), w.config && "range" === w.config.mode && 1 === w.selectedDates.length && w.clear(!1)) } } function ee(e) { if (!(!e || w.config.minDate && e < w.config.minDate.getFullYear() || w.config.maxDate && e > w.config.maxDate.getFullYear())) { var n = e, t = w.currentYear !== n; w.currentYear = n || w.currentYear, w.config.maxDate && w.currentYear === w.config.maxDate.getFullYear() ? w.currentMonth = Math.min(w.config.maxDate.getMonth(), w.currentMonth) : w.config.minDate && w.currentYear === w.config.minDate.getFullYear() && (w.currentMonth = Math.max(w.config.minDate.getMonth(), w.currentMonth)), t && (w.redraw(), De("onYearChange"), q()) } } function ne(e, n) { var t; void 0 === n && (n = !0); var a = w.parseDate(e, void 0, n); if (w.config.minDate && a && M(a, w.config.minDate, void 0 !== n ? n : !w.minDateHasTime) < 0 || w.config.maxDate && a && M(a, w.config.maxDate, void 0 !== n ? n : !w.maxDateHasTime) > 0) return !1; if (!w.config.enable && 0 === w.config.disable.length) return !0; if (void 0 === a) return !1; for (var i = !!w.config.enable, o = null !== (t = w.config.enable) && void 0 !== t ? t : w.config.disable, r = 0, l = void 0; r < o.length; r++) { if ("function" == typeof (l = o[r]) && l(a)) return i; if (l instanceof Date && void 0 !== a && l.getTime() === a.getTime()) return i; if ("string" == typeof l) { var c = w.parseDate(l, void 0, !0); return c && c.getTime() === a.getTime() ? i : !i } if ("object" == typeof l && void 0 !== a && l.from && l.to && a.getTime() >= l.from.getTime() && a.getTime() <= l.to.getTime()) return i } return !i } function te(e) { return void 0 !== w.daysContainer && (-1 === e.className.indexOf("hidden") && -1 === e.className.indexOf("flatpickr-disabled") && w.daysContainer.contains(e)) } function ae(e) { var n = e.target === w._input, t = w._input.value.trimEnd() !== Me(); !n || !t || e.relatedTarget && Q(e.relatedTarget) || w.setDate(w._input.value, !0, e.target === w.altInput ? w.config.altFormat : w.config.dateFormat) } function ie(e) { var n = g(e), t = w.config.wrap ? p.contains(n) : n === w._input, a = w.config.allowInput, i = w.isOpen && (!a || !t), o = w.config.inline && t && !a; if (13 === e.keyCode && t) { if (a) return w.setDate(w._input.value, !0, n === w.altInput ? w.config.altFormat : w.config.dateFormat), w.close(), n.blur(); w.open() } else if (Q(n) || i || o) { var r = !!w.timeContainer && w.timeContainer.contains(n); switch (e.keyCode) { case 13: r ? (e.preventDefault(), _(), fe()) : me(e); break; case 27: e.preventDefault(), fe(); break; case 8: case 46: t && !w.config.allowInput && (e.preventDefault(), w.clear()); break; case 37: case 39: if (r || t) w.hourElement && w.hourElement.focus(); else { e.preventDefault(); var l = k(); if (void 0 !== w.daysContainer && (!1 === a || l && te(l))) { var c = 39 === e.keyCode ? 1 : -1; e.ctrlKey ? (e.stopPropagation(), Z(c), J(B(1), 0)) : J(void 0, c) } } break; case 38: case 40: e.preventDefault(); var s = 40 === e.keyCode ? 1 : -1; w.daysContainer && void 0 !== n.$i || n === w.input || n === w.altInput ? e.ctrlKey ? (e.stopPropagation(), ee(w.currentYear - s), J(B(1), 0)) : r || J(void 0, 7 * s) : n === w.currentYearElement ? ee(w.currentYear - s) : w.config.enableTime && (!r && w.hourElement && w.hourElement.focus(), _(e), w._debouncedChange()); break; case 9: if (r) { var d = [w.hourElement, w.minuteElement, w.secondElement, w.amPM].concat(w.pluginElements).filter((function (e) { return e })), u = d.indexOf(n); if (-1 !== u) { var f = d[u + (e.shiftKey ? -1 : 1)]; e.preventDefault(), (f || w._input).focus() } } else !w.config.noCalendar && w.daysContainer && w.daysContainer.contains(n) && e.shiftKey && (e.preventDefault(), w._input.focus()) } } if (void 0 !== w.amPM && n === w.amPM) switch (e.key) { case w.l10n.amPM[0].charAt(0): case w.l10n.amPM[0].charAt(0).toLowerCase(): w.amPM.textContent = w.l10n.amPM[0], O(), ye(); break; case w.l10n.amPM[1].charAt(0): case w.l10n.amPM[1].charAt(0).toLowerCase(): w.amPM.textContent = w.l10n.amPM[1], O(), ye() }(t || Q(n)) && De("onKeyDown", e) } function oe(e, n) { if (void 0 === n && (n = "flatpickr-day"), 1 === w.selectedDates.length && (!e || e.classList.contains(n) && !e.classList.contains("flatpickr-disabled"))) { for (var t = e ? e.dateObj.getTime() : w.days.firstElementChild.dateObj.getTime(), a = w.parseDate(w.selectedDates[0], void 0, !0).getTime(), i = Math.min(t, w.selectedDates[0].getTime()), o = Math.max(t, w.selectedDates[0].getTime()), r = !1, l = 0, c = 0, s = i; s < o; s += x)ne(new Date(s), !0) || (r = r || s > i && s < o, s < a && (!l || s > l) ? l = s : s > a && (!c || s < c) && (c = s)); Array.from(w.rContainer.querySelectorAll("*:nth-child(-n+" + w.config.showMonths + ") > ." + n)).forEach((function (n) { var i, o, s, d = n.dateObj.getTime(), u = l > 0 && d < l || c > 0 && d > c; if (u) return n.classList.add("notAllowed"), void ["inRange", "startRange", "endRange"].forEach((function (e) { n.classList.remove(e) })); r && !u || (["startRange", "inRange", "endRange", "notAllowed"].forEach((function (e) { n.classList.remove(e) })), void 0 !== e && (e.classList.add(t <= w.selectedDates[0].getTime() ? "startRange" : "endRange"), a < t && d === a ? n.classList.add("startRange") : a > t && d === a && n.classList.add("endRange"), d >= l && (0 === c || d <= c) && (o = a, s = t, (i = d) > Math.min(o, s) && i < Math.max(o, s)) && n.classList.add("inRange"))) })) } } function re() { !w.isOpen || w.config.static || w.config.inline || de() } function le(e) { return function (n) { var t = w.config["_" + e + "Date"] = w.parseDate(n, w.config.dateFormat), a = w.config["_" + ("min" === e ? "max" : "min") + "Date"]; void 0 !== t && (w["min" === e ? "minDateHasTime" : "maxDateHasTime"] = t.getHours() > 0 || t.getMinutes() > 0 || t.getSeconds() > 0), w.selectedDates && (w.selectedDates = w.selectedDates.filter((function (e) { return ne(e) })), w.selectedDates.length || "min" !== e || F(t), ye()), w.daysContainer && (ue(), void 0 !== t ? w.currentYearElement[e] = t.getFullYear().toString() : w.currentYearElement.removeAttribute(e), w.currentYearElement.disabled = !!a && void 0 !== t && a.getFullYear() === t.getFullYear()) } } function ce() { return w.config.wrap ? p.querySelector("[data-input]") : p } function se() { "object" != typeof w.config.locale && void 0 === I.l10ns[w.config.locale] && w.config.errorHandler(new Error("flatpickr: invalid locale " + w.config.locale)), w.l10n = e(e({}, I.l10ns.default), "object" == typeof w.config.locale ? w.config.locale : "default" !== w.config.locale ? I.l10ns[w.config.locale] : void 0), D.D = "(" + w.l10n.weekdays.shorthand.join("|") + ")", D.l = "(" + w.l10n.weekdays.longhand.join("|") + ")", D.M = "(" + w.l10n.months.shorthand.join("|") + ")", D.F = "(" + w.l10n.months.longhand.join("|") + ")", D.K = "(" + w.l10n.amPM[0] + "|" + w.l10n.amPM[1] + "|" + w.l10n.amPM[0].toLowerCase() + "|" + w.l10n.amPM[1].toLowerCase() + ")", void 0 === e(e({}, v), JSON.parse(JSON.stringify(p.dataset || {}))).time_24hr && void 0 === I.defaultConfig.time_24hr && (w.config.time_24hr = w.l10n.time_24hr), w.formatDate = b(w), w.parseDate = C({ config: w.config, l10n: w.l10n }) } function de(e) { if ("function" != typeof w.config.position) { if (void 0 !== w.calendarContainer) { De("onPreCalendarPosition"); var n = e || w._positionElement, t = Array.prototype.reduce.call(w.calendarContainer.children, (function (e, n) { return e + n.offsetHeight }), 0), a = w.calendarContainer.offsetWidth, i = w.config.position.split(" "), o = i[0], r = i.length > 1 ? i[1] : null, l = n.getBoundingClientRect(), c = window.innerHeight - l.bottom, d = "above" === o || "below" !== o && c < t && l.top > t, u = window.pageYOffset + l.top + (d ? -t - 2 : n.offsetHeight + 2); if (s(w.calendarContainer, "arrowTop", !d), s(w.calendarContainer, "arrowBottom", d), !w.config.inline) { var f = window.pageXOffset + l.left, m = !1, g = !1; "center" === r ? (f -= (a - l.width) / 2, m = !0) : "right" === r && (f -= a - l.width, g = !0), s(w.calendarContainer, "arrowLeft", !m && !g), s(w.calendarContainer, "arrowCenter", m), s(w.calendarContainer, "arrowRight", g); var p = window.document.body.offsetWidth - (window.pageXOffset + l.right), h = f + a > window.document.body.offsetWidth, v = p + a > window.document.body.offsetWidth; if (s(w.calendarContainer, "rightMost", h), !w.config.static) if (w.calendarContainer.style.top = u + "px", h) if (v) { var D = function () { for (var e = null, n = 0; n < document.styleSheets.length; n++) { var t = document.styleSheets[n]; if (t.cssRules) { try { t.cssRules } catch (e) { continue } e = t; break } } return null != e ? e : (a = document.createElement("style"), document.head.appendChild(a), a.sheet); var a }(); if (void 0 === D) return; var b = window.document.body.offsetWidth, C = Math.max(0, b / 2 - a / 2), M = D.cssRules.length, y = "{left:" + l.left + "px;right:auto;}"; s(w.calendarContainer, "rightMost", !1), s(w.calendarContainer, "centerMost", !0), D.insertRule(".flatpickr-calendar.centerMost:before,.flatpickr-calendar.centerMost:after" + y, M), w.calendarContainer.style.left = C + "px", w.calendarContainer.style.right = "auto" } else w.calendarContainer.style.left = "auto", w.calendarContainer.style.right = p + "px"; else w.calendarContainer.style.left = f + "px", w.calendarContainer.style.right = "auto" } } } else w.config.position(w, e) } function ue() { w.config.noCalendar || w.isMobile || (q(), Ce(), U()) } function fe() { w._input.focus(), -1 !== window.navigator.userAgent.indexOf("MSIE") || void 0 !== navigator.msMaxTouchPoints ? setTimeout(w.close, 0) : w.close() } function me(e) { e.preventDefault(), e.stopPropagation(); var n = f(g(e), (function (e) { return e.classList && e.classList.contains("flatpickr-day") && !e.classList.contains("flatpickr-disabled") && !e.classList.contains("notAllowed") })); if (void 0 !== n) { var t = n, a = w.latestSelectedDateObj = new Date(t.dateObj.getTime()), i = (a.getMonth() < w.currentMonth || a.getMonth() > w.currentMonth + w.config.showMonths - 1) && "range" !== w.config.mode; if (w.selectedDateElem = t, "single" === w.config.mode) w.selectedDates = [a]; else if ("multiple" === w.config.mode) { var o = be(a); o ? w.selectedDates.splice(parseInt(o), 1) : w.selectedDates.push(a) } else "range" === w.config.mode && (2 === w.selectedDates.length && w.clear(!1, !1), w.latestSelectedDateObj = a, w.selectedDates.push(a), 0 !== M(a, w.selectedDates[0], !0) && w.selectedDates.sort((function (e, n) { return e.getTime() - n.getTime() }))); if (O(), i) { var r = w.currentYear !== a.getFullYear(); w.currentYear = a.getFullYear(), w.currentMonth = a.getMonth(), r && (De("onYearChange"), q()), De("onMonthChange") } if (Ce(), U(), ye(), i || "range" === w.config.mode || 1 !== w.config.showMonths ? void 0 !== w.selectedDateElem && void 0 === w.hourElement && w.selectedDateElem && w.selectedDateElem.focus() : W(t), void 0 !== w.hourElement && void 0 !== w.hourElement && w.hourElement.focus(), w.config.closeOnSelect) { var l = "single" === w.config.mode && !w.config.enableTime, c = "range" === w.config.mode && 2 === w.selectedDates.length && !w.config.enableTime; (l || c) && fe() } Y() } } w.parseDate = C({ config: w.config, l10n: w.l10n }), w._handlers = [], w.pluginElements = [], w.loadedPlugins = [], w._bind = P, w._setHoursFromDate = F, w._positionCalendar = de, w.changeMonth = Z, w.changeYear = ee, w.clear = function (e, n) { void 0 === e && (e = !0); void 0 === n && (n = !0); w.input.value = "", void 0 !== w.altInput && (w.altInput.value = ""); void 0 !== w.mobileInput && (w.mobileInput.value = ""); w.selectedDates = [], w.latestSelectedDateObj = void 0, !0 === n && (w.currentYear = w._initialDate.getFullYear(), w.currentMonth = w._initialDate.getMonth()); if (!0 === w.config.enableTime) { var t = E(w.config), a = t.hours, i = t.minutes, o = t.seconds; A(a, i, o) } w.redraw(), e && De("onChange") }, w.close = function () { w.isOpen = !1, w.isMobile || (void 0 !== w.calendarContainer && w.calendarContainer.classList.remove("open"), void 0 !== w._input && w._input.classList.remove("active")); De("onClose") }, w.onMouseOver = oe, w._createElement = d, w.createDay = R, w.destroy = function () { void 0 !== w.config && De("onDestroy"); for (var e = w._handlers.length; e--;)w._handlers[e].remove(); if (w._handlers = [], w.mobileInput) w.mobileInput.parentNode && w.mobileInput.parentNode.removeChild(w.mobileInput), w.mobileInput = void 0; else if (w.calendarContainer && w.calendarContainer.parentNode) if (w.config.static && w.calendarContainer.parentNode) { var n = w.calendarContainer.parentNode; if (n.lastChild && n.removeChild(n.lastChild), n.parentNode) { for (; n.firstChild;)n.parentNode.insertBefore(n.firstChild, n); n.parentNode.removeChild(n) } } else w.calendarContainer.parentNode.removeChild(w.calendarContainer); w.altInput && (w.input.type = "text", w.altInput.parentNode && w.altInput.parentNode.removeChild(w.altInput), delete w.altInput); w.input && (w.input.type = w.input._type, w.input.classList.remove("flatpickr-input"), w.input.removeAttribute("readonly"));["_showTimeInput", "latestSelectedDateObj", "_hideNextMonthArrow", "_hidePrevMonthArrow", "__hideNextMonthArrow", "__hidePrevMonthArrow", "isMobile", "isOpen", "selectedDateElem", "minDateHasTime", "maxDateHasTime", "days", "daysContainer", "_input", "_positionElement", "innerContainer", "rContainer", "monthNav", "todayDateElem", "calendarContainer", "weekdayContainer", "prevMonthNav", "nextMonthNav", "monthsDropdownContainer", "currentMonthElement", "currentYearElement", "navigationCurrentMonth", "selectedDateElem", "config"].forEach((function (e) { try { delete w[e] } catch (e) { } })) }, w.isEnabled = ne, w.jumpToDate = j, w.updateValue = ye, w.open = function (e, n) { void 0 === n && (n = w._positionElement); if (!0 === w.isMobile) { if (e) { e.preventDefault(); var t = g(e); t && t.blur() } return void 0 !== w.mobileInput && (w.mobileInput.focus(), w.mobileInput.click()), void De("onOpen") } if (w._input.disabled || w.config.inline) return; var a = w.isOpen; w.isOpen = !0, a || (w.calendarContainer.classList.add("open"), w._input.classList.add("active"), De("onOpen"), de(n)); !0 === w.config.enableTime && !0 === w.config.noCalendar && (!1 !== w.config.allowInput || void 0 !== e && w.timeContainer.contains(e.relatedTarget) || setTimeout((function () { return w.hourElement.select() }), 50)) }, w.redraw = ue, w.set = function (e, n) { if (null !== e && "object" == typeof e) for (var a in Object.assign(w.config, e), e) void 0 !== ge[a] && ge[a].forEach((function (e) { return e() })); else w.config[e] = n, void 0 !== ge[e] ? ge[e].forEach((function (e) { return e() })) : t.indexOf(e) > -1 && (w.config[e] = c(n)); w.redraw(), ye(!0) }, w.setDate = function (e, n, t) { void 0 === n && (n = !1); void 0 === t && (t = w.config.dateFormat); if (0 !== e && !e || e instanceof Array && 0 === e.length) return w.clear(n); pe(e, t), w.latestSelectedDateObj = w.selectedDates[w.selectedDates.length - 1], w.redraw(), j(void 0, n), F(), 0 === w.selectedDates.length && w.clear(!1); ye(n), n && De("onChange") }, w.toggle = function (e) { if (!0 === w.isOpen) return w.close(); w.open(e) }; var ge = { locale: [se, G], showMonths: [V, S, z], minDate: [j], maxDate: [j], positionElement: [ve], clickOpens: [function () { !0 === w.config.clickOpens ? (P(w._input, "focus", w.open), P(w._input, "click", w.open)) : (w._input.removeEventListener("focus", w.open), w._input.removeEventListener("click", w.open)) }] }; function pe(e, n) { var t = []; if (e instanceof Array) t = e.map((function (e) { return w.parseDate(e, n) })); else if (e instanceof Date || "number" == typeof e) t = [w.parseDate(e, n)]; else if ("string" == typeof e) switch (w.config.mode) { case "single": case "time": t = [w.parseDate(e, n)]; break; case "multiple": t = e.split(w.config.conjunction).map((function (e) { return w.parseDate(e, n) })); break; case "range": t = e.split(w.l10n.rangeSeparator).map((function (e) { return w.parseDate(e, n) })) } else w.config.errorHandler(new Error("Invalid date supplied: " + JSON.stringify(e))); w.selectedDates = w.config.allowInvalidPreload ? t : t.filter((function (e) { return e instanceof Date && ne(e, !1) })), "range" === w.config.mode && w.selectedDates.sort((function (e, n) { return e.getTime() - n.getTime() })) } function he(e) { return e.slice().map((function (e) { return "string" == typeof e || "number" == typeof e || e instanceof Date ? w.parseDate(e, void 0, !0) : e && "object" == typeof e && e.from && e.to ? { from: w.parseDate(e.from, void 0), to: w.parseDate(e.to, void 0) } : e })).filter((function (e) { return e })) } function ve() { w._positionElement = w.config.positionElement || w._input } function De(e, n) { if (void 0 !== w.config) { var t = w.config[e]; if (void 0 !== t && t.length > 0) for (var a = 0; t[a] && a < t.length; a++)t[a](w.selectedDates, w.input.value, w, n); "onChange" === e && (w.input.dispatchEvent(we("change")), w.input.dispatchEvent(we("input"))) } } function we(e) { var n = document.createEvent("Event"); return n.initEvent(e, !0, !0), n } function be(e) { for (var n = 0; n < w.selectedDates.length; n++) { var t = w.selectedDates[n]; if (t instanceof Date && 0 === M(t, e)) return "" + n } return !1 } function Ce() { w.config.noCalendar || w.isMobile || !w.monthNav || (w.yearElements.forEach((function (e, n) { var t = new Date(w.currentYear, w.currentMonth, 1); t.setMonth(w.currentMonth + n), w.config.showMonths > 1 || "static" === w.config.monthSelectorType ? w.monthElements[n].textContent = h(t.getMonth(), w.config.shorthandCurrentMonth, w.l10n) + " " : w.monthsDropdownContainer.value = t.getMonth().toString(), e.value = t.getFullYear().toString() })), w._hidePrevMonthArrow = void 0 !== w.config.minDate && (w.currentYear === w.config.minDate.getFullYear() ? w.currentMonth <= w.config.minDate.getMonth() : w.currentYear < w.config.minDate.getFullYear()), w._hideNextMonthArrow = void 0 !== w.config.maxDate && (w.currentYear === w.config.maxDate.getFullYear() ? w.currentMonth + 1 > w.config.maxDate.getMonth() : w.currentYear > w.config.maxDate.getFullYear())) } function Me(e) { var n = e || (w.config.altInput ? w.config.altFormat : w.config.dateFormat); return w.selectedDates.map((function (e) { return w.formatDate(e, n) })).filter((function (e, n, t) { return "range" !== w.config.mode || w.config.enableTime || t.indexOf(e) === n })).join("range" !== w.config.mode ? w.config.conjunction : w.l10n.rangeSeparator) } function ye(e) { void 0 === e && (e = !0), void 0 !== w.mobileInput && w.mobileFormatStr && (w.mobileInput.value = void 0 !== w.latestSelectedDateObj ? w.formatDate(w.latestSelectedDateObj, w.mobileFormatStr) : ""), w.input.value = Me(w.config.dateFormat), void 0 !== w.altInput && (w.altInput.value = Me(w.config.altFormat)), !1 !== e && De("onValueUpdate") } function xe(e) { var n = g(e), t = w.prevMonthNav.contains(n), a = w.nextMonthNav.contains(n); t || a ? Z(t ? -1 : 1) : w.yearElements.indexOf(n) >= 0 ? n.select() : n.classList.contains("arrowUp") ? w.changeYear(w.currentYear + 1) : n.classList.contains("arrowDown") && w.changeYear(w.currentYear - 1) } return function () { w.element = w.input = p, w.isOpen = !1, function () { var n = ["wrap", "weekNumbers", "allowInput", "allowInvalidPreload", "clickOpens", "time_24hr", "enableTime", "noCalendar", "altInput", "shorthandCurrentMonth", "inline", "static", "enableSeconds", "disableMobile"], i = e(e({}, JSON.parse(JSON.stringify(p.dataset || {}))), v), o = {}; w.config.parseDate = i.parseDate, w.config.formatDate = i.formatDate, Object.defineProperty(w.config, "enable", { get: function () { return w.config._enable }, set: function (e) { w.config._enable = he(e) } }), Object.defineProperty(w.config, "disable", { get: function () { return w.config._disable }, set: function (e) { w.config._disable = he(e) } }); var r = "time" === i.mode; if (!i.dateFormat && (i.enableTime || r)) { var l = I.defaultConfig.dateFormat || a.dateFormat; o.dateFormat = i.noCalendar || r ? "H:i" + (i.enableSeconds ? ":S" : "") : l + " H:i" + (i.enableSeconds ? ":S" : "") } if (i.altInput && (i.enableTime || r) && !i.altFormat) { var s = I.defaultConfig.altFormat || a.altFormat; o.altFormat = i.noCalendar || r ? "h:i" + (i.enableSeconds ? ":S K" : " K") : s + " h:i" + (i.enableSeconds ? ":S" : "") + " K" } Object.defineProperty(w.config, "minDate", { get: function () { return w.config._minDate }, set: le("min") }), Object.defineProperty(w.config, "maxDate", { get: function () { return w.config._maxDate }, set: le("max") }); var d = function (e) { return function (n) { w.config["min" === e ? "_minTime" : "_maxTime"] = w.parseDate(n, "H:i:S") } }; Object.defineProperty(w.config, "minTime", { get: function () { return w.config._minTime }, set: d("min") }), Object.defineProperty(w.config, "maxTime", { get: function () { return w.config._maxTime }, set: d("max") }), "time" === i.mode && (w.config.noCalendar = !0, w.config.enableTime = !0); Object.assign(w.config, o, i); for (var u = 0; u < n.length; u++)w.config[n[u]] = !0 === w.config[n[u]] || "true" === w.config[n[u]]; t.filter((function (e) { return void 0 !== w.config[e] })).forEach((function (e) { w.config[e] = c(w.config[e] || []).map(T) })), w.isMobile = !w.config.disableMobile && !w.config.inline && "single" === w.config.mode && !w.config.disable.length && !w.config.enable && !w.config.weekNumbers && /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent); for (u = 0; u < w.config.plugins.length; u++) { var f = w.config.plugins[u](w) || {}; for (var m in f) t.indexOf(m) > -1 ? w.config[m] = c(f[m]).map(T).concat(w.config[m]) : void 0 === i[m] && (w.config[m] = f[m]) } i.altInputClass || (w.config.altInputClass = ce().className + " " + w.config.altInputClass); De("onParseConfig") }(), se(), function () { if (w.input = ce(), !w.input) return void w.config.errorHandler(new Error("Invalid input element specified")); w.input._type = w.input.type, w.input.type = "text", w.input.classList.add("flatpickr-input"), w._input = w.input, w.config.altInput && (w.altInput = d(w.input.nodeName, w.config.altInputClass), w._input = w.altInput, w.altInput.placeholder = w.input.placeholder, w.altInput.disabled = w.input.disabled, w.altInput.required = w.input.required, w.altInput.tabIndex = w.input.tabIndex, w.altInput.type = "text", w.input.setAttribute("type", "hidden"), !w.config.static && w.input.parentNode && w.input.parentNode.insertBefore(w.altInput, w.input.nextSibling)); w.config.allowInput || w._input.setAttribute("readonly", "readonly"); ve() }(), function () { w.selectedDates = [], w.now = w.parseDate(w.config.now) || new Date; var e = w.config.defaultDate || ("INPUT" !== w.input.nodeName && "TEXTAREA" !== w.input.nodeName || !w.input.placeholder || w.input.value !== w.input.placeholder ? w.input.value : null); e && pe(e, w.config.dateFormat); w._initialDate = w.selectedDates.length > 0 ? w.selectedDates[0] : w.config.minDate && w.config.minDate.getTime() > w.now.getTime() ? w.config.minDate : w.config.maxDate && w.config.maxDate.getTime() < w.now.getTime() ? w.config.maxDate : w.now, w.currentYear = w._initialDate.getFullYear(), w.currentMonth = w._initialDate.getMonth(), w.selectedDates.length > 0 && (w.latestSelectedDateObj = w.selectedDates[0]); void 0 !== w.config.minTime && (w.config.minTime = w.parseDate(w.config.minTime, "H:i")); void 0 !== w.config.maxTime && (w.config.maxTime = w.parseDate(w.config.maxTime, "H:i")); w.minDateHasTime = !!w.config.minDate && (w.config.minDate.getHours() > 0 || w.config.minDate.getMinutes() > 0 || w.config.minDate.getSeconds() > 0), w.maxDateHasTime = !!w.config.maxDate && (w.config.maxDate.getHours() > 0 || w.config.maxDate.getMinutes() > 0 || w.config.maxDate.getSeconds() > 0) }(), w.utils = { getDaysInMonth: function (e, n) { return void 0 === e && (e = w.currentMonth), void 0 === n && (n = w.currentYear), 1 === e && (n % 4 == 0 && n % 100 != 0 || n % 400 == 0) ? 29 : w.l10n.daysInMonth[e] } }, w.isMobile || function () { var e = window.document.createDocumentFragment(); if (w.calendarContainer = d("div", "flatpickr-calendar"), w.calendarContainer.tabIndex = -1, !w.config.noCalendar) { if (e.appendChild((w.monthNav = d("div", "flatpickr-months"), w.yearElements = [], w.monthElements = [], w.prevMonthNav = d("span", "flatpickr-prev-month"), w.prevMonthNav.innerHTML = w.config.prevArrow, w.nextMonthNav = d("span", "flatpickr-next-month"), w.nextMonthNav.innerHTML = w.config.nextArrow, V(), Object.defineProperty(w, "_hidePrevMonthArrow", { get: function () { return w.__hidePrevMonthArrow }, set: function (e) { w.__hidePrevMonthArrow !== e && (s(w.prevMonthNav, "flatpickr-disabled", e), w.__hidePrevMonthArrow = e) } }), Object.defineProperty(w, "_hideNextMonthArrow", { get: function () { return w.__hideNextMonthArrow }, set: function (e) { w.__hideNextMonthArrow !== e && (s(w.nextMonthNav, "flatpickr-disabled", e), w.__hideNextMonthArrow = e) } }), w.currentYearElement = w.yearElements[0], Ce(), w.monthNav)), w.innerContainer = d("div", "flatpickr-innerContainer"), w.config.weekNumbers) { var n = function () { w.calendarContainer.classList.add("hasWeeks"); var e = d("div", "flatpickr-weekwrapper"); e.appendChild(d("span", "flatpickr-weekday", w.l10n.weekAbbreviation)); var n = d("div", "flatpickr-weeks"); return e.appendChild(n), { weekWrapper: e, weekNumbers: n } }(), t = n.weekWrapper, a = n.weekNumbers; w.innerContainer.appendChild(t), w.weekNumbers = a, w.weekWrapper = t } w.rContainer = d("div", "flatpickr-rContainer"), w.rContainer.appendChild(z()), w.daysContainer || (w.daysContainer = d("div", "flatpickr-days"), w.daysContainer.tabIndex = -1), U(), w.rContainer.appendChild(w.daysContainer), w.innerContainer.appendChild(w.rContainer), e.appendChild(w.innerContainer) } w.config.enableTime && e.appendChild(function () { w.calendarContainer.classList.add("hasTime"), w.config.noCalendar && w.calendarContainer.classList.add("noCalendar"); var e = E(w.config); w.timeContainer = d("div", "flatpickr-time"), w.timeContainer.tabIndex = -1; var n = d("span", "flatpickr-time-separator", ":"), t = m("flatpickr-hour", { "aria-label": w.l10n.hourAriaLabel }); w.hourElement = t.getElementsByTagName("input")[0]; var a = m("flatpickr-minute", { "aria-label": w.l10n.minuteAriaLabel }); w.minuteElement = a.getElementsByTagName("input")[0], w.hourElement.tabIndex = w.minuteElement.tabIndex = -1, w.hourElement.value = o(w.latestSelectedDateObj ? w.latestSelectedDateObj.getHours() : w.config.time_24hr ? e.hours : function (e) { switch (e % 24) { case 0: case 12: return 12; default: return e % 12 } }(e.hours)), w.minuteElement.value = o(w.latestSelectedDateObj ? w.latestSelectedDateObj.getMinutes() : e.minutes), w.hourElement.setAttribute("step", w.config.hourIncrement.toString()), w.minuteElement.setAttribute("step", w.config.minuteIncrement.toString()), w.hourElement.setAttribute("min", w.config.time_24hr ? "0" : "1"), w.hourElement.setAttribute("max", w.config.time_24hr ? "23" : "12"), w.hourElement.setAttribute("maxlength", "2"), w.minuteElement.setAttribute("min", "0"), w.minuteElement.setAttribute("max", "59"), w.minuteElement.setAttribute("maxlength", "2"), w.timeContainer.appendChild(t), w.timeContainer.appendChild(n), w.timeContainer.appendChild(a), w.config.time_24hr && w.timeContainer.classList.add("time24hr"); if (w.config.enableSeconds) { w.timeContainer.classList.add("hasSeconds"); var i = m("flatpickr-second"); w.secondElement = i.getElementsByTagName("input")[0], w.secondElement.value = o(w.latestSelectedDateObj ? w.latestSelectedDateObj.getSeconds() : e.seconds), w.secondElement.setAttribute("step", w.minuteElement.getAttribute("step")), w.secondElement.setAttribute("min", "0"), w.secondElement.setAttribute("max", "59"), w.secondElement.setAttribute("maxlength", "2"), w.timeContainer.appendChild(d("span", "flatpickr-time-separator", ":")), w.timeContainer.appendChild(i) } w.config.time_24hr || (w.amPM = d("span", "flatpickr-am-pm", w.l10n.amPM[r((w.latestSelectedDateObj ? w.hourElement.value : w.config.defaultHour) > 11)]), w.amPM.title = w.l10n.toggleTitle, w.amPM.tabIndex = -1, w.timeContainer.appendChild(w.amPM)); return w.timeContainer }()); s(w.calendarContainer, "rangeMode", "range" === w.config.mode), s(w.calendarContainer, "animate", !0 === w.config.animate), s(w.calendarContainer, "multiMonth", w.config.showMonths > 1), w.calendarContainer.appendChild(e); var i = void 0 !== w.config.appendTo && void 0 !== w.config.appendTo.nodeType; if ((w.config.inline || w.config.static) && (w.calendarContainer.classList.add(w.config.inline ? "inline" : "static"), w.config.inline && (!i && w.element.parentNode ? w.element.parentNode.insertBefore(w.calendarContainer, w._input.nextSibling) : void 0 !== w.config.appendTo && w.config.appendTo.appendChild(w.calendarContainer)), w.config.static)) { var l = d("div", "flatpickr-wrapper"); w.element.parentNode && w.element.parentNode.insertBefore(l, w.element), l.appendChild(w.element), w.altInput && l.appendChild(w.altInput), l.appendChild(w.calendarContainer) } w.config.static || w.config.inline || (void 0 !== w.config.appendTo ? w.config.appendTo : window.document.body).appendChild(w.calendarContainer) }(), function () { w.config.wrap && ["open", "close", "toggle", "clear"].forEach((function (e) { Array.prototype.forEach.call(w.element.querySelectorAll("[data-" + e + "]"), (function (n) { return P(n, "click", w[e]) })) })); if (w.isMobile) return void function () { var e = w.config.enableTime ? w.config.noCalendar ? "time" : "datetime-local" : "date"; w.mobileInput = d("input", w.input.className + " flatpickr-mobile"), w.mobileInput.tabIndex = 1, w.mobileInput.type = e, w.mobileInput.disabled = w.input.disabled, w.mobileInput.required = w.input.required, w.mobileInput.placeholder = w.input.placeholder, w.mobileFormatStr = "datetime-local" === e ? "Y-m-d\\TH:i:S" : "date" === e ? "Y-m-d" : "H:i:S", w.selectedDates.length > 0 && (w.mobileInput.defaultValue = w.mobileInput.value = w.formatDate(w.selectedDates[0], w.mobileFormatStr)); w.config.minDate && (w.mobileInput.min = w.formatDate(w.config.minDate, "Y-m-d")); w.config.maxDate && (w.mobileInput.max = w.formatDate(w.config.maxDate, "Y-m-d")); w.input.getAttribute("step") && (w.mobileInput.step = String(w.input.getAttribute("step"))); w.input.type = "hidden", void 0 !== w.altInput && (w.altInput.type = "hidden"); try { w.input.parentNode && w.input.parentNode.insertBefore(w.mobileInput, w.input.nextSibling) } catch (e) { } P(w.mobileInput, "change", (function (e) { w.setDate(g(e).value, !1, w.mobileFormatStr), De("onChange"), De("onClose") })) }(); var e = l(re, 50); w._debouncedChange = l(Y, 300), w.daysContainer && !/iPhone|iPad|iPod/i.test(navigator.userAgent) && P(w.daysContainer, "mouseover", (function (e) { "range" === w.config.mode && oe(g(e)) })); P(w._input, "keydown", ie), void 0 !== w.calendarContainer && P(w.calendarContainer, "keydown", ie); w.config.inline || w.config.static || P(window, "resize", e); void 0 !== window.ontouchstart ? P(window.document, "touchstart", X) : P(window.document, "mousedown", X); P(window.document, "focus", X, { capture: !0 }), !0 === w.config.clickOpens && (P(w._input, "focus", w.open), P(w._input, "click", w.open)); void 0 !== w.daysContainer && (P(w.monthNav, "click", xe), P(w.monthNav, ["keyup", "increment"], N), P(w.daysContainer, "click", me)); if (void 0 !== w.timeContainer && void 0 !== w.minuteElement && void 0 !== w.hourElement) { var n = function (e) { return g(e).select() }; P(w.timeContainer, ["increment"], _), P(w.timeContainer, "blur", _, { capture: !0 }), P(w.timeContainer, "click", H), P([w.hourElement, w.minuteElement], ["focus", "click"], n), void 0 !== w.secondElement && P(w.secondElement, "focus", (function () { return w.secondElement && w.secondElement.select() })), void 0 !== w.amPM && P(w.amPM, "click", (function (e) { _(e) })) } w.config.allowInput && P(w._input, "blur", ae) }(), (w.selectedDates.length || w.config.noCalendar) && (w.config.enableTime && F(w.config.noCalendar ? w.latestSelectedDateObj : void 0), ye(!1)), S(); var n = /^((?!chrome|android).)*safari/i.test(navigator.userAgent); !w.isMobile && n && de(), De("onReady") }(), w } function T(e, n) { for (var t = Array.prototype.slice.call(e).filter((function (e) { return e instanceof HTMLElement })), a = [], i = 0; i < t.length; i++) { var o = t[i]; try { if (null !== o.getAttribute("data-fp-omit")) continue; void 0 !== o._flatpickr && (o._flatpickr.destroy(), o._flatpickr = void 0), o._flatpickr = k(o, n || {}), a.push(o._flatpickr) } catch (e) { console.error(e) } } return 1 === a.length ? a[0] : a } "undefined" != typeof HTMLElement && "undefined" != typeof HTMLCollection && "undefined" != typeof NodeList && (HTMLCollection.prototype.flatpickr = NodeList.prototype.flatpickr = function (e) { return T(this, e) }, HTMLElement.prototype.flatpickr = function (e) { return T([this], e) }); var I = function (e, n) { return "string" == typeof e ? T(window.document.querySelectorAll(e), n) : e instanceof Node ? T([e], n) : T(e, n) }; return I.defaultConfig = {}, I.l10ns = { en: e({}, i), default: e({}, i) }, I.localize = function (n) { I.l10ns.default = e(e({}, I.l10ns.default), n) }, I.setDefaults = function (n) { I.defaultConfig = e(e({}, I.defaultConfig), n) }, I.parseDate = C({}), I.formatDate = b({}), I.compareDates = M, "undefined" != typeof jQuery && void 0 !== jQuery.fn && (jQuery.fn.flatpickr = function (e) { return T(this, e) }), Date.prototype.fp_incr = function (e) { return new Date(this.getFullYear(), this.getMonth(), this.getDate() + ("string" == typeof e ? parseInt(e, 10) : e)) }, "undefined" != typeof window && (window.flatpickr = I), I }));
|
||
</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.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="desc"><img src="${message.open_im_desc_icon}">${message.open_im_desc_icon}</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 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;
|
||
}
|
||
|
||
function handleTextMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
|
||
if (record) {
|
||
recordItem.innerHTML += `<div class="msg-container">${record.text}</div>`;
|
||
} else {
|
||
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);
|
||
}
|
||
|
||
}
|
||
function handleSystemMessage(params) {
|
||
const { message, messageElement } = params;
|
||
messageElement.className = "item item-center";
|
||
messageElement.innerHTML = `<span class="system-msg">${replaceEmoji(message.text.replace('\\"', '"'))}</span>`;
|
||
}
|
||
function handelAudioMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
|
||
if (record) {
|
||
recordItem.innerHTML += `<div class="msg-container">${record.text}</div>`;
|
||
} else {
|
||
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);
|
||
}
|
||
}
|
||
function handleImageOrEmojiMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
|
||
if (record) {
|
||
recordItem.appendChild(messageImgBox(record));
|
||
} else {
|
||
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);
|
||
}
|
||
}
|
||
|
||
function handleVideoMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
|
||
if (record) {
|
||
recordItem.appendChild(messageVideoBox(record));
|
||
} else {
|
||
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);
|
||
}
|
||
}
|
||
|
||
function handleFileMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
if (record) {
|
||
record.icon_path = getFileIcon(record.datafmt)
|
||
recordItem.appendChild(messageFileBox(record));
|
||
}
|
||
else {
|
||
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);
|
||
}
|
||
}
|
||
|
||
function handleTransferMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageTransfer(message));
|
||
// 整合
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handleLinkMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
if (record) {
|
||
recordItem.appendChild(messageCard(record));
|
||
}
|
||
else {
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageCard(message));
|
||
// 整合
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
}
|
||
|
||
function handleMusicMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageMusicAudioBox(message));
|
||
// 整合
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handleAppletMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageMiniProgram(message));
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handleMergedMessages(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, mergemessageElement, record, recordItem, zindex, i, parent_server_id} = params;
|
||
if (record) {
|
||
recordItem.appendChild(innermessageMergeCard(record, zindex + 1, i, parent_server_id));
|
||
messageContent.insertBefore(messageMergeModal(record, messageContent, zindex + 1, i, parent_server_id), messageContent.firstChild);
|
||
}
|
||
else {
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
|
||
messageContent.appendChild(messageMergeCard(message));
|
||
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);
|
||
}
|
||
}
|
||
|
||
function handleQuoteMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageBubble(message));
|
||
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);
|
||
}
|
||
|
||
function handleWeChatVideo(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageVideoNumber(message));
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handleVideoAudioCall(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageVideoAudioCall(message));
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handlePersonalCard(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
if (message.is_open_im) {
|
||
messageContent.appendChild(OpenIMCard(message));
|
||
}
|
||
else {
|
||
messageContent.appendChild(personalCard(message));
|
||
}
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handleLocationMessage(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag, record, recordItem } = params;
|
||
if (record) {
|
||
recordItem.appendChild(messageLocation(record, MapID));
|
||
}
|
||
else {
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(messageLocation(message, MapID));
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
}
|
||
|
||
function handleOpenIMCard(params) {
|
||
const { message, side, messageContent, messageElement, avatarTag } = params;
|
||
messageContent.className = `content-wrapper content-wrapper-${side}`;
|
||
messageContent.appendChild(OpenIMCard(message));
|
||
messageElement.className = `item item-${side}`;
|
||
messageElement.appendChild(message.is_send ? messageContent : avatarTag);
|
||
messageElement.appendChild(message.is_send ? avatarTag : messageContent);
|
||
}
|
||
|
||
function handleUnkownMessage(params) {
|
||
const { message } = params;
|
||
console.log("UnkownMessage: ", message);
|
||
}
|
||
|
||
const messageHandlers = {
|
||
[MessageType.Text]: handleTextMessage,
|
||
[MessageType.System]: handleSystemMessage,
|
||
[MessageType.Audio]: handelAudioMessage,
|
||
[MessageType.Image]: handleImageOrEmojiMessage,
|
||
[MessageType.Emoji]: handleImageOrEmojiMessage,
|
||
[MessageType.Video]: handleVideoMessage,
|
||
[MessageType.File]: handleFileMessage,
|
||
[MessageType.Transfer]: handleTransferMessage,
|
||
[MessageType.LinkMessage]: handleLinkMessage,
|
||
[MessageType.LinkMessage2]: handleLinkMessage,
|
||
[MessageType.LinkMessage3]: handleLinkMessage,
|
||
[MessageType.LinkMessage4]: handleLinkMessage,
|
||
[MessageType.LinkMessage5]: handleLinkMessage,
|
||
[MessageType.LinkMessage6]: handleLinkMessage,
|
||
[MessageType.Music]: handleMusicMessage,
|
||
[MessageType.Applet]: handleAppletMessage,
|
||
[MessageType.Applet2]: handleAppletMessage,
|
||
[MessageType.MergedMessages]: handleMergedMessages,
|
||
[MessageType.Quote]: handleQuoteMessage,
|
||
[MessageType.WeChatVideo]: handleWeChatVideo,
|
||
[MessageType.Voip]: handleVideoAudioCall,
|
||
[MessageType.BusinessCard]: handlePersonalCard,
|
||
[MessageType.Position]: handleLocationMessage,
|
||
[MessageType.OpenIMBCard]: handleOpenIMCard,
|
||
[MessageType.Unknown]: handleUnkownMessage,
|
||
|
||
};
|
||
|
||
function processMessage(params) {
|
||
const { message, record } = params;
|
||
if (message){
|
||
const handler = messageHandlers[message.type] || handleUnkownMessage;
|
||
if (handler && is_valid_data(message.server_id, message.token)) {
|
||
handler(params); // 将参数对象传递给处理函数
|
||
} else {
|
||
console.log("Unsupported message type or invalid data");
|
||
console.log("message",message);
|
||
}
|
||
}
|
||
else {
|
||
const handler = messageHandlers[record.type] || handleUnkownMessage;
|
||
if (handler) {
|
||
handler(params); // 将参数对象传递给处理函数
|
||
} else {
|
||
console.log("Unsupported message type or invalid data");
|
||
console.log("record",record);
|
||
}
|
||
}
|
||
|
||
}
|
||
|
||
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'
|
||
}
|
||
|
||
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`;
|
||
|
||
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`;
|
||
recordItem.innerHTML = `<div class="msg-container-top"><span>${record.display_name}</span>
|
||
<span style="font-size: 12px;">${timestampToTime(record.timestamp)}</span></div>`;
|
||
|
||
const record_params = {record, recordItem, messageContent, zindex, i, parent_server_id};
|
||
processMessage(record_params);
|
||
OnePersonMsgRight.appendChild(recordItem);
|
||
}
|
||
|
||
OnePersonMsg.appendChild(OnePersonMsgRight);
|
||
ModalContainer.appendChild(OnePersonMsg);
|
||
ModalContent.appendChild(ModalContainer);
|
||
message_MergeModal.appendChild(ModalContent);
|
||
|
||
return message_MergeModal;
|
||
|
||
}
|
||
|
||
|
||
// 从数据列表中取出对应范围的元素并添加到容器中
|
||
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));
|
||
}
|
||
|
||
const params = {
|
||
message, // 消息对象
|
||
side, // 消息显示位置(左/右)
|
||
messageContent, // 消息内容容器
|
||
messageElement, // 消息元素
|
||
avatarTag, // 头像标签
|
||
};
|
||
processMessage(params);
|
||
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> |