import { LitElementWw } from '@webwriter/lit' import { CSSResult, TemplateResult, html } from 'lit' import { customElement, property } from 'lit/decorators.js' import { consume } from '@lit/context' import { globalStyles } from '@/global_styles' import type { CLayerConnectionConf } from '@/types/c_layer_connection_conf' import type { CNetwork } from '@/components/network/network' import { networkContext } from '@/contexts/network_context' import { layerConnectionConfsContext } from '@/contexts/layer_con_confs_context' import type { CNeuron } from '@/components/network/neuron' import { CCard } from '../reusables/c-card' import { msg } from '@lit/localize' export class NeuronInputsCard extends LitElementWw { static scopedElements = { "c-card": CCard } @property({ attribute: false }) accessor neuron: CNeuron @consume({ context: layerConnectionConfsContext, subscribe: true }) accessor layerConnectionConfs: CLayerConnectionConf[] @consume({ context: networkContext, subscribe: true }) accessor network: CNetwork // STYLES - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - static styles: CSSResult = globalStyles // RENDER - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - render(): TemplateResult<1> { return html`
${msg('Inputs')}
${this.layerConnectionConfs .filter( (layerConnection) => layerConnection.targetLayerId === this.neuron.layer.conf.layerId ) .map((layerConnectionConf) => this.network.getLayerById(layerConnectionConf.sourceLayerId) ) .map( (layer) => html`

${msg('- All neurons from')} '${layer.getName()}'

` )}
` } }