Skip to content
Merged
Show file tree
Hide file tree
Changes from 10 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions FrontEnd/styles/colors.scss
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,9 @@
--debug-console-background: var(--light-blue);
--debug-console-border: var(--grey);
--debug-console-button-hover: var(--light-grey);

--custom-collections-badge-background: var(--light-grey);
--custom-collections-badge-text: var(--dark-grey);
}

// Dark mode.
Expand Down Expand Up @@ -317,5 +320,8 @@
--debug-console-background: var(--dark-blue);
--debug-console-border: var(--light-grey);
--debug-console-button-hover: var(--dark-grey);

--custom-collections-badge-background: var(--dark-grey);
--custom-collections-badge-text: var(--light-grey);
}
}
2 changes: 2 additions & 0 deletions FrontEnd/styles/images.scss
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
--image-clear-search: url('');
--image-compatibility-unknown: url('');
--image-compatible: url('');
--image-custom-collections: url('');
--image-dependencies: url('');
--image-disclosure-down: url('');
--image-documentation: url('');
Expand Down Expand Up @@ -68,6 +69,7 @@
--image-clear-search: url('');
--image-compatibility-unknown: url('');
--image-compatible: url('');
--image-custom-collections: url('');
--image-dependencies: url('');
--image-disclosure-down: url('');
--image-documentation: url('');
Expand Down
53 changes: 47 additions & 6 deletions FrontEnd/styles/package.scss
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
-webkit-line-clamp: 1;
}

span {
small > span {
margin: 0 2px;
}
}
Expand Down Expand Up @@ -156,15 +156,32 @@
align-items: center;
}
}

li.custom-collections {
grid-column-start: span 2;
background-image: var(--image-tags);
background-image: var(--image-custom-collections);

a {
display: flex;
gap: 5px;
align-items: center;
vertical-align: baseline;

.badge {
position: relative;
top: -1px;
margin-right: 3px;
padding: 1px 5px;
font-size: 12px;
font-weight: 600;
color: var(--custom-collections-badge-text);
background-color: var(--custom-collections-badge-background);
border-radius: 3px;
}

&:hover {
.badge {
color: var(--white);
background-color: var(--link-highlight);
}
}
}
}
}
Expand Down Expand Up @@ -199,6 +216,30 @@
}
}

.custom-collections-sidebar {
display: flex;
flex-direction: column;

.custom-collection-badge {
display: inline-flex;
overflow: hidden;
font-size: 13px;
border: 1px solid var(--mid-green);
border-radius: 3px;

span {
padding: 0 5px;
color: var(--black);
background-color: var(--very-light-green);

&.badge {
color: var(--white);
background-color: var(--light-green);
}
}
}
}

