diff --git a/cypress/e2e/NewLexemeForm.cy.js b/cypress/e2e/NewLexemeForm.cy.js
index 9a5ef20f..b38b2bb1 100644
--- a/cypress/e2e/NewLexemeForm.cy.js
+++ b/cypress/e2e/NewLexemeForm.cy.js
@@ -66,13 +66,16 @@ describe( 'NewLexemeForm', () => {
cy.get( '.wbl-snl-language-lookup input' )
.type( '=Q123', { delay: 0 } );
checkA11y( '.wbl-snl-language-lookup' );
- cy.get( '.wbl-snl-language-lookup .wikit-OptionsMenu__item' ).click();
+ cy.get( 'li.cdx-menu-item' ).contains( 'No match was found' ).should( 'not.exist' );
+ checkA11y( '.wbl-snl-language-lookup' );
+ cy.get( '.wbl-snl-language-lookup .cdx-menu-item' ).click();
cy.wait( '@LanguageCodeRetrieval' );
cy.get( '.wbl-snl-lexical-category-lookup input' )
.type( '=Q456', { delay: 0 } );
- cy.get( '.wbl-snl-lexical-category-lookup .wikit-OptionsMenu__item' ).click();
+ cy.get( 'li.cdx-menu-item' ).contains( 'No match was found' ).should( 'not.exist' );
+ cy.get( '.wbl-snl-lexical-category-lookup .cdx-menu-item' ).click();
cy.get( '.wbl-snl-form' )
.submit();
@@ -99,17 +102,20 @@ describe( 'NewLexemeForm', () => {
cy.get( '.wbl-snl-language-lookup input' )
.type( '=Q123', { delay: 0 } );
- cy.get( '.wbl-snl-language-lookup .wikit-OptionsMenu__item' ).click();
+ cy.get( '.wbl-snl-language-lookup li.cdx-menu-item' ).contains( 'No match was found' ).should( 'not.exist' );
+ cy.get( '.wbl-snl-language-lookup .cdx-menu-item' ).click();
cy.get( '.wbl-snl-lexical-category-lookup input' )
.type( '=Q456', { delay: 0 } );
- cy.get( '.wbl-snl-lexical-category-lookup .wikit-OptionsMenu__item' ).click();
+ cy.get( '.wbl-snl-lexical-category-lookup li.cdx-menu-item' ).contains( 'No match was found' ).should( 'not.exist' );
+ cy.get( '.wbl-snl-lexical-category-lookup .cdx-menu-item' ).click();
cy.wait( '@LanguageCodeRetrieval' );
cy.get( '.wbl-snl-spelling-variant-lookup input' )
.type( 'en-ca', { delay: 0 } );
- cy.get( '.wbl-snl-spelling-variant-lookup .wikit-OptionsMenu__item' ).click();
+ cy.get( '.wbl-snl-spelling-variant-lookup li.cdx-menu-item' ).contains( 'No match was found' ).should( 'not.exist' );
+ cy.get( '.wbl-snl-spelling-variant-lookup .cdx-menu-item' ).click();
cy.get( '.wbl-snl-form' )
.submit();
@@ -151,12 +157,12 @@ describe( 'NewLexemeForm', () => {
cy.get( '.wbl-snl-language-lookup input' ).click();
- cy.get( '.wbl-snl-language-lookup .wikit-OptionsMenu__item__label' )
+ cy.get( '.wbl-snl-language-lookup .cdx-menu-item__text__label' )
.then( ( $element ) => {
expect( $element ).to.have.text( 'test language' );
} );
- cy.get( '.wbl-snl-language-lookup .wikit-OptionsMenu__item__description' )
+ cy.get( '.wbl-snl-language-lookup .cdx-menu-item__text__description' )
.then( ( $element ) => {
expect( $element ).to.have.text( 'test language description' );
} );
diff --git a/src/components/ItemLookup.vue b/src/components/ItemLookup.vue
index ec67129d..b087ba5c 100644
--- a/src/components/ItemLookup.vue
+++ b/src/components/ItemLookup.vue
@@ -1,10 +1,20 @@
-
-
- {{ messages.getUnescaped( 'wikibase-entityselector-notfound' ) }}
+
+
+
+ {{ messages.getUnescaped( 'wikibase-entityselector-notfound' ) }}
+
+
+
+ {{ label }}
-
-
-
-
+
+
+
diff --git a/src/components/LanguageInput.vue b/src/components/LanguageInput.vue
index bab445d3..45b4f14f 100644
--- a/src/components/LanguageInput.vue
+++ b/src/components/LanguageInput.vue
@@ -5,17 +5,18 @@ import { useMessages } from '@/plugins/MessagesPlugin/Messages';
import ItemLookup from '@/components/ItemLookup.vue';
import RequiredAsterisk from '@/components/RequiredAsterisk.vue';
import { useLanguageItemSearch } from '@/plugins/ItemSearchPlugin/LanguageItemSearch';
-import { computed } from 'vue';
+import { computed, toRef } from 'vue';
import { useConfig } from '@/plugins/ConfigPlugin/Config';
+import { useModelWrapper } from '@wikimedia/codex';
interface Props {
modelValue: SearchedItemOption | null;
searchInput: string;
}
-defineProps();
+const props = defineProps();
-defineEmits<{
+const emit = defineEmits<{
( e: 'update:modelValue', modelValue: Props['modelValue'] ): void;
( e: 'update:searchInput', searchInput: Props['searchInput'] ): void;
}>();
@@ -45,6 +46,19 @@ const error = computed( () => {
};
} );
const config = useConfig();
+
+/**
+ * We want to pass the searchInput property from the parent component
+ * to the child component. The searchInput property comes in read-only
+ * and receives updates from the parent (it is a ref / computed value).
+ * Use the `useModelWrapper` helper here to turn the read-only property
+ * into a computed value that emits updates on change.
+ */
+const searchInputWrapper = useModelWrapper(
+ toRef( props, 'searchInput' ),
+ emit,
+ 'update:searchInput',
+);
-
-
- {{ messages.getUnescaped( 'wikibase-entityselector-notfound' ) }}
-
-
+ :status="fieldStatus"
+ :messages="errorMessages">
+
+
+ {{ messages.getUnescaped( 'wikibase-entityselector-notfound' ) }}
+
+
+
+ {{ messages.getUnescaped( 'wikibaselexeme-newlexeme-lemma-language' ) }}
{{ helpLinkText }}
-
+
diff --git a/tests/integration/NewLexemeForm.test.ts b/tests/integration/NewLexemeForm.test.ts
index 085a2305..0147b47e 100644
--- a/tests/integration/NewLexemeForm.test.ts
+++ b/tests/integration/NewLexemeForm.test.ts
@@ -70,13 +70,13 @@ describe( 'NewLexemeForm', () => {
async function selectLanguage( formWrapper: VueWrapper, input = '=Q123' ): Promise {
const languageInput = formWrapper.find( '.wbl-snl-language-lookup input' );
await languageInput.setValue( input );
- await formWrapper.find( '.wbl-snl-language-lookup .wikit-OptionsMenu__item' ).trigger( 'click' );
+ await formWrapper.find( '.wbl-snl-language-lookup .cdx-menu-item' ).trigger( 'click' );
}
async function selectLexicalCategory( formWrapper: VueWrapper, input = '=Q456' ): Promise {
const lexicalCategoryInput = formWrapper.find( '.wbl-snl-lexical-category-lookup input' );
await lexicalCategoryInput.setValue( input );
- await formWrapper.find( '.wbl-snl-lexical-category-lookup .wikit-OptionsMenu__item' ).trigger( 'click' );
+ await formWrapper.find( '.wbl-snl-lexical-category-lookup .cdx-menu-item' ).trigger( 'click' );
}
it( 'updates the store if something is entered into the lemma input', async () => {
@@ -100,7 +100,7 @@ describe( 'NewLexemeForm', () => {
const languageLookup = wrapper.find( '.wbl-snl-language-lookup input' );
await languageLookup.setValue( '=Q123' );
- await wrapper.find( '.wbl-snl-language-lookup .wikit-OptionsMenu__item' ).trigger( 'click' );
+ await wrapper.find( '.wbl-snl-language-lookup .cdx-menu-item' ).trigger( 'click' );
expect( wrapper.find( '.wbl-snl-spelling-variant-lookup' ).exists() ).toBe( false );
expect( store.state.language?.id ).toBe( 'Q123' );
@@ -132,7 +132,7 @@ describe( 'NewLexemeForm', () => {
expect( store.state.languageCodeFromLanguageItem ).toBe( false );
- const warning = wrapper.find( '.wikit-ValidationMessage--warning' );
+ const warning = wrapper.find( '.cdx-message--warning' );
expect( warning.exists() ).toBe( true );
} );
@@ -141,7 +141,7 @@ describe( 'NewLexemeForm', () => {
const lexicalCategoryInput = wrapper.find( '.wbl-snl-lexical-category-lookup input' );
await lexicalCategoryInput.setValue( '=Q456' );
- await wrapper.find( '.wbl-snl-lexical-category-lookup .wikit-OptionsMenu__item' ).trigger( 'click' );
+ await wrapper.find( '.wbl-snl-lexical-category-lookup .cdx-menu-item' ).trigger( 'click' );
expect( store.state.lexicalCategory?.id ).toBe( 'Q456' );
} );
@@ -169,7 +169,7 @@ describe( 'NewLexemeForm', () => {
await spellingVariantLookup.setValue( 'de' );
- await wrapper.find( '.wbl-snl-spelling-variant-lookup .wikit-OptionsMenu__item' ).trigger( 'click' );
+ await wrapper.find( '.wbl-snl-spelling-variant-lookup .cdx-menu-item' ).trigger( 'click' );
expect( store.state.spellingVariant ).toBe( 'de' );
} );
@@ -235,7 +235,7 @@ describe( 'NewLexemeForm', () => {
// will actually select en-gb, en is not in wikibaseLexemeTermLanguages
const spellingVariantInput = wrapper.find( '.wbl-snl-spelling-variant-lookup input' );
await spellingVariantInput.setValue( 'en' );
- await wrapper.find( '.wbl-snl-spelling-variant-lookup .wikit-OptionsMenu__item' ).trigger( 'click' );
+ await wrapper.find( '.wbl-snl-spelling-variant-lookup .cdx-menu-item' ).trigger( 'click' );
await wrapper.trigger( 'submit' );
await flushPromises();
@@ -339,11 +339,11 @@ describe( 'NewLexemeForm', () => {
await wrapper.trigger( 'submit' );
const lexicalCategoryInputWrapper = wrapper.get( '.wbl-snl-lexical-category-lookup' );
- expect( lexicalCategoryInputWrapper.get( '.wikit-ValidationMessage--error' ).text() )
+ expect( lexicalCategoryInputWrapper.get( '.cdx-message--error' ).text() )
.toBe( messagesPlugin.get( 'wikibaselexeme-newlexeme-lexicalcategory-empty-error' ) );
await lexicalCategoryInputWrapper.get( 'input' ).setValue( '=Q456' );
- await lexicalCategoryInputWrapper.find( '.wikit-OptionsMenu__item' ).trigger( 'click' );
- expect( lexicalCategoryInputWrapper.find( '.wikit-ValidationMessage--error' ).exists() ).toBe( false );
+ await lexicalCategoryInputWrapper.find( '.cdx-menu-item' ).trigger( 'click' );
+ expect( lexicalCategoryInputWrapper.find( '.cdx-message--error' ).exists() ).toBe( false );
expect( createLexeme ).not.toHaveBeenCalled();
} );
@@ -369,14 +369,14 @@ describe( 'NewLexemeForm', () => {
await wrapper.trigger( 'submit' );
const languageInputWrapper = wrapper.get( '.wbl-snl-language-lookup' );
- expect( languageInputWrapper.get( '.wikit-ValidationMessage--error' ).text() )
+ expect( languageInputWrapper.get( '.cdx-message--error' ).text() )
.toBe( messagesPlugin.get( 'wikibaselexeme-newlexeme-language-empty-error' ) );
await languageInputWrapper.get( 'input' ).setValue( '=Q123' );
- await languageInputWrapper.find( '.wikit-OptionsMenu__item' ).trigger( 'click' );
+ await languageInputWrapper.find( '.cdx-menu-item' ).trigger( 'click' );
await flushPromises();
- expect( languageInputWrapper.find( '.wikit-ValidationMessage--error' ).exists() ).toBe( false );
+ expect( languageInputWrapper.find( '.cdx-message--error' ).exists() ).toBe( false );
expect( createLexeme ).not.toHaveBeenCalled();
} );
@@ -406,13 +406,13 @@ describe( 'NewLexemeForm', () => {
await wrapper.trigger( 'submit' );
const spellingVariantInputWrapper = wrapper.get( '.wbl-snl-spelling-variant-lookup' );
- expect( spellingVariantInputWrapper.get( '.wikit-ValidationMessage--error' ).text() )
+ expect( spellingVariantInputWrapper.get( '.cdx-message--error' ).text() )
.toBe( messagesPlugin.get( 'wikibaselexeme-newlexeme-lemma-language-empty-error' ) );
await spellingVariantInputWrapper.get( 'input' ).setValue( 'en' );
- await spellingVariantInputWrapper.get( '.wikit-OptionsMenu__item' ).trigger( 'click' );
+ await spellingVariantInputWrapper.get( '.cdx-menu-item' ).trigger( 'click' );
- expect( spellingVariantInputWrapper.find( '.wikit-ValidationMessage--error' ).exists() ).toBe( false );
+ expect( spellingVariantInputWrapper.find( '.cdx-message--error' ).exists() ).toBe( false );
expect( createLexeme ).not.toHaveBeenCalled();
} );
diff --git a/tests/unit/components/ItemLookup.test.ts b/tests/unit/components/ItemLookup.test.ts
index 0c24afbf..ccf79ffc 100644
--- a/tests/unit/components/ItemLookup.test.ts
+++ b/tests/unit/components/ItemLookup.test.ts
@@ -3,7 +3,7 @@ import {
mount,
VueWrapper,
} from '@vue/test-utils';
-import { Lookup as WikitLookup } from '@wmde/wikit-vue-components';
+import { CdxLookup } from '@wikimedia/codex';
jest.mock( 'lodash/debounce', () => jest.fn( ( fn ) => fn ) );
@@ -103,7 +103,7 @@ describe( 'ItemLookup', () => {
const lookup = createLookup( { searchForItems } );
await setSearchInput( lookup, 'foo' );
- await lookup.findComponent( WikitLookup ).vm.$emit( 'scroll' );
+ await lookup.findComponent( CdxLookup ).vm.$emit( 'load-more' );
expect( searchForItems ).toHaveBeenCalledTimes( 2 );
expect( searchForItems ).toHaveBeenNthCalledWith( 2, 'foo', 4 );
@@ -113,11 +113,11 @@ describe( 'ItemLookup', () => {
const searchForItems = jest.fn().mockReturnValue( exampleSearchResults );
const lookup = createLookup( { searchForItems } );
await setSearchInput( lookup, 'foo' );
- const selectedItemId = 1;
+ const selectedItemId = 0;
- await lookup.setProps( { value: exampleSearchResults[ selectedItemId ] } );
+ await lookup.setProps( { inputValue: exampleSearchResults[ selectedItemId ] } );
- expect( lookup.findComponent( WikitLookup ).props().value.label )
+ expect( lookup.find( 'div.cdx-text-input' ).get( 'input' ).element.value )
.toBe( exampleSearchResults[ selectedItemId ].display.label?.value );
} );
@@ -134,7 +134,7 @@ describe( 'ItemLookup', () => {
searchForItems,
} );
- expect( lookup.findComponent( WikitLookup ).props().menuItems )
+ expect( lookup.findComponent( CdxLookup ).props().menuItems )
.toStrictEqual( [ {
value: 'Q1',
label: 'some label',
@@ -143,14 +143,14 @@ describe( 'ItemLookup', () => {
expect( searchForItems ).not.toHaveBeenCalled();
} );
- it( ':searchForItems - returned suggestions are provided to Wikit Lookup', async () => {
+ it( ':searchForItems - returned suggestions are provided to Codex Lookup', async () => {
const searchForItems = jest.fn().mockReturnValue( exampleSearchResults );
const lookup = createLookup( { searchForItems } );
await setSearchInput( lookup, 'foo' );
- const wikitLookup = lookup.getComponent( WikitLookup );
- expect( wikitLookup.props( 'menuItems' ) ).toStrictEqual( [
+ const codexLookup = lookup.getComponent( CdxLookup );
+ expect( codexLookup.props( 'menuItems' ) ).toStrictEqual( [
{
description: 'bar',
label: 'foo',
@@ -237,8 +237,8 @@ describe( 'ItemLookup', () => {
await setSearchInput( lookup, 'foo' );
- const wikitLookup = lookup.getComponent( WikitLookup );
- expect( wikitLookup.props( 'menuItems' ) ).toStrictEqual( [
+ const codexLookup = lookup.getComponent( CdxLookup );
+ expect( codexLookup.props( 'menuItems' ) ).toStrictEqual( [
// suggestions
{
description: '',
@@ -263,16 +263,6 @@ describe( 'ItemLookup', () => {
},
] );
} );
-
- it.each( [
- [ false, 'false' ],
- [ true, 'true' ],
- ] )( ':ariaRequired(%p)', ( propValue, attributeValue ) => {
- const lookup = createLookup( { ariaRequired: propValue } );
- const input = lookup.find( 'input' );
-
- expect( input.attributes( 'aria-required' ) ).toBe( attributeValue );
- } );
} );
describe( '@events', () => {
@@ -293,13 +283,9 @@ describe( 'ItemLookup', () => {
await setSearchInput( lookup, 'foo' );
const selectedItemId = 0;
- await lookup.findComponent( WikitLookup ).vm.$emit(
- 'input',
- {
- label: exampleSearchResults[ selectedItemId ].display.label?.value,
- description: exampleSearchResults[ selectedItemId ].display.description.value,
- value: exampleSearchResults[ selectedItemId ].id,
- },
+ await lookup.findComponent( CdxLookup ).vm.$emit(
+ 'update:selected',
+ exampleSearchResults[ selectedItemId ].id,
);
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
diff --git a/tests/unit/components/SpellingVariantInput.test.ts b/tests/unit/components/SpellingVariantInput.test.ts
index 507fe3a4..dffe112a 100644
--- a/tests/unit/components/SpellingVariantInput.test.ts
+++ b/tests/unit/components/SpellingVariantInput.test.ts
@@ -1,6 +1,9 @@
-import { mount } from '@vue/test-utils';
+import {
+ mount,
+ VueWrapper,
+} from '@vue/test-utils';
import SpellingVariantInput from '@/components/SpellingVariantInput.vue';
-import { Lookup as WikitLookup } from '@wmde/wikit-vue-components';
+import { CdxLookup } from '@wikimedia/codex';
import { LanguageCodesProviderKey } from '@/plugins/LanguageCodesProviderPlugin/LanguageCodesProvider';
import DevMessagesRepository from '@/plugins/MessagesPlugin/DevMessagesRepository';
import Messages, { MessagesKey } from '@/plugins/MessagesPlugin/Messages';
@@ -38,26 +41,32 @@ function createLookup( config: Record = {} ) {
} );
}
+async function setSearchInput( lookup: VueWrapper, searchInput: string ): Promise {
+ await lookup.find( 'input' ).setValue( searchInput );
+ await lookup.setProps( { searchInput } );
+}
+
describe( 'SpellingVariantInput', () => {
describe( ':props', () => {
it( ':value - selects the selected language', async () => {
const lookup = createLookup();
+
await lookup.find( 'input' ).setValue( 'en' );
await lookup.setProps( {
modelValue: 'English (en)',
} );
- expect( lookup.findComponent( WikitLookup ).props().value.value )
- .toStrictEqual( 'en' );
+ expect( lookup.find( 'div.cdx-text-input' ).get( 'input' ).element.value )
+ .toStrictEqual( 'English (en)' );
} );
- it( ':menuItems - returned suggestions are provided to Wikit Lookup', async () => {
+ it( ':menuItems - returned suggestions are provided to Codex Lookup', async () => {
const lookup = createLookup();
- await lookup.find( 'input' ).setValue( 'en' );
+ await setSearchInput( lookup, 'en' );
- const wikitLookup = lookup.getComponent( WikitLookup );
- expect( wikitLookup.props( 'menuItems' ) ).toStrictEqual( [
+ const codexLookup = lookup.getComponent( CdxLookup );
+ expect( codexLookup.props( 'menuItems' ) ).toStrictEqual( [
{
description: '',
label: 'English (en)',
@@ -126,11 +135,11 @@ describe( 'SpellingVariantInput', () => {
},
} );
- await lookup.find( 'input' ).setValue( userInput );
+ await setSearchInput( lookup, userInput );
- const wikitLookup = lookup.getComponent( WikitLookup );
+ const codexLookup = lookup.getComponent( CdxLookup );
// eslint-disable-next-line @typescript-eslint/no-explicit-any
- expect( wikitLookup.props( 'menuItems' ).map( ( option: any ) => option.value ) ).toStrictEqual( expectedOptionValues );
+ expect( codexLookup.props( 'menuItems' ).map( ( option: any ) => option.value ) ).toStrictEqual( expectedOptionValues );
} );
} );
@@ -138,25 +147,18 @@ describe( 'SpellingVariantInput', () => {
it( '@update:modelValue - emits null when the input is changed', async () => {
const lookup = createLookup();
- await lookup.find( 'input' ).setValue( 'foo' );
+ await setSearchInput( lookup, 'foo' );
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
- expect( lookup.emitted( 'update:modelValue' )[ 0 ][ 0 ] ).toBe( null );
+ expect( lookup.emitted( 'update:modelValue' )[ 0 ][ 0 ] ).toBe( undefined );
} );
it( '@update:modelValue - emits the value of the selected option', async () => {
const lookup = createLookup();
- await lookup.find( 'input' ).setValue( 'en' );
+ await setSearchInput( lookup, 'en' );
- await lookup.findComponent( WikitLookup ).vm.$emit(
- 'input',
- {
- label: 'foo',
- description: '',
- value: 'en',
- },
- );
+ await lookup.findComponent( CdxLookup ).vm.$emit( 'update:selected', 'en' );
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
@@ -166,10 +168,4 @@ describe( 'SpellingVariantInput', () => {
} );
} );
- it( 'input is required', () => {
- const lookup = createLookup();
- const input = lookup.find( 'input' );
-
- expect( input.attributes( 'aria-required' ) ).toBe( 'true' );
- } );
} );