Skip to content

Commit

Permalink
docs: add card
Browse files Browse the repository at this point in the history
  • Loading branch information
adrian-ub committed Sep 28, 2024
1 parent d2f145b commit 2b11223
Show file tree
Hide file tree
Showing 5 changed files with 196 additions and 12 deletions.
67 changes: 67 additions & 0 deletions docs/src/content/docs/components/card.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
---
title: Card
description: Displays a card with header, content, and footer.
---

<ComponentPreview name="card-with-form" description="A card with a form" />

## Installation

<Tabs defaultValue="cli">

<TabsList>
<TabsTrigger value="cli">CLI</TabsTrigger>
<TabsTrigger value="manual">Manual</TabsTrigger>
</TabsList>

<TabsContent value="cli">

```bash
npx shadcn-ng@latest add card
```

</TabsContent>

<TabsContent value="manual">

<Step>

<StepItem>Copy and paste the following code into your project.</StepItem>

<ComponentSource name="card" />

<StepItem>Update the import paths to match your project setup.</StepItem>

</Step>

</TabsContent>

</Tabs>

## Usage

```ts
import {
UbCardContentDirective,
UbCardDescriptionDirective,
UbCardDirective,
UbCardFooterDirective,
UbCardHeaderDirective,
UbCardTitleDirective,
} from '@/components/ui/card'
```

```html
<div ubCard>
<div ubCardHeader>
<h3 ubCardTitle>Card Title</h3>
<p ubCardDescription>Card Description</p>
</div>
<div ubCardContent>
<p>Card Content</p>
</div>
<div ubCardFooter>
<p>Card Footer</p>
</div>
</div>
```
59 changes: 59 additions & 0 deletions docs/src/registry/default/example/card-with-form.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
import { UbButtonDirective } from '@/registry/new-york/ui/button'
import {
UbCardContentDirective,
UbCardDescriptionDirective,
UbCardDirective,
UbCardFooterDirective,
UbCardHeaderDirective,
UbCardTitleDirective,
} from '@/registry/new-york/ui/card'
import { UbInputDirective } from '@/registry/new-york/ui/input'
import { UbLabelDirective } from '@/registry/new-york/ui/label'

import { Component } from '@angular/core'

@Component({
standalone: true,
imports: [
UbCardDirective,
UbCardHeaderDirective,
UbCardTitleDirective,
UbCardDescriptionDirective,
UbCardContentDirective,
UbCardFooterDirective,

UbInputDirective,
UbLabelDirective,
UbButtonDirective,
],
selector: 'card-with-form-default',
template: `
<div ubCard class="w-[350px]">
<div ubCardHeader>
<h3 ubCardTitle>Create project</h3>
<p ubCardDescription>Deploy your new project in one-click.</p>
</div>
<div ubCardContent>
<form>
<div class="grid w-full items-center gap-4">
<div class="flex flex-col space-y-1.5">
<label ubLabel htmlFor="name">Name</label>
<input ubInput type="text" id="name" placeholder="Name of your project" />
</div>
</div>
</form>
</div>
<div ubCardFooter class="flex justify-between">
<button ubButton variant="outline">Cancel</button>
<button ubButton>Deploy</button>
</div>
</div>
`,
})
export class CardWithFormDefault { }

export default CardWithFormDefault
12 changes: 6 additions & 6 deletions docs/src/registry/default/ui/card.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { computed, Directive, input } from '@angular/core'

@Directive({
standalone: true,
selector: '[ubCard]',
selector: 'div[ubCard]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -18,7 +18,7 @@ export class UbCardDirective {

@Directive({
standalone: true,
selector: '[ubCardHeader]',
selector: 'div[ubCardHeader]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -32,7 +32,7 @@ export class UbCardHeaderDirective {

@Directive({
standalone: true,
selector: '[ubCardTitle]',
selector: 'h3[ubCardTitle]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -46,7 +46,7 @@ export class UbCardTitleDirective {

@Directive({
standalone: true,
selector: '[ubCardDescription]',
selector: 'p[ubCardDescription]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -60,7 +60,7 @@ export class UbCardDescriptionDirective {

@Directive({
standalone: true,
selector: '[ubCardContent]',
selector: 'div[ubCardContent]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -72,7 +72,7 @@ export class UbCardContentDirective {

@Directive({
standalone: true,
selector: '[ubCardFooter]',
selector: 'div[ubCardFooter]',
host: {
'[class]': 'computedClass()',
},
Expand Down
58 changes: 58 additions & 0 deletions docs/src/registry/new-york/example/card-with-form.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import { UbButtonDirective } from '@/registry/new-york/ui/button'
import {
UbCardContentDirective,
UbCardDescriptionDirective,
UbCardDirective,
UbCardFooterDirective,
UbCardHeaderDirective,
UbCardTitleDirective,
} from '@/registry/new-york/ui/card'
import { UbInputDirective } from '@/registry/new-york/ui/input'
import { UbLabelDirective } from '@/registry/new-york/ui/label'

import { Component } from '@angular/core'

@Component({
standalone: true,
imports: [
UbCardDirective,
UbCardHeaderDirective,
UbCardTitleDirective,
UbCardDescriptionDirective,
UbCardContentDirective,
UbCardFooterDirective,

UbInputDirective,
UbLabelDirective,
UbButtonDirective,
],
selector: 'card-with-form-new-york',
template: `
<div ubCard class="w-[350px]">
<div ubCardHeader>
<h3 ubCardTitle>Create project</h3>
<p ubCardDescription>Deploy your new project in one-click.</p>
</div>
<div ubCardContent>
<form>
<div class="grid w-full items-center gap-4">
<div class="flex flex-col space-y-1.5">
<label ubLabel htmlFor="name">Name</label>
<input ubInput type="text" id="name" placeholder="Name of your project" />
</div>
</div>
</form>
</div>
<div ubCardFooter class="flex justify-between">
<button ubButton variant="outline">Cancel</button>
<button ubButton>Deploy</button>
</div>
</div>
`,
})
export class CardWithFormNewYork { }

export default CardWithFormNewYork
12 changes: 6 additions & 6 deletions docs/src/registry/new-york/ui/card.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { computed, Directive, input } from '@angular/core'

@Directive({
standalone: true,
selector: '[ubCard]',
selector: 'div[ubCard]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -18,7 +18,7 @@ export class UbCardDirective {

@Directive({
standalone: true,
selector: '[ubCardHeader]',
selector: 'div[ubCardHeader]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -32,7 +32,7 @@ export class UbCardHeaderDirective {

@Directive({
standalone: true,
selector: '[ubCardTitle]',
selector: 'h3[ubCardTitle]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -46,7 +46,7 @@ export class UbCardTitleDirective {

@Directive({
standalone: true,
selector: '[ubCardDescription]',
selector: 'p[ubCardDescription]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -60,7 +60,7 @@ export class UbCardDescriptionDirective {

@Directive({
standalone: true,
selector: '[ubCardContent]',
selector: 'div[ubCardContent]',
host: {
'[class]': 'computedClass()',
},
Expand All @@ -72,7 +72,7 @@ export class UbCardContentDirective {

@Directive({
standalone: true,
selector: '[ubCardFooter]',
selector: 'div[ubCardFooter]',
host: {
'[class]': 'computedClass()',
},
Expand Down

0 comments on commit 2b11223

Please sign in to comment.