Skip to content

Commit

Permalink
update config
Browse files Browse the repository at this point in the history
  • Loading branch information
patrickpatrickpatrick committed Nov 19, 2024
1 parent 680fb18 commit 4d6727b
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 22 deletions.
8 changes: 4 additions & 4 deletions packages/govuk-frontend/src/govuk/common/configuration.mjs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { Component } from '../component.mjs'
import { ConfigError } from '../errors/index.mjs'
import { GOVUKFrontendComponent } from '../govuk-frontend-component.mjs'

import { isObject, formatErrorMessage } from './index.mjs'

Expand All @@ -13,9 +13,9 @@ export const configOverride = Symbol.for('configOverride')
* @virtual
* @template {ObjectNested} [ConfigurationType={}]
* @template {Element & { dataset: DOMStringMap }} [RootElementType=HTMLElement]
* @augments GOVUKFrontendComponent<RootElementType>
* @augments Component<RootElementType>
*/
export class GOVUKFrontendComponentConfigurable extends GOVUKFrontendComponent {
export class ConfigurableComponent extends Component {
/**
* configOverride
*
Expand Down Expand Up @@ -354,5 +354,5 @@ export function extractConfigByNamespace(schema, dataset, namespace) {

/**
* @template {ObjectNested} [ConfigurationType={}]
* @typedef {typeof GOVUKFrontendComponent & ChildClass<ConfigurationType>} ChildClassConstructor<ConfigurationType>
* @typedef {typeof Component & ChildClass<ConfigurationType>} ChildClassConstructor<ConfigurationType>
*/
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
import { ConfigError } from '../../errors/index.mjs'
import {
GOVUKFrontendComponentConfigurable,
configOverride
} from '../configuration.mjs'
import { ConfigurableComponent, configOverride } from '../configuration.mjs'

describe('GOVUKFrontendComponentConfigurable', () => {
beforeEach(() => {
Expand All @@ -18,23 +15,23 @@ describe('GOVUKFrontendComponentConfigurable', () => {

describe('throws error', () => {
it('if no schema defined', () => {
class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
static moduleName = 'config-component'

static defaults = {
randomAttribute: 0
}
}

expect(() => new ConfigurableComponent(document.body)).toThrow(
expect(() => new MockConfigurableComponent(document.body)).toThrow(
new ConfigError(
'config-component: Config passed as parameter into constructor but no schema defined'
)
)
})

it('if no defaults defined', () => {
class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
static moduleName = 'config-component'

static schema = {
Expand All @@ -44,7 +41,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {
}
}

expect(() => new ConfigurableComponent(document.body)).toThrow(
expect(() => new MockConfigurableComponent(document.body)).toThrow(
new ConfigError(
'config-component: Config passed as parameter into constructor but no defaults defined'
)
Expand All @@ -58,7 +55,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {
<div id="test-component"></div>
`

class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
static moduleName = 'config-component'

static schema = {
Expand All @@ -74,7 +71,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {

const testComponent = document.querySelector('#test-component')

const configComponent = new ConfigurableComponent(testComponent)
const configComponent = new MockConfigurableComponent(testComponent)

expect(configComponent._config).toMatchObject({ randomAttribute: 0 })
})
Expand All @@ -84,7 +81,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {
<div id="test-component" data-random-attribute="42"></div>
`

class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
static moduleName = 'config-component'

static schema = {
Expand All @@ -100,7 +97,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {

const testComponent = document.querySelector('#test-component')

const configComponent = new ConfigurableComponent(testComponent)
const configComponent = new MockConfigurableComponent(testComponent)

expect(configComponent._config).toMatchObject({ randomAttribute: 42 })
})
Expand All @@ -110,7 +107,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {
<div id="test-component"></div>
`

class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
static moduleName = 'config-component'

static schema = {
Expand All @@ -126,7 +123,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {

const testComponent = document.querySelector('#test-component')

const configComponent = new ConfigurableComponent(testComponent, {
const configComponent = new MockConfigurableComponent(testComponent, {
randomAttribute: 100
})

Expand All @@ -138,7 +135,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {
<div id="test-component" data-random-attribute="12"></div>
`

class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
static moduleName = 'config-component'

static schema = {
Expand All @@ -154,7 +151,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {

const testComponent = document.querySelector('#test-component')

const configComponent = new ConfigurableComponent(testComponent, {
const configComponent = new MockConfigurableComponent(testComponent, {
randomAttribute: 100
})

Expand All @@ -170,7 +167,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {
<div id="test-component" data-random-attribute="13"></div>
`

class ConfigurableComponent extends GOVUKFrontendComponentConfigurable {
class MockConfigurableComponent extends ConfigurableComponent {
[configOverride](config) {
return configOverrideFunction(config)
}
Expand All @@ -190,7 +187,7 @@ describe('GOVUKFrontendComponentConfigurable', () => {

const testComponent = document.querySelector('#test-component')

const configComponent = new ConfigurableComponent(testComponent, {
const configComponent = new MockConfigurableComponent(testComponent, {
randomAttribute: '14'
})

Expand Down

0 comments on commit 4d6727b

Please sign in to comment.