MoviaBox/MoviaBox/Class/Home/View/SPHomeTrendingCell.swift

152 lines
4.4 KiB
Swift

//
// SPHomeTrendingCell.swift
// MoviaBox
//
// Created by on 2025/4/14.
//
import UIKit
class SPHomeTrendingCell: SPCollectionViewCell {
var model: SPShortModel? {
didSet {
coverImageView.sp_setImage(url: model?.image_url)
titleLabel.text = model?.name
hotView.setTitle("\(model?.watch_total ?? 0)", for: .normal)
if let tag = model?.tag_type, !tag.isEmpty {
tagView.setTitle(tag, for: .normal)
tagView.isHidden = false
} else {
tagView.isHidden = true
}
}
}
var row: Int = 0 {
didSet {
let num = row + 1
if num < 4 {
numBgView.image = UIImage(named: "num_bg_icon_\(num)")
} else {
numBgView.image = UIImage(named: "num_bg_icon_4")
}
numLabel.text = "\(num)"
}
}
//MARK: UI
private lazy var coverImageView: SPImageView = {
let imageView = SPImageView()
imageView.layer.cornerRadius = 6
imageView.layer.masksToBounds = true
return imageView
}()
private lazy var numBgView: UIImageView = {
let imageView = UIImageView()
return imageView
}()
private lazy var numLabel: UILabel = {
let label = UILabel()
label.font = .fontMedium(ofSize: 20)
label.textColor = .colorFFFFFF()
return label
}()
private lazy var titleLabel: UILabel = {
let label = UILabel()
label.font = .fontMedium(ofSize: 12)
label.textColor = .colorFFFFFF()
label.numberOfLines = 2
return label
}()
private lazy var hotView: JXButton = {
let button = JXButton(type: .custom)
button.isUserInteractionEnabled = false
button.titleDirection = .right
button.jx_font = .fontRegular(ofSize: 10)
button.leftAndRightMargin = 6
button.setImage(UIImage(named: "hot_icon_01"), for: .normal)
button.setTitleColor(.colorFFDD00(), for: .normal)
button.backgroundColor = .colorD9D9D9(alpha: 0.16)
button.layer.cornerRadius = 2
button.layer.masksToBounds = true
return button
}()
private lazy var tagView: JXButton = {
let button = JXButton(type: .custom)
button.isUserInteractionEnabled = false
button.backgroundColor = .colorD9D9D9(alpha: 0.16)
button.layer.cornerRadius = 2
button.layer.masksToBounds = true
button.jx_font = .fontRegular(ofSize: 10)
button.setTitleColor(.colorFFFFFF(), for: .normal)
button.leftAndRightMargin = 6
return button
}()
override init(frame: CGRect) {
super.init(frame: frame)
_setupUI()
}
@MainActor required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}
extension SPHomeTrendingCell {
private func _setupUI() {
contentView.addSubview(coverImageView)
coverImageView.addSubview(numBgView)
numBgView.addSubview(numLabel)
contentView.addSubview(titleLabel)
contentView.addSubview(hotView)
contentView.addSubview(tagView)
// coverImageView.addSubview(hotBgView)
// hotBgView.addSubview(hotIconImageView)
coverImageView.snp.makeConstraints { make in
make.left.top.bottom.equalToSuperview()
make.width.equalTo(82)
}
numBgView.snp.makeConstraints { make in
make.left.top.equalToSuperview()
}
numLabel.snp.makeConstraints { make in
make.center.equalToSuperview()
}
titleLabel.snp.makeConstraints { make in
make.left.equalTo(coverImageView.snp.right).offset(8)
make.top.equalToSuperview().offset(12)
make.right.lessThanOrEqualToSuperview().offset(-5)
}
hotView.snp.makeConstraints { make in
make.left.equalTo(titleLabel)
make.top.equalToSuperview().offset(56)
make.height.equalTo(18)
}
tagView.snp.makeConstraints { make in
make.left.equalTo(hotView)
make.top.equalTo(hotView.snp.bottom).offset(8)
make.height.equalTo(18)
}
}
}