148 lines
5.3 KiB
Swift
Executable File
148 lines
5.3 KiB
Swift
Executable File
//
|
|
// IMTipsContentView.swift
|
|
// LegendTeam
|
|
//
|
|
// Created by 梁博 on 21/12/21.
|
|
//
|
|
|
|
import UIKit
|
|
|
|
class IMTipsContentConfig: IMContentBaseConfig {
|
|
override func contentSize(model: SessionBaseModel) -> CGSize {
|
|
guard let message = model.v2msg else { return .zero }
|
|
|
|
let contentView = IMTipsContentView.init(frame: .zero)
|
|
contentView.contentLabel.text = contentView.contentWith(message: message)
|
|
let size = contentView.contentLabel.sizeThatFits(CGSize(width: SessionBaseModel.maxContentWidth, height: CGFloat.greatestFiniteMagnitude))
|
|
var width = size.width
|
|
if size.height > 30 {
|
|
width = SessionBaseModel.maxContentWidth
|
|
}
|
|
return CGSize(width: width + 16, height: size.height + 8 + 1)// +8
|
|
}
|
|
|
|
override func contentViewClass(model: SessionBaseModel) -> IMContentBaseView.Type {
|
|
return IMTipsContentView.self
|
|
}
|
|
|
|
override func cellInsets(model: SessionBaseModel) -> UIEdgeInsets {
|
|
return UIEdgeInsets(top: 8, left: 16, bottom: 8, right: 16)
|
|
}
|
|
|
|
override func onlyShowContent(model: SessionBaseModel) -> Bool {
|
|
return true
|
|
}
|
|
}
|
|
|
|
class IMTipsContentView: IMContentBaseView {
|
|
var effectView: UIVisualEffectView!
|
|
var contentLabel: LineSpaceLabel!
|
|
|
|
|
|
required override init(frame: CGRect) {
|
|
super.init(frame: frame)
|
|
|
|
setupUI()
|
|
}
|
|
|
|
required init?(coder: NSCoder) {
|
|
fatalError("init(coder:) has not been implemented")
|
|
}
|
|
|
|
func setupUI() {
|
|
effectView = {
|
|
let v = UIVisualEffectView(effect: UIBlurEffect(style: .light))
|
|
v.alpha = 1
|
|
v.cornerRadius = 4
|
|
insertSubview(v, at: 0)
|
|
v.snp.makeConstraints { make in
|
|
make.edges.equalToSuperview()
|
|
}
|
|
return v
|
|
}()
|
|
|
|
contentLabel = LineSpaceLabel()
|
|
addSubview(contentLabel)
|
|
contentLabel.textAlignment = .center
|
|
contentLabel.numberOfLines = 0
|
|
contentLabel.textColor = .white
|
|
let typo = CLSystemToken.typography(token: .tbs)
|
|
contentLabel.config(typo)
|
|
contentLabel.backgroundColor = .clear
|
|
contentLabel.snp.makeConstraints { make in
|
|
make.edges.equalToSuperview().inset(UIEdgeInsets(top: 4, left: 8, bottom: 4, right: 8))
|
|
}
|
|
}
|
|
|
|
func contentWith(message: V2NIMMessage?) -> String! {
|
|
var content: String? = nil
|
|
// let info = IMRemoteUtil.dealRemoteInfo(message: message)
|
|
// let remote = message?.remoteExt as? [String: Any]
|
|
// if info.cellType == .create {
|
|
// let createInfo = IMCreateRemoteInfo.deserialize(from: remote, designatedPath: nil) ?? IMCreateRemoteInfo()
|
|
// content = createInfo.getContent()
|
|
// } else if (info.cellType == .keyword) {
|
|
// var hasKeyword = false
|
|
// if let yidunExt = message?.yidunAntiSpamRes {
|
|
// let yidunInfo = IMYidunExtInfo.deserialize(from: yidunExt, designatedPath: nil)
|
|
// if yidunInfo?.code == 200 {
|
|
// hasKeyword = true
|
|
// }
|
|
// }
|
|
// if hasKeyword {
|
|
// content = IMTipsContentView.yidunContent(message: message)
|
|
// } else {
|
|
// let createInfo = IMKewordRemoteInfo.deserialize(from: remote, designatedPath: nil) ?? IMKewordRemoteInfo()
|
|
// content = createInfo.getContent()
|
|
// }
|
|
//
|
|
// }
|
|
if content == nil {
|
|
content = message?.text
|
|
}
|
|
return content ?? ""
|
|
}
|
|
|
|
override func refreshModel(model: SessionBaseModel) {
|
|
super.refreshModel(model: model)
|
|
let content = contentWith(message: model.v2msg)
|
|
contentLabel.text = content
|
|
if content?.count ?? 0 > 60 {
|
|
contentLabel.textAlignment = .left
|
|
} else {
|
|
contentLabel.textAlignment = .center
|
|
}
|
|
}
|
|
|
|
// static public func yidunContent(message:NIMMessage?) -> String {
|
|
// guard let yidunExt = message?.yidunAntiSpamRes else { return "" }
|
|
// guard let yidunInfo = IMYidunExtInfo.deserialize(from: yidunExt, designatedPath: nil) else { return "" }
|
|
// guard let antInfo = IMYidunAntispamInfo.deserialize(from: yidunInfo.ext, designatedPath: "antispam") else { return "" }
|
|
// guard let labels = antInfo.labels else { return "" }
|
|
// var values = [String]()
|
|
// for label in labels {
|
|
// if let subLabels = label.subLabels {
|
|
// for subInfo in subLabels {
|
|
// if let detailInfo = subInfo.details {
|
|
// if let hitInfos = detailInfo.hitInfos {
|
|
// for hitInfo in hitInfos {
|
|
// if let value = hitInfo.value, value.count > 0 {
|
|
// values.append(value)
|
|
// }
|
|
//
|
|
// }
|
|
// }
|
|
// }
|
|
// }
|
|
// }
|
|
// }
|
|
//
|
|
// if values.count > 0 {
|
|
// let keyword = values.joined(separator: "/")
|
|
// return R.string.localizable.contain_sensitive_words.localized([keyword])
|
|
// } else {
|
|
// return R.string.localizable.contain_sensitive_words.localized()
|
|
// }
|
|
// }
|
|
}
|