Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

♻️ refactor(datepicker) #877

Merged
merged 100 commits into from
Sep 12, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
100 commits
Select commit Hold shift + click to select a range
b6a576f
Create PR for #695
hirsch88 May 16, 2023
bff938c
refactor: date-input draft
hirsch88 May 17, 2023
beec8a9
chore: update masks
hirsch88 May 22, 2023
08db357
chore: move files
hirsch88 May 23, 2023
2651b98
chore: revert datepicker changes
hirsch88 May 23, 2023
cb91221
chore: merge branch 'main' into refactor/issue-695
hirsch88 May 23, 2023
9b926d9
chore: add changeset
hirsch88 May 23, 2023
a2aeadd
chore: remove imask
hirsch88 May 23, 2023
b667243
chore: fix lint issue
hirsch88 May 23, 2023
699b4c0
chore: update structure
hirsch88 May 23, 2023
cd419a5
test: adjust test for github actions
hirsch88 May 23, 2023
ad3fbe0
feat(input-date): add new component
hirsch88 May 25, 2023
6c04ad9
feat(input-date): add new component
hirsch88 May 25, 2023
8a9da78
feat(input-date): add new component
hirsch88 May 25, 2023
4f5730c
feat(input-date): add new component
hirsch88 May 25, 2023
90d6586
chore: improve date util
hirsch88 May 29, 2023
ecf6280
refactor: masks
hirsch88 Jun 1, 2023
6925439
chore: add unit tests
hirsch88 Jun 1, 2023
f133f04
chore: add unit tests
hirsch88 Jun 1, 2023
efb9331
chore: add unit tests for date mask
hirsch88 Jun 1, 2023
714f3de
chore: improve initial value
hirsch88 Jun 1, 2023
f3282b0
test: add visual
hirsch88 Jun 1, 2023
05d5d41
chore: fix lint issue
hirsch88 Jun 1, 2023
d4bf37c
chore(): update base images
hirsch88 Jun 1, 2023
0b9e6b4
test: add cypress tests
hirsch88 Jun 1, 2023
2c27422
chore: update story
hirsch88 Jun 1, 2023
b3a992c
Merge branch 'main' into refactor/date-input
hirsch88 Jul 3, 2023
e251059
chore: add shadow dom
hirsch88 Jul 3, 2023
31195d3
chore: improve mask logic
hirsch88 Jul 3, 2023
0c0e677
chore: adjust test lib for shadow dom
hirsch88 Jul 4, 2023
c052fbf
docs: update docs
hirsch88 Jul 4, 2023
afd44f3
chore: add first date calendar draft
hirsch88 Jul 4, 2023
4d9d899
chore: add progress
hirsch88 Jul 6, 2023
40723fb
feat(date): update calendar
hirsch88 Jul 24, 2023
a9c17d0
chore: update test and use bem
hirsch88 Jul 26, 2023
bbd119d
chore: remove fullscreen
hirsch88 Jul 26, 2023
88f4a6b
chore: format files
hirsch88 Jul 26, 2023
f032f1c
test: adjust component test
hirsch88 Jul 26, 2023
a4ff41a
test: adjust testing lib test
hirsch88 Jul 26, 2023
38f3622
chore(): update base images
hirsch88 Jul 26, 2023
711cbbd
chore: trigger build
hirsch88 Jul 26, 2023
1bb8275
chore: refactor calendar
hirsch88 Jul 27, 2023
fa71936
chore: add swipe
hirsch88 Jul 27, 2023
699af86
chore: format file
hirsch88 Aug 2, 2023
e2be494
chore: refactor swipe and render
hirsch88 Aug 2, 2023
4ab795e
chore(): update base images
hirsch88 Aug 2, 2023
8e0fabb
chore: fix cypress types
hirsch88 Aug 2, 2023
4c3886b
chore: adjust test
hirsch88 Aug 2, 2023
88ac852
chore: add popup
hirsch88 Aug 2, 2023
7d1b879
chore: adjust style
hirsch88 Aug 2, 2023
b226971
chore: add missing events
hirsch88 Aug 2, 2023
3618166
chore: adjust last edge cases
hirsch88 Aug 3, 2023
f7482c6
test: add a11y and component test for bal-date
hirsch88 Aug 8, 2023
6570fb8
chore: update tags
hirsch88 Aug 8, 2023
3eb4ce2
chore: add missing props, event and methods
hirsch88 Aug 8, 2023
54c50e1
chore: add missing props, event and methods
hirsch88 Aug 8, 2023
4a41b3d
chore: fix spell and test
hirsch88 Aug 8, 2023
fab534b
chore: adjust color of icons in shadow and outside
hirsch88 Aug 8, 2023
10accf1
test: adjust import statement
hirsch88 Aug 8, 2023
7767121
chore: fix i18n export
hirsch88 Aug 8, 2023
04e0cda
chore(): update base images
hirsch88 Aug 8, 2023
56b86a1
chore: trigger build
hirsch88 Aug 8, 2023
53be037
chore: merge branch 'main' into refactor/issue-695
hirsch88 Aug 17, 2023
6f79eb4
chore: merge branch 'main' into refactor/issue-695
hirsch88 Aug 17, 2023
2ddfebe
chore: update test lib
hirsch88 Aug 17, 2023
3c137e9
chore: format files
hirsch88 Aug 17, 2023
2c2706a
chore: add missing script
hirsch88 Aug 17, 2023
0528c1a
Merge branch 'main' into refactor/issue-695
hirsch88 Aug 21, 2023
af12d49
chore: remove shadow dom
hirsch88 Aug 21, 2023
bcfb4e8
chore: fix component tests
hirsch88 Aug 22, 2023
ada67b0
chore: fix component tests
hirsch88 Aug 22, 2023
4ebec1c
chore: add angular e2e test
hirsch88 Aug 22, 2023
a5cf8a9
chore(): update base images
hirsch88 Aug 22, 2023
21bc57b
chore: adjust visual reporting
hirsch88 Aug 22, 2023
233ef0b
chore: fix unit test
hirsch88 Aug 22, 2023
ee5dda0
chore: fix locale
hirsch88 Aug 22, 2023
8aef078
chore: update visual
hirsch88 Aug 22, 2023
a6fb745
chore: update visual 2
hirsch88 Aug 22, 2023
def5b59
chore: update visual 3
hirsch88 Aug 22, 2023
9f2214a
chore: move back
hirsch88 Aug 22, 2023
cf1507c
chore: move back
hirsch88 Aug 22, 2023
bca6c70
chore: force build
hirsch88 Aug 22, 2023
60db491
chore: adjust cypress helpers
hirsch88 Aug 22, 2023
5c984e3
chore: adjust mask blur event
hirsch88 Aug 22, 2023
887d625
chore: remove not needed class
hirsch88 Aug 22, 2023
8d5c589
chore: update docs
hirsch88 Aug 22, 2023
e1fcba7
chore: fix blur event
hirsch88 Aug 22, 2023
6cc71f3
chore: format file
hirsch88 Aug 22, 2023
0c26894
chore: fix change event
hirsch88 Aug 22, 2023
fa9eaaf
chore(): update base images
hirsch88 Aug 22, 2023
a9b5eb0
chore: update test
hirsch88 Aug 23, 2023
a439e58
chore: adjust testing wrappers
hirsch88 Aug 23, 2023
85532f3
chore: disable today test
hirsch88 Aug 23, 2023
6fe72d3
chore: fix safari bug
hirsch88 Aug 23, 2023
0395c1f
chore: fix range selections
hirsch88 Aug 23, 2023
603a512
chore: fix safari focus issue
hirsch88 Aug 24, 2023
9eb7805
chore: adjust component test
hirsch88 Aug 24, 2023
b0596db
chore: merge branch 'main' into refactor/issue-695
hirsch88 Sep 12, 2023
3e46f23
chore: adjust background
hirsch88 Sep 12, 2023
921400a
chore: adjust docs
hirsch88 Sep 12, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .build/data/tags.json
Original file line number Diff line number Diff line change
@@ -1 +1 @@
["bal-accordion","bal-app","bal-badge","bal-button","bal-card","bal-carousel","bal-checkbox","bal-close","bal-content","bal-data","bal-datepicker","bal-divider","bal-field","bal-file-upload","bal-footer","bal-form","bal-heading","bal-hint","bal-icon","bal-input","bal-label","bal-list","bal-logo","bal-modal","bal-navbar","bal-notification","bal-number-input","bal-pagination","bal-popover","bal-progress-bar","bal-radio","bal-select","bal-shape","bal-sheet","bal-snackbar","bal-spinner","bal-stack","bal-stage","bal-step-item","bal-steps","bal-table","bal-tabs","bal-tag","bal-text","bal-time-input","bal-toast","bal-tooltip"]
["bal-accordion","bal-app","bal-badge","bal-button","bal-card","bal-carousel","bal-checkbox","bal-close","bal-content","bal-data","bal-date","bal-divider","bal-field","bal-file-upload","bal-footer","bal-form","bal-heading","bal-hint","bal-icon","bal-input","bal-label","bal-list","bal-logo","bal-modal","bal-navbar","bal-notification","bal-number-input","bal-pagination","bal-popover","bal-progress-bar","bal-radio","bal-select","bal-shape","bal-sheet","bal-snackbar","bal-spinner","bal-stack","bal-stage","bal-step-item","bal-steps","bal-table","bal-tabs","bal-tag","bal-text","bal-time-input","bal-toast","bal-tooltip"]
5 changes: 5 additions & 0 deletions .changeset/quiet-poets-happen.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@baloise/design-system-components': minor
---

