diff --git a/.gitignore b/.gitignore index 4b10b69fe49..e34ae50b1dc 100644 --- a/.gitignore +++ b/.gitignore @@ -4,6 +4,7 @@ # Production /build /www +/i18n # Generated files .docusaurus diff --git a/.prettierignore b/.prettierignore index 881b5b9eeb5..c750d314e8a 100644 --- a/.prettierignore +++ b/.prettierignore @@ -7,6 +7,7 @@ docs/api docs/native versioned_docs/version-v*/native docs/cli/commands +docs/reference/glossary.md static/code/stackblitz diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index cf3eb243153..6452724858e 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -178,4 +178,4 @@ The Ionic documentation's `main` branch is deployed automatically and separately This repo is licensed and managed separately from Ionic itself. -By contributing to this repo, you agree to have your contributions licensed under the Apache 2.0 license. See [LICENSE](../LICENSE) for the full license text. +By contributing to this repo, you agree to have your contributions licensed under the Apache 2.0 license. See [LICENSE](LICENSE) for the full license text. diff --git a/_templates/playground/new/angular.md.ejs.t b/_templates/playground/new/angular.md.ejs.t deleted file mode 100644 index f44075feb06..00000000000 --- a/_templates/playground/new/angular.md.ejs.t +++ /dev/null @@ -1,7 +0,0 @@ ---- -# this file's location depends on whether or not the css option or angular_ts option is selected via the prompt -to: "<%= `static/usage/v${version}/${name}/${path}/${(css || angular_ts) ? 'angular/example_component_html.md' : 'angular.md'}` %>" ---- -```html -<<%= component %>>> -``` diff --git a/_templates/playground/new/angular_example_component_html.md.ejs.t b/_templates/playground/new/angular_example_component_html.md.ejs.t new file mode 100644 index 00000000000..98f48fde212 --- /dev/null +++ b/_templates/playground/new/angular_example_component_html.md.ejs.t @@ -0,0 +1,6 @@ +--- +to: "<%= `static/usage/v${version}/${name}/${path}/angular/example_component_html.md` %>" +--- +```html +<<%= component %>>> +``` diff --git a/_templates/playground/new/angular_example_component_ts.md.ejs.t b/_templates/playground/new/angular_example_component_ts.md.ejs.t index fb07f495acb..548a45dd57b 100644 --- a/_templates/playground/new/angular_example_component_ts.md.ejs.t +++ b/_templates/playground/new/angular_example_component_ts.md.ejs.t @@ -1,17 +1,16 @@ --- -# this file only gets generated if `angular_ts` (from the command line prompt) is true -to: "<%= angular_ts ? `static/usage/v${version}/${name}/${path}/angular/example_component_ts.md` : null %>" +arbitrary: <% pascalComponent = h.changeCase.pascal(component) %> +to: "<%= `static/usage/v${version}/${name}/${path}/angular/example_component_ts.md` %>" --- ```ts import { Component } from '@angular/core'; +import { <%= pascalComponent %> } from '@ionic/angular/standalone'; @Component({ selector: 'app-example', templateUrl: 'example.component.html', -<% if (css){ -%> styleUrls: ['./example.component.css'], -<% } -%> + imports: [<%= pascalComponent %>], }) -export class ExampleComponent { -} +export class ExampleComponent {} ``` diff --git a/_templates/playground/new/index.js b/_templates/playground/new/index.js index a0d4fd89cca..c6f9fb53b6c 100644 --- a/_templates/playground/new/index.js +++ b/_templates/playground/new/index.js @@ -62,11 +62,6 @@ module.exports = { name: 'css', message: 'Generate custom CSS files?', }, - { - type: 'toggle', - name: 'angular_ts', - message: 'Generate an Angular TypeScript file?', - }, ]) .then((answers) => { answers.name = answers.name || answers.component.replace('ion-', ''); diff --git a/_templates/playground/new/index.md.ejs.t b/_templates/playground/new/index.md.ejs.t index 5c7bbf08e81..148d3e85efe 100644 --- a/_templates/playground/new/index.md.ejs.t +++ b/_templates/playground/new/index.md.ejs.t @@ -12,17 +12,12 @@ import react_main_css from './react/main_css.md'; import react from './react.md'; <% } -%> import vue from './vue.md'; -<% if (css || angular_ts){ %> + import angular_example_component_html from './angular/example_component_html.md'; -<% } else { -%> -import angular from './angular.md'; -<% } -%> -<% if (angular_ts){ -%> -import angular_example_component_ts from './angular/example_component_ts.md'; -<% } -%> <% if (css){ -%> import angular_example_component_css from './angular/example_component_css.md'; <% } -%> +import angular_example_component_ts from './angular/example_component_ts.md'; vue, -<% if (angular_ts || css){ -%> angular: { files: { 'src/app/example.component.html': angular_example_component_html, -<% if (angular_ts){ -%> - 'src/app/example.component.ts': angular_example_component_ts, -<% } -%> <% if (css){ -%> 'src/app/example.component.css': angular_example_component_css, <% } -%> + 'src/app/example.component.ts': angular_example_component_ts, }, }, -<% } else { -%> - angular, -<% } -%> }} src="https://github.com/usage/v%3C%=%20version%20%%3E/%3C%=%20name%20%%3E/%3C%=%20path%20%%3E/demo.html" /> diff --git a/_templates/playground/new/react.md.ejs.t b/_templates/playground/new/react.md.ejs.t index 8a84f90e57f..a8320a026ba 100644 --- a/_templates/playground/new/react.md.ejs.t +++ b/_templates/playground/new/react.md.ejs.t @@ -11,9 +11,10 @@ import './main.css';<% } %> function Example() { return ( - <<%= pascalComponent %>>> + <> + <<%= pascalComponent %>>> + ); } export default Example; ``` - diff --git a/docs/angular/build-options.md b/docs/angular/build-options.md index 04a9946739b..630864d1621 100644 --- a/docs/angular/build-options.md +++ b/docs/angular/build-options.md @@ -47,11 +47,6 @@ import { provideIonicAngular, IonicRouteStrategy } from '@ionic/angular/standalo import { routes } from './app/app.routes'; import { AppComponent } from './app/app.component'; -import { environment } from './environments/environment'; - -if (environment.production) { - enableProdMode(); -} bootstrapApplication(AppComponent, { providers: [ @@ -144,7 +139,7 @@ export class AppComponent { Icons registered in an application entry point can then be referenced by name anywhere in the application. ```html title="home.page.html" - @@ -306,7 +301,7 @@ export class AppComponent { Icons registered in an application entry point can then be referenced by name anywhere in the application. ```html title="home.page.html" - @@ -432,11 +427,6 @@ import { RouteReuseStrategy, provideRouter } from '@angular/router'; import { routes } from './app/app.routes'; import { AppComponent } from './app/app.component'; -import { environment } from './environments/environment'; - -if (environment.production) { - enableProdMode(); -} bootstrapApplication(AppComponent, { providers: [ @@ -560,11 +550,6 @@ import { RouteReuseStrategy, provideRouter } from '@angular/router'; import { routes } from './app/app.routes'; import { AppComponent } from './app/app.component'; -import { environment } from './environments/environment'; - -if (environment.production) { - enableProdMode(); -} @NgModule({ declarations: [AppComponent], @@ -605,11 +590,6 @@ import { RouteReuseStrategy, provideRouter } from '@angular/router'; import { routes } from './app/app.routes'; import { AppComponent } from './app/app.component'; -import { environment } from './environments/environment'; - -if (environment.production) { - enableProdMode(); -} @NgModule({ declarations: [AppComponent], diff --git a/docs/angular/navigation.md b/docs/angular/navigation.md index 878a46a3be4..96576a1b061 100644 --- a/docs/angular/navigation.md +++ b/docs/angular/navigation.md @@ -193,6 +193,10 @@ Developers can use the existing syntax for standalone component routing from Ang export class AppRoutingModule {} ``` +:::tip +If you are using `routerLink`, `routerDirection`, or `routerAction` be sure to also import the `IonRouterLink` directive for Ionic components or the `IonRouterLinkWithHref` directive for `` elements. An example of this is available in the [Ionic Angular Build Options docs](./build-options.md#migrating-from-modules-to-standalone). +::: + To get started with standalone components [visit Angular's official docs](https://angular.io/guide/standalone-components). ## Live Example diff --git a/docs/angular/slides.md b/docs/angular/slides.md index 9e8e633579f..836b717114a 100644 --- a/docs/angular/slides.md +++ b/docs/angular/slides.md @@ -101,7 +101,7 @@ The `ion-slides` component had additional styling that helped create a native lo ```css swiper-container { - --swiper-pagination-bullet-inactive-color: var(--ion-color-step-200, #cccccc); + --swiper-pagination-bullet-inactive-color: var(--ion-text-color-step-800, #cccccc); --swiper-pagination-color: var(--ion-color-primary, #0054e9); --swiper-pagination-progressbar-bg-color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.25); --swiper-scrollbar-bg-color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.1); diff --git a/docs/angular/your-first-app/8-distribute.md b/docs/angular/your-first-app/8-distribute.md index 545e57c1945..65ef475f6be 100644 --- a/docs/angular/your-first-app/8-distribute.md +++ b/docs/angular/your-first-app/8-distribute.md @@ -55,7 +55,7 @@ To receive this live update, you will need to run the app on a device or an emul ionic [cordova | cap] run [ios | android] [options] ``` -Assuming the app is configured correctly to listen to the channel you deployed too, the app should immediately update on startup if you have chosen the auto update method during setup. If the background update method was chosen, be sure to stay in the app for about 30 seconds to ensure the update was downloaded. Then, close the application, reopen it, and you will see the updates applied! +Assuming the app is configured correctly to listen to the channel you deployed to, the app should immediately update on startup if you have chosen the auto update method during setup. If the background update method was chosen, be sure to stay in the app for about 30 seconds to ensure the update was downloaded. Then, close the application, reopen it, and you will see the updates applied! To dive into more details on the steps to deploy a live update, as well as additional information such as disabling deploy for development, check out the [Deploy a Live Update](https://ionic.io/docs/appflow/quickstart/deploy) section inside the Appflow docs. @@ -95,6 +95,6 @@ For access to the ability to create a Native Configuration, you will need to be Congratulations! You developed a complete cross-platform Photo Gallery app that runs on the web, iOS, and Android. Not only that, you have also then built the app and deployed it to your users devices! -There are many paths to follow from here. Try adding another [Ionic UI component](https://ionicframework.com/docs/components) to the app, or more [native functionality](https://capacitorjs.com/docs/apis). The sky’s the limit. Once you have added another feature, run the the build and deploy process again through Appflow to get it out to your users. +There are many paths to follow from here. Try adding another [Ionic UI component](https://ionicframework.com/docs/components) to the app, or more [native functionality](https://capacitorjs.com/docs/apis). The sky’s the limit. Once you have added another feature, run the build and deploy process again through Appflow to get it out to your users. Happy app building! 💙 diff --git a/docs/api/accordion.md b/docs/api/accordion.md index 96911389ff5..a60f352a68b 100644 --- a/docs/api/accordion.md +++ b/docs/api/accordion.md @@ -170,19 +170,19 @@ import AccessibilityAnimations from '@site/static/usage/v8/accordion/accessibili -### キーボードナビゲーション +### キーボードインタラクション `ion-accordion-group` の中で使用する場合、`ion-accordion` はキーボードによる操作を完全にサポートしています。次の表は、それぞれのキーが何をするのかの詳細です。 -| Key | Function | -| ------------------ | ------------------------------------------------------------ | -| `Space` or `Enter` | When focus is on the accordion header, the accordion will collapse or expand depending on the state of the component. | -| `Tab` | Moves focus to the next focusable element. | -| `Shift` + `Tab` | Moves focus to the previous focusable element. | -| `Down Arrow` | - When focus is on an accordion header, moves focus to the next accordion header.
- When focus is on the last accordion header, moves focus to the first accordion header. | -| `Up Arrow` | - When focus is on an accordion header, moves focus to the previous accordion header.
- When focus is on the first accordion header, moves focus to the last accordion header. | -| `Home` | When focus is on an accordion header, moves focus to the first accordion header. | -| `End` | When focus is on an accordion header, moves focus to the last accordion header. | +| Key | Description | +| ------------------------------------ | ------------------------------------------------------------ | +| Space or Enter | When focus is on the accordion header, the accordion will collapse or expand depending on the state of the component. | +| Tab | Moves focus to the next focusable element. | +| Shift + Tab | Moves focus to the previous focusable element. | +| Down Arrow | - When focus is on an accordion header, moves focus to the next accordion header.
- When focus is on the last accordion header, moves focus to the first accordion header. | +| Up Arrow | - When focus is on an accordion header, moves focus to the previous accordion header.
- When focus is on the first accordion header, moves focus to the last accordion header. | +| Home | When focus is on an accordion header, moves focus to the first accordion header. | +| End | When focus is on an accordion header, moves focus to the last accordion header. | ## パフォーマンス diff --git a/docs/api/app.md b/docs/api/app.md index c62275d20cf..32602254b86 100644 --- a/docs/api/app.md +++ b/docs/api/app.md @@ -15,8 +15,7 @@ import Slots from '@ionic-internal/component-api/v8/app/slots.md'; import EncapsulationPill from '@components/page/api/EncapsulationPill'; - -AppはIonicアプリケーションのコンテナ要素です。プロジェクトごとに `` 要素は1つだけにしてください。アプリケーションには、menus, headers, content, footersなど、多くのIonicコンポーネントを含めることができます。オーバーレイコンポーネントは、表示されるときに `` に追加されます。 +AppはIonicアプリケーションのコンテナ要素です。1つのプロジェクトにつき``要素は1つだけです。アプリはメニュー、ヘッダー、コンテンツ、フッターなど多くのIonicコンポーネントを持つことができます。オーバーレイコンポーネントは表示時に `` に追加されます。 `ion-app`を使用すると、以下の動作が可能になります。 @@ -27,6 +26,13 @@ AppはIonicアプリケーションのコンテナ要素です。プロジェク * Material Design モードでのボタン操作時の[Ripple effect](./リップルエフェクト) が使えます。 * Ionicアプリの使用感をよりネイティブなものにする、その他のタップやフォーカスのユーティリティが使えます。 +## Programmatic Focus + +Ionic offers focus utilities for components with the `ion-focusable` class. These utilities automatically manage focus for components when certain keyboard keys, like Tab, are pressed. Components can also be programmatically focused in response to user actions using the `setFocus` method from `ion-app`. + +import SetFocus from '@site/static/usage/v8/app/set-focus/index.md'; + + ## プロパティ diff --git a/docs/api/checkbox.md b/docs/api/checkbox.md index 8f8adb12a82..153e5a58566 100644 --- a/docs/api/checkbox.md +++ b/docs/api/checkbox.md @@ -74,7 +74,17 @@ import LabelLink from '@site/static/usage/v8/checkbox/label-link/index.md'; -## テーマ +## Helper & Error Text + +Helper and error text can be used inside of a checkbox with the `helperText` and `errorText` property. The error text will not be displayed unless the `ion-invalid` and `ion-touched` classes are added to the `ion-checkbox`. This ensures errors are not shown before the user has a chance to enter data. + +In Angular, this is done automatically through form validation. In JavaScript, React and Vue, the class needs to be manually added based on your own validation. + +import HelperError from '@site/static/usage/v8/checkbox/helper-error/index.md'; + + + +## Theming ## CSSカスタムプロパティ diff --git a/docs/api/datetime.md b/docs/api/datetime.md index 0667ac4c836..dc9a773ebf0 100644 --- a/docs/api/datetime.md +++ b/docs/api/datetime.md @@ -204,7 +204,7 @@ Ionic Frameworkでは、[Intl.DatetimeFormat](https://developer.mozilla.org/en-U ### 月と年の選択 -月と年の選択は、 `presentation` プロパティに `month-year` , `year-month` , `month` , または `year` を渡すことで行うことができます。 +月と年の選択は、 `presentation` プロパティに `month-year` , `month` , または `year` を渡すことで行うことができます。 この例では、 `month-year` を設定した datetime を示しています。 @@ -416,30 +416,30 @@ JavaScriptで日付を扱うために [date-fns](https://date-fns.org) を使う ## アクセシビリティ -### キーボードナビゲーション +### キーボードインタラクション `ion-datetime` は、コンポーネント内のフォーカス可能な要素間を移動するためのフルキーボードサポートを備えています。次の表は、それぞれのキーが何をするのかの詳細です。 -| Key | Function | -| ------------------ | ------------------------------------------------------------ | -| `Tab` | Moves focus to the next focusable element. | -| `Shift` + `Tab` | Moves focus to the previous focusable element. | -| `Space` or `Enter` | Clicks the focusable element. | +| Key | Description | +| ------------------------------------ | ---------------------------------------------- | +| Tab | Moves focus to the next focusable element. | +| Shift + Tab | Moves focus to the previous focusable element. | +| Space or Enter | Clicks the focusable element. | #### 日付の表示 -| Key | Function | -| ------------------ | ------------------------------------------------------------ | -| `ArrowUp` | Moves focus to the same day of the previous week. | -| `ArrowDown` | Moves focus to the same day of the next week. | -| `ArrowRight` | Moves focus to the next day. | -| `ArrowLeft` | Moves focus to the previous day. | -| `Home` | Moves focus to the first day of the current week. | -| `End` | Moves focus to the last day of the current week. | -| `PageUp` | Changes the grid of dates to the previous month. | -| `PageDown` | Changes the grid of dates to the next month. | -| `Shift` + `PageUp` | Changes the grid of dates to the previous year. | -| `Shift` + `PageDown` | Changes the grid of dates to the next year. | +| Key | Description | +| -------------------------------------- | ------------------------------------------------- | +| ArrowUp | Moves focus to the same day of the previous week. | +| ArrowDown | Moves focus to the same day of the next week. | +| ArrowRight | Moves focus to the next day. | +| ArrowLeft | Moves focus to the previous day. | +| Home | Moves focus to the first day of the current week. | +| End | Moves focus to the last day of the current week. | +| PageUp | Changes the grid of dates to the previous month. | +| PageDown | Changes the grid of dates to the next month. | +| Shift + PageUp | Changes the grid of dates to the previous year. | +| Shift + PageDown | Changes the grid of dates to the next year. | #### 時刻、月、年のホイール diff --git a/docs/api/infinite-scroll.md b/docs/api/infinite-scroll.md index 0e63b3cb368..598e8f295fa 100644 --- a/docs/api/infinite-scroll.md +++ b/docs/api/infinite-scroll.md @@ -21,6 +21,8 @@ Infinite Scrollコンポーネントは、ユーザーがページの下部ま ユーザが定義された距離に達したときに、`ionInfinite` イベントに割り当てられた関数が呼び出されます。この関数がすべてのタスクを完了したら、無限スクロールインスタンスに対して `complete()` メソッドを呼び出す必要があります。 +## Basic Usage + import Basic from '@site/static/usage/v8/infinite-scroll/basic/index.md'; @@ -118,4 +120,4 @@ interface InfiniteScrollCustomEvent extends CustomEvent { ## Slots - \ No newline at end of file + diff --git a/docs/api/input-password-toggle.md b/docs/api/input-password-toggle.md index 8467761691d..7813203667a 100644 --- a/docs/api/input-password-toggle.md +++ b/docs/api/input-password-toggle.md @@ -1,5 +1,5 @@ --- -title: "ion-password-toggle" +title: "ion-input-password-toggle" --- import Props from '@ionic-internal/component-api/v8/input-password-toggle/props.md'; import Events from '@ionic-internal/component-api/v8/input-password-toggle/events.md'; diff --git a/docs/api/input.md b/docs/api/input.md index e2b3c872289..7664fb62c33 100644 --- a/docs/api/input.md +++ b/docs/api/input.md @@ -83,9 +83,11 @@ import Clear from '@site/static/usage/v8/input/clear/index.md'; Material Design では、Inputに塗りつぶしのスタイルが用意されています。Inputの `fill` プロパティは `"solid"` または `"outline"` のいずれかに設定することができます。 -`fill` スタイルはInputコンテナを視覚的に定義するため、`fill` を使用するInputは `ion-item` で使用すべきではありません。 +Filled inputs をiOSで使うためには、inputの `mode` を `md` に設定する必要があります。 -Filled inputs can be used on iOS by setting Input's `mode` to `md`. +:::warning +Inputs that use `fill` should not be used in an `ion-item` due to styling conflicts between the components. +::: import Fill from '@site/static/usage/v8/input/fill/index.md'; @@ -160,7 +162,7 @@ In most cases, [Icon](./icon.md) components placed in these slots should have `a If slot content is meant to be interacted with, it should be wrapped in an interactive element such as a [Button](./button.md). This ensures that the content can be tabbed to. ::: -import StartEndSlots from '@site/static/usage/v7/input/start-end-slots/index.md'; +import StartEndSlots from '@site/static/usage/v8/input/start-end-slots/index.md'; diff --git a/docs/api/item.md b/docs/api/item.md index 422e98aefb1..ae23c687b98 100644 --- a/docs/api/item.md +++ b/docs/api/item.md @@ -42,7 +42,7 @@ import Basic from '@site/static/usage/v8/item/basic/index.md'; アイコン・ボタンのように、アイテムとのインタラクションにビジュアルが必要な場合、そのビジュアルはサポート・ビジュアルではなく、 [アクション](#actions) となります。 -If you find that you need a few more sentences to clarify the item's purpose, consider moving the additional sentences to a
Note at the bottom of the list. Adding the item to its own list makes it clear which item the text is associated with.} doText="Move long text outside of the list" doNotText="Don't try to fit long text in an item" @@ -82,7 +82,7 @@ import Text from '@site/static/usage/v8/item/content-types/text/index.md'; メタデータは、ステータステキストやカウントのようなアイテムの追加コンテキストを提供します。Badge](./badge)や[Note](./note)のようなコンポーネントは、メタデータを表示する素晴らしい方法です。 -} /> -入れ子になったインタラクティブ機能を作成することは避けるべきです。例えば、 `button` プロパティが `true` に設定されている場合、開発者はアイテムのメインコンテンツ内にボタンを追加することを避けるべきです。 -Actions can be added by using the Item Sliding component. Actions can also be placed directly inside of the Item without the use of Item Sliding, but this should be limited to no more than 2 actions.} doText={<>Use an Item Sliding to reveal multiple actions by swiping on the Item.} doNotText="Don't put more than 2 actions within an Item." @@ -130,7 +130,7 @@ import Actions from '@site/static/usage/v8/item/content-types/actions/index.md'; コントロールは、チェックボックス、入力、ラジオなどのフォームコンポーネントです。リスト内の各項目は、画面スペースの制約上、最大でも2つのコントロールを持つ必要があります。 -Metadata such as helper text or character counts should not be used on form controls in list views. If such metadata is needed, the form control should be placed outside of a list. Filled Inputs are a great way of visually defining the input container outside of a list.} doText="Place inputs with metadata outside of the list." doNotText="Don't put metadata for inputs in the list." @@ -138,7 +138,7 @@ import Actions from '@site/static/usage/v8/item/content-types/actions/index.md'; doNotImage={There is a list containing an email input and a password input. Both have helper texts associated with them. However, the divider between each item and between the helper text makes it hard to tell which input each helper text is associated with.} /> -Alternatively, the metadata can be placed in a Note at the bottom of the list.} doText="Place metadata for inputs at the end of a list." doNotText="Don't put metadata for inputs in the list." @@ -146,7 +146,7 @@ import Actions from '@site/static/usage/v8/item/content-types/actions/index.md'; doNotImage={There is one list of inputs. One of the inputs is a password input with text below the input that says 'Password must be at least 16 characters'. However, this text is placed directly above another input, so it's not immediately clear which input the text is associated with.} /> -Items should typically have no more than two controls. If you need more controls, consider adding the additional controls in a Modal that is accessible from the item.} doText="Move additional controls to a submenu accessible from the item." doNotText="Don't use more than two controls within an item." @@ -245,7 +245,38 @@ import CSSProps from '@site/static/usage/v8/item/theming/css-properties/index.md 3. アイテムは決して[入れ子になったインタラクティヴ](https://dequeuniversity.com/rules/axe/4.4/nested-interactive)をレンダリングすべきではありません。入れ子になったインタラクティブ要素が使用されている場合、スクリーンリーダーは正しいインタラクティブ要素を選択することができません。例えば、`button="true"`を持つ`ion-item`の中にボタンを置くことは避けてください。 4. コンテントタイプ](#content-types)を正しく使用してください。Itemコンポーネントは、[List](./list)内の行として設計されており、汎用コンテナとして使用すべきではありません。 -## プロパティ +## アクセシビリティ + +### キーボードインタラクション + +An `` has the following keyboard interactions when any of these conditions are met: +- The `button` property is set to `"true"`, rendering a native `