mirror of
https://github.com/Ranchero-Software/NetNewsWire.git
synced 2025-01-04 13:59:23 +01:00
Place avatars on the left in the timeline.
This commit is contained in:
parent
1b22abbbfc
commit
52b1ef2350
@ -37,6 +37,7 @@ struct TimelineCellAppearance: Equatable {
|
|||||||
|
|
||||||
let avatarSize = NSSize(width: 48, height: 48)
|
let avatarSize = NSSize(width: 48, height: 48)
|
||||||
let avatarMarginLeft: CGFloat = 8.0
|
let avatarMarginLeft: CGFloat = 8.0
|
||||||
|
let avatarMarginRight: CGFloat = 8.0
|
||||||
let avatarAdjustmentTop: CGFloat = 4.0
|
let avatarAdjustmentTop: CGFloat = 4.0
|
||||||
let avatarCornerRadius: CGFloat = 4.0
|
let avatarCornerRadius: CGFloat = 4.0
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ struct TimelineCellLayout {
|
|||||||
|
|
||||||
// If height == 0.0, then height is calculated.
|
// If height == 0.0, then height is calculated.
|
||||||
|
|
||||||
let showAvatar = hasAvatar && cellData.showAvatar
|
let showAvatar = cellData.showAvatar
|
||||||
var textBoxRect = TimelineCellLayout.rectForTextBox(appearance, cellData, showAvatar, width)
|
var textBoxRect = TimelineCellLayout.rectForTextBox(appearance, cellData, showAvatar, width)
|
||||||
|
|
||||||
let (titleRect, numberOfLinesForTitle) = TimelineCellLayout.rectForTitle(textBoxRect, appearance, cellData)
|
let (titleRect, numberOfLinesForTitle) = TimelineCellLayout.rectForTitle(textBoxRect, appearance, cellData)
|
||||||
@ -94,8 +94,9 @@ private extension TimelineCellLayout {
|
|||||||
|
|
||||||
// Returned height is a placeholder. Not needed when this is calculated.
|
// Returned height is a placeholder. Not needed when this is calculated.
|
||||||
|
|
||||||
let textBoxOriginX = appearance.cellPadding.left + appearance.unreadCircleDimension + appearance.unreadCircleMarginRight
|
let avatarSpace = showAvatar ? appearance.avatarSize.width + appearance.avatarMarginRight : 0.0
|
||||||
let textBoxMaxX = floor((width - appearance.cellPadding.right) - (showAvatar ? appearance.avatarSize.width + appearance.avatarMarginLeft : 0.0))
|
let textBoxOriginX = appearance.cellPadding.left + appearance.unreadCircleDimension + appearance.unreadCircleMarginRight + avatarSpace
|
||||||
|
let textBoxMaxX = floor(width - appearance.cellPadding.right)
|
||||||
let textBoxWidth = floor(textBoxMaxX - textBoxOriginX)
|
let textBoxWidth = floor(textBoxMaxX - textBoxOriginX)
|
||||||
let textBoxRect = NSRect(x: textBoxOriginX, y: appearance.cellPadding.top, width: textBoxWidth, height: 1000000)
|
let textBoxRect = NSRect(x: textBoxOriginX, y: appearance.cellPadding.top, width: textBoxWidth, height: 1000000)
|
||||||
|
|
||||||
@ -204,16 +205,8 @@ private extension TimelineCellLayout {
|
|||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
r.size = appearance.avatarSize
|
r.size = appearance.avatarSize
|
||||||
r.origin.x = (width - appearance.cellPadding.right) - r.size.width
|
r.origin.x = appearance.cellPadding.left + appearance.unreadCircleDimension + appearance.unreadCircleMarginRight
|
||||||
r.origin.y = textBoxRect.origin.y + 4.0
|
r.origin.y = textBoxRect.origin.y + appearance.avatarAdjustmentTop
|
||||||
// r = RSRectCenteredVerticallyInRect(r, textBoxRect)
|
|
||||||
// if height > 0.1 {
|
|
||||||
// let bounds = NSRect(x: 0.0, y: 0.0, width: width, height: height)
|
|
||||||
// r = RSRectCenteredVerticallyInRect(r, bounds)
|
|
||||||
// }
|
|
||||||
// else {
|
|
||||||
// r = RSRectCenteredVerticallyInRect(r, textBoxRect)
|
|
||||||
// }
|
|
||||||
|
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user