Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add <BaselineStatus> component #156

Merged
merged 43 commits into from
Oct 27, 2024
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
4057ff2
Sketch out `<BaselineStatus>` component
delucis Oct 24, 2024
ce19795
Fix duplicated types
delucis Oct 24, 2024
e045315
Clean up some templating issues
delucis Oct 24, 2024
aafa32a
Styling fixes
delucis Oct 24, 2024
9d85134
Add a couple more instances to demo page
delucis Oct 24, 2024
862c3db
Re-export `BaselineStatus` from `astro-embed`
delucis Oct 24, 2024
0b76e78
Add draft docs
delucis Oct 24, 2024
9c4bf72
Make browser icons external SVGs & run them through SVGO
delucis Oct 25, 2024
34900e1
Move browser support lockup & labelling inside dedicated component
delucis Oct 25, 2024
16c1de9
Remove `aria-label` in favour of actual content
delucis Oct 25, 2024
db1a4b3
Add a few more examples to docs page
delucis Oct 25, 2024
c4751fc
Simplify disclosure SVG icon
delucis Oct 25, 2024
83448ec
No empty paragraph when there’s no Learn more link
delucis Oct 25, 2024
0feb875
Don’t use h1 for feature name
delucis Oct 25, 2024
3365934
Use logical properties
delucis Oct 25, 2024
4ef264c
Use `rem` for `font-size`
delucis Oct 25, 2024
9799ecc
Merge branch 'main' into chris/baseline-status
delucis Oct 25, 2024
9909472
Use webstatus.dev URLs for more link
delucis Oct 25, 2024
7a3d2f1
Avoid meaningless “Learn more” link labels
delucis Oct 25, 2024
e6ef371
Refactor baseline icon, `light-dark()` support & inline SVG
delucis Oct 25, 2024
34cfbd2
Undo accidentally included line
delucis Oct 25, 2024
4e1e84f
More robust light-dark usage
delucis Oct 25, 2024
78273dc
Refactor to use DSD and `::part()` for styling
delucis Oct 25, 2024
246bfb6
Document component styling API
delucis Oct 25, 2024
6f78c66
One more example on the demo page
delucis Oct 25, 2024
df68d57
Add changeset
delucis Oct 25, 2024
7eaf0a1
Link `<baseline-status>` implementation in docs
delucis Oct 25, 2024
afa5a2f
Add color variables for newly available badge
delucis Oct 26, 2024
ac34cb1
Simplify custom property naming
delucis Oct 26, 2024
010cc65
Workaround Astro compiler bug
delucis Oct 26, 2024
5019ebe
Consolidate color variables
delucis Oct 26, 2024
f66e887
Docs tweaks
delucis Oct 26, 2024
9cce0ed
Less aggressive default dark outline
delucis Oct 26, 2024
ac4d13b
Remove redundant `display: block`
delucis Oct 26, 2024
fc4edd2
Use `rem` instead of `px` most of the time
delucis Oct 26, 2024
e978111
Let summary label and browser icons wrap on small screens
delucis Oct 26, 2024
cf50030
Tweak line heights/alignment
delucis Oct 26, 2024
c0bc4ac
Add variant class name API
delucis Oct 26, 2024
cfd1bd1
Add custom property for card background
delucis Oct 26, 2024
37f9eb5
Add custom style test to demo page
delucis Oct 26, 2024
5d8ab73
Improve CSS class name docs example
delucis Oct 26, 2024
3c048fb
Improve `package.json`
delucis Oct 27, 2024
ea56cdd
Fix colors in Chrome logo
delucis Oct 27, 2024
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
25 changes: 25 additions & 0 deletions demo/src/pages/baseline-status.astro
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
---
import { BaselineStatus } from '@astro-community/astro-embed-baseline-status';
import Base from '../layouts/Base.astro';
---

<Base title="BaselineStatus component example">
<h2>Basics</h2>
<p>
<code>&lt;BaselineStatus id="anchor-positioning" /&gt;</code>
</p>
<BaselineStatus id="anchor-positioning" />
<p>
<code>&lt;BaselineStatus id="scroll-snap" /&gt;</code>
</p>
<BaselineStatus id="scroll-snap" />
<p>
<code>&lt;BaselineStatus id="masonry" /&gt;</code>
</p>
<BaselineStatus id="masonry" />
<h2>Missing feature</h2>
<p>
<code>&lt;BaselineStatus id="rainbow-unicorns" /&gt;</code>
</p>
<BaselineStatus id="rainbow-unicorns" />
</Base>
3 changes: 3 additions & 0 deletions demo/src/pages/index.astro
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@ import Base from '../layouts/Base.astro';
><code>&lt;LinkPreview/&gt;</code> component examples</a
>
</li>
<li>
<a href="/baseline-status"><code>&lt;BaselineStatus/&gt;</code> component examples</a>
</li>
</ul>
<h2>Other examples</h2>
<ul>
Expand Down
49 changes: 49 additions & 0 deletions docs/src/content/docs/components/baseline-status.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
---
title: Baseline Status
description: Learn how to display the Baseline status of a web feature in your website
---

