import {css, html, LitElement} from 'lit';
import {customElement} from 'lit/decorators/custom-element.js';
import {property} from 'lit/decorators/property.js';
import {MicButtonPressedEvent} from './GeminiLiveEvents';
@customElement('xrblocks-simulator-geminilive-micbutton')
export class MicButton extends LitElement {
@property({type: Boolean}) micRecording = false;
static override styles = css`
.mic-input {
flex-grow: 0;
border-radius: 3rem;
width: 3rem;
height: 100%;
background: #00000088;
color: white;
border: none;
}
.mic-input-icon {
text-align: center;
line-height: 3rem;
width: 100%;
}
.material-symbols-outlined {
font-variation-settings:
'FILL' 0,
'wght' 400,
'GRAD' 0,
'opsz' 24;
}
`;
onMicButtonClicked() {
this.dispatchEvent(new MicButtonPressedEvent());
}
getHaloCss() {
return `box-shadow:
0 0 10px rgba(22,127,56, 0.4),
0 0 20px rgba(22,127,56, 0.3),
0 0 30px rgba(22,127,56, 0.2);
`;
}
override render() {
let micInputStyle = '';
if (this.micRecording) {
micInputStyle = this.getHaloCss();
}
return html`
`;
}
}