import { CSSResult, customElement, html, LitElement, property, TemplateResult } from "lit-element"; import { ifDefined } from "lit-html/directives/if-defined"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFToolbar from "@patternfly/patternfly/components/Toolbar/toolbar.css"; import PFInputGroup from "@patternfly/patternfly/components/InputGroup/input-group.css"; import PFFormControl from "@patternfly/patternfly/components/FormControl/form-control.css"; @customElement("ak-table-search") export class TableSearch extends LitElement { @property() value?: string; @property() onSearch?: (value: string) => void; static get styles(): CSSResult[] { return [PFBase, PFButton, PFToolbar, PFInputGroup, PFFormControl]; } render(): TemplateResult { return html`
{ e.preventDefault(); if (!this.onSearch) return; const el = this.shadowRoot?.querySelector("input[type=search]"); if (!el) return; if (el.value === "") return; this.onSearch(el?.value); }}> { if (!this.onSearch) return; this.onSearch((ev.target as HTMLInputElement).value); }}>
`; } }