Enhance the newly refactored `bal-date` components. `bal-datepicker` is marked as deprecated.
2 changes: 1 addition & 1 deletion .github/workflows/actions/test-e2e/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,5 +26,5 @@ runs:
uses: actions/upload-artifact@v3
if: failure()
with:
name: cypress-snapshots-components-${{ strategy.job-index }}
name: cypress-snapshots-e2e-${{ strategy.job-index }}
path: test/cypress/snapshots
9 changes: 9 additions & 0 deletions .github/workflows/continuous.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ jobs:
build:
name: 👷 Build Design System
runs-on: ubuntu-latest
timeout-minutes: 15
env:
HUSKY: 0
steps:
Expand All @@ -29,6 +30,7 @@ jobs:
docs:
name: 📝 Build Documentation
runs-on: ubuntu-latest
timeout-minutes: 15
env:
HUSKY: 0
steps:
Expand All @@ -41,6 +43,7 @@ jobs:
format:
name: 🚨 Verify Code Format
runs-on: ubuntu-latest
timeout-minutes: 15
env:
HUSKY: 0
steps:
Expand All @@ -53,6 +56,7 @@ jobs:
spell:
name: 🚨 Spell Checking
runs-on: ubuntu-latest
timeout-minutes: 15
env:
HUSKY: 0
steps:
Expand All @@ -65,6 +69,7 @@ jobs:
lint:
name: 🚨 Analyze Code
runs-on: ubuntu-latest
timeout-minutes: 15
env:
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
Expand All @@ -80,6 +85,7 @@ jobs:
test:
name: 🧪 Unit Tests
runs-on: ubuntu-latest
timeout-minutes: 15
env:
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
Expand All @@ -95,6 +101,7 @@ jobs:
test-components:
name: 🧪 Component Tests
runs-on: ubuntu-22.04
timeout-minutes: 30
env:
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
Expand All @@ -112,6 +119,7 @@ jobs:
test-angular:
name: 🧪 Angular Tests
runs-on: ubuntu-22.04
timeout-minutes: 30
env:
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
Expand All @@ -129,6 +137,7 @@ jobs:
test-e2e:
name: 🧪 E2E Tests
runs-on: ubuntu-22.04
timeout-minutes: 30
env:
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
Expand Down
1 change: 0 additions & 1 deletion CHANGELOG_NEXT.md
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,6 @@ See [Conventional Commits](https://conventionalcommits.org) for commit guideline

## [10.24.0](https://github.com/baloise/design-system/compare/v10.23.3...v10.24.0) (2022-09-30)


### Features

* **list:** synchronices the accrodion bodies is set ([f6bd2e5](https://github.com/baloise/design-system/commit/f6bd2e57cba71983bf97abd11d3541db75c6ea39))
Expand Down
1 change: 0 additions & 1 deletion CHANGELOG_v12.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,6 @@ Follow the migration guide [Migration from 11.x to 12.x](https://baloise-design-

## [11.0.15](https://github.com/baloise/design-system/compare/v11.0.14...v11.0.15) (2022-11-29)


### Bug Fixes

* **bal-radio:** change link color to inverted when selected ([f1068ed](https://github.com/baloise/design-system/commit/f1068edeb069c048853a32e73a1f0e8db215ccec))
Expand Down
40 changes: 40 additions & 0 deletions apps/angular/cypress/e2e/bal-datepicker.spec.cy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
describe('bal-datepicker', () => {
beforeEach(() => {
cy.visit('/').platform('desktop').waitForDesignSystem()
})
it('should change value', () => {
cy.getByLabelText('Datepicker Label')
.should('have.value', '09.09.2023')
.clear()
.click()
.blur()
.shouldBeInvalid()
.getDescribingElement()
.contains('This field is required')

cy.getByPlaceholder('Pick a date')
.type('20.02.2024')
.blur()
.should('have.value', '20.02.2024')
.shouldBeValid()
.getDescribingElement()
.should('not.contain', 'This field is required')

cy.get('body').type('{esc}')

cy.getByRole('button', { name: 'Update Datepicker' }).click()
cy.getByPlaceholder('Pick a date')
.should('have.value', '21.10.2023')
.shouldBeValid()
.getDescribingElement()
.should('not.contain', 'This field is required')

cy.getByRole('button', { name: 'Disable Datepicker' }).click()
cy.getByPlaceholder('Pick a date').should('be.disabled')

cy.getByRole('button', { name: 'Enable Datepicker' }).click()
cy.getByPlaceholder('Pick a date').should('not.be.disabled')

cy.getByTestId('result').contains('"datepicker": "2023-10-21"')
})
})
40 changes: 40 additions & 0 deletions apps/angular/cypress/e2e/bal-input-date.spec.cy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
describe('bal-input-date', () => {
beforeEach(() => {
cy.visit('/').platform('desktop').waitForDesignSystem()
})
it('should change value', () => {
cy.getByLabelText('Input Date Label')
.should('have.value', '09.09.2023')
.clear()
.click()
.blur()
.shouldBeInvalid()
.getDescribingElement()
.contains('This field is required')

cy.getByPlaceholder('Type a date')
.type('20.02.2024')
.blur()
.should('have.value', '20.02.2024')
.shouldBeValid()
.getDescribingElement()
.should('not.contain', 'This field is required')

cy.get('body').type('{esc}')

cy.getByRole('button', { name: 'Update Input Date' }).click()
cy.getByPlaceholder('Type a date')
.should('have.value', '21.10.2023')
.shouldBeValid()
.getDescribingElement()
.should('not.contain', 'This field is required')

cy.getByRole('button', { name: 'Disable Input Date' }).click()
cy.getByPlaceholder('Type a date').should('be.disabled')

cy.getByRole('button', { name: 'Enable Input Date' }).click()
cy.getByPlaceholder('Type a date').should('not.be.disabled')

cy.getByTestId('result').contains('"inputDate": "2023-10-21"')
})
})
5 changes: 0 additions & 5 deletions apps/angular/cypress/fixtures/example.json

This file was deleted.

153 changes: 6 additions & 147 deletions apps/angular/cypress/support/commands.ts
Original file line number Diff line number Diff line change
@@ -1,152 +1,11 @@
/// <reference types="cypress" />

import '@baloise/design-system-testing/src/add-custom-commands'
import { checkAriaLabel, log, wrapOptions } from './helpers'

declare global {
namespace Cypress {
interface GetByRoleOptions {
name?: string
hidden?: boolean
}
// declare global {
// namespace Cypress {

interface Chainable {
getControl(labelText: string, options?: Partial<Loggable & Timeoutable & Withinable & Shadow>): Chainable<void>
getDescribingElement(options?: Partial<Loggable & Timeoutable & Withinable & Shadow>): Chainable<void>
shouldBeInvalid(options?: Partial<Loggable & Timeoutable & Withinable & Shadow>): Chainable<void>
shouldBeValid(options?: Partial<Loggable & Timeoutable & Withinable & Shadow>): Chainable<void>
getByLabelText(
labelText: string,
options?: Partial<Loggable & Timeoutable & Withinable & Shadow>,
): Chainable<void>
getByPlaceholder(
placeholder: string,
options?: Partial<Loggable & Timeoutable & Withinable & Shadow>,
): Chainable<JQuery>
getByRole(
role: 'button' | 'label',
options: GetByRoleOptions & Partial<Loggable & Timeoutable & Withinable & Shadow>,
): Chainable<JQuery>
}
}
}

Cypress.Commands.add('getDescribingElement', { prevSubject: true }, (subject, options?: Partial<Cypress.Loggable>) => {
const o = wrapOptions(options)
return cy.wrap(subject, o).then(subjectElement => {
const ariaDescribedBy = subjectElement.attr('aria-describedby')
if (ariaDescribedBy) {
return cy
.get(`[id="${ariaDescribedBy}"]`, o)
.then(o, $el => log('-getDescribingElement', ariaDescribedBy, $el, options))
} else {
throw new Error(`The subject element does not have an aria-describedby attribute.`)
}
})
})

Cypress.Commands.add('shouldBeInvalid', { prevSubject: true }, (subject, options) => {
const o = wrapOptions(options)
return cy.wrap(subject, o).should('have.attr', 'aria-invalid', 'true')
})

Cypress.Commands.add('shouldBeValid', { prevSubject: true }, (subject, options) => {
const o = wrapOptions(options)
return cy.wrap(subject, o).should('not.have.attr', 'aria-invalid', 'true')
})

Cypress.Commands.add('getByLabelText', { prevSubject: 'optional' }, (subject, labelText: string, options) => {
const o = wrapOptions(options)

if (subject) {
return cy
.wrap(subject, o)
.contains('label', labelText, o)
.invoke(o, 'attr', 'for')
.then(forAttributeValue => {
return cy.get(`input[id="${forAttributeValue}"], textarea[id="${forAttributeValue}"]`, o)
})
.then(o, $el => log(!!subject ? '-getByLabelText' : 'getByLabelText', labelText, $el, options))
}

return cy
.contains('label', labelText, o)
.invoke(o, 'attr', 'for')
.then(forAttributeValue => {
return cy.get(`input[id="${forAttributeValue}"], textarea[id="${forAttributeValue}"]`, o)
})
.then(o, $el => log(!!subject ? '-getByLabelText' : 'getByLabelText', labelText, $el, options))
})

Cypress.Commands.add(
'getByPlaceholder',
{
prevSubject: 'optional',
},
(subject, placeholder, options?: Partial<Cypress.Loggable>) => {
const o = wrapOptions(options)

const element = subject
? cy
.wrap(subject, o)
.find(`input[placeholder="${placeholder}"], textarea[placeholder="${placeholder}"]`, o)
.waitForComponents(o)
: cy.get(`input[placeholder="${placeholder}"], textarea[placeholder="${placeholder}"]`, o).waitForComponents(o)

element.then(o, $el => log(!!subject ? '-getByPlaceholder' : 'getByPlaceholder', placeholder, $el, options))
return element
},
)

Cypress.Commands.add(
'getByRole',
{
prevSubject: 'optional',
},
(subject, role, options) => {
const o = wrapOptions(options)

function findElements() {
return subject ? cy.wrap(subject, o).find(`${role}, [role="${role}"]`, o) : cy.get(`${role}, [role="${role}"]`, o)
}

function filterVisibleElements(elements) {
return elements.filter((_index, element) => {
const isElementAriaHidden = options.hidden === true ? false : !!Cypress.$(element).attr('aria-hidden')
return !isElementAriaHidden
}, o)
}

function filterLabeling(elements) {
return elements.filter((_index, element) => checkAriaLabel(element, options.name), o)
}

const elements = findElements()
const visibleElements = filterVisibleElements(elements)
const labeledElements = filterLabeling(visibleElements)
const firstElement = labeledElements.first(o).waitForComponents(o)
firstElement.then(o, $el =>
log(!!subject ? '-getByRole' : 'getByRole', `${role} ${JSON.stringify(options)}`, $el, options),
)
return firstElement
},
)

Cypress.Commands.add(
'getControl',
{
prevSubject: true,
},
(subject, labelText, options) => {
const o = wrapOptions(options)

const clearedLabelText = `${labelText || ''}`.trim()

return cy
.wrap(subject, o)
.invoke(o, 'attr', 'id')
.then(id => cy.get(`button[aria-controls="${id}"]`, o))
.filter((_index, element) => checkAriaLabel(element, clearedLabelText), o)
.then(o, $el => log('-getControl', `${labelText}`, $el, options))
},
)
// interface Chainable {
// }
// }
// }
Loading