Skip to content

Commit

Permalink
fix: setting title when textfield is invalid
Browse files Browse the repository at this point in the history
  • Loading branch information
TheMcMurder authored and Westbrook committed Jul 28, 2023
1 parent 6be9a5f commit 36d0537
Show file tree
Hide file tree
Showing 2 changed files with 77 additions and 1 deletion.
2 changes: 2 additions & 0 deletions packages/textfield/src/Textfield.ts
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,7 @@ export class TextfieldBase extends ManageHelpText(
minlength=${ifDefined(
this.minlength > -1 ? this.minlength : undefined
)}
title=${this.invalid ? '' : nothing}
pattern=${ifDefined(this.pattern)}
placeholder=${this.placeholder}
.value=${this.displayValue}
Expand Down Expand Up @@ -276,6 +277,7 @@ export class TextfieldBase extends ManageHelpText(
this.placeholder}
aria-invalid=${ifDefined(this.invalid || undefined)}
class="input"
title=${this.invalid ? '' : nothing}
maxlength=${ifDefined(
this.maxlength > -1 ? this.maxlength : undefined
)}
Expand Down
76 changes: 75 additions & 1 deletion packages/textfield/test/textfield.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,9 @@ describe('Textfield', () => {

const boundsDefaultElement = defaultTextarea?.getBoundingClientRect();
const boundsOneRowElement = oneRowTextarea?.getBoundingClientRect();
expect(boundsDefaultElement?.height).to.be.greaterThan(boundsOneRowElement?.height ?? 0);
expect(boundsDefaultElement?.height).to.be.greaterThan(
boundsOneRowElement?.height ?? 0
);
});
it('multiline with rows does not resize', async () => {
const el = await litFixture<Textfield>(
Expand Down Expand Up @@ -429,6 +431,41 @@ describe('Textfield', () => {
: null;
expect(input).to.not.be.null;
});
it('valid - boundary-type assertions and title', async () => {
const el = await litFixture<Textfield>(
html`
<sp-textfield
placeholder="Enter your number"
pattern="^[\\d]+$"
value="123"
></sp-textfield>
`
);
await elementUpdated(el);

expect(el).to.not.equal(undefined);
const input = el.shadowRoot.querySelector('#valid');
expect(input).to.not.be.null;
expect(el.focusElement).to.not.have.attribute('title');
});
it('valid - multiline - boundary-type assertions and title', async () => {
const el = await litFixture<Textfield>(
html`
<sp-textfield
multiline
placeholder="Enter your number"
pattern="^[\\d]+$"
value="123"
></sp-textfield>
`
);
await elementUpdated(el);

expect(el).to.not.equal(undefined);
const input = el.shadowRoot.querySelector('#valid');
expect(input).to.not.be.null;
expect(el.focusElement).to.not.have.attribute('title');
});
it('valid - unicode', async () => {
const el = await litFixture<Textfield>(
html`
Expand Down Expand Up @@ -602,6 +639,43 @@ describe('Textfield', () => {
: null;
expect(input).to.not.be.null;
});
it('invalid - boundary-type assertions and title', async () => {
const el = await litFixture<Textfield>(
html`
<sp-textfield
placeholder="Enter your number"
type="url"
value="invalid-email"
invalid
></sp-textfield>
`
);
await elementUpdated(el);

expect(el).to.not.equal(undefined);
const input = el.shadowRoot.querySelector('#invalid');
expect(input).to.not.be.null;
expect(el.focusElement).to.have.attribute('title');
});
it('invalid - multiline - boundary-type assertions and title', async () => {
const el = await litFixture<Textfield>(
html`
<sp-textfield
multiline
placeholder="Enter your number"
type="url"
value="invalid-email"
invalid
></sp-textfield>
`
);
await elementUpdated(el);

expect(el).to.not.equal(undefined);
const input = el.shadowRoot.querySelector('#invalid');
expect(input).to.not.be.null;
expect(el.focusElement).to.have.attribute('title');
});
it('invalid - multiline - boundary-type assertions', async () => {
const el = await litFixture<Textfield>(
html`
Expand Down

0 comments on commit 36d0537

Please sign in to comment.