Skip to content

Commit

Permalink
Clarify typing for no arguments/blocks
Browse files Browse the repository at this point in the history
Update verbiage and add code example to make it clear how to handle scenarios where a component has no arguments or no block invocation
  • Loading branch information
elwayman02 authored Jan 8, 2025
1 parent eabfa3c commit 7b3e39e
Showing 1 changed file with 28 additions and 2 deletions.
30 changes: 28 additions & 2 deletions docs/ember/component-signatures.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ compatible with the DOM element(s) they're ultimately attached to. If no `Elemen
to set any HTML attributes or modifiers when invoking your component.

The `Blocks` field specifies the names of any blocks the component yields to, as well as the type of any parameter(s)
those blocks will receive. If no `Blocks` key is specified, it will be a type error to invoke your component in block
form.
those blocks will receive. If your component does not support block invocation, omit the `Blocks` field altogether
to generate type errors when invoked in block form.

Note that the `inverse` block is an alias for `else`. These should be defined in `Blocks` as `else`, though
`{{yield to="inverse"}}` will continue to work.
Expand Down Expand Up @@ -67,6 +67,32 @@ export default class SuperTable<T> extends Component<SuperTableSignature<T>> {}

{% endcode %}

{% code title="app/components/simple-hello.ts" %}

```typescript
import Component from '@glimmer/component';

export interface SimpleHelloSignature {
// We have a `<div>` as our root element
Element: HTMLDivElement;
// We accept no arguments
Args: Record<string, never>;
// We do not accept block form, so don't specify it in the signature
}

export default class SimpleHello extends Component<SimpleHelloSignature> {}
```

{% endcode %}

{% code title="app/components/simple-hello.hbs" %}

```handlebars
<div>Hello World!</div>
```

{% endcode %}

## Ember Components

Since Ember components don't have `this.args`, it takes slightly more boilerplate to make them typesafe.
Expand Down

0 comments on commit 7b3e39e

Please sign in to comment.