@primer/doctocat-nextjs 0.0.0-20250626100459 → 0.0.0-20250626102357

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,12 +1,12 @@
1
1
  # @primer/doctocat-nextjs
2
2
 
3
- ## 0.0.0-20250626100459
3
+ ## 0.0.0-20250626102357
4
4
 
5
5
  ### Patch Changes
6
6
 
7
7
  - Fake entry to force publishing
8
8
 
9
- ## 0.0.0-20250626100457
9
+ ## 0.0.0-20250626102355
10
10
 
11
11
  ### Patch Changes
12
12
 
@@ -149,46 +149,43 @@ export function Theme({pageMap, children}: ThemeProps) {
149
149
  {activeHeaderLink ? activeHeaderLink.title : siteTitle}
150
150
  </Breadcrumbs.Item>
151
151
  )}
152
- {activePath.reduce((acc, item, index, items) => {
153
- const nextItem = items[index + 1]
152
+ {activePath
153
+ .filter((item, index, array) => {
154
+ const nextItem = array[index + 1]
154
155
 
155
- // Skip items in these cases:
156
- // 1. When current item is a folder followed by its index page
157
- // 2. When current item is an index page with a tab-label
158
- if (
159
- (index < items.length - 1 &&
160
- nextItem.name === 'index' &&
161
- item.route === nextItem.route &&
162
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
163
- !nextItem.frontMatter?.['tab-label']) ||
164
- (item.name === 'index' &&
165
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
166
- item.frontMatter?.['tab-label'])
167
- ) {
168
- return acc
169
- }
156
+ // Skip when current item is a folder followed by its index page
157
+ // or when it is an index page with a tabbed navigation
158
+ return !(
159
+ (index < array.length - 1 &&
160
+ nextItem.name === 'index' &&
161
+ item.route === nextItem.route &&
162
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
163
+ !nextItem.frontMatter?.['tab-label']) ||
164
+ (item.name === 'index' &&
165
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
166
+ item.frontMatter?.['tab-label'])
167
+ )
168
+ })
169
+ .map((item, index, visibleItems) => {
170
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
171
+ const itemTitle = item.frontMatter?.['tab-label'] || item.title
172
+ const isLastItem = index === visibleItems.length - 1
170
173
 
171
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
172
- const itemTitle = item.frontMatter?.['tab-label'] || item.title
173
- const isLastItem = index === items.length - 1
174
-
175
- acc.push(
176
- <Breadcrumbs.Item
177
- as={NextLink}
178
- key={item.name}
179
- href={item.route}
180
- selected={isLastItem}
181
- sx={{
182
- textTransform: 'capitalize',
183
- color: 'var(--brand-InlineLink-color-rest)',
184
- }}
185
- >
186
- {itemTitle.replace(/-/g, ' ')}
187
- </Breadcrumbs.Item>,
188
- )
189
-
190
- return acc
191
- }, [] as React.ReactNode[])}
174
+ return (
175
+ <Breadcrumbs.Item
176
+ as={NextLink}
177
+ key={item.name}
178
+ href={item.route}
179
+ selected={isLastItem}
180
+ sx={{
181
+ textTransform: 'capitalize',
182
+ color: 'var(--brand-InlineLink-color-rest)',
183
+ }}
184
+ >
185
+ {itemTitle.replace(/-/g, ' ')}
186
+ </Breadcrumbs.Item>
187
+ )
188
+ })}
192
189
  </Breadcrumbs>
193
190
  )}
194
191
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@primer/doctocat-nextjs",
3
- "version": "0.0.0-20250626100459",
3
+ "version": "0.0.0-20250626102357",
4
4
  "description": "A Next.js theme for building Primer documentation sites",
5
5
  "main": "index.js",
6
6
  "type": "module",