@amedia/brick-mcp 1.0.1 → 1.0.3
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/data/components/brick-alt-teaser.md +9 -4
- package/data/components/brick-button.md +3 -2
- package/data/components/brick-byline.md +138 -0
- package/data/components/brick-carousel.md +8 -6
- package/data/components/brick-classnames.md +19 -14
- package/data/components/brick-dialog.md +3 -3
- package/data/components/brick-expand.md +129 -0
- package/data/components/brick-illustrations.md +6 -5
- package/data/components/brick-pill.md +11 -9
- package/data/components/brick-player.md +6 -3
- package/data/components/brick-share.md +5 -2
- package/data/components/brick-skip-link.md +78 -0
- package/data/components/brick-stepper.md +2 -2
- package/data/components/brick-teaser.md +8 -7
- package/data/components/brick-tokens.md +12 -8
- package/data/components-metadata.json +45 -33
- package/dist/data/components/brick-alt-teaser.md +9 -4
- package/dist/data/components/brick-button.md +3 -2
- package/dist/data/components/brick-byline.md +138 -0
- package/dist/data/components/brick-carousel.md +8 -6
- package/dist/data/components/brick-classnames.md +19 -14
- package/dist/data/components/brick-dialog.md +3 -3
- package/dist/data/components/brick-expand.md +129 -0
- package/dist/data/components/brick-illustrations.md +6 -5
- package/dist/data/components/brick-pill.md +11 -9
- package/dist/data/components/brick-player.md +6 -3
- package/dist/data/components/brick-share.md +5 -2
- package/dist/data/components/brick-skip-link.md +78 -0
- package/dist/data/components/brick-stepper.md +2 -2
- package/dist/data/components/brick-teaser.md +8 -7
- package/dist/data/components/brick-tokens.md +12 -8
- package/dist/data/components-metadata.json +45 -33
- package/dist/http.js +2 -4
- package/dist/http.js.map +1 -1
- package/dist/index.js +2 -4
- package/dist/index.js.map +1 -1
- package/package.json +37 -37
- package/scripts/check-docs-versions.js +121 -0
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: brick-skip-link
|
|
3
|
+
version: 0.0.1
|
|
4
|
+
selector: brick-skip-link-v0
|
|
5
|
+
category: Navigation
|
|
6
|
+
tags: [accessibility, a11y, skip-link, navigation, focus, keyboard, bypass]
|
|
7
|
+
use_cases: [main-navigation, header, keyboard-navigation, accessibility-improvement, bypass-blocks]
|
|
8
|
+
related: []
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
# Brick Skip Link
|
|
12
|
+
|
|
13
|
+
A component that allows keyboard users to bypass blocks of repetitive content, such as navigation menus.
|
|
14
|
+
|
|
15
|
+
## Key Capabilities
|
|
16
|
+
|
|
17
|
+
- Provides a "skip to content" link for improved keyboard navigation.
|
|
18
|
+
- Becomes visible only when it receives focus via keyboard tabbing.
|
|
19
|
+
- Helps users meet WCAG 2.4.1 (Bypass Blocks).
|
|
20
|
+
- Renders a semantic `<a>` tag for accessibility and SEO.
|
|
21
|
+
- Customizable link text and target element ID.
|
|
22
|
+
- Server-side rendering support for immediate availability.
|
|
23
|
+
|
|
24
|
+
## Props/Attributes
|
|
25
|
+
|
|
26
|
+
| Attribute | Type | Default | Required | Description |
|
|
27
|
+
| ----------- | ------ | ----------------------- | -------- | ---------------------------------------------------- |
|
|
28
|
+
| `data-href` | string | - | yes | The selector for the target element (e.g., `#main`). |
|
|
29
|
+
| `data-text` | string | "Skip to main content" | no | The accessible text for the link. |
|
|
30
|
+
|
|
31
|
+
## Usage
|
|
32
|
+
|
|
33
|
+
### Server-side rendering (preferred)
|
|
34
|
+
|
|
35
|
+
Import the render function from the `/template` submodule and call it to produce an HTML string.
|
|
36
|
+
|
|
37
|
+
```ts
|
|
38
|
+
import { renderBrickSkipLink } from '@amedia/brick-skip-link/template';
|
|
39
|
+
|
|
40
|
+
const html = renderBrickSkipLink({
|
|
41
|
+
dataHref: '#main-content',
|
|
42
|
+
dataText: 'Hopp til hovedinnhold'
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
// Include CSS file
|
|
46
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-skip-link/v0/css/styles.css">
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
### Client-side (declarative HTML)
|
|
50
|
+
|
|
51
|
+
Use the custom element directly in HTML
|
|
52
|
+
|
|
53
|
+
```html
|
|
54
|
+
<script type="module" src="https://assets.acdn.no/pkg/@amedia/brick-skip-link/v0/brick-skip-link.js"></script>
|
|
55
|
+
|
|
56
|
+
<brick-skip-link-v0 data-href="#main-content" data-text="Hopp til hovedinnhold"></brick-skip-link-v0>
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
## Accessibility
|
|
60
|
+
|
|
61
|
+
This component is a fundamental accessibility feature.
|
|
62
|
+
|
|
63
|
+
- **Bypass Blocks**: It directly addresses WCAG 2.4.1 by providing a mechanism to bypass blocks of content that are repeated on multiple Web pages.
|
|
64
|
+
- **Focus Management**: The component is designed to be visually hidden until it receives keyboard focus, making it unobtrusive for mouse users but available for keyboard and screen reader users.
|
|
65
|
+
- **Semantic HTML**: It renders a native `<a>` element with a valid `href`, ensuring it is correctly identified as a link by assistive technologies.
|
|
66
|
+
|
|
67
|
+
## Technical Details
|
|
68
|
+
|
|
69
|
+
- **Package version**: `0.0.1`
|
|
70
|
+
- **Custom Element tag**: `brick-skip-link-v0`
|
|
71
|
+
- **Dependencies**:
|
|
72
|
+
- `@amedia/brick-template`
|
|
73
|
+
- `@amedia/brick-tokens`
|
|
74
|
+
|
|
75
|
+
## Important Notes
|
|
76
|
+
|
|
77
|
+
- For the skip link to be effective, it should be one of the very first focusable elements in the page's DOM, ideally right after the `<body>` tag.
|
|
78
|
+
- The value of `data-href` must be a valid CSS selector that points to a single, existing element on the page (e.g., `#main-content`). The target element should have a corresponding `id`.
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: brick-stepper
|
|
3
|
-
version: 1.
|
|
3
|
+
version: 1.1.9
|
|
4
4
|
selector: brick-stepper-v1
|
|
5
5
|
category: Navigation
|
|
6
6
|
tags: [stepper, progress, steps, wizard, multi-step, process, indicator, accessibility]
|
|
@@ -316,4 +316,4 @@ function CheckoutFlow() {
|
|
|
316
316
|
|
|
317
317
|
## Version
|
|
318
318
|
|
|
319
|
-
Current version: 1.
|
|
319
|
+
Current version: 1.1.9
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: brick-teaser
|
|
3
|
-
version:
|
|
3
|
+
version: 22.2.9
|
|
4
4
|
selector: brick-teaser-v22
|
|
5
5
|
category: Data Display
|
|
6
6
|
tags: [teaser, card, article, content, preview, link, image, metadata]
|
|
7
7
|
use_cases: [article-listings, content-grids, news-feeds, content-previews, homepage, front-page]
|
|
8
|
-
related: [brick-image, brick-avatar, brick-countdown, brick-icon, brick-pill, brick-player, brick-button]
|
|
8
|
+
related: [brick-image, brick-avatar, brick-countdown, brick-icon, brick-pill, brick-teaser-player, brick-button]
|
|
9
9
|
---
|
|
10
10
|
|
|
11
11
|
# Brick Teaser
|
|
@@ -19,7 +19,7 @@ A comprehensive content teaser/card component for displaying article previews wi
|
|
|
19
19
|
- Avatar support for authors/publications
|
|
20
20
|
- Countdown timer integration
|
|
21
21
|
- Premium content indicators (pill badges)
|
|
22
|
-
- Video player
|
|
22
|
+
- Video teaser support (inline playback via brick-teaser-player)
|
|
23
23
|
- Breaking news styling
|
|
24
24
|
- Commercial/sponsored content support
|
|
25
25
|
- Analytics (ADP) integration
|
|
@@ -62,7 +62,7 @@ The component supports multiple content types:
|
|
|
62
62
|
|
|
63
63
|
### Interactive Elements
|
|
64
64
|
- Clickable teaser links
|
|
65
|
-
- Video player
|
|
65
|
+
- Video teaser support (inline playback via brick-teaser-player)
|
|
66
66
|
- Countdown timers for live events
|
|
67
67
|
- Action buttons
|
|
68
68
|
|
|
@@ -246,12 +246,13 @@ The component integrates with ADP (Amedia Data Platform):
|
|
|
246
246
|
|
|
247
247
|
## Important Notes
|
|
248
248
|
|
|
249
|
-
- Version
|
|
249
|
+
- Version 22.2.9 is the current stable version (mature component)
|
|
250
250
|
- Supports complex teaser configurations with many optional features
|
|
251
251
|
- Integrates deeply with Amedia's content management system (ACP)
|
|
252
252
|
- The component is highly configurable for different content types
|
|
253
253
|
- Breaking news, premium, and commercial content have special styling
|
|
254
|
-
-
|
|
254
|
+
- **Breaking change in v22.0.0**: Removed `playOnFront` attribute and inline video playback functionality. Use `brick-teaser-player` for teasers that play videos
|
|
255
|
+
- Video teasers now require `brick-teaser-player` wrapper for inline playback
|
|
255
256
|
- Gallery teasers show image count
|
|
256
257
|
- Countdown timers for live events
|
|
257
258
|
- The component generates custom-elements.json for IDE autocomplete
|
|
@@ -259,4 +260,4 @@ The component integrates with ADP (Amedia Data Platform):
|
|
|
259
260
|
|
|
260
261
|
## Version
|
|
261
262
|
|
|
262
|
-
Current version:
|
|
263
|
+
Current version: 22.2.9
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: brick-tokens
|
|
3
|
-
version: 6.
|
|
3
|
+
version: 6.2.1
|
|
4
4
|
selector: N/A
|
|
5
5
|
category: Utilities
|
|
6
6
|
tags: [design-tokens, css, styling, themes, colors, spacing, typography, shadows]
|
|
@@ -106,11 +106,11 @@ Load the theme CSS file and set the corresponding class on a container (e.g. `<b
|
|
|
106
106
|
|
|
107
107
|
```html
|
|
108
108
|
<!-- Load theme CSS from Eik CDN -->
|
|
109
|
-
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.
|
|
110
|
-
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.
|
|
111
|
-
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.
|
|
112
|
-
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.
|
|
113
|
-
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.
|
|
109
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.2.1/css/alfa/styles.css" crossorigin="anonymous" />
|
|
110
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.2.1/css/bravo/styles.css" crossorigin="anonymous" />
|
|
111
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.2.1/css/charlie/styles.css" crossorigin="anonymous" />
|
|
112
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.2.1/css/nettavisen/styles.css" crossorigin="anonymous" />
|
|
113
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.2.1/css/alt/styles.css" crossorigin="anonymous" />
|
|
114
114
|
|
|
115
115
|
<!-- Apply theme class to a container -->
|
|
116
116
|
<body class="themeAlfa">...</body>
|
|
@@ -128,7 +128,7 @@ The package provides multiple formats:
|
|
|
128
128
|
|
|
129
129
|
```html
|
|
130
130
|
<!-- Load theme CSS (one per page) -->
|
|
131
|
-
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.
|
|
131
|
+
<link rel="stylesheet" href="https://assets.acdn.no/pkg/@amedia/brick-tokens/6.2.1/css/alfa/styles.css" crossorigin="anonymous" />
|
|
132
132
|
```
|
|
133
133
|
|
|
134
134
|
## Common Token Examples
|
|
@@ -188,10 +188,14 @@ npm run validate # Validate CSS files
|
|
|
188
188
|
|
|
189
189
|
## Important Notes
|
|
190
190
|
|
|
191
|
-
- Version 6.
|
|
191
|
+
- Version 6.2.1 is the current stable version
|
|
192
192
|
- Tokens are generated from Figma via Tokens Studio + Style Dictionary
|
|
193
193
|
- CSS custom properties use `--brick-{category}-{tokenName}` prefix (e.g. `--brick-colors-baseFg`, `--brick-space-x1`)
|
|
194
194
|
- Theme CSS files are scoped to a class (e.g. `.themeAlfa`) — apply the class to a container element
|
|
195
195
|
- There is no single `tokens.css` — CSS is per-theme: `dist/css/{theme}/styles.css`
|
|
196
196
|
- The package is used by all Brick components for consistent styling
|
|
197
197
|
- `sroStyle` is a utility class export for screen-reader-only visually hidden content
|
|
198
|
+
- Brand accent colors available since v6.2.0: `custom-one`, `custom-two`, `custom-three`, and `opinion` with `surface`, `surface-subtle`, and `text` variants
|
|
199
|
+
- Brand-specific publication colors available since v6.1.0 via CDN:
|
|
200
|
+
- CSS: `https://assets.acdn.no/pkg/@amedia/brick-tokens/v6/brand/css/{publication-key}/styles.css`
|
|
201
|
+
- JSON: `https://assets.acdn.no/pkg/@amedia/brick-tokens/v6/brand/mobile/{publication-key}/colors.json`
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
[
|
|
2
2
|
{
|
|
3
3
|
"name": "brick-alt-teaser",
|
|
4
|
-
"version": "8.1.
|
|
4
|
+
"version": "8.1.24",
|
|
5
5
|
"selector": "brick-alt-teaser-v8",
|
|
6
6
|
"category": "Display",
|
|
7
7
|
"tags": [
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
},
|
|
12
12
|
{
|
|
13
13
|
"name": "brick-avatar",
|
|
14
|
-
"version": "0.2.
|
|
14
|
+
"version": "0.2.61",
|
|
15
15
|
"selector": "brick-avatar-v0",
|
|
16
16
|
"description": "brick-avatar component",
|
|
17
17
|
"category": "Display",
|
|
@@ -23,7 +23,7 @@
|
|
|
23
23
|
},
|
|
24
24
|
{
|
|
25
25
|
"name": "brick-button",
|
|
26
|
-
"version": "9.4.
|
|
26
|
+
"version": "9.4.19",
|
|
27
27
|
"selector": "brick-button-v9",
|
|
28
28
|
"category": "Forms",
|
|
29
29
|
"tags": [
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
},
|
|
36
36
|
{
|
|
37
37
|
"name": "brick-byline",
|
|
38
|
-
"version": "1.0.
|
|
38
|
+
"version": "1.0.23",
|
|
39
39
|
"selector": "brick-byline-v1",
|
|
40
40
|
"description": "brick-byline component",
|
|
41
41
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-byline",
|
|
@@ -43,7 +43,7 @@
|
|
|
43
43
|
},
|
|
44
44
|
{
|
|
45
45
|
"name": "brick-card",
|
|
46
|
-
"version": "7.3.
|
|
46
|
+
"version": "7.3.33",
|
|
47
47
|
"selector": "brick-card-v7",
|
|
48
48
|
"category": "Layout",
|
|
49
49
|
"tags": [
|
|
@@ -54,7 +54,7 @@
|
|
|
54
54
|
},
|
|
55
55
|
{
|
|
56
56
|
"name": "brick-carousel",
|
|
57
|
-
"version": "2.3.
|
|
57
|
+
"version": "2.3.6",
|
|
58
58
|
"selector": "brick-carousel-v2",
|
|
59
59
|
"description": "Simple carousel for any content passed to it.",
|
|
60
60
|
"category": "Display",
|
|
@@ -66,7 +66,7 @@
|
|
|
66
66
|
},
|
|
67
67
|
{
|
|
68
68
|
"name": "brick-classnames",
|
|
69
|
-
"version": "3.0.
|
|
69
|
+
"version": "3.0.3",
|
|
70
70
|
"selector": "brick-classnames-v3",
|
|
71
71
|
"description": "Utility method to create a safe string from a design name",
|
|
72
72
|
"category": "Utilities",
|
|
@@ -78,7 +78,7 @@
|
|
|
78
78
|
},
|
|
79
79
|
{
|
|
80
80
|
"name": "brick-countdown",
|
|
81
|
-
"version": "3.0.
|
|
81
|
+
"version": "3.0.8",
|
|
82
82
|
"selector": "brick-countdown-v3",
|
|
83
83
|
"description": "brick-countdown component",
|
|
84
84
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-countdown",
|
|
@@ -86,7 +86,7 @@
|
|
|
86
86
|
},
|
|
87
87
|
{
|
|
88
88
|
"name": "brick-dialog",
|
|
89
|
-
"version": "2.1.
|
|
89
|
+
"version": "2.1.16",
|
|
90
90
|
"selector": "brick-dialog-v2",
|
|
91
91
|
"description": "brick-dialog component",
|
|
92
92
|
"category": "Feedback",
|
|
@@ -98,7 +98,7 @@
|
|
|
98
98
|
},
|
|
99
99
|
{
|
|
100
100
|
"name": "brick-expand",
|
|
101
|
-
"version": "0.0.
|
|
101
|
+
"version": "0.0.28",
|
|
102
102
|
"selector": "brick-expand-v0",
|
|
103
103
|
"description": "brick-expand component",
|
|
104
104
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-expand",
|
|
@@ -106,7 +106,7 @@
|
|
|
106
106
|
},
|
|
107
107
|
{
|
|
108
108
|
"name": "brick-fonts",
|
|
109
|
-
"version": "2.0.
|
|
109
|
+
"version": "2.0.3",
|
|
110
110
|
"selector": "brick-fonts-v2",
|
|
111
111
|
"description": "Distribution of font files",
|
|
112
112
|
"category": "Utilities",
|
|
@@ -117,7 +117,7 @@
|
|
|
117
117
|
},
|
|
118
118
|
{
|
|
119
119
|
"name": "brick-helloworld",
|
|
120
|
-
"version": "2.0.
|
|
120
|
+
"version": "2.0.29",
|
|
121
121
|
"selector": "brick-helloworld-v2",
|
|
122
122
|
"description": "Brick Hello World component",
|
|
123
123
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-helloworld",
|
|
@@ -125,7 +125,7 @@
|
|
|
125
125
|
},
|
|
126
126
|
{
|
|
127
127
|
"name": "brick-icon",
|
|
128
|
-
"version": "2.
|
|
128
|
+
"version": "2.4.0",
|
|
129
129
|
"selector": "brick-icon-v2",
|
|
130
130
|
"category": "Display",
|
|
131
131
|
"tags": [
|
|
@@ -136,14 +136,14 @@
|
|
|
136
136
|
},
|
|
137
137
|
{
|
|
138
138
|
"name": "brick-illustrations",
|
|
139
|
-
"version": "1.3.
|
|
139
|
+
"version": "1.3.1",
|
|
140
140
|
"selector": "brick-illustrations-v1",
|
|
141
141
|
"description": "brick-illustrations",
|
|
142
142
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-illustrations"
|
|
143
143
|
},
|
|
144
144
|
{
|
|
145
145
|
"name": "brick-image",
|
|
146
|
-
"version": "6.0.
|
|
146
|
+
"version": "6.0.28",
|
|
147
147
|
"selector": "brick-image-v6",
|
|
148
148
|
"category": "Display",
|
|
149
149
|
"tags": [
|
|
@@ -154,7 +154,7 @@
|
|
|
154
154
|
},
|
|
155
155
|
{
|
|
156
156
|
"name": "brick-input",
|
|
157
|
-
"version": "4.0.
|
|
157
|
+
"version": "4.0.8",
|
|
158
158
|
"selector": "brick-input-v4",
|
|
159
159
|
"description": "brick-input component",
|
|
160
160
|
"category": "Forms",
|
|
@@ -167,14 +167,14 @@
|
|
|
167
167
|
},
|
|
168
168
|
{
|
|
169
169
|
"name": "brick-pill",
|
|
170
|
-
"version": "10.1.
|
|
170
|
+
"version": "10.1.7",
|
|
171
171
|
"selector": "brick-pill-v10",
|
|
172
172
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-pill",
|
|
173
173
|
"mainJsFile": "brick-pill.js"
|
|
174
174
|
},
|
|
175
175
|
{
|
|
176
176
|
"name": "brick-player",
|
|
177
|
-
"version": "2.
|
|
177
|
+
"version": "2.4.4",
|
|
178
178
|
"selector": "brick-player-v2",
|
|
179
179
|
"description": "Component for playing video and audio files",
|
|
180
180
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-player",
|
|
@@ -182,7 +182,7 @@
|
|
|
182
182
|
},
|
|
183
183
|
{
|
|
184
184
|
"name": "brick-published",
|
|
185
|
-
"version": "4.0.
|
|
185
|
+
"version": "4.0.24",
|
|
186
186
|
"selector": "brick-published-v4",
|
|
187
187
|
"description": "brick-published",
|
|
188
188
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-published",
|
|
@@ -190,15 +190,27 @@
|
|
|
190
190
|
},
|
|
191
191
|
{
|
|
192
192
|
"name": "brick-share",
|
|
193
|
-
"version": "0.
|
|
193
|
+
"version": "0.4.4",
|
|
194
194
|
"selector": "brick-share-v0",
|
|
195
195
|
"description": "brick-share component",
|
|
196
196
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-share",
|
|
197
197
|
"mainJsFile": "brick-share.js"
|
|
198
198
|
},
|
|
199
|
+
{
|
|
200
|
+
"name": "brick-skip-link",
|
|
201
|
+
"version": "0.0.3",
|
|
202
|
+
"selector": "brick-skip-link-v0",
|
|
203
|
+
"description": "brick-skip-link component",
|
|
204
|
+
"category": "Navigation",
|
|
205
|
+
"tags": [
|
|
206
|
+
"navigation"
|
|
207
|
+
],
|
|
208
|
+
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-skip-link",
|
|
209
|
+
"mainJsFile": "brick-skip-link.js"
|
|
210
|
+
},
|
|
199
211
|
{
|
|
200
212
|
"name": "brick-stepper",
|
|
201
|
-
"version": "1.1.
|
|
213
|
+
"version": "1.1.10",
|
|
202
214
|
"selector": "brick-stepper-v1",
|
|
203
215
|
"description": "brick-stepper component",
|
|
204
216
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-stepper",
|
|
@@ -206,7 +218,7 @@
|
|
|
206
218
|
},
|
|
207
219
|
{
|
|
208
220
|
"name": "brick-tab",
|
|
209
|
-
"version": "0.1.
|
|
221
|
+
"version": "0.1.31",
|
|
210
222
|
"selector": "brick-tab-v0",
|
|
211
223
|
"description": "brick-tab component",
|
|
212
224
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-tab",
|
|
@@ -214,7 +226,7 @@
|
|
|
214
226
|
},
|
|
215
227
|
{
|
|
216
228
|
"name": "brick-tabs",
|
|
217
|
-
"version": "0.1.
|
|
229
|
+
"version": "0.1.32",
|
|
218
230
|
"selector": "brick-tabs-v0",
|
|
219
231
|
"description": "brick-tabs component handling tablist, tabs and tabpanel",
|
|
220
232
|
"category": "Navigation",
|
|
@@ -226,7 +238,7 @@
|
|
|
226
238
|
},
|
|
227
239
|
{
|
|
228
240
|
"name": "brick-tag",
|
|
229
|
-
"version": "0.0.
|
|
241
|
+
"version": "0.0.31",
|
|
230
242
|
"selector": "brick-tag-v0",
|
|
231
243
|
"description": "brick-tag component",
|
|
232
244
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-tag",
|
|
@@ -234,7 +246,7 @@
|
|
|
234
246
|
},
|
|
235
247
|
{
|
|
236
248
|
"name": "brick-teaser",
|
|
237
|
-
"version": "22.2.
|
|
249
|
+
"version": "22.2.10",
|
|
238
250
|
"selector": "brick-teaser-v22",
|
|
239
251
|
"description": "Teaser component.",
|
|
240
252
|
"category": "Display",
|
|
@@ -246,7 +258,7 @@
|
|
|
246
258
|
},
|
|
247
259
|
{
|
|
248
260
|
"name": "brick-teaser-player",
|
|
249
|
-
"version": "1.1.
|
|
261
|
+
"version": "1.1.21",
|
|
250
262
|
"selector": "brick-teaser-player-v1",
|
|
251
263
|
"description": "brick-video-teaser component",
|
|
252
264
|
"category": "Display",
|
|
@@ -258,7 +270,7 @@
|
|
|
258
270
|
},
|
|
259
271
|
{
|
|
260
272
|
"name": "brick-teaser-reels",
|
|
261
|
-
"version": "0.4.
|
|
273
|
+
"version": "0.4.23",
|
|
262
274
|
"selector": "brick-teaser-reels-v0",
|
|
263
275
|
"description": "brick-teaser-reels component",
|
|
264
276
|
"category": "Display",
|
|
@@ -270,7 +282,7 @@
|
|
|
270
282
|
},
|
|
271
283
|
{
|
|
272
284
|
"name": "brick-textarea",
|
|
273
|
-
"version": "2.0.
|
|
285
|
+
"version": "2.0.27",
|
|
274
286
|
"selector": "brick-textarea-v2",
|
|
275
287
|
"description": "brick-textarea component",
|
|
276
288
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-textarea",
|
|
@@ -278,7 +290,7 @@
|
|
|
278
290
|
},
|
|
279
291
|
{
|
|
280
292
|
"name": "brick-themes",
|
|
281
|
-
"version": "1.0.
|
|
293
|
+
"version": "1.0.3",
|
|
282
294
|
"selector": "brick-themes-v1",
|
|
283
295
|
"description": "Brick theme names",
|
|
284
296
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-themes",
|
|
@@ -286,7 +298,7 @@
|
|
|
286
298
|
},
|
|
287
299
|
{
|
|
288
300
|
"name": "brick-toast",
|
|
289
|
-
"version": "0.1.
|
|
301
|
+
"version": "0.1.45",
|
|
290
302
|
"selector": "brick-toast-v0",
|
|
291
303
|
"description": "brick-toast component",
|
|
292
304
|
"category": "Feedback",
|
|
@@ -298,7 +310,7 @@
|
|
|
298
310
|
},
|
|
299
311
|
{
|
|
300
312
|
"name": "brick-toggle",
|
|
301
|
-
"version": "3.1.
|
|
313
|
+
"version": "3.1.33",
|
|
302
314
|
"selector": "brick-toggle-v3",
|
|
303
315
|
"description": "brick-toggle component",
|
|
304
316
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-toggle",
|
|
@@ -306,7 +318,7 @@
|
|
|
306
318
|
},
|
|
307
319
|
{
|
|
308
320
|
"name": "brick-tokens",
|
|
309
|
-
"version": "6.
|
|
321
|
+
"version": "6.2.2",
|
|
310
322
|
"selector": "brick-tokens-v6",
|
|
311
323
|
"description": "Tokens package",
|
|
312
324
|
"category": "Utilities",
|
|
@@ -318,7 +330,7 @@
|
|
|
318
330
|
},
|
|
319
331
|
{
|
|
320
332
|
"name": "brick-tooltip",
|
|
321
|
-
"version": "1.0.
|
|
333
|
+
"version": "1.0.34",
|
|
322
334
|
"selector": "brick-tooltip-v1",
|
|
323
335
|
"description": "brick-tooltip component",
|
|
324
336
|
"assetUrl": "https://assets.acdn.no/pkg/@amedia/brick-tooltip",
|
package/dist/http.js
CHANGED
|
@@ -31,8 +31,7 @@ function getDataPath() {
|
|
|
31
31
|
return join(dir, "data");
|
|
32
32
|
} catch {
|
|
33
33
|
const parent = dirname(dir);
|
|
34
|
-
if (parent === dir)
|
|
35
|
-
break;
|
|
34
|
+
if (parent === dir) break;
|
|
36
35
|
dir = parent;
|
|
37
36
|
}
|
|
38
37
|
}
|
|
@@ -141,8 +140,7 @@ async function loadAllTokens() {
|
|
|
141
140
|
}
|
|
142
141
|
function tokenMatchesCategory(token, category) {
|
|
143
142
|
const prefixes = CATEGORY_PREFIXES[category];
|
|
144
|
-
if (!prefixes)
|
|
145
|
-
return false;
|
|
143
|
+
if (!prefixes) return false;
|
|
146
144
|
const path = token.path.toLowerCase();
|
|
147
145
|
return prefixes.some((prefix) => path.startsWith(prefix));
|
|
148
146
|
}
|
package/dist/http.js.map
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/http.ts", "../src/server.ts", "../src/tools/getComponentDocs.ts", "../src/utils/dataPath.ts", "../src/extractors/packageScanner.ts", "../src/tools/getDesignTokens.ts", "../src/tools/listComponents.ts"],
|
|
4
4
|
"sourcesContent": ["/**\n * HTTP server entry point for local development only\n * Uses Fastify and SSE transport for MCP communication\n */\n\nimport cors from '@fastify/cors';\nimport { SSEServerTransport } from '@modelcontextprotocol/sdk/server/sse.js';\nimport Fastify from 'fastify';\n\nimport { createServer } from './server.ts';\n\nconst PORT = 3000;\nconst HOST = 'localhost';\n\nconst fastify = Fastify({\n logger: {\n level: 'info',\n },\n});\n\n// Store active transports and servers by sessionId\nconst activeTransports = new Map<string, SSEServerTransport>();\nconst activeMcpServers = new Map<string, ReturnType<typeof createServer>>();\n\n// Enable CORS for local development\nawait fastify.register(cors, {\n origin: true,\n credentials: true,\n});\n\n// Health check endpoint\nfastify.get('/health', async () => {\n return { status: 'ok' };\n});\n\n// SSE endpoint for MCP communication\nfastify.get('/sse', async (_request, reply) => {\n // Prevent Fastify from automatically sending a response\n reply.hijack();\n\n // Create a new MCP server instance for this connection\n const mcpServer = createServer();\n\n // Create SSE transport (this will handle headers internally)\n const transport = new SSEServerTransport('/message', reply.raw);\n\n // Handle the SSE connection (this calls transport.start() which writes headers)\n await mcpServer.connect(transport);\n\n // Store the transport and server by sessionId for POST message handling\n // The sessionId is available after the transport starts via the public getter\n const sessionId = transport.sessionId;\n activeTransports.set(sessionId, transport);\n activeMcpServers.set(sessionId, mcpServer);\n\n // Clean up when the connection closes\n reply.raw.on('close', async () => {\n activeTransports.delete(sessionId);\n const server = activeMcpServers.get(sessionId);\n if (server) {\n await server.close();\n activeMcpServers.delete(sessionId);\n }\n });\n});\n\n// POST endpoint for messages\nfastify.post<{\n Querystring: { sessionId: string };\n}>('/message', async (request, reply) => {\n // Prevent Fastify from automatically sending a response\n reply.hijack();\n\n // Extract sessionId from query parameters (now properly typed)\n const { sessionId } = request.query;\n\n // Find the transport for this session\n const transport = activeTransports.get(sessionId);\n\n if (!transport) {\n reply.raw.writeHead(404, { 'Content-Type': 'application/json' });\n reply.raw.end(JSON.stringify({ error: 'Session not found' }));\n return;\n }\n\n // Let the transport handle the POST message\n await transport.handlePostMessage(request.raw, reply.raw, request.body);\n});\n\n// Start the server\ntry {\n await fastify.listen({ port: PORT, host: HOST });\n console.log(`Brick MCP HTTP server listening on http://${HOST}:${PORT}`);\n console.log(`SSE endpoint: http://${HOST}:${PORT}/sse`);\n} catch (err) {\n fastify.log.error(err);\n process.exit(1);\n}\n", "/**\n * MCP server setup and registration\n */\n\nimport { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\nimport { z } from 'zod';\n\nimport { getComponentDocs } from './tools/getComponentDocs.ts';\nimport { getDesignTokens } from './tools/getDesignTokens.ts';\nimport { listComponents } from './tools/listComponents.ts';\n\n/**\n * Create and configure the MCP server\n */\nexport function createServer(): McpServer {\n // Create an MCP server\n const server = new McpServer({\n name: 'brick-design-system',\n version: '1.0.0',\n });\n\n // Register list-components tool\n server.registerTool(\n 'list-components',\n {\n title: 'List Brick Components',\n description:\n 'List all available Brick components with metadata. Optionally filter by category, tag, or name.',\n inputSchema: z.object({\n filter: z\n .string()\n .optional()\n .describe('Optional filter by category, tag, or name'),\n }),\n } as const,\n async ({ filter }: { filter?: string }) => {\n const result = await listComponents({ filter });\n\n return {\n content: [\n {\n type: 'text',\n text: JSON.stringify(result, null, 2),\n },\n ],\n };\n }\n );\n\n // Register get-component-docs tool\n server.registerTool(\n 'get-component-docs',\n {\n title: 'Get Component Documentation',\n description:\n 'Retrieve detailed documentation for specific Brick component(s) including props, events, examples, and accessibility information.',\n inputSchema: z.object({\n components: z\n .array(z.string())\n .describe(\n 'Array of component names (e.g., [\"brick-button\", \"brick-modal\"])'\n ),\n }),\n } as const,\n async ({ components }: { components: string[] }) => {\n const result = await getComponentDocs({ components });\n\n return {\n content: [\n {\n type: 'text',\n text: JSON.stringify(result, null, 2),\n },\n ],\n };\n }\n );\n\n // Register get-design-tokens tool\n server.registerTool(\n 'get-design-tokens',\n {\n title: 'Get Design Tokens',\n description:\n 'Access design tokens from brick-tokens. Optionally filter by category (colors, spacing, typography, shadows, borders).',\n inputSchema: z.object({\n category: z\n .enum(['colors', 'spacing', 'typography', 'shadows', 'borders'])\n .optional()\n .describe('Filter tokens by category'),\n }),\n } as const,\n async ({\n category,\n }: {\n category?: 'colors' | 'spacing' | 'typography' | 'shadows' | 'borders';\n }) => {\n const result = await getDesignTokens({ category });\n\n return {\n content: [\n {\n type: 'text',\n text: result,\n },\n ],\n };\n }\n );\n\n return server;\n}\n", "/**\n * Get Component Docs tool implementation\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { join } from 'node:path';\n\nimport { getDataPath } from '../utils/dataPath.ts';\nimport { loadComponentData } from '../extractors/packageScanner.ts';\n\nexport interface GetComponentDocsInput {\n components: string[]; // e.g., [\"brick-button\", \"brick-modal\"]\n}\n\nexport interface GetComponentDocsOutput {\n docs: string[];\n}\n\n/**\n * Load markdown documentation for a component\n */\nasync function loadComponentMarkdown(\n componentName: string\n): Promise<string | undefined> {\n try {\n const markdownPath = join(\n getDataPath(),\n 'components',\n `${componentName}.md`\n );\n const content = await readFile(markdownPath, 'utf-8');\n return content;\n } catch (error) {\n console.error(`Error loading markdown for ${componentName}:`, error);\n return undefined;\n }\n}\n\n/**\n * Get detailed documentation for specific component(s)\n */\nexport async function getComponentDocs(\n input: GetComponentDocsInput\n): Promise<GetComponentDocsOutput> {\n // Load markdown documentation for each requested component\n const docsPromises = input.components.map(async (componentName) => {\n const md = await loadComponentMarkdown(componentName);\n if (!md) {\n const json = await loadComponentData(componentName);\n return json ? JSON.stringify(json) : undefined;\n }\n return md;\n });\n\n const docsResults = await Promise.all(docsPromises);\n\n // Filter out any components that failed to load\n const docs = docsResults.filter((doc): doc is string => doc !== undefined);\n\n return { docs };\n}\n", "/**\n * Utility for finding the data directory path\n * Works both in development (from src/) and production (from dist/)\n */\n\nimport { accessSync } from 'node:fs';\nimport { dirname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\n/**\n * Get the path to the data directory\n * When running from dist/, looks for dist/data\n * When running from src/, looks for package root data\n */\nexport function getDataPath(): string {\n const currentFilePath = fileURLToPath(import.meta.url);\n let dir = dirname(currentFilePath);\n\n // First check if there's a data directory in the same parent as the current file\n // This handles the dist/data case when running from dist/\n const localDataPath = join(dir, 'data');\n try {\n accessSync(localDataPath);\n return localDataPath;\n } catch {\n // Continue to package root search\n }\n\n // Walk up the directory tree to find package root (where package.json exists)\n for (let i = 0; i < 5; i++) {\n try {\n const testPath = join(dir, 'package.json');\n accessSync(testPath);\n return join(dir, 'data');\n } catch {\n // Go up one level\n const parent = dirname(dir);\n if (parent === dir) break; // Reached filesystem root\n dir = parent;\n }\n }\n\n return join(dirname(currentFilePath), '..', '..', 'data');\n}\n", "/**\n * Package scanner for discovering Brick components\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { join } from 'node:path';\n\nimport { type BrickComponent, type BrickComponentMetadata } from '../types.ts';\nimport { getDataPath } from '../utils/dataPath.ts';\n\n/**\n * Load all component metadata (lightweight, for listing)\n */\nexport async function scanAllPackages(): Promise<BrickComponentMetadata[]> {\n try {\n const metadataPath = join(getDataPath(), 'components-metadata.json');\n const content = await readFile(metadataPath, 'utf-8');\n const metadata: BrickComponentMetadata[] = JSON.parse(content);\n return metadata;\n } catch (error) {\n console.error('Error loading component metadata:', error);\n return [];\n }\n}\n\n/**\n * Load full component data for a specific component\n */\nexport async function loadComponentData(\n componentName: string\n): Promise<BrickComponent | undefined> {\n try {\n const componentPath = join(\n getDataPath(),\n 'components',\n `${componentName}.json`\n );\n const content = await readFile(componentPath, 'utf-8');\n const component: BrickComponent = JSON.parse(content);\n return component;\n } catch (error) {\n console.error(`Error loading component data for ${componentName}:`, error);\n return undefined;\n }\n}\n\n/**\n * Filter components by category or tag\n */\nexport function filterComponents(\n components: BrickComponentMetadata[],\n filter?: string\n): BrickComponentMetadata[] {\n if (!filter) {\n return components;\n }\n\n const filterLower = filter.toLowerCase();\n\n return components.filter((component) => {\n // Match against name\n if (component.name.toLowerCase().includes(filterLower)) {\n return true;\n }\n\n // Match against category\n if (component.category?.toLowerCase().includes(filterLower)) {\n return true;\n }\n\n // Match against tags\n if (\n component.tags?.some((tag) => tag.toLowerCase().includes(filterLower))\n ) {\n return true;\n }\n\n return false;\n });\n}\n", "/**\n * Get Design Tokens tool implementation\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { join } from 'node:path';\n\nimport { getDataPath } from '../utils/dataPath.ts';\n\nexport interface DesignToken {\n path: string;\n name: string;\n type: string;\n value: string;\n description?: string;\n cssVariable: string;\n}\n\nexport interface GetDesignTokensInput {\n category?: 'colors' | 'spacing' | 'typography' | 'shadows' | 'borders';\n}\n\n/**\n * Category filter definitions mapping category names to path prefixes\n */\nconst CATEGORY_PREFIXES: Record<string, string[]> = {\n colors: ['color.'],\n spacing: ['spacing.'],\n typography: ['typography.'],\n shadows: ['box-shadow.'],\n borders: ['border-width.', 'border-radius.', 'border.'],\n};\n\n/**\n * Get the path to the bundled tokens data\n */\nfunction getTokensDataPath(): string {\n return join(getDataPath(), 'tokens.json');\n}\n\n/**\n * Load all tokens from bundled JSON data\n */\nasync function loadAllTokens(): Promise<DesignToken[]> {\n try {\n const dataPath = getTokensDataPath();\n const content = await readFile(dataPath, 'utf-8');\n return JSON.parse(content);\n } catch (error) {\n console.error('Error loading tokens data:', error);\n return [];\n }\n}\n\n/**\n * Check if a token belongs to a given category\n */\nfunction tokenMatchesCategory(token: DesignToken, category: string): boolean {\n const prefixes = CATEGORY_PREFIXES[category];\n if (!prefixes) return false;\n const path = token.path.toLowerCase();\n return prefixes.some((prefix) => path.startsWith(prefix));\n}\n\n/**\n * Format tokens as a compact text listing\n */\nfunction formatTokensCompact(tokens: DesignToken[]): string {\n return tokens\n .map((t) => {\n const base = `${t.cssVariable}: ${t.value}`;\n return t.description ? `${base} \u2014 ${t.description}` : base;\n })\n .join('\\n');\n}\n\n/**\n * Build a category summary with counts and example token paths\n */\nfunction buildCategorySummary(allTokens: DesignToken[]): string {\n const lines: string[] = ['Available token categories:'];\n\n for (const category of Object.keys(CATEGORY_PREFIXES)) {\n const matching = allTokens.filter((t) => tokenMatchesCategory(t, category));\n const count = matching.length;\n const examples = matching\n .slice(0, 3)\n .map((t) => t.path)\n .join(', ');\n const suffix = examples ? ` (${examples}, ...)` : '';\n lines.push(`- ${category}: ${count} tokens${suffix}`);\n }\n\n lines.push('', 'Call with a specific category to see tokens.');\n return lines.join('\\n');\n}\n\n/**\n * Get design tokens with optional filtering.\n * Returns a compact text string to minimize context window usage.\n */\nexport async function getDesignTokens(\n input: GetDesignTokensInput\n): Promise<string> {\n const allTokens = await loadAllTokens();\n\n // No category: return summary instead of dumping all tokens\n if (!input.category) {\n return buildCategorySummary(allTokens);\n }\n\n const filteredTokens = allTokens.filter((t) =>\n tokenMatchesCategory(t, input.category!)\n );\n\n const header = `${input.category} tokens (${filteredTokens.length} tokens). Values shown are examples from one theme. Actual values vary across themes (alfa, bravo, charlie, nettavisen, alt). Use the CSS variable for theme-aware styling.\\n`;\n return header + formatTokensCompact(filteredTokens);\n}\n", "/**\n * List Components tool implementation\n */\n\nimport {\n filterComponents,\n scanAllPackages,\n} from '../extractors/packageScanner.ts';\nimport type { BrickComponentMetadata } from '../types.ts';\n\nexport interface ListComponentsInput {\n filter?: string;\n}\n\nexport interface ListComponentsOutput {\n components: BrickComponentMetadata[];\n}\n\n/**\n * List all available Brick components with optional filtering\n */\nexport async function listComponents(\n input: ListComponentsInput\n): Promise<ListComponentsOutput> {\n // Scan all packages in the monorepo (returns lightweight metadata)\n const allComponents = await scanAllPackages();\n\n // Apply filter if provided\n const components = filterComponents(allComponents, input.filter);\n\n return {\n components,\n };\n}\n"],
|
|
5
|
-
"mappings": ";AAKA,OAAO,UAAU;AACjB,SAAS,0BAA0B;AACnC,OAAO,aAAa;;;ACHpB,SAAS,iBAAiB;AAC1B,SAAS,SAAS;;;ACDlB,SAAS,YAAAA,iBAAgB;AACzB,SAAS,QAAAC,aAAY;;;ACArB,SAAS,kBAAkB;AAC3B,SAAS,SAAS,YAAY;AAC9B,SAAS,qBAAqB;AAOvB,SAAS,cAAsB;AACpC,QAAM,kBAAkB,cAAc,YAAY,GAAG;AACrD,MAAI,MAAM,QAAQ,eAAe;AAIjC,QAAM,gBAAgB,KAAK,KAAK,MAAM;AACtC,MAAI;AACF,eAAW,aAAa;AACxB,WAAO;AAAA,EACT,
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["readFile", "join", "join", "join", "join", "readFile", "readFile", "join", "join", "readFile"]
|
|
7
7
|
}
|
package/dist/index.js
CHANGED
|
@@ -30,8 +30,7 @@ function getDataPath() {
|
|
|
30
30
|
return join(dir, "data");
|
|
31
31
|
} catch {
|
|
32
32
|
const parent = dirname(dir);
|
|
33
|
-
if (parent === dir)
|
|
34
|
-
break;
|
|
33
|
+
if (parent === dir) break;
|
|
35
34
|
dir = parent;
|
|
36
35
|
}
|
|
37
36
|
}
|
|
@@ -140,8 +139,7 @@ async function loadAllTokens() {
|
|
|
140
139
|
}
|
|
141
140
|
function tokenMatchesCategory(token, category) {
|
|
142
141
|
const prefixes = CATEGORY_PREFIXES[category];
|
|
143
|
-
if (!prefixes)
|
|
144
|
-
return false;
|
|
142
|
+
if (!prefixes) return false;
|
|
145
143
|
const path = token.path.toLowerCase();
|
|
146
144
|
return prefixes.some((prefix) => path.startsWith(prefix));
|
|
147
145
|
}
|