mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-06 15:08:50 +00:00
Summary: ## Changes in this pull request ### Checklist - [x] All tests pass. Demo project builds and runs. - [x] I added tests, an experiment, or detailed why my change isn't tested. - [x] I added an entry to the `CHANGELOG.md` for any breaking changes, enhancements, or bug fixes. - [x] I have reviewed the [contributing guide](https://github.com/Instagram/IGListKit/blob/master/.github/CONTRIBUTING.md) Pull Request resolved: https://github.com/Instagram/IGListKit/pull/1453 Reviewed By: lorixx Differential Revision: D23836038 Pulled By: joetam fbshipit-source-id: 8245415992a5b1ed49f67ebfcf9f85a2745a8042
79 lines
2 KiB
Swift
79 lines
2 KiB
Swift
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
import IGListKit
|
|
import UIKit
|
|
|
|
final class CalendarDayCell: UICollectionViewCell {
|
|
|
|
lazy fileprivate var label: UILabel = {
|
|
let view = UILabel()
|
|
view.backgroundColor = .clear
|
|
view.textAlignment = .center
|
|
view.font = .boldSystemFont(ofSize: 16)
|
|
view.layer.borderWidth = 2
|
|
view.clipsToBounds = true
|
|
self.contentView.addSubview(view)
|
|
return view
|
|
}()
|
|
|
|
lazy fileprivate var dotsLabel: UILabel = {
|
|
let view = UILabel()
|
|
view.backgroundColor = .clear
|
|
view.textAlignment = .center
|
|
view.textColor = .red
|
|
view.font = .boldSystemFont(ofSize: 30)
|
|
self.contentView.addSubview(view)
|
|
return view
|
|
}()
|
|
|
|
var text: String? {
|
|
get {
|
|
return label.text
|
|
}
|
|
set {
|
|
label.text = newValue
|
|
}
|
|
}
|
|
|
|
var dots: String? {
|
|
get {
|
|
return dotsLabel.text
|
|
}
|
|
set {
|
|
dotsLabel.text = newValue
|
|
}
|
|
}
|
|
|
|
override func layoutSubviews() {
|
|
super.layoutSubviews()
|
|
let bounds = contentView.bounds
|
|
let half = bounds.height / 2
|
|
label.frame = bounds
|
|
label.layer.cornerRadius = half
|
|
dotsLabel.frame = CGRect(x: 0, y: half - 10, width: bounds.width, height: half)
|
|
}
|
|
|
|
}
|
|
|
|
extension CalendarDayCell: ListBindable {
|
|
|
|
func bindViewModel(_ viewModel: Any) {
|
|
guard let viewModel = viewModel as? DayViewModel else { return }
|
|
label.text = viewModel.day.description
|
|
|
|
label.layer.borderColor = viewModel.today ? UIColor.red.cgColor : UIColor.clear.cgColor
|
|
label.backgroundColor = viewModel.selected ? UIColor.red.withAlphaComponent(0.3) : UIColor.clear
|
|
|
|
var dots = ""
|
|
for _ in 0..<viewModel.appointments {
|
|
dots += "."
|
|
}
|
|
dotsLabel.text = dots
|
|
}
|
|
|
|
}
|