<form-matter upgrade=form if-wants-to-be=formatted></form-matter>
...
<form method=GET action="//mydomain.com/api/company/{#company.value}" be-formatted>
<input id=company>
<input type=search name=surname>
<button type=submit></button>
</form>
<form-matter if-wants-to-be=formatted req-init='{"mode": "cors"}'></form-matter>
...
<form method=GET action={##myPreconnectLinkId.href}/api/company/{#company.value} be-formatted>
<input id=company>
<input type=search name=surname>
<button type=submit></button>
</form>
When submitted, makes fetch call (or uses iframe) to //mydomain.com/api/company/{company}?surname=...
Fires events with response.
<form-matter if-wants-to-be=formatted req-init='{"mode": "cors"}'></form-matter>
...
<form method=GET action={##myPreconnectLinkId.href}/api/company/{#company.value} be-formatted target=myIframe>
<input id=company>
<input type=search name=surname>
<button type=submit></button>
</form>
<iframe name=myIframe class=hide-if-no-src></iframe>
be-formatted (or another "decorator"?) adds class, "src-set" on submit, so iframe can appear.
Stream to DOM Element via hidden iframe
Fire event and/or set prop of host container
<form-matter upgrade=form if-wants-to-be=formatted></form-matter>
...
<form method=GET action="//mydomain.com/api/company/{company}" be-formatted='{"autosubmit":true}'>
<input id=company>
<input type=search name=surname>
</form>
Submits with every change