From dd1e7dfcb87e45d0a63d6495876bda0a1a83c2c0 Mon Sep 17 00:00:00 2001 From: Ron Chaplin Date: Sun, 7 Apr 2024 21:05:38 -0500 Subject: [PATCH] lwb-106 Implement inline_text_semantics dfn component --- .../views/inline_text_semantics/dfn.blade.php | 3 + src/Components/InlineTextSemantics/Dfn.php | 41 ++++++ tests/Feature/InlineTextSemantics/DfnTest.php | 119 ++++++++++++++++++ .../Components/InlineTextSemantics/MyDfn.php | 9 ++ 4 files changed, 172 insertions(+) create mode 100644 resources/views/inline_text_semantics/dfn.blade.php create mode 100644 src/Components/InlineTextSemantics/Dfn.php create mode 100644 tests/Feature/InlineTextSemantics/DfnTest.php create mode 100644 tests/TestSupport/Components/InlineTextSemantics/MyDfn.php diff --git a/resources/views/inline_text_semantics/dfn.blade.php b/resources/views/inline_text_semantics/dfn.blade.php new file mode 100644 index 00000000..ef4a897e --- /dev/null +++ b/resources/views/inline_text_semantics/dfn.blade.php @@ -0,0 +1,3 @@ + + {{ $slot }} + diff --git a/src/Components/InlineTextSemantics/Dfn.php b/src/Components/InlineTextSemantics/Dfn.php new file mode 100644 index 00000000..bb44fbfa --- /dev/null +++ b/src/Components/InlineTextSemantics/Dfn.php @@ -0,0 +1,41 @@ +setGlobalAttributes(); + } + + /** + * Standard render function + */ + public function render(): Application|ContractedApplication|ContractedView|Factory|View + { + return view( + 'lw-bits::inline_text_semantics.dfn', + [ + 'globalAttributes' => $this->getGlobalAttributes(), + 'slot' => '', + ] + ); + } +} diff --git a/tests/Feature/InlineTextSemantics/DfnTest.php b/tests/Feature/InlineTextSemantics/DfnTest.php new file mode 100644 index 00000000..640c7a1e --- /dev/null +++ b/tests/Feature/InlineTextSemantics/DfnTest.php @@ -0,0 +1,119 @@ +assertStatus(200); +}); + +it('can render with accesskey', function () { + Livewire::test(MyDfn::class, ['accessKey' => true]) + ->assertSee('accesskey'); +}); + +it('can render with autocapitalize', function () { + Livewire::test(MyDfn::class, ['autoCapitalize' => true]) + ->assertSee('autocapitalize'); +}); + +it('can render with autofocus', function () { + Livewire::test(MyDfn::class, ['autoFocus' => true]) + ->assertSee('autofocus'); +}); + +it('can render with contenteditable', function () { + Livewire::test(MyDfn::class, ['contentEditable' => true]) + ->assertSee('contenteditable'); +}); + +it('can render with css classes', function () { + Livewire::test(MyDfn::class, ['cssClasses' => ['class1', 'class2']]) + ->assertSee('class="class1 class2"', false); +}); + +it('can render with data-*', function () { + Livewire::test(MyDfn::class, ['data' => ['name' => 'main-dfn']]) + ->assertSee('data-name="main-dfn"', false); +}); + +it('can render with dir', function () { + Livewire::test(MyDfn::class, ['direction' => 'rtl']) + ->assertSee('dir="rtl"', false); +}); + +it('can render with draggable', function () { + Livewire::test(MyDfn::class, ['draggable' => true]) + ->assertSee('draggable'); +}); + +it('can render with enterkeyhint', function () { + Livewire::test(MyDfn::class, ['enterKeyHint' => 'enter']) + ->assertSee('enterkeyhint="enter"', false); +}); + +it('can render with hidden', function () { + Livewire::test(MyDfn::class, ['hidden' => true]) + ->assertSee('hidden'); +}); + +it('can render with id', function () { + Livewire::test(MyDfn::class, ['id' => 'main-dfn']) + ->assertSee('id="main-dfn"', false); +}); + +it('can render with language', function () { + Livewire::test(MyDfn::class, ['language' => 'en']) + ->assertSee('lang="en"', false); +}); + +it('can render with nonce', function () { + Livewire::test(MyDfn::class, ['nonce' => 'abc123']) + ->assertSee('nonce="abc123"', false); +}); + +it('can render with parts', function () { + Livewire::test(MyDfn::class, ['parts' => ['part1', 'part2']]) + ->assertSee('part="part1 part2"', false); +}); + +it('can render with popOver', function () { + Livewire::test(MyDfn::class, ['popOver' => true]) + ->assertSee('popover'); +}); + +it('can render with role', function () { + Livewire::test(MyDfn::class, ['role' => 'main']) + ->assertSee('role="main"', false); +}); + +it('can render with slot', function () { + Livewire::test(MyDfn::class, ['slotAttribute' => 'main-dfn']) + ->assertSee('slot="main-dfn"', false); +}); + +it('can render with spellcheck', function () { + Livewire::test(MyDfn::class, ['spellCheck' => true]) + ->assertSee('spellcheck'); +}); + +it('can render with styles', function () { + Livewire::test(MyDfn::class, ['styles' => ['color' => 'red', 'font-size' => '16px']]) + ->assertSee('style="color:red;font-size:16px"', false); +}); + +it('can render with tabindex', function () { + Livewire::test(MyDfn::class, ['tabIndex' => 1]) + ->assertSee('tabindex="1"', false); +}); + +it('can render with title', function () { + Livewire::test(MyDfn::class, ['title' => 'main-dfn']) + ->assertSee('title="main-dfn"', false); +}); + +it('can render with translate', function () { + Livewire::test(MyDfn::class, ['translate' => true]) + ->assertSee('translate'); +}); diff --git a/tests/TestSupport/Components/InlineTextSemantics/MyDfn.php b/tests/TestSupport/Components/InlineTextSemantics/MyDfn.php new file mode 100644 index 00000000..efdfa421 --- /dev/null +++ b/tests/TestSupport/Components/InlineTextSemantics/MyDfn.php @@ -0,0 +1,9 @@ +