366 lines
10 KiB
Swift
366 lines
10 KiB
Swift
//
|
|
// GroupMemberView.swift
|
|
// QuickLocation
|
|
//
|
|
// Created by 八条 on 2026/5/29.
|
|
//
|
|
|
|
import UIKit
|
|
import UIKit
|
|
import RxSwift
|
|
import RxCocoa
|
|
|
|
class GroupMemberView: UIView {
|
|
|
|
func setupCountData(_ memberCount: Int, _ memberOnlineCount: Int) {
|
|
groupContentLab.text = "共\(memberCount)成员/\(memberOnlineCount)在线"
|
|
}
|
|
|
|
private func setupRx() {
|
|
|
|
}
|
|
|
|
private func setupUI() {
|
|
addSubview(headerBgView)
|
|
addSubview(bgView)
|
|
addSubview(groupIcon)
|
|
addSubview(titleIcon)
|
|
addSubview(groupContentLab)
|
|
addSubview(refreshBtn)
|
|
addSubview(inviteJoinBtn)
|
|
addSubview(tableView)
|
|
|
|
headerBgView.layoutChain
|
|
.edges(excludingEdge: .bottom)
|
|
.heightToWidth(136/375)
|
|
|
|
bgView.layoutChain
|
|
.topToBottomOfView(headerBgView)
|
|
.edges(excludingEdge: .top)
|
|
|
|
groupIcon.layoutChain
|
|
.top()
|
|
.left()
|
|
.width(52)
|
|
.height(52)
|
|
|
|
titleIcon.layoutChain
|
|
.top(5)
|
|
.leftToRightOfView(groupIcon)
|
|
.width(110)
|
|
.height(26)
|
|
|
|
groupContentLab.layoutChain
|
|
.topToBottomOfView(titleIcon, offset: 8)
|
|
.leftToView(titleIcon)
|
|
|
|
inviteJoinBtn.layoutChain
|
|
.top(23)
|
|
.right(15)
|
|
.height(20)
|
|
|
|
refreshBtn.layoutChain
|
|
.topToView(inviteJoinBtn)
|
|
.rightToLeftOfView(inviteJoinBtn, offset: -20)
|
|
.height(20)
|
|
|
|
inviteJoinBtn.sizeToFit()
|
|
refreshBtn.sizeToFit()
|
|
|
|
tableView.layoutChain
|
|
.topToBottomOfView(groupContentLab, offset: 8)
|
|
.edges(excludingEdge: .top)
|
|
}
|
|
|
|
lazy var headerBgView: UIImageView = {
|
|
let view = UIImageView()
|
|
view.image = UIImage(named: "Home/group_member_bg")
|
|
view.backgroundColor = .clear
|
|
view.contentMode = .scaleAspectFill
|
|
return view
|
|
}()
|
|
|
|
lazy var bgView: UIView = {
|
|
let view = UIView()
|
|
view.backgroundColor = .white
|
|
return view
|
|
}()
|
|
|
|
lazy var groupIcon: UIImageView = {
|
|
let view = UIImageView()
|
|
view.image = UIImage(named: "Home/group_icon")
|
|
view.backgroundColor = .clear
|
|
view.contentMode = .scaleAspectFill
|
|
return view
|
|
}()
|
|
|
|
lazy var titleIcon: UIImageView = {
|
|
let view = UIImageView()
|
|
view.image = UIImage(named: "Home/title_icon")
|
|
view.backgroundColor = .clear
|
|
view.contentMode = .scaleAspectFill
|
|
return view
|
|
}()
|
|
|
|
lazy var groupContentLab: UILabel = {
|
|
let label = UILabel()
|
|
label.text = "共0成员/0在线"
|
|
label.font = .systemFont(ofSize: 12, weight: .medium)
|
|
label.textColor = UIColor(hexStr: "#0F2846")
|
|
return label
|
|
}()
|
|
|
|
lazy var refreshBtn: UIButton = {
|
|
let btn = UIButton(type: .custom)
|
|
btn.setTitle(" 刷新列表", for: .normal)
|
|
btn.setTitleColor(UIColor(hexStr: "#1A1A1A"), for: .normal)
|
|
btn.titleLabel?.font = .systemFont(ofSize: 12, weight: .regular)
|
|
btn.setImage(UIImage(named: "Home/refresh"), for: .normal)
|
|
return btn
|
|
}()
|
|
|
|
lazy var inviteJoinBtn: UIButton = {
|
|
let btn = UIButton(type: .custom)
|
|
btn.setTitle(" 邀请加入", for: .normal)
|
|
btn.setTitleColor(UIColor(hexStr: "#1A1A1A"), for: .normal)
|
|
btn.titleLabel?.font = .systemFont(ofSize: 12, weight: .regular)
|
|
btn.setImage(UIImage(named: "Home/member"), for: .normal)
|
|
return btn
|
|
}()
|
|
|
|
lazy var tableView: UITableView = {
|
|
let tableView = UITableView(frame: .zero, style: .plain)
|
|
tableView.backgroundColor = .clear
|
|
tableView.separatorStyle = .none
|
|
tableView.estimatedRowHeight = 76
|
|
tableView.showsVerticalScrollIndicator = false
|
|
tableView.register(GroupMemberCell.self)
|
|
return tableView
|
|
}()
|
|
|
|
override init(frame: CGRect) {
|
|
super.init(frame: frame)
|
|
backgroundColor = .clear
|
|
setupUI()
|
|
setupRx()
|
|
}
|
|
|
|
required init?(coder aDecoder: NSCoder) {
|
|
fatalError("init(coder:) has not been implemented")
|
|
}
|
|
}
|
|
|
|
// MARK: - GroupMemberCell
|
|
class GroupMemberCell: UITableViewCell {
|
|
|
|
func configure(model: GroupMemberModel, isCurrentUser: Bool, isOwn: Bool) {
|
|
ownView.isHidden = !isOwn
|
|
avaterImgView.image = model.userIcon
|
|
vipIcon.image = model.vipIcon
|
|
nameLab.text = model.nick_name
|
|
locationLab.text = "在 " + model.lastLocation
|
|
|
|
nameLab.textColor = UIColor(hexStr: isCurrentUser ? "#16B3FF" : "#0F2846")
|
|
}
|
|
|
|
private func setupSubviews() {
|
|
contentView.addSubview(ownBgView)
|
|
contentView.addSubview(avaterImgView)
|
|
contentView.addSubview(vipIcon)
|
|
contentView.addSubview(nameLab)
|
|
contentView.addSubview(locationIcon)
|
|
contentView.addSubview(locationLab)
|
|
contentView.addSubview(tagView)
|
|
contentView.addSubview(onlineView)
|
|
|
|
setupLayout()
|
|
}
|
|
|
|
private func setupLayout() {
|
|
ownBgView.layoutChain
|
|
.edgesHorzontal(15)
|
|
.edgesVertical()
|
|
|
|
avaterImgView.layoutChain
|
|
.edgesVertical(13)
|
|
.left(28)
|
|
.width(50)
|
|
.height(50)
|
|
|
|
vipIcon.layoutChain
|
|
.topToView(avaterImgView, offset: -8)
|
|
.leftToView(avaterImgView, offset: -6)
|
|
.width(25)
|
|
.height(21)
|
|
|
|
nameLab.layoutChain
|
|
.topToView(avaterImgView, offset: 6)
|
|
.leftToRightOfView(avaterImgView, offset: 8)
|
|
|
|
locationLab.layoutChain
|
|
.bottomToView(avaterImgView, offset: -6)
|
|
.leftToView(nameLab)
|
|
|
|
locationIcon.layoutChain
|
|
.leftToRightOfView(locationLab, offset: 4)
|
|
.centerY(locationLab)
|
|
.width(10)
|
|
.height(10)
|
|
|
|
tagView.layoutChain
|
|
.leftToRightOfView(nameLab, offset: 4)
|
|
.centerY(nameLab)
|
|
.height(20)
|
|
|
|
ownView.layoutChain.height(15)
|
|
|
|
offlineView.layoutChain.height(15)
|
|
|
|
onlineView.layoutChain
|
|
.right(26)
|
|
.bottom(18)
|
|
}
|
|
|
|
lazy var ownBgView: UIView = {
|
|
let view = UIView()
|
|
view.backgroundColor = UIColor(hexStr: "#EAFBFF")
|
|
view.cornerRadius = 10
|
|
view.isHidden = true
|
|
return view
|
|
}()
|
|
|
|
lazy var avaterImgView: UIImageView = {
|
|
let view = UIImageView()
|
|
view.backgroundColor = .lightGray
|
|
view.contentMode = .scaleAspectFill
|
|
view.cornerRadius = 25
|
|
return view
|
|
}()
|
|
|
|
lazy var vipIcon: UIImageView = {
|
|
let view = UIImageView()
|
|
return view
|
|
}()
|
|
|
|
lazy var nameLab: UILabel = {
|
|
let label = UILabel()
|
|
label.textColor = UIColor(hexStr: "#0F2846")
|
|
label.font = .systemFont(ofSize: 14, weight: .semibold)
|
|
return label
|
|
}()
|
|
|
|
lazy var locationIcon: UIImageView = {
|
|
let view = UIImageView()
|
|
view.image = UIImage(named: "Home/member_location")
|
|
return view
|
|
}()
|
|
|
|
lazy var locationLab: UILabel = {
|
|
let label = UILabel()
|
|
label.textColor = UIColor(hexStr: "#8D8D8D")
|
|
label.font = .systemFont(ofSize: 10, weight: .regular)
|
|
return label
|
|
}()
|
|
|
|
lazy var tagView: UIStackView = {
|
|
let view = UIStackView(arrangedSubviews: [ownView, offlineView])
|
|
view.axis = .horizontal
|
|
view.alignment = .center
|
|
view.spacing = 0
|
|
view.backgroundColor = .clear
|
|
return view
|
|
}()
|
|
|
|
// 圈主
|
|
lazy var ownView: UIView = {
|
|
let view = UIView()
|
|
view.backgroundColor = UIColor(hexStr: "#9FD9FF")
|
|
view.cornerRadius = 2
|
|
|
|
let label = UILabel()
|
|
label.textColor = UIColor(hexStr: "#194045")
|
|
label.font = .systemFont(ofSize: 8, weight: .medium)
|
|
label.text = "圈主"
|
|
|
|
view.addSubview(label)
|
|
label.layoutChain
|
|
.edgesVertical(2)
|
|
.edgesHorzontal(8)
|
|
|
|
return view
|
|
}()
|
|
|
|
// 离线
|
|
lazy var offlineView: UIView = {
|
|
let view = UIView()
|
|
view.backgroundColor = UIColor(hexStr: "#EDEDED")
|
|
view.cornerRadius = 2
|
|
|
|
let label = UILabel()
|
|
label.textColor = ThemeManager.shared.color.contentColor
|
|
label.font = .systemFont(ofSize: 8, weight: .medium)
|
|
label.text = "离线"
|
|
|
|
view.addSubview(label)
|
|
label.layoutChain
|
|
.edgesVertical(2)
|
|
.edgesHorzontal(8)
|
|
|
|
view.isHidden = true
|
|
return view
|
|
}()
|
|
|
|
// 在线
|
|
lazy var onlineView: UIView = {
|
|
let view = UIView()
|
|
view.backgroundColor = .clear
|
|
|
|
let dot = UIView()
|
|
dot.backgroundColor = UIColor(hexStr: "#67EA76")
|
|
dot.cornerRadius = 4
|
|
|
|
let label = UILabel()
|
|
label.textColor = ThemeManager.shared.color.subTitleColor
|
|
label.font = .systemFont(ofSize: 10, weight: .medium)
|
|
label.text = "在线"
|
|
|
|
view.addSubview(dot)
|
|
view.addSubview(label)
|
|
|
|
dot.layoutChain
|
|
.left()
|
|
.centerY()
|
|
.height(8)
|
|
.width(8)
|
|
|
|
label.layoutChain
|
|
.edgesVertical()
|
|
.leftToRightOfView(dot, offset: 3)
|
|
.right()
|
|
|
|
return view
|
|
}()
|
|
|
|
override func awakeFromNib() {
|
|
super.awakeFromNib()
|
|
// Initialization code
|
|
}
|
|
|
|
override init(style: CellStyle, reuseIdentifier: String?) {
|
|
super.init(style: style, reuseIdentifier: reuseIdentifier)
|
|
selectionStyle = .none
|
|
backgroundColor = .clear
|
|
setupSubviews()
|
|
}
|
|
|
|
required init?(coder: NSCoder) {
|
|
fatalError("init(coder:) has not been implemented")
|
|
}
|
|
|
|
override func setSelected(_ selected: Bool, animated: Bool) {
|
|
super.setSelected(selected, animated: animated)
|
|
|
|
// Configure the view for the selected state
|
|
}
|
|
}
|