From 07e5a976c9228c05fc7cec706af82181ef75bd2f Mon Sep 17 00:00:00 2001 From: amar-ABgoclearv Date: Tue, 7 Feb 2023 12:29:15 -0500 Subject: [PATCH] feat(DDIDS-1152): Table component number column styling --- apps/angular-demo/src/app/table/table.html | 2 +- apps/react-demo/src/routes/table.tsx | 2 +- .../src/components/common/Table.stories.mdx | 18 ++++++++++++------ .../src/lib/notification/notification.spec.tsx | 5 +++-- libs/web-components/package-lock.json | 5 +++++ libs/web-components/package.json | 3 ++- libs/web-components/rollup.config.js | 9 +++++++++ .../src/components/table/Table.svelte | 17 +++++++++++------ libs/web-components/svelte.build.config.js | 14 ++++++++++++++ package-lock.json | 6 ++++++ package.json | 1 + workspace.json | 1 + 12 files changed, 66 insertions(+), 17 deletions(-) create mode 100644 libs/web-components/svelte.build.config.js diff --git a/apps/angular-demo/src/app/table/table.html b/apps/angular-demo/src/app/table/table.html index 646485c64..0e3e12493 100644 --- a/apps/angular-demo/src/app/table/table.html +++ b/apps/angular-demo/src/app/table/table.html @@ -16,7 +16,7 @@ {{ user.firstName }} {{ user.lastName }} - {{ user.age }} + {{ user.age }} diff --git a/apps/react-demo/src/routes/table.tsx b/apps/react-demo/src/routes/table.tsx index e43cdb902..5671b820d 100644 --- a/apps/react-demo/src/routes/table.tsx +++ b/apps/react-demo/src/routes/table.tsx @@ -52,7 +52,7 @@ export default function Table() { {user.firstName} {user.lastName} - {user.age} + {user.age} ))} diff --git a/libs/docs/src/components/common/Table.stories.mdx b/libs/docs/src/components/common/Table.stories.mdx index 0b03442f9..35825f7c9 100644 --- a/libs/docs/src/components/common/Table.stories.mdx +++ b/libs/docs/src/components/common/Table.stories.mdx @@ -8,7 +8,7 @@ import { SupportInfo, Markdown, } from "@abgov/shared/storybook-common"; -import { GoATable } from "@abgov/react-components"; +import { GoATable, GoACallout } from "@abgov/react-components"; import { useState, useEffect } from "react"; import { faker } from "@faker-js/faker"; @@ -153,7 +153,7 @@ export const SortableTableTemplate = (args) => { {user.firstName} {user.lastName} - {user.age} + {user.age} ))} @@ -356,6 +356,12 @@ export const SortableTableTemplate = (args) => { #### Sortable columns + + Columns with numerical data can be styled by adding a css class{" "} + goa-table-column-number. This sets the appropriate font and alignment + on these table cells + + {SortableTableTemplate.bind()} @@ -388,7 +394,7 @@ export const SortableTableTemplate = (args) => { return (a[sortBy] > b[sortBy] ? -1 : 1) * sortDir; }) } - } + } `} /> { {{ user.firstName }} {{ user.lastName }} - {{ user.age }} + {{ user.age }} @@ -449,11 +455,11 @@ export const SortableTableTemplate = (args) => { - {users.map(user => + {users.map(user => {user.firstName} {user.lastName} - {user.age} + {user.age} )} diff --git a/libs/react-components/src/lib/notification/notification.spec.tsx b/libs/react-components/src/lib/notification/notification.spec.tsx index 11e32b4d2..93faeba07 100644 --- a/libs/react-components/src/lib/notification/notification.spec.tsx +++ b/libs/react-components/src/lib/notification/notification.spec.tsx @@ -25,11 +25,12 @@ describe("Notification Banner", () => { it("Event triggered on notification banner dismiss", async () => { const onDismiss = jest.fn(); const { container } = render( - Information to the user goes in the content + + Information to the user goes in the content + ); const notificationBanner = container.querySelector("goa-notification"); fireEvent(notificationBanner, new CustomEvent("_dismiss")); expect(onDismiss).toBeCalled(); }); - }); diff --git a/libs/web-components/package-lock.json b/libs/web-components/package-lock.json index 7ae6b2ec2..4e324bcae 100644 --- a/libs/web-components/package-lock.json +++ b/libs/web-components/package-lock.json @@ -2636,6 +2636,11 @@ } } }, + "vite-plugin-replace": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/vite-plugin-replace/-/vite-plugin-replace-0.1.1.tgz", + "integrity": "sha512-v+okl3JNt2pf1jDYijw+WPVt6h9FWa/atTi+qnSFBqmKThLTDhlesx0r3bh+oFPmxRJmis5tNx9HtN6lGFoqWg==" + }, "which": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", diff --git a/libs/web-components/package.json b/libs/web-components/package.json index fd4b4ccf1..59a19a09d 100644 --- a/libs/web-components/package.json +++ b/libs/web-components/package.json @@ -43,6 +43,7 @@ "svelte-check": "^2.0.0", "svelte-preprocess": "^4.0.0", "tslib": "^2.0.0", - "typescript": "^4.0.0" + "typescript": "^4.0.0", + "vite-plugin-replace": "^0.1.1" } } diff --git a/libs/web-components/rollup.config.js b/libs/web-components/rollup.config.js index 6ddc39c08..65a93880e 100644 --- a/libs/web-components/rollup.config.js +++ b/libs/web-components/rollup.config.js @@ -6,6 +6,7 @@ import preprocess from "svelte-preprocess"; import commonjs from "@rollup/plugin-commonjs"; import typescript from "@rollup/plugin-typescript"; import css from 'rollup-plugin-css-only'; +import {replaceCodePlugin} from 'vite-plugin-replace'; export default { input: "src/index.ts", @@ -34,6 +35,14 @@ export default { resolve(), terser(), summary(), + replaceCodePlugin({ + replacements: [ + { + from: /:global\(([\[\]\(\)\-\.\:\*\w]+)\)/g, + to: "$1", + } + ] + }), ], watch: { clearScreen: true, diff --git a/libs/web-components/src/components/table/Table.svelte b/libs/web-components/src/components/table/Table.svelte index 0446692f9..681c4d016 100644 --- a/libs/web-components/src/components/table/Table.svelte +++ b/libs/web-components/src/components/table/Table.svelte @@ -35,7 +35,7 @@ const slot = _rootEl.querySelector("slot") as HTMLSlotElement; if (!slot || slot.assignedElements().length === 0) { return; - } + } // React needs to nest data in a const content = slot.assignedElements()[0].querySelectorAll("template table > *"); _rootEl.append(...(content.length > 0 ? content : slot.assignedElements())); @@ -57,7 +57,7 @@ const newDirection = direction === "desc" ? "asc" : "desc"; sortDir = newDirection === "asc" ? 1 : -1 - child.setAttribute("direction", newDirection) + child.setAttribute("direction", newDirection) } else { child.setAttribute("direction", "none") } @@ -87,8 +87,8 @@ > -