diff --git a/src/components/sys-form-button.vue b/src/components/sys-form-button.vue index a34a13c..68cbc0a 100644 --- a/src/components/sys-form-button.vue +++ b/src/components/sys-form-button.vue @@ -83,7 +83,7 @@ export default { return {} } - switch (this.tag) { + switch (this.component) { case 'nuxt-link': case 'router-link': return { to: this.href } diff --git a/test/spec/components/sys-form-button.js b/test/spec/components/sys-form-button.js index 8992bdc..9a58f33 100644 --- a/test/spec/components/sys-form-button.js +++ b/test/spec/components/sys-form-button.js @@ -63,3 +63,31 @@ test('renders as router-link if not in a nuxt app', (t) => { t.log(button.html()) t.true(button.contains('router-link')) }) + +test('uses to prop when rendering as a router-link', (t) => { + const button = shallowMount(SysFormButton, { + propsData: { + href: '/test', + tag: 'router-link' + } + }) + + const html = button.html() + + t.log(html) + t.true(html.includes('to="/test"')) +}) + +test('uses to prop when rendering as a nuxt-link', (t) => { + const button = shallowMount(SysFormButton, { + propsData: { + href: '/test', + tag: 'nuxt-link' + } + }) + + const html = button.html() + + t.log(html) + t.true(html.includes('to="/test"')) +})