import { Tabs, TabItem } from '@astrojs/starlight/components';
import { BaselineStatus } from '@astro-community/astro-embed-baseline-status';

The `<BaselineStatus>` component displays browser support for a given web feature according to the [Baseline](https://web.dev/baseline/) project.

## Usage

<Tabs>
<TabItem label="Astro" icon="astro">
```astro
---
import { BaselineStatus } from 'astro-embed';
---

<BaselineStatus id="anchor-positioning" />
````
</TabItem>
<TabItem label="MDX" icon="seti:markdown">
```mdx
import { BaselineStatus } from 'astro-embed';

<BaselineStatus id="anchor-positioning" />
````

</TabItem>
</Tabs>

The above code produces the following result:

<BaselineStatus id="anchor-positioning" />

## Standalone installation

If you only need the `<BaselineStatus>` component, you can install the package directly instead of the main `astro-embed` package:

import { PackageManagers } from 'starlight-package-managers';

<PackageManagers pkg="@astro-community/astro-embed-baseline-status" />

The `<BaselineStatus>` component can then be imported as:

```js
import { BaselineStatus } from '@astro-community/astro-embed-baseline-status';
```
1 change: 1 addition & 0 deletions docs/src/content/docs/getting-started.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ Learn how to set up the integration in the [“Auto-embed URLs”](/integration/
Astro Embed currently supports the following services:

<CardGrid>
<LinkCard title="Baseline" href="/components/baseline-status/" />
<LinkCard title="Open Graph" href="/components/link-preview/" />
<LinkCard title="Twitter" href="/components/twitter/" />
<LinkCard title="Vimeo" href="/components/vimeo/" />
Expand Down
8 changes: 8 additions & 0 deletions docs/src/content/docs/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,14 @@ import { Icon, Card, CardGrid } from '@astrojs/starlight/components';

</Card>

<Card title="Baseline Status" icon="laptop">

Display browser support for a web feature according to the Baseline project.

[Baseline Status docs](/components/baseline-status/)

</Card>

<Card title="Auto-embed URLs" icon="document">

Automatically convert matching URLs in your MDX content to a rich media
Expand Down
12 changes: 12 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

53 changes: 53 additions & 0 deletions packages/astro-embed-baseline-status/BaselineIcon.astro
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
---
import type { StatusLevel } from './types';

interface Props {
support: StatusLevel;
}
---

<baseline-icon aria-hidden="true">
<div class={`support-${Astro.props.support}`}></div>
</baseline-icon>

<style>
baseline-icon {
--baseline-icon-limited: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M10 0L16 6L14 8L8 2L10 0Z' fill='%23F09409'/%3E%3Cpath d='M28 2L36 10L28 18L26 16L32 10L26 4L28 2Z' fill='%23C6C6C6'/%3E%3Cpath d='M22 12L20 14L26 20L28 18L22 12Z' fill='%23F09409'/%3E%3Cpath d='M8 2L10 4L4 10L10 16L8 18L0 10L8 2Z' fill='%23C6C6C6'/%3E%3Cpath d='M26 0L28 2L10 20L8 18L26 0Z' fill='%23F09409'/%3E%3C/svg%3E");
--baseline-icon-widely: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M18 8L20 10L18 12L16 10L18 8Z' fill='%231EA446'/%3E%3Cpath d='M28 2L26 4L32 10L26 16L22 12L20 14L26 20L36 10L28 2Z' fill='%23C4EED0'/%3E%3Cpath d='M10 0L2 8L4 10L10 4L14 8L16 6L10 0Z' fill='%23C4EED0'/%3E%3Cpath d='M26 0L28 2L10 20L0 10L2 8L10 16L26 0Z' fill='%231EA446'/%3E%3C/svg%3E");
--baseline-icon-newly: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M10 0L12 2L10 4L8 2L10 0Z' fill='%23A8C7FA'/%3E%3Cpath d='M14 4L16 6L14 8L12 6L14 4Z' fill='%23A8C7FA'/%3E%3Cpath d='M30 4L32 6L30 8L28 6L30 4Z' fill='%23A8C7FA'/%3E%3Cpath d='M34 8L36 10L34 12L32 10L34 8Z' fill='%23A8C7FA'/%3E%3Cpath d='M30 12L32 14L30 16L28 14L30 12Z' fill='%23A8C7FA'/%3E%3Cpath d='M26 16L28 18L26 20L24 18L26 16Z' fill='%23A8C7FA'/%3E%3Cpath d='M22 12L24 14L22 16L20 14L22 12Z' fill='%23A8C7FA'/%3E%3Cpath d='M6 4L8 6L6 8L4 6L6 4Z' fill='%23A8C7FA'/%3E%3Cpath d='M26 0L28 2L10 20L0 10L2 8L10 16L26 0Z' fill='%231B6EF3'/%3E%3C/svg%3E");
--baseline-icon-no_data: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M18 8L20 10L18 12L16 10L18 8Z' fill='%23909090'/%3E%3Cpath d='M28 2L26 4L32 10L26 16L22 12L20 14L26 20L36 10L28 2Z' fill='%23909090'/%3E%3Cpath d='M10 0L2 8L4 10L10 4L14 8L16 6L10 0Z' fill='%23909090'/%3E%3Cpath d='M26 0L28 2L10 20L0 10L2 8L10 16L26 0Z' fill='%23909090'/%3E%3C/svg%3E");
height: 20px;
}

@media (prefers-color-scheme: dark) {
baseline-icon {
--baseline-icon-limited: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M10 0L16 6L14 8L8 2L10 0Z' fill='%23F09409'/%3E%3Cpath d='M28 2L36 10L28 18L26 16L32 10L26 4L28 2Z' fill='%23565656'/%3E%3Cpath d='M22 12L20 14L26 20L28 18L22 12Z' fill='%23F09409'/%3E%3Cpath d='M8 2L10 4L4 10L10 16L8 18L0 10L8 2Z' fill='%23565656'/%3E%3Cpath d='M26 0L28 2L10 20L8 18L26 0Z' fill='%23F09409'/%3E%3C/svg%3E%0A");
--baseline-icon-widely: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M18 8L20 10L18 12L16 10L18 8Z' fill='%231EA446'/%3E%3Cpath d='M28 2L26 4L32 10L26 16L22 12L20 14L26 20L36 10L28 2Z' fill='%23125225'/%3E%3Cpath d='M10 0L2 8L4 10L10 4L14 8L16 6L10 0Z' fill='%23125225'/%3E%3Cpath d='M26 0L28 2L10 20L0 10L2 8L10 16L26 0Z' fill='%231EA446'/%3E%3C/svg%3E");
--baseline-icon-newly: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M10 0L12 2L10 4L8 2L10 0Z' fill='%232D509E'/%3E%3Cpath d='M14 4L16 6L14 8L12 6L14 4Z' fill='%232D509E'/%3E%3Cpath d='M30 4L32 6L30 8L28 6L30 4Z' fill='%232D509E'/%3E%3Cpath d='M34 8L36 10L34 12L32 10L34 8Z' fill='%232D509E'/%3E%3Cpath d='M30 12L32 14L30 16L28 14L30 12Z' fill='%232D509E'/%3E%3Cpath d='M26 16L28 18L26 20L24 18L26 16Z' fill='%232D509E'/%3E%3Cpath d='M22 12L24 14L22 16L20 14L22 12Z' fill='%232D509E'/%3E%3Cpath d='M6 4L8 6L6 8L4 6L6 4Z' fill='%232D509E'/%3E%3Cpath d='M26 0L28 2L10 20L0 10L2 8L10 16L26 0Z' fill='%234185FF'/%3E%3C/svg%3E");
--baseline-icon-no_data: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='20' viewBox='0 0 36 20' fill='none'%3E%3Cpath d='M18 8L20 10L18 12L16 10L18 8Z' fill='%23666666'/%3E%3Cpath d='M28 2L26 4L32 10L26 16L22 12L20 14L26 20L36 10L28 2Z' fill='%23666666'/%3E%3Cpath d='M10 0L2 8L4 10L10 4L14 8L16 6L10 0Z' fill='%23666666'/%3E%3Cpath d='M26 0L28 2L10 20L0 10L2 8L10 16L26 0Z' fill='%23666666'/%3E%3C/svg%3E");
}
}

div {
background-repeat: no-repeat;
width: 36px;
height: 20px;
display: inline-block;
}

.support-limited {
background-image: var(--baseline-icon-limited);
}

.support-widely {
background-image: var(--baseline-icon-widely);
}

.support-newly {
background-image: var(--baseline-icon-newly);
}

.support-no_data {
background-image: var(--baseline-icon-no_data);
}
</style>
Loading
Loading