Skip to content

Commit

Permalink
Update documentation and private members
Browse files Browse the repository at this point in the history
  • Loading branch information
PavelHolec committed Nov 27, 2023
1 parent 0a590a2 commit 32b2d93
Show file tree
Hide file tree
Showing 17 changed files with 515 additions and 282 deletions.
46 changes: 27 additions & 19 deletions Sources/Orbit/Components/Alert.swift
Original file line number Diff line number Diff line change
@@ -1,38 +1,46 @@
import SwiftUI

/// Breaks the main user flow to present information.
/// Orbit component that breaks the main user flow to present information.
///
/// There are times when just simple information isn’t enough and the user needs
/// to take additional steps to resolve the problem or get additional details.
///
/// In such cases, provide additional actions for your message.
/// Alerts use special status buttons to match the button color with the alert color.
///
/// Use at most two actions in each Alert: one primary and one subtle.
/// An `Alert` consists of a title, description, icon, optional custom content and at most two actions.
///
/// ```swift
/// Alert("Alert", description: "Description") {
/// customContent
/// } buttons: {
/// Alert("Alert") {
/// Button("Primary") { /* */ }
/// Button("Secondary") { /* */ }
/// }
/// .status(.warning)
/// ```
///
/// ### Customizing appearance
///
/// The title and icon colors can be modified by ``textColor(_:)`` and ``iconColor(_:)`` modifiers.
/// The icon size can be modified by ``iconSize(custom:)`` modifier.
///
/// A default ``Status/info`` status can be modified by ``status(_:)`` modifier:
///
/// ```swift
/// Alert("Alert", description: "Please check your <applink1>visa</applink1>")
/// .status(.warning)
/// ```
///
/// The button priority can be overridden by using `buttonPriority()` modifier.
/// The automatic button priority can be overridden by ``buttonPriority(_:)`` modifier:
///
/// ```swift
/// Alert("Alert") {
/// customContent
/// content
/// } buttons: {
/// Button("Secondary Only") { /* */ }
/// .buttonPriority(.secondary)
/// }
/// ```
///
/// - Note: [Orbit definition](https://orbit.kiwi/components/alert/)
/// - Important: Component expands horizontally unless prevented by `fixedSize` or `idealSize` modifier.
/// For compact variant, use ``AlertInline`` component.
///
/// ### Layout
///
/// Component expands horizontally unless prevented by native `fixedSize()` or ``idealSize()`` modifier.
///
/// - Note: [Orbit.kiwi documentation](https://orbit.kiwi/components/alert/)
public struct Alert<Content: View, Icon: View, Buttons: View>: View {

private let title: String
Expand All @@ -56,7 +64,7 @@ public struct Alert<Content: View, Icon: View, Buttons: View>: View {

public extension Alert {

/// Creates Orbit Alert component.
/// Creates Orbit ``Alert`` component.
init(
_ title: String = "",
description: String = "",
Expand All @@ -73,7 +81,7 @@ public extension Alert {
}
}

/// Creates Orbit Alert component with no buttons.
/// Creates Orbit ``Alert`` component with no buttons.
init(
_ title: String = "",
description: String = "",
Expand All @@ -89,7 +97,7 @@ public extension Alert {
}
}

/// Creates Orbit Alert component with custom content and icon.
/// Creates Orbit ``Alert`` component with custom content and icon.
init(
_ title: String = "",
description: String = "",
Expand Down
36 changes: 29 additions & 7 deletions Sources/Orbit/Components/AlertInline.swift
Original file line number Diff line number Diff line change
@@ -1,12 +1,34 @@
import SwiftUI

/// Breaks the main user flow to present information.
/// Orbit component that breaks the main user flow to present information.
///
/// There are times when just simple information isn’t enough and the user needs
/// to take additional steps to resolve the problem or get additional details.
/// An `AlertInline` (an inline variant of ``Alert``) consists of a title, icon and a single action.
///
/// - Note: [Orbit definition](https://orbit.kiwi/components/alert/)
/// - Important: Component expands horizontally unless prevented by `fixedSize` or `idealSize` modifier.
/// ```swift
/// AlertInline("Alert") {
/// Button("Primary") { /* */ }
/// }
/// ```
///
/// ### Customizing appearance
///
/// The title and icon colors can be modified by ``textColor(_:)`` and ``iconColor(_:)`` modifiers.
/// The icon size can be modified by ``iconSize(custom:)`` modifier.
///
/// A default ``Status/info`` status can be modified by ``status(_:)`` modifier:
///
/// ```swift
/// AlertInline("Alert") {
/// Button("Primary") { /* */ }
/// }
/// .status(.warning)
/// ```
///
/// ### Layout
///
/// Component expands horizontally unless prevented by native `fixedSize()` or ``idealSize()`` modifier.
///
/// - Note: [Orbit.kiwi documentation](https://orbit.kiwi/components/alert/)
public struct AlertInline<Icon: View, Button: View>: View {

private let title: String
Expand All @@ -28,7 +50,7 @@ public struct AlertInline<Icon: View, Button: View>: View {

public extension AlertInline {

/// Creates Orbit AlertInline component.
/// Creates Orbit ``AlertInline`` component.
init(
_ title: String = "",
icon: Icon.Symbol? = nil,
Expand All @@ -40,7 +62,7 @@ public extension AlertInline {
}
}

/// Creates Orbit AlertInline component with custom content and icon.
/// Creates Orbit ``AlertInline`` component with custom content and icon.
init(
_ title: String = "",
isSubtle: Bool = false,
Expand Down
53 changes: 31 additions & 22 deletions Sources/Orbit/Components/Badge.swift
Original file line number Diff line number Diff line change
@@ -1,11 +1,26 @@
import SwiftUI

/// Presents users with short, relevant information.
/// Orbit component that displays non-actionable, short and static information.
///
/// Badges are indicators of static information.
/// They can be updated when a status changes, but they should not be actionable.
/// A `Badge` consists of a title and up to two icons.
///
/// - Note: [Orbit definition](https://orbit.kiwi/components/badge/)
/// ```swift
/// Badge("Label", icon: .grid, type: .lightInverted)
/// ```
///
/// ### Customizing appearance
///
/// The label and icon colors can be modified by ``textColor(_:)`` and ``iconColor(_:)`` modifiers.
/// The icon size can be modified by ``iconSize(custom:)`` modifier.
///
/// When a type is set to ``BadgeType/status(_:inverted:)`` with a `nil` value, the default ``Status/info`` status can be modified by ``status(_:)`` modifier:
///
/// ```swift
/// Badge("Label", type: .status(nil))
/// .status(.warning)
/// ```
///
/// - Note: [Orbit.kiwi documentation](https://orbit.kiwi/components/badge/)
public struct Badge<LeadingIcon: View, TrailingIcon: View>: View, PotentiallyEmptyView {

@Environment(\.backgroundShape) private var backgroundShape
Expand Down Expand Up @@ -47,19 +62,23 @@ public struct Badge<LeadingIcon: View, TrailingIcon: View>: View, PotentiallyEmp
}
}

@ViewBuilder var resolvedBackground: some View {
@ViewBuilder private var resolvedBackground: some View {
if let backgroundShape {
backgroundShape.inactiveView
} else {
defaultBackgroundColor
}
}

var resolvedLabelColor: Color {
var isEmpty: Bool {
leadingIcon.isEmpty && label.isEmpty && trailingIcon.isEmpty
}

private var resolvedLabelColor: Color {
textColor ?? labelColor
}

var labelColor: Color {
private var labelColor: Color {
switch type {
case .light: return .inkDark
case .lightInverted: return .whiteNormal
Expand All @@ -69,7 +88,7 @@ public struct Badge<LeadingIcon: View, TrailingIcon: View>: View, PotentiallyEmp
}
}

var defaultBackgroundColor: Color {
private var defaultBackgroundColor: Color {
switch type {
case .light: return .whiteDarker
case .lightInverted: return .inkDark
Expand All @@ -79,26 +98,19 @@ public struct Badge<LeadingIcon: View, TrailingIcon: View>: View, PotentiallyEmp
}
}

var minTextWidth: CGFloat {
private var minTextWidth: CGFloat {
Text.Size.small.lineHeight * sizeCategory.ratio - .xSmall
}

var isEmpty: Bool {
leadingIcon.isEmpty && label.isEmpty && trailingIcon.isEmpty
}

var defaultStatus: Status {
private var defaultStatus: Status {
status ?? .info
}
}

// MARK: - Inits
public extension Badge {

/// Creates Orbit Badge component.
///
/// - Parameters:
/// - type: A visual style of component. A `status` style can be optionally modified using `status()` modifier when `nil` value is provided.
/// Creates Orbit ``Badge`` component.
init(
_ label: String = "",
icon: Icon.Symbol? = nil,
Expand All @@ -112,10 +124,7 @@ public extension Badge {
}
}

/// Creates Orbit Badge component with custom icons.
///
/// - Parameters:
/// - style: A visual style of component. A `status` style can be optionally modified using `status()` modifier when `nil` value is provided.
/// Creates Orbit ``Badge`` component with custom icons.
init(
_ label: String = "",
type: BadgeType = .neutral,
Expand Down
55 changes: 32 additions & 23 deletions Sources/Orbit/Components/BadgeList.swift
Original file line number Diff line number Diff line change
@@ -1,19 +1,34 @@
import SwiftUI

/// Presents a list of short details with added visual information.
/// Orbit component that displays non-actionable, short details with added visual information.
///
/// The items in the list should all be static information, *not* actionable.
/// A `BadgeList` consists of a description and icon.
///
/// - Note: [Orbit definition](https://orbit.kiwi/components/information/badgelist/)
/// ```swift
/// BadgeList("You must collect <applink1>your baggage</applink1>", icon: .baggage)
/// ```
///
/// ### Customizing appearance
///
/// The label color can be modified by ``textColor(_:)``.
///
/// When a type is set to ``BadgeListType/status(_:)`` with a `nil` value, the default ``Status/info`` status can be modified by ``status(_:)`` modifier:
///
/// ```swift
/// BadgeList("Does not include guarantee", type: .status(nil))
/// .status(.warning)
/// ```
///
/// - Note: [Orbit.kiwi documentation](https://orbit.kiwi/components/information/badgelist/)
public struct BadgeList<Icon: View, Content: View>: View, PotentiallyEmptyView {

@Environment(\.status) private var status
@Environment(\.textAccentColor) private var textAccentColor
@Environment(\.textColor) private var textColor

let type: BadgeListType
@ViewBuilder let icon: Icon
@ViewBuilder let content: Content
private let type: BadgeListType
@ViewBuilder private let icon: Icon
@ViewBuilder private let content: Content

public var body: some View {
if isEmpty == false {
Expand All @@ -32,7 +47,7 @@ public struct BadgeList<Icon: View, Content: View>: View, PotentiallyEmptyView {
}
}

@ViewBuilder var badge: some View {
@ViewBuilder private var badge: some View {
if icon.isEmpty {
Orbit.Icon(.grid)
.iconSize(.small)
Expand All @@ -42,45 +57,42 @@ public struct BadgeList<Icon: View, Content: View>: View, PotentiallyEmptyView {
}
}

@ViewBuilder var badgeBackground: some View {
@ViewBuilder private var badgeBackground: some View {
if icon.isEmpty == false {
backgroundColor
.clipShape(Circle())
}
}

var isEmpty: Bool {
content.isEmpty && icon.isEmpty
}

public var iconColor: Color {
private var iconColor: Color {
switch type {
case .neutral: return .inkNormal
case .status(let status): return (status ?? defaultStatus).color
case .custom(let iconColor, _): return iconColor
}
}

public var backgroundColor: Color {
private var backgroundColor: Color {
switch type {
case .neutral: return .cloudLight
case .status(let status): return (status ?? defaultStatus).lightColor
case .custom(_, let backgroundColor): return backgroundColor
}
}

var defaultStatus: Status {
private var defaultStatus: Status {
status ?? .info
}

var isEmpty: Bool {
content.isEmpty && icon.isEmpty
}
}

// MARK: - Inits
public extension BadgeList {

/// Creates Orbit BadgeList component.
///
/// - Parameters:
/// - type: A visual style of component. A `status` style can be optionally modified using `status()` modifier when `nil` value is provided.
/// Creates Orbit ``BadgeList`` component.
init(
_ label: String = "",
icon: Icon.Symbol? = nil,
Expand All @@ -92,10 +104,7 @@ public extension BadgeList {
}
}

/// Creates Orbit BadgeList component with custom icon.
///
/// - Parameters:
/// - type: A visual style of component. A `status` style can be optionally modified using `status()` modifier when `nil` value is provided.
/// Creates Orbit ``BadgeList`` component with custom icon.
init(
_ label: String = "",
type: BadgeListType = .neutral,
Expand Down
Loading

0 comments on commit 32b2d93

Please sign in to comment.