File: RenderTile.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (99 lines) | stat: -rw-r--r-- 3,558 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2021 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

/// A render-friendly representation of a view that links
/// to a specified type of content.
///
/// Depending on its type, a render tile contains links to a 
/// specific kind of resource such as sample code, videos,
/// or forum topics.
public struct RenderTile: Codable, TextIndexing, Equatable {
    /// Predefined semantic tile identifiers.
    public enum Identifier: String, Codable {
        /// Identifies a tile that links to featured content.
        case featured = "featured"

        /// Identifies a tile that links to documentation.
        case documentation = "documentation"

        /// Identifies a tile that links to sample code.
        case sampleCode = "sampleCode"

        /// Identifies a tile that links to downloads.
        case downloads = "downloads"

        /// Identifies a tile that links to videos.
        case videos = "videos"

        /// Identifies a tile that links to forum topics.
        case forums = "forums"
        
        /// Creates a new render-friendly tile identifier from a tile
        /// identifier.
        init(tileIdentifier: Tile.Identifier) {
            switch tileIdentifier {
                case .documentation: self = .documentation
                case .sampleCode: self = .sampleCode
                case .downloads: self = .downloads
                case .videos: self = .videos
                case .forums: self = .forums
            }
        }
    }
    
    /// The type of tile.
    ///
    /// Use this identifier to determine the tile's type during layout.
    public var identifier: RenderTile.Identifier
    
    /// The tile's title.
    public var title: String
    
    /// The main content of the tile.
    public var content: [RenderBlockContent] = []
    
    /// The tile's call-to-action content, if any.
    public var action: RenderInlineContent?
    
    /// A reference to the tile's media content, if any.
    public var media: RenderReferenceIdentifier?
    
    /// Creates a new tile from the given parameters.
    ///
    /// - Parameters:
    ///   - identifier: The type of tile.
    ///   - title: The tile's title.
    ///   - content: The main content for the tile.
    ///   - action: The tile's call-to-action content.
    ///   - media: A reference to the tile's media content.
    public init(identifier: RenderTile.Identifier, title: String, content: [RenderBlockContent] = [], action: RenderInlineContent?, media: RenderReferenceIdentifier?) {
        self.identifier = identifier
        self.title = title
        self.content = content
        self.action = action
        self.media = media
    }
}

extension RenderTile {
    /// Returns a call-to-action title for the given tile identifier. 
    ///
    /// This string is intended for use as a title for a tile's call-to-action
    /// link. An example title is "View more".
    public static func defaultCallToActionTitle(for identifier: Tile.Identifier) -> String {
        switch identifier {
            case .documentation: return "View more"
            case .sampleCode: return "View more"
            case .downloads: return "View downloads"
            case .videos: return "Watch videos"
            case .forums: return "View forums"
        }
    }
}