public static string Gravar(TRegistro_PistaBoliche val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_PistaBoliche qtb_orc = new TCD_PistaBoliche(); try { if (banco == null) { st_transacao = qtb_orc.CriarBanco_Dados(true); } else { qtb_orc.Banco_Dados = banco; } string ret = qtb_orc.Gravar(val); val.Id_Pista = Convert.ToDecimal(CamadaDados.TDataQuery.getPubVariavel(ret, "@P_ID_PISTA")); if (st_transacao) { qtb_orc.Banco_Dados.Commit_Tran(); } return(val.Id_Pista.ToString()); } catch (Exception ex) { if (st_transacao) { qtb_orc.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro gravar pista: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_orc.deletarBanco_Dados(); } } }
public static string Excluir(TRegistro_PistaBoliche val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_PistaBoliche qtb_orc = new TCD_PistaBoliche(); try { if (banco == null) { st_transacao = qtb_orc.CriarBanco_Dados(true); } else { qtb_orc.Banco_Dados = banco; } qtb_orc.Excluir(val); if (st_transacao) { qtb_orc.Banco_Dados.Commit_Tran(); } return("OK"); } catch (Exception ex) { if (st_transacao) { qtb_orc.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro excluir pista: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_orc.deletarBanco_Dados(); } } }
private void fecharPista(object sender, ListViewItemSelectionChangedEventArgs e) { if (!e.IsSelected) { return; } modo = TTpModo.tm_Edit; //Busca caixa aberto CamadaDados.Faturamento.PDV.TList_CaixaPDV lCaixa = new CamadaDados.Faturamento.PDV.TCD_CaixaPDV().Select( new Utils.TpBusca[] { new Utils.TpBusca() { vNM_Campo = "a.login", vOperador = "=", vVL_Busca = "'" + Utils.Parametros.pubLogin + "'" }, new Utils.TpBusca() { vNM_Campo = "isnull(a.st_registro, 'A')", vOperador = "=", vVL_Busca = "'A'" } }, 1, string.Empty); if (lCaixa.Count > 0) { rCaixa = lCaixa[0]; } else { MessageBox.Show("Não existe caixa aberto para finalizar a movimentação!", "Mensagem", MessageBoxButtons.OK, MessageBoxIcon.Information); return; } //Controlar tempo minimo para fechamento try { string[] minTime = e.Item.Text.ToString().Split(new string[] { " \n", " Tempo: " }, 0); if (Convert.ToDateTime(minTime[2]).TimeOfDay <= new TimeSpan(0, 0, 5)) { MessageBox.Show("Tempo mínimo para fechamento é de 5 segundos.", "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } } catch { } //Busca Movimentação boliche pela ID DataRow rMov = new TCD_MovBoliche().Buscar( new TpBusca[] { new TpBusca() { vNM_Campo = "a.id_pista", vOperador = "=", vVL_Busca = "'" + e.Item.SubItems[1].Text.Trim() + "'" }, new TpBusca() { vNM_Campo = "a.DT_Fechamento", vOperador = "", vVL_Busca = "is null" } }, 1).Rows[0]; if (rMov == null) { return; } //Valida existencia de prevenda DataRow rPreVenda = new TCD_PreVenda().Buscar( new TpBusca[] { new TpBusca() { vNM_Campo = "a.cd_empresa", vOperador = "=", vVL_Busca = "'" + rMov[0].ToString().Trim() + "'" }, new TpBusca() { vNM_Campo = "a.id_cartao", vOperador = "=", vVL_Busca = "'" + rMov[1].ToString().Trim() + "'" }, new TpBusca() { vNM_Campo = "a.st_registro", vOperador = "=", vVL_Busca = "'A'" } }, 1).Rows[0]; if (rPreVenda == null) { MessageBox.Show("Não existe lançamento de pré-venda para o cartão informado.", "Mensagem", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } //Obtém valor por hora rMov[7] = CamadaDados.UtilData.Data_Servidor(); object rValorhora = null; TList_HoraBoliche lHora = null; //Buscar tipo servico pela pista object tp_servico = new TCD_PistaBoliche().BuscarEscalar(new TpBusca[] { new TpBusca() { vNM_Campo = "a.id_pista", vOperador = "=", vVL_Busca = "'" + e.Item.SubItems[1].Text.Trim() + "'" } }, "a.tp_servico"); if (tp_servico == null || string.IsNullOrEmpty(tp_servico.ToString())) { MessageBox.Show("Não foi possível obter o tipo de serviço, para o item selecionado.", "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } switch (tp_servico.ToString()) { case "B": lHora = new TCD_HoraBoliche().Select(new TpBusca[] { new TpBusca() { vNM_Campo = "a.tp_servico", vOperador = "=", vVL_Busca = "'B'" } }, 0, string.Empty, " dia, hora asc"); break; case "S": lHora = new TCD_HoraBoliche().Select(new TpBusca[] { new TpBusca() { vNM_Campo = "a.tp_servico", vOperador = "=", vVL_Busca = "'S'" } }, 0, string.Empty, " dia, hora asc"); break; } calcularVlPorServico(ref rValorhora, lHora, Convert.ToDateTime(rMov[6].ToString())); if (lHora == null || lHora.Count.Equals(0)) { MessageBox.Show("Não foi possível obter o valor por hora, para a pista de boliche.", "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } if (rValorhora == null) { MessageBox.Show("Não foi possível obter o valor por hora, para a pista de boliche.", "Mensagem", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } //Lança item na prevenda TRegistro_PreVenda_Item rItem = new TRegistro_PreVenda_Item() { Cd_empresa = rMov[0].ToString(), cd_produto = tp_servico.ToString().Equals("B") ? (string)new TCD_CFG().BuscarEscalar(new TpBusca[] { new TpBusca() { vNM_Campo = "a.cd_empresa", vOperador = "=", vVL_Busca = "'" + rMov[0].ToString().Trim() + "'" } }, "a.cd_horaboliche") : (string)new TCD_CFG().BuscarEscalar(new TpBusca[] { new TpBusca() { vNM_Campo = "a.cd_empresa", vOperador = "=", vVL_Busca = "'" + rMov[0].ToString().Trim() + "'" } }, "a.cd_horasinuca"), id_prevenda = decimal.Parse(rPreVenda[17].ToString().Trim()), quantidade = (decimal)Convert.ToDateTime(rMov[7].ToString()).Subtract(Convert.ToDateTime(rMov[6].ToString())).TotalMinutes / 60, vl_unitario = decimal.Parse(rValorhora.ToString()), vl_desconto = 0, obsItem = "Tempo: " + (Convert.ToDateTime(rMov[7].ToString()) - Convert.ToDateTime(rMov[6].ToString())), st_registro = "A", St_impresso = "N" }; TCN_PreVenda_Item.Gravar(rItem, null); //Atualiza prevenda e itemprevenda na movimentacao TCN_MovBoliche.Gravar(new TRegistro_MovBoliche() { Cd_Empresa = rItem.Cd_empresa, Id_Cartao = decimal.Parse(rMov[1].ToString().Trim()), Id_Pista = decimal.Parse(e.Item.SubItems[1].Text.Trim()), Id_Mov = decimal.Parse(rMov[3].ToString().Trim()), Id_PreVenda = rItem.id_prevenda, Id_Item = rItem.id_item, Dt_abertura = Convert.ToDateTime(rMov[6].ToString().Trim()), Dt_fechamento = Convert.ToDateTime(rMov[7].ToString().Trim()) }, null); //Reatualiza listagem de pistas atualizaListagem(); }
private void atualizaListagem() { lvPistas.Clear(); TList_PistaBoliche lPista = TCN_PistaBoliche.Buscar(string.Empty, string.Empty, "A", null); if (lPista.Count > 0) { //Listo todas pistas cadastradas lPista.ForEach(p => { int img; // 0 aberto pista 1 fechado pista 2 aberto sinuca 3 fechado sinuca if (p.Tp_servico.Equals("B")) { img = 0; } else { img = 2; } lvPistas.Items.Add(new ListViewItem(new string[] { p.Ds_Pista, p.Id_Pista.ToString() }, img)); }); lvPistas.View = View.Tile; //Adicionar timer foreach (ListViewItem item in lvPistas.Items) { object obj = new CamadaDados.Restaurante.TCD_MovBoliche().BuscarEscalar(new TpBusca[] { new TpBusca() { vNM_Campo = "a.id_pista", vOperador = "=", vVL_Busca = "'" + item.SubItems[1].Text + "'" }, new TpBusca() { vNM_Campo = "a.dt_fechamento", vOperador = "is null", vVL_Busca = "" } }, "a.id_mov"); //Para pista abertura if (obj != null) { if (!string.IsNullOrEmpty(obj.ToString())) { instanciaTimer(); //Icone vermelho object tpServico = new TCD_PistaBoliche().BuscarEscalar(new TpBusca[] { new TpBusca() { vNM_Campo = "a.id_pista", vOperador = "=", vVL_Busca = "'" + item.SubItems[1].Text + "'" } }, "a.tp_servico"); if (tpServico != null && !string.IsNullOrEmpty(tpServico.ToString())) { if (tpServico.Equals("B")) { item.ImageIndex = 1; //fechado pista } else { item.ImageIndex = 3; //fechado sinuca } } } else { //Icone vermelho object tpServico = new TCD_PistaBoliche().BuscarEscalar(new TpBusca[] { new TpBusca() { vNM_Campo = "a.id_pista", vOperador = "=", vVL_Busca = "'" + item.SubItems[1].Text + "'" } }, "a.tp_servico"); if (tpServico != null && !string.IsNullOrEmpty(tpServico.ToString())) { if (tpServico.Equals("B")) { item.ImageIndex = 0; //fechado pista } else { item.ImageIndex = 2; //fechado sinuca } } } } } } else { MessageBox.Show("Não existe pistas de boliche ou mesas de sinuca pré-cadastradas para serem listadas.", "Mensagem", MessageBoxButtons.OK, MessageBoxIcon.Information); return; } }