Skip to content

Commit

Permalink
feat: qr code card (#174)
Browse files Browse the repository at this point in the history
* feat: qr code card

* tests
  • Loading branch information
phoebus-84 authored Oct 12, 2024
1 parent d5192ae commit b75f643
Show file tree
Hide file tree
Showing 9 changed files with 170 additions and 0 deletions.
23 changes: 23 additions & 0 deletions src/components.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,13 @@ export namespace Components {
"description"?: string;
"title": string;
}
interface DQrCode {
"generationDate": string;
"generationHour": string;
"qr": string;
"sessionId": string;
"sessionIdLabel": string;
}
interface DScanButton {
"href": string;
}
Expand Down Expand Up @@ -457,6 +464,12 @@ declare global {
prototype: HTMLDPageDescriptionElement;
new (): HTMLDPageDescriptionElement;
};
interface HTMLDQrCodeElement extends Components.DQrCode, HTMLStencilElement {
}
var HTMLDQrCodeElement: {
prototype: HTMLDQrCodeElement;
new (): HTMLDQrCodeElement;
};
interface HTMLDScanButtonElement extends Components.DScanButton, HTMLStencilElement {
}
var HTMLDScanButtonElement: {
Expand Down Expand Up @@ -558,6 +571,7 @@ declare global {
"d-logo": HTMLDLogoElement;
"d-organizations": HTMLDOrganizationsElement;
"d-page-description": HTMLDPageDescriptionElement;
"d-qr-code": HTMLDQrCodeElement;
"d-scan-button": HTMLDScanButtonElement;
"d-session-card": HTMLDSessionCardElement;
"d-settings-menu": HTMLDSettingsMenuElement;
Expand Down Expand Up @@ -714,6 +728,13 @@ declare namespace LocalJSX {
"description"?: string;
"title"?: string;
}
interface DQrCode {
"generationDate"?: string;
"generationHour"?: string;
"qr"?: string;
"sessionId"?: string;
"sessionIdLabel"?: string;
}
interface DScanButton {
"href"?: string;
}
Expand Down Expand Up @@ -803,6 +824,7 @@ declare namespace LocalJSX {
"d-logo": DLogo;
"d-organizations": DOrganizations;
"d-page-description": DPageDescription;
"d-qr-code": DQrCode;
"d-scan-button": DScanButton;
"d-session-card": DSessionCard;
"d-settings-menu": DSettingsMenu;
Expand Down Expand Up @@ -845,6 +867,7 @@ declare module "@stencil/core" {
"d-logo": LocalJSX.DLogo & JSXBase.HTMLAttributes<HTMLDLogoElement>;
"d-organizations": LocalJSX.DOrganizations & JSXBase.HTMLAttributes<HTMLDOrganizationsElement>;
"d-page-description": LocalJSX.DPageDescription & JSXBase.HTMLAttributes<HTMLDPageDescriptionElement>;
"d-qr-code": LocalJSX.DQrCode & JSXBase.HTMLAttributes<HTMLDQrCodeElement>;
"d-scan-button": LocalJSX.DScanButton & JSXBase.HTMLAttributes<HTMLDScanButtonElement>;
"d-session-card": LocalJSX.DSessionCard & JSXBase.HTMLAttributes<HTMLDSessionCardElement>;
"d-settings-menu": LocalJSX.DSettingsMenu & JSXBase.HTMLAttributes<HTMLDSettingsMenuElement>;
Expand Down
2 changes: 2 additions & 0 deletions src/components/heading/readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
- [d-logo](../logo)
- [d-organizations](../organizations)
- [d-page-description](../page-description)
- [d-qr-code](../qr-code)
- [d-session-card](../session-card)
- [d-swipable-page](../swipable-page)

Expand All @@ -33,6 +34,7 @@ graph TD;
d-logo --> d-heading
d-organizations --> d-heading
d-page-description --> d-heading
d-qr-code --> d-heading
d-session-card --> d-heading
d-swipable-page --> d-heading
style d-heading fill:#f9f,stroke:#333,stroke-width:4px
Expand Down
3 changes: 3 additions & 0 deletions src/components/qr-code/d-qr-code.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
:host {
display: block;
}
33 changes: 33 additions & 0 deletions src/components/qr-code/d-qr-code.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
import { Component, Host, Prop, h } from '@stencil/core';

@Component({
tag: 'd-qr-code',
styleUrl: 'd-qr-code.css',
shadow: true,
})
export class DQrCode {
@Prop() qr: string;
@Prop() sessionIdLabel: string = 'Session ID:';
@Prop() sessionId: string;
@Prop() generationDate: string;
@Prop() generationHour: string;

render() {
return (
<Host>
<div class="flex flex-col items-center justify-center rounded-lg bg-primary p-4">
<div class="w-full pb-2">
<img src={this.qr} alt="qrCode" class="w-full" />
</div>

<d-text size="l" class="w-max">
{this.sessionIdLabel}
</d-text>
<d-heading size="s">{this.sessionId}</d-heading>
<d-text size="m">{this.generationDate}</d-text>
<d-text size="m">{this.generationHour}</d-text>
</div>
</Host>
);
}
}
32 changes: 32 additions & 0 deletions src/components/qr-code/qr-code.stories.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
import { Meta, StoryObj } from '@storybook/html';
import type { Components } from '../../components.js';

const meta = {
title: 'Design System/DATA DISPLAY/QrCode',
render: args => `<d-qr-code
qr="${args.qr}"
session-id-label="${args.sessionIdLabel}"
session-id="${args.sessionId}"
generation-date="${args.generationDate}"
generation-hour="${args.generationHour}"
></d-qr-code>`,
} satisfies Meta<Components.DQrCode>;

export default meta;
type Story = StoryObj<Components.DQrCode>;

export const Default: Story = {
args: {
sessionIdLabel: 'Session ID:',
sessionId: '12345',
generationDate: '05/09/2024',
generationHour: '12:00:00',
qr: '',
},
parameters: {
design: {
type: 'figma',
url: 'https://www.figma.com/design/pdwfO3dMKtaCAQakht0JE6/DIDRoom-%2B-Signroom---WF-and-GUI---Dyne.org?node-id=3603-35766&node-type=frame&t=tJgEDXcrsNlriD0U-0',
},
},
};
36 changes: 36 additions & 0 deletions src/components/qr-code/readme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# d-qr-code



<!-- Auto Generated Below -->


## Properties

| Property | Attribute | Description | Type | Default |
| ---------------- | ------------------ | ----------- | -------- | --------------- |
| `generationDate` | `generation-date` | | `string` | `undefined` |
| `generationHour` | `generation-hour` | | `string` | `undefined` |
| `qr` | `qr` | | `string` | `undefined` |
| `sessionId` | `session-id` | | `string` | `undefined` |
| `sessionIdLabel` | `session-id-label` | | `string` | `'Session ID:'` |


## Dependencies

### Depends on

- [d-text](../text)
- [d-heading](../heading)

### Graph
```mermaid
graph TD;
d-qr-code --> d-text
d-qr-code --> d-heading
style d-qr-code fill:#f9f,stroke:#333,stroke-width:4px
```

----------------------------------------------

*Built with [StencilJS](https://stenciljs.com/)*
Loading

0 comments on commit b75f643

Please sign in to comment.