Skip to content

Commit

Permalink
fix: makes Card components susceptible to external attributes (e.g. s…
Browse files Browse the repository at this point in the history
…tyle/class)
  • Loading branch information
vatson committed Oct 15, 2020
1 parent 503d327 commit 4621a4f
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 10 deletions.
11 changes: 9 additions & 2 deletions src/components/Card/Card.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
import * as tsx from 'vue-tsx-support';
import { CreateElement, VNode } from 'vue';
import { mergeCss } from '../../utils/css';

export const Card = tsx.component({
name: 'Card',
functional: true,
render(h: CreateElement, { children }): VNode {
return <div staticClass="card">{children}</div>;
render(h: CreateElement, { children, data }): VNode {
const cssClass = mergeCss(data, 'card');

return (
<div {...data} class={cssClass}>
{children}
</div>
);
},
});
11 changes: 9 additions & 2 deletions src/components/Card/CardBody.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
import * as tsx from 'vue-tsx-support';
import { CreateElement, VNode } from 'vue';
import { mergeCss } from '../../utils/css';

export const CardBody = tsx.component({
name: 'CardBody',
functional: true,
render(h: CreateElement, { children }): VNode {
return <div staticClass="card-body">{children}</div>;
render(h: CreateElement, { children, data }): VNode {
const cssClass = mergeCss(data, 'card-body');

return (
<div {...data} class={cssClass}>
{children}
</div>
);
},
});
11 changes: 9 additions & 2 deletions src/components/Card/CardFooter.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
import * as tsx from 'vue-tsx-support';
import { CreateElement, VNode } from 'vue';
import { mergeCss } from '../../utils/css';

export const CardFooter = tsx.component({
name: 'CardFooter',
functional: true,
render(h: CreateElement, { children }): VNode {
return <div staticClass="card-footer">{children}</div>;
render(h: CreateElement, { children, data }): VNode {
const cssClass = mergeCss(data, 'card-footer');

return (
<div {...data} class={cssClass}>
{children}
</div>
);
},
});
11 changes: 9 additions & 2 deletions src/components/Card/CardHeader.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
import * as tsx from 'vue-tsx-support';
import { CreateElement, VNode } from 'vue';
import { mergeCss } from '../../utils/css';

export const CardHeader = tsx.component({
name: 'CardHeader',
functional: true,
render(h: CreateElement, { children }): VNode {
return <div staticClass="card-header">{children}</div>;
render(h: CreateElement, { children, data }): VNode {
const cssClass = mergeCss(data, 'card-header');

return (
<div {...data} class={cssClass}>
{children}
</div>
);
},
});
7 changes: 5 additions & 2 deletions src/components/Card/CardImage.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,18 @@
import * as tsx from 'vue-tsx-support';
import { CreateElement, VNode } from 'vue';
import { mergeCss } from '../../utils/css';

export const CardImage = tsx.component({
name: 'CardImage',
functional: true,
props: {
img: { type: String, required: true },
},
render(h: CreateElement, { props }): VNode {
render(h: CreateElement, { props, data }): VNode {
const cssClass = mergeCss(data, 'card-image');

return (
<div staticClass="card-image">
<div {...data} class={cssClass}>
<img src={props.img} staticClass="img-responsive" />
</div>
);
Expand Down

0 comments on commit 4621a4f

Please sign in to comment.