section.main-compatibility .title {
display: flex;
align-items: baseline;
Expand Down
1 change: 1 addition & 0 deletions Resources/SVGs/custom-collections~dark.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions Resources/SVGs/custom-collections~light.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions Sources/App/Controllers/CustomCollectionsController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ enum CustomCollectionsController {
let model = CustomCollectionShow.Model(
key: collection.key,
name: collection.name,
badge: collection.badge,
packages: packageInfo,
page: query.page,
hasMoreResults: page.hasMoreResults
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,20 +16,31 @@ extension CustomCollectionShow {
struct Model {
var key: String
var name: String
var badge: String?
var packages: [PackageInfo]
var page: Int
var hasMoreResults: Bool

internal init(key: String,
name: String,
badge: String?,
packages: [PackageInfo],
page: Int,
hasMoreResults: Bool) {
self.key = key
self.name = name
self.badge = badge
self.packages = packages
self.page = page
self.hasMoreResults = hasMoreResults
}

var fullName: String {
if let badge {
"\(badge) \(name)"
} else {
name
}
}
}
}
16 changes: 12 additions & 4 deletions Sources/App/Views/CustomCollection/CustomCollectionShow+View.swift
Original file line number Diff line number Diff line change
Expand Up @@ -38,23 +38,31 @@ enum CustomCollectionShow {
override func breadcrumbs() -> [Breadcrumb] {
[
Breadcrumb(title: "Home", url: SiteURL.home.relativeURL()),
Breadcrumb(title: model.name)
Breadcrumb(title: "Collections"),
Breadcrumb(title: model.fullName)
]
}

override func content() -> Node<HTML.BodyContext> {
.group(
.h2(
.class("trimmed"),
.text("\(model.name) package collection")
.text("\(model.fullName) package collection")
),
.p(
.text("These packages are available as a package collection, "),
.text("The packages in this collection are part of a custom package collection, "),
.a(
.href(SiteURL.packageCollections.relativeURL()),
"usable in Xcode 13 or the Swift Package Manager 5.5"
.text("usable in Xcode or SwiftPM")
),
.text(". You can find out more about custom package collections and how to request one in the "),
.a(
.href(SiteURL.blogPost(.value("introducing-custom-package-collections")).relativeURL()),
.text("launch blog post")

),
.text(".")

),
.copyableInputForm(buttonName: "Copy Package Collection URL",
eventName: "Copy Package Collection URL Button",
Expand Down
45 changes: 42 additions & 3 deletions Sources/App/Views/PackageController/GetRoute.Model+ext.swift
Original file line number Diff line number Diff line change
Expand Up @@ -398,14 +398,53 @@ extension API.PackageController.GetRoute.Model {
}
}

func customCollectionsItem() -> Node<HTML.ListContext> {
guard !customCollections.isEmpty else { return .empty }
func customCollectionsListItem() -> Node<HTML.ListContext> {
guard customCollections.isEmpty == false
else { return .empty }

let closing = if customCollections.count > 1 { " collections." } else { " collection." }

return .li(
.class("custom-collections"),
.group(listPhrase(opening: .text("Member of the "),
nodes: customCollections.map({ collection in
.a(
.href(SiteURL.collections(.value(collection.key)).relativeURL()),
.unwrap(collection.badge, { badge in
.span(
.class("badge"),
.text(badge)
)
}),
.text(collection.name)
)
}),
closing: .text(closing))
)
)
}

func customCollectionBadges() -> Node<HTML.BodyContext> {
guard customCollections.isEmpty == false
else { return .empty }

return .div(
.class("custom-collections-sidebar"),
.forEach(customCollections, { collection in
.a(
.href(SiteURL.collections(.value(collection.key)).relativeURL()),
.text("\(collection.name)")
.div(
.class("custom-collection-badge"),
.unwrap(collection.badge, { badge in
.span(
.class("badge"),
.text(badge)
)
}),
.span(
.text(collection.name)
)
)
)
})
)
Expand Down
5 changes: 3 additions & 2 deletions Sources/App/Views/PackageController/PackageShow+View.swift
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,7 @@ extension PackageShow {
.hr(
.class("minor")
),
model.customCollectionBadges(),
sidebarVersions(),
.hr(
.class("minor")
Expand All @@ -173,15 +174,15 @@ extension PackageShow {
model.historyListItem(),
model.activityListItem(),
model.dependenciesListItem(),
model.customCollectionsListItem(),
model.licenseListItem(),
model.starsListItem(),
model.productTypeListItem(.library),
model.productTypeListItem(.executable),
model.productTypeListItem(.plugin),
model.targetTypeListItem(.macro),
model.dataRaceSafeListItem(),
model.keywordsListItem(),
model.customCollectionsItem()
model.keywordsListItem()
)
)
}
Expand Down
1 change: 1 addition & 0 deletions Tests/AppTests/Mocks/CustomCollectionShow+mock.swift
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ extension CustomCollectionShow.Model {
) }
return .init(key: "custom-collection",
name: "Custom Collection",
badge: "BADGE",
packages: packages, page: 1,
hasMoreResults: false)
}
Expand Down
Loading
Loading