Skip to content

refactor(components): dlt-3282 renamed show prop to open#1190

Merged
Ignacio Ropolo (iropolo) merged 3 commits intonextfrom
DLT-3282
Apr 13, 2026
Merged

refactor(components): dlt-3282 renamed show prop to open#1190
Ignacio Ropolo (iropolo) merged 3 commits intonextfrom
DLT-3282

Conversation

@iropolo
Copy link
Copy Markdown
Contributor

@iropolo Ignacio Ropolo (iropolo) commented Apr 9, 2026

Renamed show prop to open

🛠️ Type Of Change

These types will increment the version number on release:

  • Refactor

📖 Jira Ticket

https://dialpad.atlassian.net/browse/DLT-3282

📖 Description

We are fixing some inconsistencies in prop naming and this show vs open will be always open.

Components updated:

  • Modal
  • Tooltip
  • Toast <-- doubts on this but still updated it.

Doubt:

  • dt-lazy-show , this uses show, but it is semantically different from overlay open/close. I didn't update this.

Breaking changes

DtModal

Before After Impact
:show="value" :open="value" Prop binding
Update (@update):show="handler" Update (@update):open="handler" Event listener
v-model:show="value" v-model:open="value" Two-way binding

DtTooltip

:show="value" :open="value" Prop binding
Update (@update):show="handler" Update (@update):open="handler" Event listener
:show.sync="value" (Vue 2 compat) :open.sync="value" Legacy sync binding

DtToast

Before After Impact
:show="value" :open="value" Prop binding
v-model:show="value" v-model:open="value" Two-way binding
Update (@update):show="handler" Update (@update):open="handler" Event listener

Migration Examples:

<!-- Modal -->
- <dt-modal :show="isOpen" @update:show="onClose">
+ <dt-modal :open="isOpen" @update:open="onClose">
 
<!-- Tooltip (programmatic) -->
- <dt-tooltip :show="visible" @update:show="onToggle">
+ <dt-tooltip :open="visible" @update:open="onToggle">
 
<!-- Toast -->
- <dt-toast :show="isShown" @update:show="onDismiss">
+ <dt-toast :open="isShown" @update:open="onDismiss">
 
<!-- Toast with v-model -->
- <dt-toast v-model:show="isShown">
+ <dt-toast v-model:open="isShown">

Renames the show prop/event to open across DtModal, DtTooltip, and DtToast (implementations, tests, stories, and docs) for consistent overlay APIs; dt-lazy-show remains show. Breaking API changes: v-model/events renamed to open/update:open.

@coderabbitai
Copy link
Copy Markdown
Contributor

coderabbitai bot commented Apr 9, 2026

Walkthrough

Unified the visibility v-model naming by replacing show/update:show with open/update:open across components, stories, tests, documentation, and internal guidance files for Modal, Tooltip, Toast, Popover, and related examples.

Changes

