diff --git a/.changeset/clever-trees-sort.md b/.changeset/clever-trees-sort.md
new file mode 100644
index 0000000000..f90d1b40aa
--- /dev/null
+++ b/.changeset/clever-trees-sort.md
@@ -0,0 +1,5 @@
+---
+"@justeattakeaway/pie-button": minor
+---
+
+[Changed] - Styling allowing for text-overflow in buttons
diff --git a/packages/components/pie-button/src/button.scss b/packages/components/pie-button/src/button.scss
index c0b701d491..917c5a3c31 100644
--- a/packages/components/pie-button/src/button.scss
+++ b/packages/components/pie-button/src/button.scss
@@ -32,12 +32,6 @@ $breakpoint-wide: 768px;
// currently this sets the primary button styles
--btn-bg-color: var(--dt-color-interactive-brand);
--btn-text-color: var(--dt-color-content-interactive-primary);
-
- // Heights for the different button sizes
- --btn-height--xsmall: 32px;
- --btn-height--small: 40px;
- --btn-height--medium: 48px;
- --btn-height--large: 56px;
--icon-display-override: block;
/**
@@ -46,31 +40,26 @@ $breakpoint-wide: 768px;
*/
@mixin button-size($size) {
@if $size == 'xsmall' {
- --btn-height: var(--btn-height--xsmall);
--btn-padding: 6px var(--dt-spacing-b);
--btn-font-size: #{p.font-size(--dt-font-size-14)};
--btn-line-height: calc(var(--dt-font-size-14-line-height) * 1px);
--icon-size-override: 16px;
} @else if $size == 'small-expressive' {
- --btn-height: var(--btn-height--small);
--btn-padding: 6px var(--dt-spacing-d);
--btn-font-size: #{p.font-size(--dt-font-size-20)};
--btn-line-height: calc(var(--dt-font-size-20-line-height) * 1px);
--icon-size-override: 20px;
} @else if $size == 'small-productive' {
- --btn-height: var(--btn-height--small);
--btn-padding: 8px var(--dt-spacing-d);
--btn-font-size: #{p.font-size(--dt-font-size-16)};
--btn-line-height: calc(var(--dt-font-size-16-line-height) * 1px);
--icon-size-override: 20px;
} @else if $size == 'medium' {
- --btn-height: var(--btn-height--medium);
--btn-padding: 10px var(--dt-spacing-e);
--btn-font-size: #{p.font-size(--dt-font-size-20)};
--btn-line-height: calc(var(--dt-font-size-20-line-height) * 1px);
--icon-size-override: 24px;
} @else if $size == 'large' {
- --btn-height: var(--btn-height--large);
--btn-padding: 14px var(--dt-spacing-e);
--btn-font-size: #{p.font-size(--dt-font-size-20)};
--btn-line-height: calc(var(--dt-font-size-20-line-height) * 1px);
@@ -84,7 +73,6 @@ $breakpoint-wide: 768px;
align-items: center;
justify-content: center;
box-sizing: border-box;
- height: var(--btn-height);
padding: var(--btn-padding);
border: none;
border-radius: var(--btn-border-radius);
@@ -253,6 +241,14 @@ $breakpoint-wide: 768px;
}
}
+// The inner span for the button text is needed to handle the text-overflow
+// Without this, single word overflow wouldn't be possible in combination
+// with display: flex.
+.o-btn-text {
+ text-overflow: ellipsis;
+ overflow: hidden;
+}
+
// Used to size an SVG if one is passed in (when not using the component icons)
::slotted(svg) {
height: var(--icon-size-override);
diff --git a/packages/components/pie-button/src/index.ts b/packages/components/pie-button/src/index.ts
index 5c8a74342d..0b8f4a0cfa 100644
--- a/packages/components/pie-button/src/index.ts
+++ b/packages/components/pie-button/src/index.ts
@@ -240,7 +240,7 @@ export class PieButton extends FormControlMixin(LitElement) implements ButtonPro
?isLoading=${isLoading}>
${isLoading ? this.renderSpinner() : nothing}
${iconPlacement === 'leading' ? html`` : nothing}
-
+
${iconPlacement === 'trailing' ? html`` : nothing}
`;
}