|
|
@ -5,12 +5,13 @@ import Foundation |
|
|
|
|
|
|
|
|
|
|
|
extension ParentPanelController: NSCollectionViewDataSource, NSCollectionViewDelegate { |
|
|
|
extension ParentPanelController: NSCollectionViewDataSource, NSCollectionViewDelegate { |
|
|
|
func collectionView(_: NSCollectionView, numberOfItemsInSection _: Int) -> Int { |
|
|
|
func collectionView(_: NSCollectionView, numberOfItemsInSection _: Int) -> Int { |
|
|
|
return 96 |
|
|
|
return modernSliderDataSource.count |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func collectionView(_ collectionView: NSCollectionView, itemForRepresentedObjectAt indexPath: IndexPath) -> NSCollectionViewItem { |
|
|
|
func collectionView(_ collectionView: NSCollectionView, itemForRepresentedObjectAt indexPath: IndexPath) -> NSCollectionViewItem { |
|
|
|
let item = collectionView.makeItem(withIdentifier: HourMarkerViewItem.reuseIdentifier, for: indexPath) as! HourMarkerViewItem |
|
|
|
let item = collectionView.makeItem(withIdentifier: HourMarkerViewItem.reuseIdentifier, for: indexPath) as! HourMarkerViewItem |
|
|
|
item.setup(with: indexPath.item) |
|
|
|
let dataSoureValue = modernSliderDataSource[indexPath.item] |
|
|
|
|
|
|
|
item.setup(with: indexPath.item, value: dataSoureValue) |
|
|
|
return item |
|
|
|
return item |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -22,8 +23,8 @@ extension ParentPanelController { |
|
|
|
let newPoint = NSPoint(x: changedOrigin.x + contentView.frame.width / 2, y: changedOrigin.y) |
|
|
|
let newPoint = NSPoint(x: changedOrigin.x + contentView.frame.width / 2, y: changedOrigin.y) |
|
|
|
let indexPath = modernSlider.indexPathForItem(at: newPoint) |
|
|
|
let indexPath = modernSlider.indexPathForItem(at: newPoint) |
|
|
|
if let correctIndexPath = indexPath?.item, let item = modernSlider.item(at: correctIndexPath) as? HourMarkerViewItem { |
|
|
|
if let correctIndexPath = indexPath?.item, let item = modernSlider.item(at: correctIndexPath) as? HourMarkerViewItem { |
|
|
|
setModernSliderLabel(item.indexTag) |
|
|
|
modernSliderLabel.stringValue = item.timeRepresentation |
|
|
|
setTimezoneDatasourceSlider(sliderValue: item.indexTag * 15) |
|
|
|
// setTimezoneDatasourceSlider(sliderValue: item.indexTag * 15) |
|
|
|
item.setupLineColor() |
|
|
|
item.setupLineColor() |
|
|
|
mainTableView.reloadData() |
|
|
|
mainTableView.reloadData() |
|
|
|
|
|
|
|
|
|
|
@ -36,16 +37,59 @@ extension ParentPanelController { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func setModernSliderLabel(_ index: Int) { |
|
|
|
private func minuteFromCalendar() -> (Date, Int) { |
|
|
|
var dateComponents = DateComponents() |
|
|
|
let currentDate = Date() |
|
|
|
dateComponents.minute = index * 15 |
|
|
|
var minute = Calendar.current.component(.minute, from: currentDate) |
|
|
|
if let newDate = Calendar.autoupdatingCurrent.date(byAdding: dateComponents, to: Date().nextHour) { |
|
|
|
if minute < 15 { |
|
|
|
let dateFormatter = DateFormatterManager.dateFormatterWithFormat(with: .none, |
|
|
|
minute = 15 |
|
|
|
format: "MMM d HH:mm", |
|
|
|
} else if minute < 30 { |
|
|
|
timezoneIdentifier: TimeZone.current.identifier, |
|
|
|
minute = 30 |
|
|
|
locale: Locale.autoupdatingCurrent) |
|
|
|
} else if minute < 45 { |
|
|
|
|
|
|
|
minute = 45 |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
minute = 0 |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return (currentDate, minute) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public func forward15Minutes() -> [String] { |
|
|
|
|
|
|
|
let defaultParameters = minuteFromCalendar() |
|
|
|
|
|
|
|
let hourQuarterDate = Calendar.current.nextDate(after: defaultParameters.0, matching: DateComponents(minute: defaultParameters.1), matchingPolicy: .strict, repeatedTimePolicy: .first, direction: .forward)! |
|
|
|
|
|
|
|
var backwards = hourQuarterDate |
|
|
|
|
|
|
|
var forwards = hourQuarterDate |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var hourQuarters = [String]() |
|
|
|
|
|
|
|
for _ in 1 ... 96 { |
|
|
|
|
|
|
|
backwards = Calendar.current.date(byAdding: .minute, value: -15, to: backwards)! |
|
|
|
|
|
|
|
hourQuarters.append(timezoneFormattedStringRepresentation(backwards)) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
modernSliderLabel.stringValue = dateFormatter.string(from: newDate) |
|
|
|
hourQuarters.append(timezoneFormattedStringRepresentation(forwards)) |
|
|
|
|
|
|
|
for _ in 1 ... 96 { |
|
|
|
|
|
|
|
forwards = Calendar.current.date(byAdding: .minute, value: 15, to: forwards)! |
|
|
|
|
|
|
|
hourQuarters.append(timezoneFormattedStringRepresentation(forwards)) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
return hourQuarters |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public func backward15Minutes() -> [String] { |
|
|
|
|
|
|
|
let defaultParameters = minuteFromCalendar() |
|
|
|
|
|
|
|
var hourQuarterDate = Calendar.current.nextDate(after: defaultParameters.0, matching: DateComponents(minute: defaultParameters.1), matchingPolicy: .strict, repeatedTimePolicy: .first, direction: .forward)! |
|
|
|
|
|
|
|
var hourQuarters = [String]() |
|
|
|
|
|
|
|
for _ in 1 ... 96 { |
|
|
|
|
|
|
|
hourQuarterDate = Calendar.current.date(byAdding: .minute, value: -15, to: hourQuarterDate)! |
|
|
|
|
|
|
|
hourQuarters.append(timezoneFormattedStringRepresentation(hourQuarterDate)) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return hourQuarters |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private func timezoneFormattedStringRepresentation(_ date: Date) -> String { |
|
|
|
|
|
|
|
let dateFormatter = DateFormatterManager.dateFormatterWithFormat(with: .none, |
|
|
|
|
|
|
|
format: "MMM d HH:mm", |
|
|
|
|
|
|
|
timezoneIdentifier: TimeZone.current.identifier, |
|
|
|
|
|
|
|
locale: Locale.autoupdatingCurrent) |
|
|
|
|
|
|
|
return dateFormatter.string(from: date) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|