Cohort / File(s) Summary
Conventions & Docs
.claude/rules/vue-components.md, .claude/skills/vue-conventions.md, CLAUDE.md, packages/dialtone-docs/src/content/reference/reference-component-api-patterns.md
Updated guidance and reference docs to require update:open as the unified visibility v-model event; removed legacy update:show guidance.
Modal
packages/dialtone-vue/components/modal/modal.vue, packages/dialtone-vue/components/modal/modal.stories.js, packages/dialtone-vue/components/modal/modal.test.js, packages/dialtone-vue/components/modal/modal_default.story.vue, apps/dialtone-documentation/docs/components/modal.md, apps/dialtone-documentation/docs/.vuepress/exampleComponents/ExampleModal.vue, apps/dialtone-documentation/docs/.vuepress/views/IconCatalog.vue
Renamed prop showopen and emitted event update:showupdate:open in component, tests, stories, docs, and examples; updated bindings and handlers accordingly.
Tooltip
packages/dialtone-vue/components/tooltip/tooltip.vue, packages/dialtone-vue/components/tooltip/*.story.vue, packages/dialtone-vue/components/tooltip/tooltip.stories.js, packages/dialtone-vue/components/tooltip/tooltip.test.js
Renamed controlled prop and emit (showopen, update:showupdate:open) across implementation, tests, and all story variants; updated computed/watch usage and story bindings.
Toast
packages/dialtone-vue/components/toast/toast.vue, packages/dialtone-vue/components/toast/toast.stories.js, packages/dialtone-vue/components/toast/toast.test.js, packages/dialtone-vue/components/toast/toast_default.story.vue, apps/dialtone-documentation/docs/.vuepress/exampleComponents/ExampleToast.vue, apps/dialtone-documentation/docs/components/toast.md, apps/dialtone-documentation/docs/scratch.md
Renamed prop/emit pairs and story controls from show/update:show to open/update:open; adjusted docs and examples, plus test fixtures and story Percy args.
Popover & Recipes
packages/dialtone-vue/components/popover/popover_variants.story.vue, packages/dialtone-vue/recipes/buttons/callbar_button/callbar_button.vue
Updated dt-tooltip and related usages to bind open instead of show where driven by parent $attrs.open.
Storybook / Examples Sweep
apps/dialtone-documentation/**, packages/**/.../*.story.vue, *.stories.js (multiple files)
Consistent update of story controls/args, Percy args, and example templates to use open/update:open rather than show/update:show.

Estimated code review effort

🎯 3 (Moderate) | ⏱️ ~20 minutes

✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch DLT-3282

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@github-actions
Copy link
Copy Markdown
Contributor

github-actions bot commented Apr 9, 2026

Please add either the visual-test-ready or no-visual-test label to this PR depending on whether you want to run visual tests or not.
It is recommended to run visual tests if your PR changes any UI. ‼️

@iropolo Ignacio Ropolo (iropolo) added the no-visual-test Add this tag when the PR does not need visual testing label Apr 9, 2026
@iropolo Ignacio Ropolo (iropolo) marked this pull request as ready for review April 9, 2026 15:54
Copy link
Copy Markdown
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Caution

Some comments are outside the diff and can’t be posted inline due to platform limitations.

⚠️ Outside diff range comments (1)
packages/dialtone-docs/src/content/reference/reference-component-api-patterns.md (1)

78-97: ⚠️ Potential issue | 🟡 Minor

Update the remaining Tooltip warning text to open for consistency.

This section correctly standardizes visibility to open, but the same page still says DtTooltip warns on enabled + show. Please rename that mention to enabled + open to avoid mixed guidance.

Suggested doc fix
-- DtTooltip: warns when both `enabled` and `show` props are set
+- DtTooltip: warns when both `enabled` and `open` props are set

Based on learnings: Component documentation must include Vue source, tests, Storybook stories, component docs JSON, VuePress documentation, and MCP server data — all must stay in sync.

🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In
`@packages/dialtone-docs/src/content/reference/reference-component-api-patterns.md`
around lines 78 - 97, Locate the remaining tooltip warning that says "enabled +
show" and update it to "enabled + open" for consistency with the visibility prop
naming; specifically, search for the DtTooltip mention in the
reference-component-api-patterns content and replace the wording (and any
example or explanatory text) to use "open" instead of "show" so it matches the
`update:open` convention and the table/listing of emits.
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.

Outside diff comments:
In
`@packages/dialtone-docs/src/content/reference/reference-component-api-patterns.md`:
- Around line 78-97: Locate the remaining tooltip warning that says "enabled +
show" and update it to "enabled + open" for consistency with the visibility prop
naming; specifically, search for the DtTooltip mention in the
reference-component-api-patterns content and replace the wording (and any
example or explanatory text) to use "open" instead of "show" so it matches the
`update:open` convention and the table/listing of emits.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Central YAML (base), Organization UI (inherited)

Review profile: CHILL

Plan: Pro

Run ID: c2347579-2bd2-4b94-8aa2-4c63a9aeb099

📥 Commits

Reviewing files that changed from the base of the PR and between 2d00fe0 and 2422aef.

📒 Files selected for processing (27)
  • .claude/rules/vue-components.md
  • .claude/skills/vue-conventions.md
  • CLAUDE.md
  • apps/dialtone-documentation/docs/.vuepress/exampleComponents/ExampleModal.vue
  • apps/dialtone-documentation/docs/.vuepress/exampleComponents/ExampleToast.vue
  • apps/dialtone-documentation/docs/.vuepress/views/IconCatalog.vue
  • apps/dialtone-documentation/docs/components/modal.md
  • apps/dialtone-documentation/docs/components/toast.md
  • apps/dialtone-documentation/docs/scratch.md
  • packages/dialtone-docs/src/content/reference/reference-component-api-patterns.md
  • packages/dialtone-vue/components/modal/modal.stories.js
  • packages/dialtone-vue/components/modal/modal.test.js
  • packages/dialtone-vue/components/modal/modal.vue
  • packages/dialtone-vue/components/modal/modal_default.story.vue
  • packages/dialtone-vue/components/popover/popover_variants.story.vue
  • packages/dialtone-vue/components/toast/toast.stories.js
  • packages/dialtone-vue/components/toast/toast.test.js
  • packages/dialtone-vue/components/toast/toast.vue
  • packages/dialtone-vue/components/toast/toast_default.story.vue
  • packages/dialtone-vue/components/tooltip/tooltip.stories.js
  • packages/dialtone-vue/components/tooltip/tooltip.test.js
  • packages/dialtone-vue/components/tooltip/tooltip.vue
  • packages/dialtone-vue/components/tooltip/tooltip_change_on_click.story.vue
  • packages/dialtone-vue/components/tooltip/tooltip_default.story.vue
  • packages/dialtone-vue/components/tooltip/tooltip_flip.story.vue
  • packages/dialtone-vue/components/tooltip/tooltip_variants.story.vue
  • packages/dialtone-vue/recipes/buttons/callbar_button/callbar_button.vue

Copy link
Copy Markdown
Contributor

@braddialpad Brad Paugh (braddialpad) left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We are fixing some inconsistencies in prop naming and this show vs open will be always open.

Components updated:

Modal
Tooltip
Toast <-- doubts on this but still updated it.
Doubt:

dt-lazy-show , this uses show, but it is semantically different from overlay open/close. I didn't update this.

lol hate to say this.. but does it make sense to use "show" instead of "open" for everything then? I think it kinda works for everything while open doesn't.

@francisrupert
Copy link
Copy Markdown
Contributor

Francis Rupert (francisrupert) commented Apr 10, 2026

lol hate to say this.. but does it make sense to use "show" instead of "open" for everything then? I think it kinda works for everything while open doesn't.

Heh. Did a little research...


The web platform strongly favors open:

  • The native HTML <dialog> element uses the open attribute
  • The HTML <details> element uses open
  • The Popover API uses showPopover()/hidePopover() methods but the state is conceptually "open"

Top-tier Vue libraries:

  • Radix Vue / Reka UI — uses open (and v-model:open)
  • Headless UI — uses open
  • Vuetify — historically used v-model (with value/modelValue), but their dialog/menu components conceptually track "open" state
  • PrimeVue — uses visible for Dialog
  • Quasar — uses v-model (no named prop)
  • Element Plus — uses v-model / modelValue for Dialog
  • Naive UI — uses show

Non-Vue design systems:

  • Radix (React) — open / onOpenChange
  • Chakra UI — isOpen / onOpen / onClose
  • MUI — open
  • Adobe Spectrum — isOpen
  • Shoelace/Web Awesome — open (mirrors native <dialog>)
  • Carbon (IBM) — open
  • Ant Design — open (migrated away from visible in v5)

The trend is clearly toward open:

  • Align with the HTML platform (<dialog open>, <details open>)
  • The most respected headless/unstyled libraries (Radix, Headless UI) use it
  • MUI, Carbon, Shoecase all use it
  • Ant Design explicitly migrated from visible to open
  • show is a minority choice (mainly Naive UI)

Bottom line

open is the right call. The strongest argument is platform alignment — native HTML uses open, and the most influential modern component libraries (Radix, Headless UI, MUI, Shoelace) all converge on it. The Ant Design migration from visibleopen is particularly telling — a massive library chose to take a breaking change specifically to align with this convention.

Copy link
Copy Markdown
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Caution

Some comments are outside the diff and can’t be posted inline due to platform limitations.

⚠️ Outside diff range comments (1)
packages/dialtone-vue/components/modal/modal.test.js (1)

247-252: ⚠️ Potential issue | 🟡 Minor

Replace stale show prop in this migrated test case.

Line 249 still sets show: true. This no longer validates the renamed API and can mask coverage gaps; use open: true here as well.

Patch
     it('Should apply critical banner kind', async () => {
       await wrapper.setProps({
-        show: true,
+        open: true,
         bannerKind: 'critical',
         bannerTitle: 'title',
       });
🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@packages/dialtone-vue/components/modal/modal.test.js` around lines 247 - 252,
In the test "Should apply critical banner kind" update the props passed to
wrapper.setProps to use the new API: replace the stale show: true with open:
true so the test exercises the renamed prop; ensure wrapper.setProps({ open:
true, bannerKind: 'critical', bannerTitle: 'title' }) is used instead of setting
show.
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.

Outside diff comments:
In `@packages/dialtone-vue/components/modal/modal.test.js`:
- Around line 247-252: In the test "Should apply critical banner kind" update
the props passed to wrapper.setProps to use the new API: replace the stale show:
true with open: true so the test exercises the renamed prop; ensure
wrapper.setProps({ open: true, bannerKind: 'critical', bannerTitle: 'title' })
is used instead of setting show.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Central YAML (base), Organization UI (inherited)

Review profile: CHILL

Plan: Pro Plus

Run ID: a909a42c-4f5e-40be-ade7-aec63cf7e4d0

📥 Commits

Reviewing files that changed from the base of the PR and between 2422aef and fd61e6b.

📒 Files selected for processing (13)
  • apps/dialtone-documentation/docs/components/modal.md
  • apps/dialtone-documentation/docs/components/toast.md
  • apps/dialtone-documentation/docs/scratch.md
  • packages/dialtone-docs/src/content/reference/reference-component-api-patterns.md
  • packages/dialtone-vue/components/modal/modal.stories.js
  • packages/dialtone-vue/components/modal/modal.test.js
  • packages/dialtone-vue/components/modal/modal.vue
  • packages/dialtone-vue/components/modal/modal_default.story.vue
  • packages/dialtone-vue/components/toast/toast.stories.js
  • packages/dialtone-vue/components/toast/toast.test.js
  • packages/dialtone-vue/components/toast/toast.vue
  • packages/dialtone-vue/components/toast/toast_default.story.vue
  • packages/dialtone-vue/recipes/buttons/callbar_button/callbar_button.vue
✅ Files skipped from review due to trivial changes (2)
  • apps/dialtone-documentation/docs/components/toast.md
  • apps/dialtone-documentation/docs/scratch.md
🚧 Files skipped from review as they are similar to previous changes (6)
  • packages/dialtone-vue/components/toast/toast.test.js
  • packages/dialtone-vue/recipes/buttons/callbar_button/callbar_button.vue
  • packages/dialtone-vue/components/toast/toast_default.story.vue
  • packages/dialtone-vue/components/toast/toast.stories.js
  • packages/dialtone-vue/components/toast/toast.vue
  • packages/dialtone-vue/components/modal/modal_default.story.vue

@github-actions
Copy link
Copy Markdown
Contributor

✔️ Deploy previews ready!
😎 Dialtone documentation preview: https://dialtone.dialpad.com/deploy-previews/pr-1190/
😎 Dialtone-vue preview: https://dialtone.dialpad.com/vue/deploy-previews/pr-1190/

@iropolo
Copy link
Copy Markdown
Contributor Author

We will continue the update of this prop to open.

@iropolo Ignacio Ropolo (iropolo) merged commit 5509d0f into next Apr 13, 2026
16 checks passed
@iropolo Ignacio Ropolo (iropolo) deleted the DLT-3282 branch April 13, 2026 17:04
Brad Paugh (braddialpad) pushed a commit that referenced this pull request Apr 15, 2026
# [3.220.0-next.1](dialtone-vue/v3.219.0...dialtone-vue/v3.220.0-next.1) (2026-04-15)

### Bug Fixes

* **Editor:** NO-JIRA remove extra blank line in editor.mdx ([18c47ef](18c47ef))
* **Split Button, Filter Pill:** DLT-3260 DLT-3261 correct misalignment at size 100 ([#1176](#1176)) ([fe2b777](fe2b777))
* **Tabs:** DLT-3251 improve accessibility ([#1171](#1171)) ([01b101e](01b101e))

### Code Refactoring

* **Combobox Multi Select:** NO-JIRA use logical css properties ([#1104](#1104)) ([a675daf](a675daf))
* **Components,recipes:** DLT-3043 DLT-3046 logical start/end naming with deprecated backward-compatible fallbacks ([#1079](#1079)) ([1d26a4e](1d26a4e))
* **Components:** DLT-3100 remove rootClass references ([#1184](#1184)) ([6531783](6531783))
* **Components:** dlt-3282 renamed show prop to open ([#1190](#1190)) ([5509d0f](5509d0f))
* **Components:** dlt-3283 refactor prop/slots to be consistent ([#1196](#1196)) ([2d22c76](2d22c76))
* **Modal:** DLT-3262 migrate DtModal to native dialog element ([#1179](#1179)) ([589edb5](589edb5))
* **Text:** DLT-3302 tone prop uses css variables instead of css utilities ([#1197](#1197)) ([75df16f](75df16f))
* **Tokens,css,link,text,breadcrumbs,input Group,split Button:** tokens, CSS foundation, deprecations, tooling DLT-3011 DLT-2961 DLT-3068 DLT-3069 DLT-3070 DLT-3071 DLT-3072 ([#1092](#1092)) ([7783090](7783090))
* **Tokens:** DLT-3013 convert color system from HSL to OKLCH ([#1060](#1060)) ([42dc418](42dc418))

### Documentation

* **Dialtone Vue:** DLT-3226 update documentation and consuming code to numeric size scale ([#1158](#1158)) ([149c763](149c763))
* **Playground:** DLT-3119 refine playground UI and integrate across doc site ([#1127](#1127)) ([ba6b599](ba6b599))

### Features

* **Avatar:** DLT-2942 updated avatar component ([#1047](#1047)) ([e50563d](e50563d))
* **Avatar:** DLT-3161 change from clickable to "interactive" ([#1182](#1182)) ([2d00fe0](2d00fe0))
* **Banner, Notice, Toast, Breadcrumbs, Checkbox, Radio, Input, Select Menu, Empty State:** visual refresh, dt-text integration, form api parity DLT-2944 DLT-2945 DLT-2949 DLT-2959 DLT-2960 DLT-2957 ([#1091](#1091)) ([16e908a](16e908a))
* **Button,tabs,split Button:** visual refresh and slot updates DLT-2946 DLT-2947 DLT-2965 ([#1090](#1090)) ([ffdd56f](ffdd56f))
* **Components:** DLT-3157 align critical/positive prop values and CSS class names ([#1177](#1177)) ([edd98b2](edd98b2))
* **Components:** DLT-3159 enforce positive boolean props ([#1198](#1198)) ([ac73bdc](ac73bdc))
* **Dialtone Css, Dialtone Tokens, Dialtone Vue:** DLT-3197 DLT-3198 DLT-3199 DLT-3200 DLT-3201 DLT-3202 DLT-3203 DLT-3204 DLT-3205 DLT-3206 DLT-3207 DLT-3208 DLT-3209 DLT-3210 DLT-3211 token-stop utility classes, migration tooling, and documentation ([#1150](#1150)) ([6237b84](6237b84))
* **Dialtone Vue:** DLT-3225 migrate component size props to numeric ordinal scale ([#1157](#1157)) ([725bd41](725bd41))
* **Filter Pill:** DLT-2941 DtFilterPill improvements ([#1110](#1110)) ([23c5689](23c5689))
* **Focusgroup:** DLT-3285 add v-dt-focusgroup directive for declarative roving tabindex ([#1187](#1187)) ([e1ea074](e1ea074))
* **Focustrap:** DLT-3297 add v-dt-focustrap directive for declarative focus trapping ([#1195](#1195)) ([6ef9a21](6ef9a21))
* **Link,button:** DLT-3012 add underline prop ([#1059](#1059)) ([1cb91ea](1cb91ea))
* **Mode Directive, Mode Island:** DLT-3067 DLT-3078 DLT-3077 add `v-dt-mode` directive ([#1109](#1109)) ([f97efca](f97efca))
* **Segmented Control:** DLT-413 new component ([#1144](#1144)) ([ad4c6c3](ad4c6c3))
* **Split Button:** DLT-3257 add show-divider prop ([#1173](#1173)) ([5bef411](5bef411))
* **Tabs:** DLT-3114 add vertical orientation variant ([#1120](#1120)) ([3290a23](3290a23))
* **Tabs:** DLT-3162 add spread prop for horizontal distribution ([#1135](#1135)) ([6e7cd04](6e7cd04))
* **Text:** export text component from dialtone-vue ([757fdb7](757fdb7))
* **Tokens:** DLT-2937 introduce spacing and layout token systems ([#1045](#1045)) ([de23e12](de23e12))
* **Tokens:** update color ramps and consumer color migration tools DLT-3004 DLT-3005 DLT-3006 DLT-3007 DLT-3008 ([#1054](#1054)) ([28cb1de](28cb1de))
Brad Paugh (braddialpad) pushed a commit that referenced this pull request Apr 15, 2026
# [9.180.0-next.1](dialtone/v9.179.0...dialtone/v9.180.0-next.1) (2026-04-15)

### Bug Fixes

* **Doc:** NO-JIRA correct font size utility json ([#1015](#1015)) ([76cf0fa](76cf0fa))
* **Editor:** NO-JIRA remove extra blank line in editor.mdx ([18c47ef](18c47ef))
* possible merge issue in sidebarItem.vue ([5e2e91b](5e2e91b))
* **Split Button, Filter Pill:** DLT-3260 DLT-3261 correct misalignment at size 100 ([#1176](#1176)) ([fe2b777](fe2b777))
* **Stylelint:** disable hue-degree-notation rule and update OKLCH color syntax ([81f886e](81f886e))
* **Stylelint:** disable hue-degree-notation rule and update OKLCH color syntax ([8721f43](8721f43))
* **Tabs:** DLT-3251 improve accessibility ([#1171](#1171)) ([01b101e](01b101e))
* **Tokens:** DLT-3053 preserve root font size variable as reference ([#1093](#1093)) ([112ab4b](112ab4b))
* **Tokens:** handle multi-layer box shadows correctly in postcss plugin ([feea7f1](feea7f1))
* **Tokens:** NO-JIRA output line-height as unitless instead of percentages ([#1040](#1040)) ([33d8505](33d8505))
* **Tokens:** wrap css math expressions with calc() in layered build ([#966](#966)) ([1635f61](1635f61))
* update @dialpad/i18n dependencies to latest versions ([7a4b777](7a4b777))

### Code Refactoring

* **Combobox Multi Select:** NO-JIRA use logical css properties ([#1104](#1104)) ([a675daf](a675daf))
* **Components,recipes:** DLT-3043 DLT-3046 logical start/end naming with deprecated backward-compatible fallbacks ([#1079](#1079)) ([1d26a4e](1d26a4e))
* **Components:** DLT-3100 remove rootClass references ([#1184](#1184)) ([6531783](6531783))
* **Components:** dlt-3282 renamed show prop to open ([#1190](#1190)) ([5509d0f](5509d0f))
* **Components:** dlt-3283 refactor prop/slots to be consistent ([#1196](#1196)) ([2d22c76](2d22c76))
* **Css:** DLT-1876 css logical properties ([#872](#872)) ([1acd6c9](1acd6c9))
* **Modal:** DLT-3262 migrate DtModal to native dialog element ([#1179](#1179)) ([589edb5](589edb5))
* **Notice,banner,toast:** DLT-3296 decouple CSS and fix specificity violations ([#1194](#1194)) ([9579ac0](9579ac0))
* **Style:** DLT-3014 wrap all styles in css cascade layers ([#1061](#1061)) ([f8b3fed](f8b3fed))
* **Text:** DLT-2883 rename headline sizes from xxl => 2xl, etc ([#1029](#1029)) ([0ac86f3](0ac86f3))
* **Text:** DLT-3302 tone prop uses css variables instead of css utilities ([#1197](#1197)) ([75df16f](75df16f))
* **Tokens,css,link,text,breadcrumbs,input Group,split Button:** tokens, CSS foundation, deprecations, tooling DLT-3011 DLT-2961 DLT-3068 DLT-3069 DLT-3070 DLT-3071 DLT-3072 ([#1092](#1092)) ([7783090](7783090))
* **Tokens:** DLT-2884 deprecate space tokens in favor of size tokens ([#1013](#1013)) ([63f6d2f](63f6d2f))
* **Tokens:** DLT-3013 convert color system from HSL to OKLCH ([#1060](#1060)) ([42dc418](42dc418))

### Documentation

* **Components:** DLT-3178 DLT-3182 unify code examples into single code-example component ([#1147](#1147)) ([d0b6e14](d0b6e14))
* **Css Utilities:** DLT-3295 DLT-3280 mark physical utilities as deprecated ([#1193](#1193)) ([73f1479](73f1479))
* **Dialtone Vue:** DLT-3226 update documentation and consuming code to numeric size scale ([#1158](#1158)) ([149c763](149c763))
* DLT-1510 DLT-1511 DLT-1512 site redesign and ia ([#968](#968)) ([6ea7eb9](6ea7eb9))
* DLT-2908 ui kits landing page ([#1049](#1049)) ([d805b9d](d805b9d))
* DLT-3243 fenced code blocks for examples and snippets ([#1166](#1166)) ([cb169df](cb169df))
* DLT-3250 display component status badges in sidebar and page headers ([#1170](#1170)) ([7d5f5d5](7d5f5d5))
* DLT-3252 add GFM alert syntax for notices ([#1172](#1172)) ([1697911](1697911))
* DLT-3258 DLT-3259 improve sidebar search with logical keywords and fuzzy matching ([#1174](#1174)) ([2bf4639](2bf4639))
* NO-JIRA fix focus left-nav items on keypress down up ([#1106](#1106)) ([882c9b9](882c9b9))
* **Playground:** DLT-3119 refine playground UI and integrate across doc site ([#1127](#1127)) ([ba6b599](ba6b599))
* **Playground:** DLT-3242 segmented control for compact enum props ([#1165](#1165)) ([fa440d8](fa440d8))
* **Utilities:** DLT-3183 convert to vue demo fenced block ([#1167](#1167)) ([522197f](522197f))

### Features

* **Avatar:** DLT-2942 updated avatar component ([#1047](#1047)) ([e50563d](e50563d))
* **Avatar:** DLT-3161 change from clickable to "interactive" ([#1182](#1182)) ([2d00fe0](2d00fe0))
* **Banner, Notice, Toast, Breadcrumbs, Checkbox, Radio, Input, Select Menu, Empty State:** visual refresh, dt-text integration, form api parity DLT-2944 DLT-2945 DLT-2949 DLT-2959 DLT-2960 DLT-2957 ([#1091](#1091)) ([16e908a](16e908a))
* **Button,tabs,split Button:** visual refresh and slot updates DLT-2946 DLT-2947 DLT-2965 ([#1090](#1090)) ([ffdd56f](ffdd56f))
* **Components:** DLT-3157 align critical/positive prop values and CSS class names ([#1177](#1177)) ([edd98b2](edd98b2))
* **Components:** DLT-3159 enforce positive boolean props ([#1198](#1198)) ([ac73bdc](ac73bdc))
* **Css Utility:** DLT-2715 add default color for border css utilities ([#874](#874)) ([71310ab](71310ab))
* **Dialtone Css, Dialtone Tokens, Dialtone Vue:** DLT-3197 DLT-3198 DLT-3199 DLT-3200 DLT-3201 DLT-3202 DLT-3203 DLT-3204 DLT-3205 DLT-3206 DLT-3207 DLT-3208 DLT-3209 DLT-3210 DLT-3211 token-stop utility classes, migration tooling, and documentation ([#1150](#1150)) ([6237b84](6237b84))
* **Dialtone Vue:** DLT-3225 migrate component size props to numeric ordinal scale ([#1157](#1157)) ([725bd41](725bd41))
* **Eslint Plugin Dialtone:** DLT-3047 physical-to-logical naming migration tooling ([#1163](#1163)) ([d94dc4b](d94dc4b))
* **Eslint Plugin Dialtone:** DLT-3227 DLT-3228 add deprecated-tshirt-sizes ESLint rule and migration codemod ([#1159](#1159)) ([21a011f](21a011f))
* **Filter Pill:** DLT-2704 create component ([#473](#473)) ([6267445](6267445))
* **Filter Pill:** DLT-2941 DtFilterPill improvements ([#1110](#1110)) ([23c5689](23c5689))
* **Focusgroup:** DLT-3285 add v-dt-focusgroup directive for declarative roving tabindex ([#1187](#1187)) ([e1ea074](e1ea074))
* **Focustrap:** DLT-3297 add v-dt-focustrap directive for declarative focus trapping ([#1195](#1195)) ([6ef9a21](6ef9a21))
* **Link,button:** DLT-3012 add underline prop ([#1059](#1059)) ([1cb91ea](1cb91ea))
* **Mode Directive, Mode Island:** DLT-3067 DLT-3078 DLT-3077 add `v-dt-mode` directive ([#1109](#1109)) ([f97efca](f97efca))
* **Segmented Control:** DLT-413 new component ([#1144](#1144)) ([ad4c6c3](ad4c6c3))
* **Split Button:** DLT-3257 add show-divider prop ([#1173](#1173)) ([5bef411](5bef411))
* **Style:** DLT-2976 update underline thickness and offset ([#1058](#1058)) ([1e56947](1e56947))
* **Tabs:** DLT-3114 add vertical orientation variant ([#1120](#1120)) ([3290a23](3290a23))
* **Tabs:** DLT-3162 add spread prop for horizontal distribution ([#1135](#1135)) ([6e7cd04](6e7cd04))
* **Text:** export text component from dialtone-vue ([757fdb7](757fdb7))
* **Text:** new vue component DLT-2864 DLT-2863 DLT-2862 ([#995](#995)) ([196ef8a](196ef8a))
* **Tokens:** DLT-1977 add high contrast design tokens and theme ([#938](#938)) ([a1c0457](a1c0457))
* **Tokens:** DLT-2767 exploratory shell themes ([#909](#909)) ([3afcf63](3afcf63))
* **Tokens:** DLT-2781 create color-assistive themes ([#921](#921)) ([a6cc397](a6cc397))
* **Tokens:** DLT-2802 DLT-2563 layered theming system and mode island component ([#945](#945)) ([5c72c6c](5c72c6c))
* **Tokens:** DLT-2937 introduce spacing and layout token systems ([#1045](#1045)) ([de23e12](de23e12))
* **Tokens:** update color ramps and consumer color migration tools DLT-3004 DLT-3005 DLT-3006 DLT-3007 DLT-3008 ([#1054](#1054)) ([28cb1de](28cb1de))
* **Typography, Tokens:** DLT-2856 DLT-2857 next typography system ([#994](#994)) ([d744e97](d744e97))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

no-visual-test Add this tag when the PR does not need visual testing

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants