diff --git a/.changeset/small-turkeys-change.md b/.changeset/small-turkeys-change.md new file mode 100644 index 0000000000..d51f44aaa5 --- /dev/null +++ b/.changeset/small-turkeys-change.md @@ -0,0 +1,6 @@ +--- +"@twilio-paste/form-pill-group": patch +"@twilio-paste/core": patch +--- + +[Form Pill Group]: Fix position of dismiss button for large pill size diff --git a/cypress/integration/sitemap-vrt/constants.ts b/cypress/integration/sitemap-vrt/constants.ts index ec4ec6d669..cca536358b 100644 --- a/cypress/integration/sitemap-vrt/constants.ts +++ b/cypress/integration/sitemap-vrt/constants.ts @@ -21,6 +21,7 @@ export const SITEMAP = [ "/blog/2023-08-02-paste-newsletter/", "/blog/2023-11-08-paste-newsletter/", "/blog/2024-02-06-paste-2023-year-in-review/", + "/blog/2024-07-17-paste-newsletter/", "/components/account-switcher/", "/components/account-switcher/api", "/components/account-switcher/changelog", diff --git a/packages/paste-core/components/form-pill-group/src/FormPillButton.tsx b/packages/paste-core/components/form-pill-group/src/FormPillButton.tsx index 9242f81854..f06f1582d5 100644 --- a/packages/paste-core/components/form-pill-group/src/FormPillButton.tsx +++ b/packages/paste-core/components/form-pill-group/src/FormPillButton.tsx @@ -75,14 +75,14 @@ export const FormPillButton = React.forwardRef fontWeight="fontWeightMedium" outline="none" paddingLeft="space30" - paddingRight={isDismissable ? "space80" : "space30"} + paddingRight={isDismissable ? (size === "large" ? "space90" : "space80") : "space30"} transition="background-color 150ms ease-in, border-color 150ms ease-in, box-shadow 150ms ease-in, color 150ms ease-in" {...computedStyles} > {variant === "error" ? ( <> - + {i18nErrorLabel} ) : null} diff --git a/packages/paste-core/components/form-pill-group/src/PillCloseIcon.tsx b/packages/paste-core/components/form-pill-group/src/PillCloseIcon.tsx index 14594b2e60..bbf5e09530 100644 --- a/packages/paste-core/components/form-pill-group/src/PillCloseIcon.tsx +++ b/packages/paste-core/components/form-pill-group/src/PillCloseIcon.tsx @@ -12,6 +12,7 @@ import { selectedCloseColorStyles, } from "./FormPill.styles"; import type { PillVariant } from "./types"; +import { FormPillGroupContext } from "./useFormPillState"; interface PillCloseIconProps { onClick?: (event: React.MouseEvent) => void; @@ -29,6 +30,8 @@ export const PillCloseIcon: React.FC variant = "default", pillIsHoverable = false, }) => { + const { size } = React.useContext(FormPillGroupContext); + const baseStyles = selected ? selectedBaseCloseStyles[variant] : baseCloseStyles[variant]; let colorStyles = selected ? selectedCloseColorStyles[variant] : closeColorStyles[variant]; @@ -49,15 +52,15 @@ export const PillCloseIcon: React.FC display="flex" alignItems="center" justifyContent="center" - height="sizeIcon40" - width="sizeIcon40" + height={size === "large" ? "sizeIcon50" : "sizeIcon40"} + width={size === "large" ? "sizeIcon50" : "sizeIcon40"} borderRadius="borderRadiusCircle" borderWidth="borderWidth10" borderStyle="solid" borderColor="transparent" transition="color 150ms ease-in, border-color 150ms ease-in, background-color 150ms ease-in" > - + ); }; diff --git a/packages/paste-core/components/form-pill-group/stories/index.stories.tsx b/packages/paste-core/components/form-pill-group/stories/index.stories.tsx index cde970c838..360c1b21bd 100644 --- a/packages/paste-core/components/form-pill-group/stories/index.stories.tsx +++ b/packages/paste-core/components/form-pill-group/stories/index.stories.tsx @@ -1,3 +1,4 @@ +// eslint-disable-next-line import/no-extraneous-dependencies import { Avatar } from "@twilio-paste/avatar"; import { Box } from "@twilio-paste/box"; import { CalendarIcon } from "@twilio-paste/icons/esm/CalendarIcon"; @@ -38,8 +39,14 @@ export const Basic: React.FC< onDismiss={dismissable ? () => {} : undefined} disabled={disabled} > - {index % 3 === 2 ? : null} - {index % 3 === 1 ? : null} + {index % 3 === 2 ? ( + + ) : null} + {index % 3 === 1 ? : null} {pill} ))} @@ -52,6 +59,9 @@ export const Large = (): JSX.Element => ; export const Selected = (): JSX.Element => ; export const Dismissable = (): JSX.Element => ; +export const LargeAndDismissable = (): JSX.Element => ( + +); export const OverflowWrapping = (): JSX.Element => ( diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/ai-ui-kit.gif b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/ai-ui-kit.gif new file mode 100644 index 0000000000..08f546a8cd Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/ai-ui-kit.gif differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/illustrations.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/illustrations.png new file mode 100644 index 0000000000..fa206fad89 Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/illustrations.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/joe_fehrman.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/joe_fehrman.png new file mode 100644 index 0000000000..8419f7021a Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/joe_fehrman.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/kristian.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/kristian.png new file mode 100644 index 0000000000..54d846963d Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/kristian.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/marketing-card.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/marketing-card.png new file mode 100644 index 0000000000..0a7d4e6675 Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/marketing-card.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/ordered-display-list.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/ordered-display-list.png new file mode 100644 index 0000000000..90bf0b0d16 Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/ordered-display-list.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/page-header.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/page-header.png new file mode 100644 index 0000000000..3cfb6e019e Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/page-header.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/roxana.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/roxana.png new file mode 100644 index 0000000000..1b928c3964 Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/roxana.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/shoaib.png b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/shoaib.png new file mode 100644 index 0000000000..9f4f41ad54 Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/shoaib.png differ diff --git a/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/summary-detail.gif b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/summary-detail.gif new file mode 100644 index 0000000000..714c3c9bc0 Binary files /dev/null and b/packages/paste-website/src/assets/images/articles/2024-07-17-paste-newsletter/summary-detail.gif differ diff --git a/packages/paste-website/src/components/ResponsiveBorderedImage.tsx b/packages/paste-website/src/components/ResponsiveBorderedImage.tsx new file mode 100644 index 0000000000..7bada72e54 --- /dev/null +++ b/packages/paste-website/src/components/ResponsiveBorderedImage.tsx @@ -0,0 +1,23 @@ +import { Box } from "@twilio-paste/box"; +import Image from "next/image"; +import type { ImageProps } from "next/image"; +import * as React from "react"; + +const ResponsiveBorderedImage: React.FC = (props) => { + return ( + + + + ); +}; + +export { ResponsiveBorderedImage }; diff --git a/packages/paste-website/src/pages/blog/2024-07-17-paste-newsletter.mdx b/packages/paste-website/src/pages/blog/2024-07-17-paste-newsletter.mdx new file mode 100644 index 0000000000..5198d81970 --- /dev/null +++ b/packages/paste-website/src/pages/blog/2024-07-17-paste-newsletter.mdx @@ -0,0 +1,234 @@ +export const meta = { + title: "Paste Design System Newsletter - July 2024 Edition", + slug: "/blog/2024-07-17-paste-newsletter/", + date: "2024-07-17", + author: "Kristian Antrobus", + avatar: "https://avatars.githubusercontent.com/u/55083528", + excerpt: "What's new in Paste in July 2024? AI UI Kit, Page Header, Summary Detail components and much more!", +}; + +import Image from "next/image"; +import { Paragraph } from "@twilio-paste/paragraph"; +import { Box } from "@twilio-paste/box"; +import { Text } from "@twilio-paste/text"; +import { Anchor } from "@twilio-paste/anchor"; +import { Callout, CalloutHeading, CalloutText } from "@twilio-paste/callout"; + +import { ResponsiveImage } from "../../components/ResponsiveImage"; +import { ResponsiveBorderedImage } from "../../components/ResponsiveBorderedImage"; + +import AIUIKit from "../../assets/images/articles/2024-07-17-paste-newsletter/ai-ui-kit.gif"; +import PageHeaderImg from "../../assets/images/articles/2024-07-17-paste-newsletter/page-header.png"; +import SummaryDetail from "../../assets/images/articles/2024-07-17-paste-newsletter/summary-detail.gif"; +import MarketingCard from "../../assets/images/articles/2024-07-17-paste-newsletter/marketing-card.png"; +import OrderedDisplayList from "../../assets/images/articles/2024-07-17-paste-newsletter/ordered-display-list.png"; +import Illustrations from "../../assets/images/articles/2024-07-17-paste-newsletter/illustrations.png"; +import KristianProfile from "../../assets/images/articles/2024-07-17-paste-newsletter/kristian.png"; +import RoxanaProfile from "../../assets/images/articles/2024-07-17-paste-newsletter/roxana.png"; +import ShoaibProfile from "../../assets/images/articles/2024-07-17-paste-newsletter/shoaib.png"; +import JoeProfile from "../../assets/images/articles/2024-07-17-paste-newsletter/joe_fehrman.png"; + +import DefaultLayout from "../../layouts/DefaultLayout"; +import { getNavigationData } from "../../utils/api"; + +export default DefaultLayout; + +export const getStaticProps = async () => { + const navigationData = await getNavigationData(); + return { + props: { + navigationData, + }, + }; +}; + + + +--- + + + + + + + +Hey all, it's been a while! This newsletter summarizes our releases for all of 2024 so far, especially one release you've all been waiting for… + +## 📣 What was new in Paste? + +### The AI UI Kit is live! + + + + + + + +The AI UI Kit includes: + +- [AI experience guidelines](/experiences/artificial-intelligence) that summarize all Paste AI components and guidelines, and collect resources from the great research and work that's already been done across the Segment, Flex, and Privacy teams. +- New [AI Chat Log](/components/ai-chat-log) components, which we've made distinct from our Conversations [Chat Log](/components/chat-log) components, in order to ensure differentiation between the two interaction types. +- An updated [Chat Composer](/components/chat-composer) component, with a `ChatComposerContainer` for standard layout and styling of the Chat Composer. This can be used in any chat use case. +- A new [Side Panel](/components/side-panel) component, which can be used for showing AI features side-by-side with main page content, for our upcoming update to the Filter pattern, and more. +- A new [ArtificialIntelligenceIcon](/components/icon) + +Thanks to everyone for their partnership and feedback, including **Jiyeon Kang, Eileen Tong, Megan Allison, Amira Chalbi Neffati, Wai-Jee Ho, and Barbara Chicca**. + +### Page Header component + + + + + +The [Page Header](/components/page-header) component controls the spacing and layout for any components used at the top of the page, including Breadcrumbs, Headings, actions, and metadata. This component helps standardize content and layout of our pages, and includes a compact variant, too, for narrow containers. + +### Summary Detail component + + + + + + + +The [Summary Detail](/components/summary-detail) component displays a summary of information that can be expanded to show more information. It's most useful when you need to provide more actions and information than the [Disclosure](/components/disclosure) can provide. Use this component to organize information in a clear, accessible way to allow users to access detailed data only when needed. + +### Brand Badges and marketing Cards + + + + + +We've released new [brand Badges](/components/badge#brand) to highlight cross-selling opportunities across our platforms and on pricing plans. These Badges also mirror similar elements on [twilio.com](http://twilio.com) for enhanced cohesion across our customer touchpoints. + +These Badges also come with [updated guidelines on our Card component for marketing use cases](/components/card#marketing-card). We're also working on a more general card layout pattern, so stay tuned! + +### Ordered Display List + + + + + +The [Ordered Display List](/components/list#ordered-display-list) component helps improve the scannability and visual design of steps or instructions, especially in onboarding use cases. You can use this component with all sorts of nested content as you would with the typical List component to walk a user through complex steps. + +### Refined illustration foundations + + + + + +Our updated [illustration foundations](/foundations/illustrations) include clearer guidelines on: + +- When to use illustrations +- Which ones to use +- How to access and request them + +In Figma, you can turn on the [Web Spot Image library](https://www.figma.com/file/tr1bGht8drBOMaeX5EpJ7m/Web-Spot-Image-Repository?type=design&node-id=2310-5106&mode=design) for easy access to illustrations. Thanks to **Shane Brown** on the Web team for your partnership on this! + +### Additional updates + +#### New + +- Added [icons](/components/icon) for sentiment, different data types, e-commerce, transfer, admin dashboard, and the Conversational Insights product. +- Added dark theme as a mode in the Paste Components Figma library. + +#### Updates + +- Thanks to **Megan Allison** for updating our content foundations, including the [voice and tone](/foundations/content/voice-and-tone) guidelines, [content checklist](/foundations/content/content-checklist), and [product style guide](/foundations/content/product-style-guide), to more closely align with the recently released [Twilio Style Guide](https://library.twilio.com/guidelines/guide/1b8c14a4-287d-47a4-8ac6-1621bfe97a6d/page/34720f98-b7f8-4436-8e66-4f814801eec1). + +## 👋 Welcome to the team: Roxana, Kristian & Shoaib! + +This year, we've added 3 new members to our team. + +### Roxana Gómez, Product Designer + + + + + +Roxana joined us in January from Medellín, Colombia. She's been a Product Designer for several years. Over the past couple of years, she has been advocating for reusable systems for different teams and their benefits for speed, quality, and consistency. + +Outside of work you can find her playing with her dogs, doing yoga, playing MTG, binge watching anime and reading historical fiction. + +### Kristian Antrobus, UX Engineer + + + + + +Kristian joined us in May from Minneapolis in the US. He's been at Twilio for nearly 2 years already, most recently with the Messaging team. + +Outside of work, his passions include sketching technical studies, paddle boarding, and immersing himself in fantasy novels brimming with magic and adventure. He also enjoys baking and tackling home improvement projects. + +### Shoaib Ahmed, UX Engineer + + + + + +Shoaib joined us in July from Bengaluru in India. He has been working at the intersection of design and tech for all his career. He led the design system initiative in his previous organization, combining the principles of open source systems and accessibility. + +Outside of work, Shoaib usually indulges himself with movies, music, anime, and biryani. + +## ✨ Pastemates™ spotlight + +_Pastemates are individuals and teams who have been critical contributors to Paste, through advocating for adoption within their products and channeling important feedback and contributions back into the system._ + + + + + +In this edition of Pastemates, we're spotlighting Joe Fehrman! Joe Fehrman ([@cogwizzle](https://github.com/cogwizzle)) has been an incredible collaborator over the past few months. They embody the Twilio Owner spirit by digging deep into the Paste repo, understanding how the team builds, thinking long term, and contributing betterments for our consumers. + +Joe's contributions are already improving the developer experience both within the Paste team and for Twilio engineers at large. Their work has included helpful JSDoc additions to elevate consumers' understanding of component usage and a new variant to Form Pill Group as part of the new Filter Pattern. Not only that, but we are also working closely to facilitate upcoming contributions directly related to sprint work to deliver a lasting impact and accelerate our roadmap. Thank you, Joe! + +## 👀 What we're working on next + +| Feature | Description | +| ------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| **Corner ornament pattern** | A corner ornament is a way to relate an item count or graphic element to another element. | +| **Redesigned filter pattern** | Filters enable users to narrow down and refine results across various types of content pages, including rich content pages, data tables, lists, data insights, and more. | +| **Add typography and effect variables to Paste Components Figma library** | Apply typography and effect variables to the Paste Components Figma library so designers can more accurately switch themes. | + + + +As always, we're better together. + +— The UX Infrastructure Team + + + +