IGListKit/Examples/Examples-iOS/IGListKitExamples/Views/CalendarDayCell.swift
dirtmelon 019b22da07 Adapts to dark mode for iOS example project. (#1453)
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
2020-10-03 01:39:08 -07:00

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
}
}