chat.scss 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389
  1. page {
  2. background-color: #f2f2f2;
  3. }
  4. @font-face {
  5. font-family:"HMfont-home";src:url('data:application/x-font-woff2;charset=utf-8;base64,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') format('woff2');
  6. }
  7. .icon {
  8. font-family:"HMfont-home" !important;
  9. font-size: 56rpx;
  10. font-style: normal;
  11. color: #333;
  12. &.biaoqing:before {
  13. content: "\e797";
  14. }
  15. &.jianpan:before {
  16. content: "\e7b2";
  17. }
  18. &.yuyin:before {
  19. content: "\e805";
  20. }
  21. &.tupian:before {
  22. content: "\e639";
  23. }
  24. &.chehui:before {
  25. content: "\e904";
  26. }
  27. &.luyin:before {
  28. content: "\e905";
  29. }
  30. &.luyin2:before {
  31. content: "\e677";
  32. }
  33. &.other-voice:before {
  34. content: "\e667";
  35. }
  36. &.my-voice:before {
  37. content: "\e906";
  38. }
  39. &.hongbao:before {
  40. content: "\e626";
  41. }
  42. &.tupian2:before {
  43. content: "\e674";
  44. }
  45. &.paizhao:before {
  46. content: "\e63e";
  47. }
  48. &.add:before {
  49. content: "\e655";
  50. }
  51. &.close:before {
  52. content: "\e607";
  53. }
  54. &.to:before {
  55. content: "\e675";
  56. }
  57. }
  58. .chat {
  59. width: 100%;
  60. &-content {
  61. width: 100%;
  62. }
  63. }
  64. .hidden{
  65. display: none !important;
  66. }
  67. .chat-content-srcoll-loading {
  68. display: flex;
  69. justify-content: center;
  70. @keyframes stretchdelay {
  71. 0%, 40%, 100% {
  72. transform: scaleY(0.6);
  73. }
  74. 20% {
  75. transform: scaleY(1.0);
  76. }
  77. }
  78. .spinner {
  79. margin: 20rpx 0;
  80. width: 60rpx;
  81. height: 100rpx;
  82. display: flex;
  83. align-items: center;
  84. justify-content: space-between;
  85. view {
  86. background-color: #f06c7a;
  87. height: 50rpx;
  88. width: 6rpx;
  89. border-radius: 6rpx;
  90. animation: stretchdelay 1.2s infinite ease-in-out;
  91. }
  92. .rect2 {
  93. animation-delay: -1.1s;
  94. }
  95. .rect3 {
  96. animation-delay: -1.0s;
  97. }
  98. .rect4 {
  99. animation-delay: -0.9s;
  100. }
  101. .rect5 {
  102. animation-delay: -0.8s;
  103. }
  104. }
  105. }
  106. #chat-content-srcoll {
  107. width: 96%;
  108. padding: 0 2%;
  109. position: absolute;
  110. top: 0;
  111. bottom: 100rpx;
  112. }
  113. .chat-content-srcoll-list {
  114. width: 100%;
  115. height: 100%;
  116. &-item {
  117. padding: 20rpx 30rpx;
  118. &:first-child {
  119. margin-top: 20rpx;
  120. }
  121. .my-info {
  122. width: 100%;
  123. display: flex;
  124. justify-content: flex-end;
  125. align-items: center;
  126. &-left {
  127. width: 100%;
  128. display: flex;
  129. justify-content: flex-end;
  130. .time {
  131. height: 45rpx;
  132. font-size: 24rpx;
  133. color: #999;
  134. text-align: right;
  135. padding-right: 30rpx;
  136. }
  137. .my-username {
  138. display: flex;
  139. justify-content: space-between;
  140. }
  141. .bubble {
  142. max-width: 90%;
  143. min-height: 50rpx;
  144. border-radius: 10rpx;
  145. padding: 18rpx 28rpx;
  146. display: flex;
  147. align-items: center;
  148. font-size: 26rpx;
  149. word-break: break-word;
  150. background-color: #BDE5C3;
  151. color: #333333;
  152. margin-right: 20rpx;
  153. position: relative;
  154. &::before {
  155. position: absolute;
  156. content: "";
  157. width: 0;
  158. height: 0;
  159. left: 100%;
  160. top: 8rpx;
  161. border-top: 10rpx solid transparent;
  162. border-left: 20rpx solid #BDE5C3;
  163. border-bottom: 10rpx solid transparent;
  164. }
  165. }
  166. }
  167. &-right {
  168. display: flex;
  169. justify-content: flex-end;
  170. }
  171. }
  172. .other-info {
  173. width: 100%;
  174. display: flex;
  175. align-items: center;
  176. &-left {
  177. margin-right: 30rpx;
  178. }
  179. &-right {
  180. flex-wrap: wrap;
  181. .username {
  182. width: 100%;
  183. height: 45rpx;
  184. font-size: 24rpx;
  185. color: #999;
  186. display: flex;
  187. .name{
  188. margin-right: 50rpx;
  189. }
  190. }
  191. .bubble {
  192. max-width: 90%;
  193. min-height: 50rpx;
  194. border-radius: 10rpx;
  195. padding: 18rpx 28rpx;
  196. display: flex;
  197. align-items: center;
  198. font-size: 26rpx;
  199. word-break: break-word;
  200. background-color: #fff;
  201. color: #606060;
  202. position: relative;
  203. &::before {
  204. position: absolute;
  205. content: "";
  206. width: 0;
  207. height: 0;
  208. right: 100%;
  209. top: 10rpx;
  210. border-top: 10rpx solid transparent;
  211. border-right: 20rpx solid #fff;
  212. border-bottom: 10rpx solid transparent;
  213. }
  214. &.voice{
  215. .icon{
  216. color: #333;
  217. }
  218. .length{
  219. margin-left: 20rpx;
  220. }
  221. }
  222. &.play{
  223. @keyframes other-play {
  224. 0% {
  225. transform: translateX(-80%);
  226. }
  227. 100% {
  228. transform: translateX(0%);
  229. }
  230. }
  231. .icon:after {
  232. border-right: solid 10rpx rgba(255,255,255,.8);
  233. animation: other-play 1s linear infinite;
  234. }
  235. }
  236. }
  237. }
  238. }
  239. }
  240. }
  241. .input-box {
  242. width: 100%;
  243. min-height: 100rpx;
  244. background-color: #f2f2f2;
  245. display: flex;
  246. position: fixed;
  247. z-index: 20;
  248. bottom: -2rpx;
  249. padding: 0 10rpx;
  250. &.showLayer{
  251. transform: translate3d(0, -42vw, 0);
  252. }
  253. transition: all .15s linear;
  254. border-bottom: solid 1px #ddd;
  255. border-top: solid 1px #ddd;
  256. .voice,.more{
  257. flex-shrink: 0;
  258. width: 90rpx;
  259. height: 100rpx;
  260. display: flex;
  261. justify-content: center;
  262. align-items: center;
  263. }
  264. .send{
  265. /* #ifdef H5 */
  266. margin-left: 20rpx;
  267. /* #endif */
  268. flex-shrink: 0;
  269. width: 100rpx;
  270. height: 100rpx;
  271. display: flex;
  272. align-items: center;
  273. .btn{
  274. width: 90rpx;
  275. height: 56rpx;
  276. display: flex;
  277. justify-content: center;
  278. align-items: center;
  279. background:linear-gradient(to right,#f09b37,#eb632c);
  280. color: #fff;
  281. border-radius: 6rpx;
  282. font-size: 24rpx;
  283. }
  284. }
  285. .textbox{
  286. width: 100%;
  287. min-height: 70rpx;
  288. margin-top: 15rpx;
  289. .voice-mode{
  290. width: calc(100% - 2rpx);
  291. height: 68rpx;
  292. border-radius: 70rpx;
  293. border:solid 1rpx #cdcdcd;
  294. display: flex;
  295. justify-content: center;
  296. align-items: center;
  297. font-size: 28rpx;
  298. background-color: #fff;
  299. color: #555;
  300. &.recording{
  301. background-color: #e5e5e5;
  302. }
  303. }
  304. .text-mode{
  305. width: 100%;
  306. min-height: 70rpx;
  307. display: flex;
  308. background-color: #fff;
  309. border-radius: 40rpx;
  310. .box {
  311. width: 100%;
  312. padding-left: 30rpx;
  313. min-height: 70rpx;
  314. display: flex;
  315. align-items: center;
  316. textarea{
  317. width: 100%;
  318. }
  319. }
  320. .em {
  321. flex-shrink: 0;
  322. width: 80rpx;
  323. padding-left: 10rpx;
  324. height: 70rpx;
  325. display: flex;
  326. justify-content: center;
  327. align-items: center;
  328. }
  329. }
  330. }
  331. }
  332. .popup-layer{
  333. &.showLayer{transform: translate3d(0,-42vw,0);}
  334. transition: all .15s linear;
  335. width: 100%;
  336. height: 42vw;
  337. padding: 10rpx;
  338. background-color: #f3f3f3;
  339. border-top: solid 1rpx #ddd;
  340. position: fixed;
  341. z-index: 20;
  342. top: 100%;
  343. .emoji-swiper{
  344. height: 40vw;
  345. swiper-item{
  346. display: flex;
  347. align-content: flex-start;
  348. flex-wrap: wrap;
  349. view{
  350. width: 12vw;
  351. height: 12vw;
  352. display: flex;
  353. justify-content: center;
  354. align-items: center;
  355. image{
  356. width: 8.4vw;
  357. height: 8.4vw;
  358. }
  359. }
  360. }
  361. }
  362. .more-layer{
  363. width: 100%;
  364. height: 42vw;
  365. .list{
  366. width: 100%;
  367. display: flex;
  368. flex-wrap: wrap;
  369. padding: 30rpx;
  370. .box {
  371. width: 18vw;
  372. height: 18vw;
  373. border-radius: 20rpx;
  374. background-color: #fff;
  375. display: flex;
  376. justify-content: center;
  377. align-items: center;
  378. margin-right: 30rpx;
  379. .icon {
  380. font-size: 70rpx;
  381. }
  382. .shipin {
  383. font-size: 70rpx;
  384. }
  385. }
  386. }
  387. }
  388. }