Solucionado (ver solução)
Solucionado
(ver solução)
2
respostas

javax.el.PropertyNotFoundException: Property 'livroDataModel' not found on type br.com.caelum.livraria.bean.LivroBean

Estranho é a terceira coisa que eu crio que dá o mesmo problema

package br.com.caelum.livraria.bean;

import java.io.Serializable;
import java.util.List;

import javax.faces.application.FacesMessage;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.validator.ValidatorException;

import br.com.caelum.livraria.dao.DAO;
import br.com.caelum.livraria.modelo.Autor;
import br.com.caelum.livraria.modelo.Livro;
import br.com.caelum.livraria.modelo.LivroDataModel;
import br.com.caelum.livraria.util.RedirectView;

@ManagedBean
@ViewScoped
public class LivroBean implements Serializable{

    private static final long serialVersionUID = 1L;

    private Livro livro = new Livro();

    private LivroDataModel livroDataModel = new LivroDataModel();

    private Integer autorId;

    private List<Livro> livros;

    public LivroDataModel getLivroDataModel() {
        return livroDataModel;
    }

    public void setLivroDataModel(LivroDataModel livroDataModel) {
        this.livroDataModel = livroDataModel;
    }

    public Livro getLivro() {
        return livro;
    }

    public void setLivro(Livro livro) {
        this.livro = livro;
    }

    public void setAutorId(Integer autorId) {
        this.autorId = autorId;
    }

    public Integer getAutorId() {
        return autorId;
    }

    public List<Autor> getAutores(){
        return new DAO<Autor>(Autor.class).listaTodos();
    }

    public List<Autor> getAutoresDoLivro(){
        return this.livro.getAutores();
    }

    public List<Livro> getLivros(){
        if(this.livros == null) {
            this.livros = new DAO<Livro>(Livro.class).listaTodos();
        }
        return this.livros;
    }

    public void gravarAutor() {
        Autor autor = new DAO<Autor>(Autor.class).buscaPorId(this.autorId);
        this.livro.adicionaAutor(autor);
    }

    public RedirectView autorForm() {
        return new RedirectView("autor");
    }

    public void gravar() {
        System.out.println("Gravando livro " + this.livro.getTitulo());

        if (livro.getAutores().isEmpty()) {
            FacesContext.getCurrentInstance().addMessage("autor", new FacesMessage("O livro precisa de um autor, "
                    + "a não ser que foi escrito pelo gasparzinho"));
            return;
        }

        if(this.livro.getId()==null) {
            new DAO<Livro>(Livro.class).adiciona(this.livro);
            this.livros = new DAO<Livro>(Livro.class).listaTodos();
        }else {
            new DAO<Livro>(Livro.class).atualiza(this.livro);
        }

        this.livro = new Livro();
    }

    public void remove(Livro livro) {
        new DAO<Livro>(Livro.class).remove(livro);
        this.livros = new DAO<Livro>(Livro.class).listaTodos();
    }

    public void removeAutor(Autor autor) {
        this.livro.removeAutor(autor);
    }

    public void carrega(Livro livro) {
        this.livro = livro;
    }

    public void carregaPeloId() {
        Integer id = this.livro.getId();
        this.livro = new DAO<Livro>(Livro.class).buscaPorId(id);
        if(this.livro == null) {
            this.livro = new Livro();
        }
    }

    public void comecaComDigitoUm(FacesContext facesContext,UIComponent uiComponent, Object valor) {
        if(!valor.toString().startsWith("1")) {
            throw new ValidatorException(new FacesMessage("O ISBN só pode começar com 1, vc (Faustão: -EROUUUU"));
        }
    }

}
<p:dataTable id="tabelaLivros" value="#{livroBean.livroDataModel}" var="livro" paginator="true" rows="5">
                <f:facet name="header">Livros</f:facet>
                <p:column headerText="Título" sortBy="#{livro.titulo}" filterBy="#{livro.titulo}" filterMatchMode="startsWith">
                    <h:outputText value="#{livro.titulo}"/>
                </p:column>
                <p:column headerText="ISBN" sortBy="#{livro.isbn}" filterBy="#{livro.isbn}" filterMatchMode="contains">
                    <h:outputText value="#{livro.isbn}"/>
                </p:column>
                <p:column headerText="Preço" sortBy="#{livro.preco}">
                    <h:outputText value="#{livro.preco}">
                        <f:convertNumber type="currency" pattern="R$ #0.00" currencySymbol="R$" locale="pt_BR"/>
                    </h:outputText>
                </p:column>
                <p:column headerText="Data" sortBy="#{livro.dataLancamento.time}" filterBy="#{livro.dataLancamento.time}" filterMatchMode="contains">
                    <h:outputText value="#{livro.dataLancamento.time}">
                        <f:convertDateTime pattern="dd/MM/yyyy" timeZone="America/Sao_Paulo"/>
                    </h:outputText>
                </p:column>
                <p:column headerText="Remover">
                    <p:commandButton icon="fa fa-fw fa-remove" update="tabelaLivros" process="@this" action="#{livroBean.remove(livro)}"/>
                </p:column>
                <p:column headerText="Alterar">
                    <p:commandButton icon="fa fa-fw fa-edit" update=":livroForm" action="#{livroBean.carrega(livro)}"/>
                </p:column>
            </p:dataTable>
2 respostas
solução!

Esse também foi por causa de hackers, formatei, funcionou.

Rafael, tudo bem ?

Tive um problema similar, mas era devido a versão do eclipse que estava usando, toda vez tinha que ficar fazendo clean e build do projeto para as coisas entrarem em "produção"