RevOrc.apl 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911
  1. #include "PROTHEUS.CH"
  2. #include "RWMAKE.CH"
  3. #include "APWEBEX.CH"
  4. #include "TOPCONN.CH"
  5. #include "TBICONN.CH"
  6. #DEFINE SMSDEBUG
  7. /*__________________________________________________________________________
  8. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  9. ¦¦+-----------------------------------------------------------------------+¦¦
  10. ¦¦¦Funçäo ¦ MntOrc ¦ Autor ¦ Lucilene Mendes ¦ Data ¦28.08.17 ¦¦¦
  11. ¦¦+----------+------------------------------------------------------------¦¦¦
  12. ¦¦¦Descriçäo ¦ Manutenção de Orçamento de Venda. ¦¦¦
  13. ¦¦+-----------------------------------------------------------------------+¦¦
  14. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  15. ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯*/
  16. User Function RevOrc()
  17. Local cHtml
  18. Local cItem := ""
  19. Local nPosFrete := 0
  20. Local nPerCom := 0
  21. Local nValCom := 0
  22. Local nOpc := 0
  23. Local nLin := 0
  24. Local f := 0
  25. Local lMoeda := .F.
  26. Local lNumber := .F.
  27. Local lVencido := .F.
  28. Local aTpFrete := {}
  29. Local nRecSCJ := 0
  30. private cLisPar := ""
  31. private cParUs := ""
  32. Private cFilVen := ""
  33. Private cCodLogin := ""
  34. Private cVendLogin := ""
  35. Private cVendedor := ""
  36. Private cSite := "u_PortalLogin.apw"
  37. Private cPagina := "Revisão de Orçamento"
  38. Private cTitle := "Portal SMS"
  39. Private cMenus := ""
  40. Private cAnexos := ""
  41. Private cDirOrc := "\anexosPortal\orcamentos\"
  42. Private cDirPortal := ""
  43. Private cEndServ := "" // Endereço do servidor da pagina de Portal
  44. Private cOrcCabec := ""
  45. Private cOrcItens := ""
  46. Private cItensHid := ""
  47. Private cBotoes := ""
  48. Private cBtnItens := ""
  49. Private cOptUF := ""
  50. Private cOptMun := ""
  51. Private cOptProd := ""
  52. Private cOptCond := ""
  53. Private cOptModal := ""
  54. Private cTblDesc := ""
  55. Private cCodOrc := ""
  56. Private cTabela := ""
  57. Private cCliente := ""
  58. Private cContato := ""
  59. Private cContDDD := ""
  60. Private cContTel := ""
  61. Private cTpCliente := ""
  62. Private cGrpTrib := ""
  63. Private cCondPag := ""
  64. Private cLocalEnt := ""
  65. Private cObra := ""
  66. Private cStatusObra := ""
  67. Private cIntermed := ""
  68. Private cOport := ""
  69. Private cRevOpt := ""
  70. Private cRegional := ""
  71. Private cTpFrete := ""
  72. Private cValFre := ""
  73. Private cPrazoEmb := ""
  74. Private cEstudo := ""
  75. Private cNumEst := ""
  76. Private cPrevFecha := ""
  77. Private cMargemCont := ""
  78. Private cTransp := ""
  79. Private cOptCli := ""
  80. Private cTotalReg := ""
  81. Private cLisPar := ""
  82. Private cParUs := ""
  83. //Private cEntrega := ""
  84. //Private cValidade := ""
  85. Private nTVlrUnit := 0
  86. Private nTVlrSDesc := 0
  87. Private nTQtdItem := 0
  88. Private nTTotal := 0
  89. Private nTComiss := 0
  90. Private nTImpostos := 0
  91. Private nTAcresc := 0
  92. Private nTFrete := 0
  93. Private nItens := 0
  94. Private lNewOrc := .F.
  95. Private lEdit := .F.
  96. Private lCopy := .F.
  97. Private cShowDesc := "false"
  98. Private aItens := {}
  99. Private aAnexos := {}
  100. Web Extended Init cHtml Start U_inSite()
  101. cVendLogin := u_GetUsrPR()
  102. cCodLogin := U_SetParPR(cVendLogin)
  103. If Empty(HttpSession->CodVend)
  104. cHtml:= '<META HTTP-EQUIV="Refresh" CONTENT="0 ; URL='+cSite+'">'
  105. Return cHtml
  106. Else
  107. If !Empty(HttpSession->Superv) .and. HttpSession->Superv <> HttpSession->CodVend
  108. HttpSession->CodVend:= HttpSession->Superv
  109. Endif
  110. Endif
  111. // Pega do parâmetro com o Titulo do Portal
  112. cTitle := SuperGetMV("PS_TITLE", .T., "Portal SMS")
  113. // Define a funcao a ser chama no link
  114. cSite := "u_SMSPortal.apw?PR="+cCodLogin
  115. // Monta o cabeçalho para a pagina
  116. cHeader := U_PSHeader(cTitle, cSite)
  117. //Função que atualiza os menus
  118. cMenus := U_GetMenus(AllTrim(Upper(Procname())), cVendLogin)
  119. //Atualiza as variáveis
  120. cEndServ := GetMv('MV_WFBRWSR')
  121. cParUs := GetMv('LC_FA074G1')
  122. cCodVend := cVendLogin
  123. cNomeVend:= HttpSession->Nome
  124. cItem := StrZero(1,TamSX3("CK_ITEM")[1])
  125. cOpcao := HttpGet->opc
  126. if !empty(HttpGet->rec)
  127. nRecSCJ := val(HttpGet->rec)
  128. EndIf
  129. lEdit := .F.
  130. lDele := .F.
  131. Do Case
  132. Case cOpcao == "view"
  133. nOpc:= 2
  134. cPagina += " - Visualizar"
  135. Case cOpcao == "edit"
  136. nOpc:= 4
  137. cPagina += " - Alterar"
  138. lEdit := .T.
  139. Case cOpcao == "dele"
  140. nOpc:= 5
  141. cPagina += " - Excluir"
  142. lDele := .T.
  143. Case cOpcao == "copy"
  144. nOpc = 3
  145. cPagina += " - Copiar"
  146. lEdit := .T.
  147. lCopy := .T.
  148. Case cOpcao == "rev"
  149. nOpc = 3
  150. cPagina += " - Revisar"
  151. lEdit := .T.
  152. lCopy := .T.
  153. EndCase
  154. //Posiciona no Orçamento
  155. If !Empty(nRecSCJ)
  156. dbSelectArea("SCJ")
  157. SCJ->(dbGoTo(nRecSCJ))
  158. //Troca de filial
  159. u_PTChgFil(SCJ->CJ_FILIAL)
  160. dbSelectArea("SCJ")
  161. SCJ->(dbGoTo(nRecSCJ))
  162. dbSelectArea("SCK")
  163. SCK->(DbSetOrder(1))
  164. SCK->(dbgotop())
  165. SCK->(dbSeek(xFilial("SCK")+SCJ->CJ_NUM))
  166. dbSelectArea("SA1")
  167. SA1->(DbSetOrder(1))
  168. SA1->(dbgotop())
  169. SA1->(dbSeek(xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA))
  170. Endif
  171. cLisPar:='<select class="form-control" name="parceiro" id="cmbParceiro"> '
  172. cLisPar+= '<option value="">Selecione...</option>'
  173. cLisPar+= U_GETPARC()
  174. cLisPar+='</select>'
  175. cFilOrc:= '<div class="row form-group">'
  176. cFilOrc+= ' <div class="col-lg-2">'
  177. cFilOrc+= ' <label class="control-label">Filial</label>'
  178. cFilOrc+= ' <input id="CJ_FILIAL" name="CJ_FILIAL" class="form-control" value="'+SCJ->CJ_FILIAL+'" disabled >'
  179. //cFilOrc+= ' <input id="CJ_VEND" name="CJ_VEND" type="hidden" value="'+SCJ->CJ_VEND+'">'
  180. cFilOrc+= ' </div>'
  181. cCodOrc:= ' <div class="col-lg-2">'
  182. cCodOrc+= ' <label class="control-label">Número</label>'
  183. cCodOrc+= ' <input id="CJ_NUM" name="CJ_NUM" class="form-control" value="'+IIf(lCopy, "", SCJ->CJ_NUM)+'" disabled >'
  184. cCodOrc+= ' <input type="hidden" id="RECCJANT" name="RECCJANT" value="'+CVALTOCHAR(nRecSCJ)+'" >'
  185. cCodOrc+= ' </div>'
  186. cCodOrc+= '</div>'
  187. //Cliente
  188. If lEdit .or. lCopy
  189. cCliente:=' <div class="flexContainer">
  190. cCliente+=' <input type="text" class="form-control smsediticon" placeholder="Digite o código, CPF/CNPJ ou Razão Social..." '
  191. cCliente+=' name="CJ_CLIENTE" id="CJ_CLIENTE"'
  192. cCliente+=' aria-required="true" data-live-search="true" '
  193. cCliente+=' autocomplete="off" value="'+SCJ->CJ_CLIENTE+'/'+SCJ->CJ_LOJA+' - '+Alltrim(Posicione("SA1",1,xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA,"A1_NOME"))+'" />'
  194. cCliente+=' <button class="btSearchCli" id="btSearchCli">'
  195. cCliente+=' <i class="fa fa-search" alt="Pesquisar"></i>'
  196. cCliente+=' </button>
  197. cCliente+=' </div>
  198. cOptCli+= u_ListaCli(cVendLogin,"",'S')
  199. HttpSession->Cliente:= SCJ->CJ_CLIENTE+SCJ->CJ_LOJA
  200. Else
  201. cCliente:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  202. cCliente+='{ "placeholder": "Selecione um Cliente", "allowClear": false }'+"'"+' name="CJ_CLIENTE" id="CJ_CLIENTE" '
  203. cCliente+=' disabled >' //value='+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA+'
  204. cCliente+=' <option value='+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA+'>'+SCJ->CJ_CLIENTE+'/'+SCJ->CJ_LOJA+' - '+Alltrim(Posicione("SA1",1,xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA,"A1_NOME"))+'</option>'
  205. cCliente+='</select>'
  206. Endif
  207. //Oportunidade
  208. cOport:= '<input id="CJ_NROPOR" name="CJ_NROPOR" class="form-control" value="'+SCJ->CJ_NROPOR+'" disabled >'
  209. cRevOpt:= '<input id="CJ_REVISA" name="CJ_REVISA" class="form-control" value="'+soma1(SCJ->CJ_REVISA)+'" disabled>'
  210. //Combo da tabela de preço
  211. cTabPadrao:= GetNewPar("PR_TABPADR","001")
  212. cTabela:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  213. cTabela+='{ "placeholder": "Selecione", "allowClear": false }'+"'"+' name="CJ_TABELA" id="CJ_TABELA" '
  214. cTabela+='</select>'
  215. //Tabela de preço por filial
  216. cQry:= "SELECT DA0_CODTAB, DA0_DESCRI "
  217. cQry+= "FROM "+RetSqlName("DA0")+" DA0 "
  218. cQry+= "WHERE DA0_FILIAL = '"+xFilial("DA0")+"'
  219. cQry+= "AND DA0_ATIVO = '1' "
  220. cQry+= "AND (DA0_DATATE = '' OR DA0_DATATE >= '"+dtos(dDataBase)+"') "
  221. cQry+= "AND DA0.D_E_L_E_T_ = ' ' "
  222. If Select("QFIL") > 0
  223. QFIL->(dbCloseArea())
  224. Endif
  225. TcQuery cQry New Alias "QFIL"
  226. While QFIL->(!Eof())
  227. cTabela+=' <option value="'+Alltrim(QFIL->DA0_CODTAB)+'" '+Iif(QFIL->DA0_CODTAB == SCJ->CJ_TABELA,'selected','')+'>'+Alltrim(QFIL->DA0_CODTAB)+' - '+Alltrim(QFIL->DA0_DESCRI)+'</option>'
  228. QFIL->(dbSkip())
  229. End
  230. cTabela+='</select>'
  231. //Tipo de cliente
  232. Posicione("SA1",1,xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA,"A1_TIPO")
  233. cTpCliente:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  234. cTpCliente+='{ "placeholder": "Selecione um Cliente", "allowClear": false }'+"'"+' name="CJ_TIPOCLI" id="A1_TIPOCLI" '
  235. cTpCliente+=' disabled >'
  236. cTpCliente+=' <option value="'+SA1->A1_TIPO+'">'+X3COMBO("A1_TIPO",SA1->A1_TIPO)+'</option>'
  237. cTpCliente+='</select>'
  238. //Grupo de tributação do cliente
  239. cGrpTrib:= '<input id="CJ_GRPTRIB" name="CJ_GRPTRIB" class="form-control" value="'+SCJ->CJ_GRPTRIB+'" disabled>'
  240. //Contato
  241. cContato:= ' <input id="CJ_XCONTAT" name="CJ_XCONTAT" maxlength="'+cvaltochar(GetSX3Cache("CJ_XCONTAT","X3_TAMANHO"))+'" class="form-control" value="'+Alltrim(SCJ->CJ_XCONTAT)+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  242. cContDDD:= ' <input id="CJ_XCONDDD" name="CJ_XCONDDD" maxlength="'+cvaltochar(GetSX3Cache("CJ_XCONDDD","X3_TAMANHO"))+'" class="form-control only-numbers" value="'+Alltrim(SCJ->CJ_XCONDDD)+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  243. cContTel:= ' <input id="CJ_XCONTEL" name="CJ_XCONTEL" maxlength="'+cvaltochar(GetSX3Cache("CJ_XCONTEL","X3_TAMANHO"))+'" class="form-control only-numbers" value="'+Alltrim(SCJ->CJ_XCONTEL)+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  244. //Cliente de Entrega
  245. cCliEntr:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  246. cCliEntr+='{ "placeholder": "Selecione um Cliente", "allowClear": false }'+"'"
  247. cCliEntr+='name="CJ_CLIENT" id="CJ_CLIENT" '
  248. If lEdit .or. lCopy
  249. cCliEntr+='onchange="javascript:atuLocEnt();" '
  250. Else
  251. cCliEntr+='disabled'
  252. Endif
  253. cCliEntr+='>'
  254. If lEdit .or. lCopy
  255. cCliEntr+=' <option data-hidden="true"></option>'
  256. Endif
  257. // Localiza os clientes
  258. cCliEntr+= u_ListaCli(cVendLogin,"QRY->A1_COD+QRY->A1_LOJA==SCJ->CJ_CLIENT+SCJ->CJ_LOJAENT",'N')
  259. cCliEntr+='</select>'
  260. //Local de entrega
  261. cLocalEnt:= '<div class="flexContainer">'
  262. cLocalEnt+= ' <input id="CJ_UFENT" name="CJ_UFENT" class="form-control" value="'+Alltrim(SCJ->CJ_UFENT)+'" disabled>' //onchange="javascript:atuVlrFrete();"
  263. cLocalEnt+=' <button class="btEndEntrega" id="btEndEntrega">'
  264. cLocalEnt+=' <i class="fa fa-exchange" title="Alterar endereço"></i>'
  265. cLocalEnt+=' </button>'
  266. cLocalEnt+='</div>'
  267. //Alimenta os estados
  268. cOptUF:= u_ListaUF()
  269. //Nome da obra
  270. cObra:= ' <input id="CJ_OBRA" name="CJ_OBRA" maxlength="'+cvaltochar(GetSX3Cache("CJ_OBRA","X3_TAMANHO"))+'" class="form-control text-uppercase" value="'+Alltrim(Upper(SCJ->CJ_OBRA))+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  271. //cStatusObra:= ' <input id="CJ_VEND6" name="CJ_VEND6" class="form-control" value="'+Upper(X3COMBO("CJ_VEND6",SCJ->CJ_VEND6))+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  272. aStObra:= RetSx3Box(Posicione('SX3',2,'CJ_VEND6','X3CBox()'),,,1)
  273. cStatusObra:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  274. cStatusObra+=' name="CJ_VEND6" id="CJ_VEND6" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  275. cStatusObra+='<option value=""></option>'
  276. For f:= 1 to Len(aStObra)
  277. cStatusObra+=' <option value="'+Left(aStObra[f,1],2)+'" '+Iif(Left(aStObra[f,1],2)==Alltrim(SCJ->CJ_VEND6),'selected','')+'>'+aStObra[f,1]+'</option>'
  278. Next
  279. cStatusObra+='</select>'
  280. //Tipo da Obra
  281. cTpObra:='<select data-plugin-selectTwo class="form-control poulate mb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  282. cTpObra+=' name="CJ_YOBRATP" id="CJ_YOBRATP" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  283. cTpObra+='<option value=""></option>'
  284. //Alimenta os tipos de obra
  285. cTpObra+= u_ListaObra(SCJ->CJ_YOBRATP)
  286. cTpObra+='</select>'
  287. //Seleciona as condições de pagamento disponíveis no combo
  288. cCondPag:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  289. cCondPag+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_CONDPAG" id="CJ_CONDPAG" '
  290. cCondPag+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+' onchange="javascript:vldCond()">'
  291. cCondPag+=' <option value="'+SCJ->CJ_CONDPAG+'">'+SCJ->CJ_CONDPAG+" - "+Posicione("SE4",1,xFilial("SE4")+SCJ->CJ_CONDPAG,"E4_DESCRI")+'</option>'
  292. If lEdit
  293. //Verifica a tabela cadastrada no cliente
  294. SE4->(dbSeek(xFilial("SE4")+SA1->A1_COND))
  295. //Seleciona as condições de pagamento disponíveis no combo
  296. cQry:= " Select E4_CODIGO, E4_DESCRI, E4_ACRSFIN"
  297. cQry+= " From "+RetSqlName("SE4")+" SE4 "
  298. cQry+= " Where E4_FILIAL = '"+xFilial("SE4")+"' "
  299. cQry+= " And E4_MSBLQL <> '1' "
  300. cQry+= " And E4_CODIGO NOT IN ('"+SCJ->CJ_CONDPAG+"') "
  301. cQry+= " And SE4.D_E_L_E_T_ = ' ' "
  302. If Select("QRP") > 0
  303. QRP->(dbCloseArea())
  304. Endif
  305. TcQuery cqry New Alias "QRP"
  306. While QRP->(!Eof())
  307. cCondPag+=' <option value="'+QRP->E4_CODIGO+'" '+Iif(Alltrim(QRP->E4_CODIGO) == AllTrim(SCJ->CJ_CONDPAG),'selected','')+'>'+Alltrim(QRP->E4_CODIGO)+" - "+Alltrim(QRP->E4_DESCRI)+'</option>'
  308. QRP->(dbSkip())
  309. End
  310. QRP->(dbCloseArea())
  311. Endif
  312. cCondPag+='</select>'
  313. //Previsão Fechamento
  314. aPrevisao:= {{"B","Balizador"},{"A","30/120 dias"},{"V","Em 30 dias"},{"M","Após 4 meses"},{"C","Concorrência"}}
  315. //cPrevFecha:= ' <input id="CJ_TERMOME" name="CJ_TERMOME" class="form-control" value="'+cPrevisao+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  316. cPrevFecha:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  317. cPrevFecha+=' name="CJ_TERMOME" id="CJ_TERMOME" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  318. cPrevFecha+='<option value=""></option>'
  319. For f:= 1 to Len(aPrevisao)
  320. cPrevFecha+=' <option value="'+aPrevisao[f,1]+'" '+Iif(aPrevisao[f,1]==SCJ->CJ_TERMOME,'selected','')+'>'+aPrevisao[f,2]+'</option>'
  321. Next
  322. cPrevFecha+='</select>'
  323. //Intermediador
  324. If !(lEdit .or. lCopy)
  325. cIntermed:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  326. cIntermed+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' disabled '
  327. Else
  328. cIntermed:='<select class="form-control populate selectpicker" data-live-search="true" '
  329. cIntermed+='title="Selecione..." '
  330. Endif
  331. cIntermed+=' name="CJ_CLIINTE" id="CJ_CLIINTE" >'
  332. cIntermed+='<option data-hidden="true"></option>'
  333. //Busca a lista de clientes
  334. cIntermed+= u_ListaCli(cVendLogin,"QRY->A1_COD==SCJ->CJ_CLIINTE",'S')
  335. cIntermed+='</select>'
  336. //Retorno
  337. nDiasVal:= 0
  338. cRetorno:='<input type="text" id="CJ_RETORNO" name="CJ_RETORNO" data-plugin-datepicker data-plugin-options='+"'"+'{ "startDate": "+'+cvaltochar(nDiasVal)+'d", "language": "pt-BR",'
  339. cRetorno+='"daysOfWeekDisabled": "[0]","daysOfWeekHighlighted":"[0]","autoclose": "true","disabled":"true"}'+"'"+' class="form-control only-numbers" placeholder="__/__/____" '
  340. cRetorno+='value="'+dtoc(SCJ->CJ_RETORNO)+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  341. //Estudo Luminotécnico
  342. //cEstudo:= ' <input id="CJ_LUMINOT" name="CJ_LUMINOT" class="form-control" value="'+Upper(X3COMBO("CJ_LUMINOT",SCJ->CJ_LUMINOT))+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  343. aEstd:= RetSx3Box(Posicione('SX3',2,'CJ_LUMINOT','X3CBox()'),,,1)
  344. aSort(aEstd)
  345. cEstudo:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  346. cEstudo+=' name="CJ_LUMINOT" id="CJ_LUMINOT" '+Iif(lCopy .or. lEdit,'','disabled')+' onchange="javascript:vldEstudo()">'
  347. cEstudo+='<option value=""></option>'
  348. For f:= 1 to Len(aEstd)
  349. cEstudo+=' <option value="'+aEstd[f,2]+'" '+Iif(AllTrim(aEstd[f,2]) == AllTrim(SCJ->CJ_LUMINOT),'selected','')+'>'+Upper(aEstd[f,3])+'</option>'
  350. Next
  351. cEstudo+='</select>'
  352. cNumEst:= ' <input id="CJ_REGLUMI" name="CJ_REGLUMI" maxlength="'+cvaltochar(GetSX3Cache("CJ_REGLUMI","X3_TAMANHO"))+'" class="form-control" value="'+SCJ->CJ_REGLUMI+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  353. //Segmento
  354. aSegmen:= RetSx3Box(Posicione('SX3',2,'CJ_SEGMENT','X3CBox()'),,,1)
  355. cSegmento:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...","minimumResultsForSearch": "-1"}'+"'"'
  356. cSegmento+=' name="CJ_SEGMENT" id="CJ_SEGMENT" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  357. cSegmento+=' <option value=""></option>'
  358. For f:= 1 to Len(aSegmen)
  359. cSegmento+=' <option value="'+aSegmen[f,1]+'" '+Iif(aSegmen[f,1]==Alltrim(SCJ->CJ_SEGMENT),'selected','')+'>'+aSegmen[f,1]+'</option>'
  360. Next
  361. cSegmento+='</select>'
  362. //Prospecção
  363. aProsp:= RetSx3Box(Posicione('SX3',2,'CJ_PROPECC','X3CBox()'),,,1)
  364. aSort(aProsp)
  365. cProsp:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  366. cProsp+=' name="CJ_PROPECC" id="CJ_PROPECC" onchange="javascript:vldProspec()" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  367. cProsp+='<option value=""></option>'
  368. For f:= 1 to Len(aProsp)
  369. cProsp+=' <option value="'+aProsp[f,2]+'" '+Iif(aProsp[f,2]==SCJ->CJ_PROPECC,'selected','')+'>'+Upper(aProsp[f,3])+'</option>'
  370. Next
  371. cProsp+='</select>'
  372. //Prospectado por
  373. aProsp:= RetSx3Box(Posicione('SX3',2,'CJ_PROSCOD','X3CBox()'),,,1)
  374. cProspPor:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...","minimumResultsForSearch": "-1"}'+"'"'
  375. cProspPor+=' name="CJ_PROSCOD" id="CJ_PROSCOD" '+Iif(lCopy .or. lEdit /*.or. !Empty(SCJ->CJ_PROSCOD)*/,'','disabled')+'>'
  376. cProspPor+=' <option value=""></option>'
  377. For f:= 1 to Len(aProsp)
  378. cProspPor+=' <option value="'+aProsp[f,1]+'" '+Iif(aProsp[f,1]==Alltrim(SCJ->CJ_PROSCOD),'selected','')+'>'+aProsp[f,1]+'</option>'
  379. Next
  380. cProspPor+='</select>'
  381. //Regional
  382. cRegional:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  383. cRegional+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_REGIAO" id="CJ_REGIAO" '
  384. cRegional+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  385. If lCopy .or. lEdit
  386. cRegional+= u_ListaVend(.T.,SCJ->CJ_REGIAO)
  387. Else
  388. cRegional+='<option value="'+SCJ->CJ_REGIAO+'">'+SCJ->CJ_REGIAO+" - "+Posicione("SA3",1,xFilial("SA3")+SCJ->CJ_REGIAO,"A3_NOME")+'</option>'
  389. Endif
  390. cRegional+='</select>'
  391. //Vendedor do cliente
  392. cVend2:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  393. cVend2+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_VEND" id="CJ_VEND" '
  394. cVend2+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  395. If lCopy .or. lEdit
  396. cVend2+= u_ListaVend(.F.,SCJ->CJ_VEND)
  397. Else
  398. cVend2+='<option value="'+SCJ->CJ_VEND+'">'+SCJ->CJ_VEND+" - "+Posicione("SA3",1,xFilial("SA3")+SCJ->CJ_VEND,"A3_NOME")+'</option>'
  399. Endif
  400. cVend2+='</select>'
  401. //Vendedor da oportunidade
  402. cVend3:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-live-search="true" data-plugin-options='+"'"
  403. cVend3+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"
  404. cVend3+=' name="CJ_VEND3" id="CJ_VEND3" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  405. If lCopy .or. lEdit
  406. cVend3+= u_ListaVend(.F.,SCJ->CJ_VEND3)
  407. Else
  408. cVend3+='<option value="'+SCJ->CJ_VEND3+'">'+SCJ->CJ_VEND3+" - "+Posicione("SA3",1,xFilial("SA3")+SCJ->CJ_VEND3,"A3_NOME")+'</option>'
  409. Endif
  410. cVend3+='</select>'
  411. //Vendedor 4
  412. cVend4:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  413. cVend4+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_VEND4" id="CJ_VEND4" '
  414. cVend4+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  415. cVend4+= u_Vend04(SCJ->CJ_VEND4)
  416. cVend4+='</select>'
  417. //Especificado por
  418. cEspecif:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  419. cEspecif+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_CODESP" id="CJ_CODESP" '
  420. cEspecif+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  421. cEspecif+= u_ListaEsp(SCJ->CJ_CODESP)
  422. cEspecif+='</select>'
  423. //Negociadora
  424. cNegociad:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  425. cNegociad+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_VEND7" id="CJ_VEND7" '
  426. cNegociad+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  427. cNegociad+= u_ListaNeg(SCJ->CJ_VEND7)
  428. cNegociad+='</select>'
  429. //Validade do Orçamento
  430. nDiasVal:= GetNewPar("PR_DTVALID",10)
  431. cValidade:='<input type="text" id="CJ_VALIDA" name="CJ_VALIDA" data-plugin-datepicker data-plugin-options='+"'"+'{ "startDate": "+'+cvaltochar(nDiasVal)+'d", "language": "pt-BR",'
  432. cValidade+='"daysOfWeekDisabled": "[0]","daysOfWeekHighlighted":"[0]","autoclose": "true","disabled":"true"}'+"'"+' class="form-control only-numbers" placeholder="__/__/____" '
  433. cValidade+='value="'+dtoc(SCJ->CJ_VALIDA)+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  434. //Prazo de embarque
  435. cPrazoEmb:= '<input id="CJ_PRZEMB" name="CJ_PRZEMB" maxlength="'+cvaltochar(GetSX3Cache("CJ_PRZEMB","X3_TAMANHO"))+'" class="form-control" value="'+SCJ->CJ_PRZEMB+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  436. //Tipo de frete
  437. aTpFrete:= {{"S","Sem Frete"},{"C","CIF"},{"F","FOB"}}
  438. cTpFrete:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"minimumResultsForSearch": "-1"}'+"'"'
  439. cTpFrete+=' name="CJ_TPFRETE" id="CJ_TPFRETE" onchange="javascript:VldFrete()" '
  440. //cTpFrete:='<select class="form-control mb-md" name="CJ_TPFRETE" id="CJ_TPFRETE" onchange="javascript:VldFrete()" value="'+SCJ->CJ_TPFRETE+'"'
  441. cTpFrete+= Iif(!lEdit,'disabled','')+'>'
  442. If lEdit
  443. For f:= 1 to Len(aTpFrete)
  444. cTpFrete+=' <option value="'+aTpFrete[f,1]+'" '+Iif(AllTrim(aTpFrete[f,1]) == AllTrim(SCJ->CJ_TPFRETE),'selected','')+'>'+aTpFrete[f,2]+'</option>'
  445. Next
  446. Else
  447. nPosFrete:= aScan(aTpFrete,{|x|x[1]==SCJ->CJ_TPFRETE})
  448. If nPosFrete = 0
  449. nPosFrete:= 1
  450. Endif
  451. cTpFrete+=' <option value="'+SCJ->CJ_TPFRETE+'">'+aTpFrete[nPosFrete,2]+'</option>'
  452. Endif
  453. cTpFrete+='</select>'
  454. cPFrete:= '<input id="CJ_PERCFRT" name="CJ_PERCFRT" class="form-control percentual text-right" placeholder="0,00" maxlength="'+cvaltochar(GetSX3Cache("CJ_PERCFRT","X3_TAMANHO")+1)+'" '
  455. cPFrete+= 'value="'+TransForm(SCJ->CJ_PERCFRT,"@E 999.99")+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  456. cValFre:= '<input id="CJ_FRETE" name="CJ_FRETE" class="form-control money text-right" placeholder="0,00" '
  457. cValFre+= 'value="'+Transform(SCJ->CJ_FRETE,"@E 999,999,999,999.99")+'" '
  458. cValFre+= Iif((!lCopy .and. !lEdit) .or. SCJ->CJ_TPFRETE = "S" ,'disabled','')+'>'
  459. nTFrete+= SCJ->CJ_FRETE
  460. //% RT
  461. cComRT:= '<input id="CJ_COMISTR" name="CJ_COMISTR" class="form-control percentual text-right" placeholder="0,00" maxlength="'+cvaltochar(GetSX3Cache("CJ_COMISTR","X3_TAMANHO")+1)+'" '
  462. cComRT+= 'value="'+Transform(SCJ->CJ_COMISTR,PesqPict("SCJ","CJ_COMISTR"))+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  463. //Observação Comercial
  464. cObsCom:= SCJ->CJ_OBS
  465. //Margem de Contribuição
  466. If HttpSession->Tipo <> "R" //Representante
  467. cMargemCont:= ' <div class="col-lg-2"> '
  468. cMargemCont+= ' <label class="control-label">MC</label> '
  469. cMargemCont+= ' <input id="MARGEM" name="MARGEM" class="form-control" value="'+u_getMCOrc() + "%"+'" disabled >'
  470. cMargemCont+= ' </div>'
  471. Endif
  472. //Preenchimento dos itens
  473. /*
  474. aItens - array que define o cabeçalho da tabela de produtos
  475. [1] - Nome da coluna
  476. [2] - Nome do campo
  477. [3] - Tamanho
  478. [4] - Alinhamento
  479. [5] - Tipo
  480. [6] - Editável
  481. [7] - Obrigatório
  482. [8] - Moeda
  483. [9] - Placeholder
  484. [10]- Hidden
  485. [11] - MaxLength
  486. */
  487. aAdd(aItens, {"Item","CK_ITEM","*","text-left","C",.F.,.F.,.F.,"",.F.,""})
  488. aAdd(aItens, {"Produto","CK_PRODUTO","300px"," text-left","C",lEdit,.T.,.F.,"Selecione...",.F.,""})
  489. aAdd(aItens, {"Quant.","CK_QTDVEN","*"," text-right only-numbers","N",lEdit,.T.,.F.,"0",.F.,""})
  490. aAdd(aItens, {"Observação","CK_OBS","*"," text-left","C",lEdit,.F.,.F.,"",.F.,"80"})
  491. aAdd(aItens, {"Prazo de Embarque","CK_PRZEMB","70px","text-right only-numbers","N",.F.,.F.,.F.,"",.F.,"3"})
  492. aAdd(aItens, {"Vlr Unitário","CK_PRCVEN","*"," text-right","N",lEdit,.F.,.T.,"0,00",.F.,""})
  493. aAdd(aItens, {"Vlr c/ Impostos","CK_XPRCIMP","*","text-right","N",.F.,.F.,.T.,"0,00",.T.,""})
  494. aAdd(aItens, {"Vlr de Venda","iCK_PRCVEN","*"," text-right myformato","N",.F.,.T.,.T.,"0,00",.T.,""})
  495. aAdd(aItens, {"Custo","CK_CUSTO","*"," text-right myformato","N",.F.,.F.,.T.,"0,00",.T.,""})
  496. aAdd(aItens, {"IPI","CK_XVALIPI","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  497. aAdd(aItens, {"ICMS","CK_XVALICM","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  498. aAdd(aItens, {"ICMS ST","CK_XICMST","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  499. aAdd(aItens, {"% Desconto","CK_DESCONT","*"," text-right percentual","N",lEdit,.F.,.T.,"0,00",Iif(HttpSession->Tipo <> "R",.F.,.T.) ,"7"})
  500. aAdd(aItens, {"Diretor","CK_NOMDIRE","*"," text-left","C",.T.,.F.,.T.,"",.T.,"12"})
  501. aAdd(aItens, {"% Comissão","PER_COM","*"," text-right ","N",.F.,.F.,.T.,"0,00",.T.,""})
  502. aAdd(aItens, {"Vlr Comissão","VAL_COM","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  503. aAdd(aItens, {"Total","CK_VALOR","150px"," text-right","N",.F.,.F.,.T.,"0,00",.F.,""})
  504. aAdd(aItens, {"","ACAO","*"," text-center","X",lEdit,.F.,.F.,"",.F.,""})
  505. // Cria o cabeçalho dos Itens
  506. For nLin := 1 to Len(aItens)
  507. cOrcCabec += '<th'+Iif(aItens[nLin,2] == "CK_VALOR",' width="'+aItens[nLin,3]+'"',Iif(aItens[nLin,2] == "CK_PRODUTO",' width="'+aItens[nLin,3]+'"',''))
  508. cOrcCabec+= Iif(aItens[nLin,10],' hidden','')+'>'+aItens[nLin][1]+'</th>'
  509. Next
  510. dbSelectArea("SCK")
  511. SCK->(dbSeek(SCJ->CJ_FILIAL+SCJ->CJ_NUM))
  512. While SCK->(!Eof()) .and. SCK->CK_FILIAL == SCJ->CJ_FILIAL .and. SCK->CK_NUM == SCJ->CJ_NUM
  513. nItens++
  514. cItem := StrZero(nItens,TamSX3("CK_ITEM")[1])
  515. Posicione("SB1",1,xFilial("SB1")+SCK->CK_PRODUTO,"B1_DESC")
  516. If SB5->(MsSeek(xFilial("SB5")+SCK->CK_PRODUTO))
  517. If SB5->B5_DTVLESP + 30 < dDataBase
  518. lVencido:= .T.
  519. Endif
  520. Endif
  521. cOrcItens += '<tr class="odd" id="linha'+StrZero(nItens,2)+'">'
  522. lProdBloq:= .F.
  523. SB1->(dbSetOrder(1))
  524. SB1->(dbSeek(xFilial("SB1")+SCK->CK_PRODUTO))
  525. If SB1->B1_MSBLQL = '1'
  526. lProdBloq:= .T.
  527. Endif
  528. DA1->(dbSetOrder(1))
  529. DA1->(dbSeek(xFilial("DA1")+SCJ->CJ_TABELA+SCK->CK_PRODUTO))
  530. // gera os produtos de acordo com o Cliente e Tabela
  531. //cOptProd := u_GetProdOrc(SCJ->CJ_CLIENTE, SCJ->CJ_TABELA, "")
  532. For nLin := 1 to Len(aItens)
  533. If aItens[nLin,2] == "ACAO"
  534. cOrcItens += '<td class="actions">'
  535. If lEdit .or. lCopy //!lDele
  536. //cOrcItens += ' <a href="#" id="btnRemItm" name="btnRemItm" class="on-default remove-row"><i class="fa fa-times-circle"></i></a>'
  537. //cOrcItens += ' <i class="fa fa-info fa-lg" data-toggle="tooltip" data-original-title="Detalhes da linha" onclick="detalheOrc('+"'"+cItem+"'"+');"></i>'
  538. If lEdit .or. lCopy
  539. cOrcItens += ' <i class="fa fa-times-circle fa-lg" data-toggle="tooltip" data-original-title="Remover a linha" onclick="removeItem('+"'"+cItem+"'"+');"></i>
  540. Endif
  541. Endif
  542. If !lDele
  543. cOrcItens += ' <i class="fa fa-info fa-lg" data-toggle="tooltip" data-original-title="Detalhes da linha" onclick="detalheOrc('+"'"+cItem+"'"+');"></i>'
  544. Endif
  545. cOrcItens += '</td>
  546. Else
  547. If aItens[nLin,2] == "CK_PRODUTO"
  548. cOrcItens += '<td>' //class="form-group row pb-4"
  549. Else
  550. cOrcItens += '<td'+Iif(!Empty(aItens[nLin][4]),' align="'+aItens[nLin][4]+'"',"")+Iif(aItens[nLin,10],'hidden','')+'>'
  551. Endif
  552. lMoeda:= aItens[nLin,8] //Indica se é Moeda
  553. lNumber:= aItens[nLin,5] = "N" //Indica que é numérico
  554. xValue:= ""
  555. Do Case
  556. Case aItens[nLin][5] == 'C'
  557. If aItens[nLin,2] == "CK_PRODUTO"
  558. xValue := AllTrim(SCK->&(aItens[nLin][2]))+' - '+Alltrim(SB1->B1_DESC)
  559. Else
  560. //Verifica se o produto está bloqueado
  561. If aItens[nLin,2] == "CK_ITEM" .and. lEdit .and. lProdBloq //lCopy .and. SB1->B1_MSBLQL = '1'
  562. xValue := 'xx'
  563. //lProdBloq:= .T.
  564. Else
  565. xValue := AllTrim(SCK->&(aItens[nLin][2]))
  566. Endif
  567. Endif
  568. Case aItens[nLin][5] == 'N'
  569. If aItens[nLin,2] == "CK_QTDVEN"
  570. xValue := Iif(lNewOrc,"",Alltrim(cvaltochar(SCK->&(aItens[nLin][2]))))
  571. ElseIf aItens[nLin,2] == "PER_COM"
  572. xValue := Iif(lNewOrc,"",Alltrim(PadR(TransForm(nPerCom,PesqPict("SD2","D2_COMIS1")),TamSX3("D2_COMIS1")[1])))
  573. ElseIf aItens[nLin,2] == "VAL_COM"
  574. xValue := Iif(lNewOrc,"",Alltrim(PadR(TransForm(nValCom,PesqPict("SCK","CK_PRCVEN")),TamSX3("CK_PRCVEN")[1])))
  575. ElseIf aItens[nLin,2] == "iCK_PRCVEN"
  576. //xValue := Iif(lNewOrc,"",Alltrim(cvaltochar(SCK->CK_PRCVEN)))
  577. If lEdit
  578. nVlrProd:= u_getValProd(SCJ->CJ_COMISTR,SCJ->CJ_PERCFRT)
  579. xValue := Alltrim(TransForm(nVlrProd,PesqPict("DA1","DA1_PRCVEN")))
  580. Else
  581. xValue := Iif(lNewOrc,"",Alltrim(TransForm(SCK->CK_PRCVEN,PesqPict("SCK","CK_PRCVEN"))))
  582. Endif
  583. Elseif aItens[nLin,2] == "CK_PRCVEN"
  584. If lEdit
  585. nVlrProd:= u_getValProd(SCJ->CJ_COMISTR,SCJ->CJ_PERCFRT)
  586. xValue := Alltrim(TransForm(nVlrProd,PesqPict("DA1","DA1_PRCVEN")))
  587. nVlrCDesc:= nVlrProd
  588. Else
  589. xValue := Alltrim(TransForm(SCK->CK_PRUNIT,PesqPict("SCK","CK_PRUNIT")))
  590. nVlrCDesc:= SCK->CK_PRUNIT
  591. Endif
  592. Elseif aItens[nLin,2] == "CK_DESCONT"
  593. xValue:= Alltrim(TransForm(SCK->CK_DESCACM,PesqPict("SCK","CK_DESCONT")))
  594. Elseif aItens[nLin,2] == "CK_VALOR"
  595. If lEdit
  596. nVlrProd:= u_getValProd(SCJ->CJ_COMISTR,SCJ->CJ_PERCFRT)
  597. xValue := Alltrim(TransForm(nVlrProd*SCK->CK_QTDVEN,PesqPict("SCK",aItens[nLin,2])))
  598. nTotValor:= nVlrProd*SCK->CK_QTDVEN
  599. Else
  600. xValue := Alltrim(TransForm(SCK->(CK_VALOR/*+CK_XVALIPI+CK_XICMST*/),PesqPict("SCK",aItens[nLin,2])))
  601. nTotValor:=SCK->CK_VALOR
  602. Endif
  603. Else
  604. If SCK->(FieldPos(aItens[nLin][2])) > 0
  605. xValue := Alltrim(TransForm(SCK->&(aItens[nLin][2]),PesqPict("SCK",aItens[nLin,2])))
  606. Else
  607. xValue := ""
  608. Endif
  609. Endif
  610. EndCase
  611. If aItens[nLin,6] //Campo Editável
  612. If aItens[nLin,2] == "CK_PRODUTO"
  613. //Cria o select para o produto
  614. If (lEdit .or. lCopy) .and. SB1->B1_MSBLQL <> '1'
  615. cOrcItens +='<div class="form-group">'
  616. cOrcItens +=' <div class="col-md-12">
  617. cOrcItens +=' <div class="flexContainer">
  618. cOrcItens +=' <input type="text" class="form-control smsediticon" placeholder="Digite o código ou descrição..." '
  619. cOrcItens +=' name="CK_PRODUTO'+cItem+'" id="CK_PRODUTO'+cItem+'"'
  620. cOrcItens += Iif(aItens[nLin][7],'required="" aria-required="true" ','')+' data-live-search="true" autocomplete="off" '
  621. cOrcItens +=' value="'+Alltrim(SCK->CK_PRODUTO)+' -- '+Alltrim(SB1->B1_DESC)+'" >'
  622. cOrcItens +=' <button class="btSearch" id="btSearch"'+cItem+'>'
  623. cOrcItens +=' <i class="fa fa-search" alt="Pesquisar"></i>'
  624. cOrcItens +=' </button>
  625. cOrcItens +=' </div>
  626. cOrcItens +=' </div>
  627. cOrcItens +='</div>
  628. Else
  629. cOrcItens +='<select class="selectpicker" name="CK_PRODUTO'+cItem+'" id="CK_PRODUTO'+cItem+'" '
  630. cOrcItens += Iif(aItens[nLin][7],'required="" aria-required="true" ','')+' data-live-search="true" '
  631. cOrcItens +=' data-width="569px" title="Produto bloqueado" disabled >' //style="size:4" data-width="90%" style="height:90%"
  632. cOrcItens += U_GetProdOrc(SCJ->CJ_CLIENTE, SCJ->CJ_TABELA, SCK->CK_PRODUTO)
  633. cOrcItens+='</select>'
  634. Endif
  635. Else
  636. cOrcItens += '<input id="'+aItens[nLin][2]+cItem+'" data-prop="'+aItens[nLin][2]+'" name="'+aItens[nLin][2]+cItem+'" class="form-control'
  637. cOrcItens += Iif(lNumber, aItens[nLin][4], "")
  638. cOrcItens +=If(lMoeda," ",If(lNumber," only-numbers",""))+'" type="text" '
  639. cOrcItens += 'placeholder="'+aItens[nLin,9]+'" '
  640. //Atribui as funções javascript
  641. If aItens[nLin,2] == "CK_QTDVEN"
  642. cOrcItens+='onblur="javascript:VldQtd('+"'"+cItem+"'"+') "'
  643. Endif
  644. If aItens[nLin,2] == "iCK_PRCVEN"
  645. cOrcItens+='onblur="javascript:VldValor('+"'"+cItem+"'"+') " '
  646. Endif
  647. If aItens[nLin,2] == "CK_DESCONT"
  648. cVldDesc:= Iif(GetMv("LC_OR1012A",,.F.),'S','N')
  649. cOrcItens+='onblur="javascript:VldValor('+"'"+cItem+"'"+','+"'"+cVldDesc+"'"+')" maxlength="7" '
  650. Endif
  651. If aItens[nLin,2] $ ("CK_QTDVEN|iCK_PRCVEN|CK_DESCONT")
  652. cOrcItens+='onkeyup="javascript:TotalItem('+"'"+cItem+"'"+') "'
  653. Endif
  654. //Campo obrigatório
  655. cOrcItens += Iif(aItens[nLin][7],'required="" aria-required="true" ','')
  656. If (lEdit .or. lCopy) .and. !lProdBloq//Inicia todos os campos desabilitados caso não for para editar ou copiar
  657. If !(aItens[nLin,2] $ "CK_QTDVEN|CK_DESCONT|CK_OBS|CK_PRZEMB") //.And. aItens[nLin,2] <> "CK_XPEDCLI" .And. aItens[nLin,2] <> "CK_XITEMCL"
  658. cOrcItens += 'disabled '
  659. EndIf
  660. Else
  661. cOrcItens += 'disabled '
  662. EndIf
  663. cOrcItens += 'value="'+Alltrim(xValue)+'">'
  664. Endif
  665. Else
  666. cOrcItens += '<input id="'+aItens[nLin][2]+cItem+'" data-prop="'+aItens[nLin][2]+'" name="'+aItens[nLin][2]+cItem+'" '
  667. cOrcItens += 'class="form-control input-block '+Iif(lNumber, aItens[nLin][4], "")+'" '
  668. cOrcItens += 'type="text" disabled width="" '
  669. If aItens[nLin,2] $ "CK_PRODUTO|CK_OBS"
  670. cOrcItens += 'title="'+Alltrim(xValue)+'" '
  671. Endif
  672. cOrcItens += 'value="'+Alltrim(xValue)+'">'
  673. Endif
  674. Endif
  675. cOrcItens += '</td>'
  676. Next
  677. //Inputs Hidden
  678. cItensHid += '<input type="hidden" class="" id="ALIQ_ICMS'+cItem+'" name="ALIQ_ICMS'+cItem+'" value="'+cValtochar(SCK->CK_XALIICM)+'">'
  679. cItensHid += '<input type="hidden" class="" id="ALIQ_IPI'+cItem+'" name="ALIQ_IPI'+cItem+'" value="'+cValtochar(SCK->CK_XALIIPI)+'">'
  680. cItensHid += '<input type="hidden" class="" id="ALIQ_ST'+cItem+'" name="ALIQ_ST'+cItem+'" value="'+cValtochar(SCK->CK_XALIST)+'">'
  681. cItensHid += '<input type="hidden" class="" id="VAL_ICMS'+cItem+'" name="VAL_ICMS'+cItem+'" value="'+Alltrim(Transform(SCK->CK_ICMS,PesqPict("SCK","CK_ICMS")))+'">'
  682. cItensHid += '<input type="hidden" class="" id="VAL_IPI'+cItem+'" name="VAL_IPI'+cItem+'" value="'+Alltrim(Transform(SCK->CK_IPI,PesqPict("SCK","CK_IPI")))+'">'
  683. cItensHid += '<input type="hidden" class="" id="VAL_ST'+cItem+'" name="VAL_ST'+cItem+'" value="'+Alltrim(Transform(SCK->CK_ST,PesqPict("SCK","CK_ST")))+'">'
  684. cItensHid += '<input type="hidden" class="" id="BASE_ICMS'+cItem+'" name="BASE_ICMS'+cItem+'" value="0">'
  685. cItensHid += '<input type="hidden" class="" id="BASE_ST'+cItem+'" name="BASE_ST'+cItem+'" value="0">'
  686. cItensHid += '<input type="hidden" class="" id="BASE_IPI'+cItem+'" name="BASE_IPI'+cItem+'" value="0">'
  687. cItensHid += '<input type="hidden" class="" id="IMP_PRCTAB'+cItem+'" name="IMP_PRCTAB'+cItem+'" value="0">'
  688. cItensHid += '<input type="hidden" class="" id="QTD_EMB'+cItem+'" name="QTD_EMB'+cItem+'" value="'+cValtochar(SB1->B1_QE)+'">'
  689. cItensHid += '<input type="hidden" class="" id="CK_TES'+cItem+'" name="CK_TES'+cItem+'" value="'+SCK->CK_TES+'">'
  690. cItensHid += '<input type="hidden" class="" id="QTDMIN'+cItem+'" name="QTDMIN'+cItem+'" value="">'
  691. cItensHid += '<input type="hidden" class="" id="GRUPO'+cItem+'" name="GRUPO'+cItem+'" value="'+SB1->B1_GRUPO+'">'
  692. cItensHid += '<input type="hidden" class="" id="VENCIMENTO'+cItem+'" name="VENCIMENTO'+cItem+'" value="'+Iif(lVencido,'1','0')+'">'
  693. cItensHid += '<input type="hidden" class="" id="B1_COMIS'+cItem+'" name="B1_COMIS'+cItem+'" value="'+cvaltochar(SB1->B1_COMIS)+'">'
  694. cItensHid += '<input type="hidden" class="" id="CK_COMIS1'+cItem+'" name="CK_COMIS1'+cItem+'" value="'+cvaltochar(SCK->CK_COMIS1)+'">'
  695. cItensHid += '<input type="hidden" class="" id="CK_COMIS3'+cItem+'" name="CK_COMIS3'+cItem+'" value="'+cvaltochar(SCK->CK_COMIS3)+'">'
  696. cOrcItens+=cItensHid
  697. //Totais
  698. nTImpostos += SCK->(CK_ST+CK_IPI)
  699. nTVlrUnit += nTotValor //total do item c/desconto
  700. nTTotal += nTotValor + SCK->(CK_IPI+CK_ST) //total com desconto + impostos
  701. nTQtdItem += SCK->CK_QTDVEN
  702. nValDesc += nTotValor * (SCK->CK_DESCACM/100)
  703. //nValDesc += nTotValor * (SCK->CK_DESCONT/100)
  704. nTVlrSDesc += nTotValor + (nTotValor * (SCK->CK_DESCACM/100)) //Total sem desconto
  705. //nTVlrSDesc += nTotValor + (nTotValor * (SCK->CK_DESCONT/100)) //Total sem desconto
  706. nPerCom:= SCK->CK_COMIS1
  707. nValCom:= SCK->CK_COMISSA //(SCK->CK_QTDVEN * SCK->CK_PRCVEN) * (nPerCom/100)
  708. nTComiss+= nValCom
  709. SCK->(dbSkip())
  710. End
  711. //nTAcresc:= Round(nTTotal*(nAcresc/100),2)
  712. nTTotal+= nTFrete
  713. //nTTotal+= nTFrete+nTAcresc
  714. cOrcItens += '<input type="hidden" name="QtdItens" id="QtdItens" value="'+cValtoChar(nItens)+'"/>'
  715. cOrcItens += '<input type="hidden" id="PROXIMO" name="PROXIMO" value="'+StrZero(nItens,2)+'"/>
  716. cOrcItens += '<input type="hidden" class="" name="CJ_NUM" id="CJ_NUM" value="'+IIf(lCopy, "", SCJ->CJ_NUM)+'" />'
  717. cOrcItens += '<input type="hidden" name="OPCAO" id="OPCAO" value="'+cValtoChar(nOpc)+'" />'
  718. cOrcItens += '<input type="hidden" name="DESCCOND" id="DESCCOND" value="" />'
  719. cOrcItens += '<input type="hidden" name="CJ_DSDIRET" id="CJ_DSDIRET" value="'+IIf(lCopy, "", cvaltochar(SCJ->CJ_DSDIRET))+'" />'
  720. cOrcItens += '<input type="hidden" name="FRETEMIN" id="FRETEMIN" value="'+cvaltochar(GetMv("MV_FRETMIN"))+'" />'
  721. cOrcItens += '</tr>'
  722. //Adiciona os botões de ações na tabela de itens
  723. If lEdit
  724. cBtnItens+='<div class="row form-group">'
  725. cBtnItens+=' <div class="col-sm-2">'
  726. cBtnItens+=' <button class="btn btn-primary" id="btAddItm" name="btAddItm">' //onclick="javascript:newItem()" >'
  727. cBtnItens+=' <i class="fa fa-plus-square"></i> Novo Item</button>'
  728. cBtnItens+=' </div>'
  729. cBtnItens+='</div>'
  730. Endif
  731. //Adiciona os botões da página
  732. If lEdit
  733. //cBotoes+='<h5 class="text-primary">Orçamento válido apenas dentro do mês de '+MesExtenso(SCJ->CJ_EMISSAO)+' de '+cvaltochar(Year(SCJ->CJ_EMISSAO))+'.</h5>'
  734. cBotoes+='<input class="btn btn-primary" type="button" id="btSalvar" name="btSalvar" value="Salvar"/>'+chr(13)+chr(10)
  735. Elseif lDele
  736. cBotoes+='<input class="btn btn-primary " type="button" id="btExcluir" name="btExcluir" value="Excluir"/>'+chr(13)+chr(10)
  737. Endif
  738. cBotoes+='<input class="btn btn-primary" type="button" id="btVoltar" name="btVoltar" value="Voltar" onclick="javascript: location.href='+"'"+'U_orcamento.apw?PR='+cCodLogin+"';"+'"/>'+chr(13)+chr(10)
  739. //Totalizador disponível apenas para regional
  740. If HttpSession->Tipo <> "R"
  741. cTotalReg:='<div class="col-sm-12">'
  742. cTotalReg+=' <label class="">Itens sem Desconto&nbsp;</label>'
  743. cTotalReg+=' <input class="form-control text-right" id="TOTAL_ITENS_NODESC" name="TOTAL_ITENS_NODESC" placeholder="0,00" disabled="" type="text" value="'+Transform(nTVlrSDesc,"@E 999,999,999,999.99")+'"></input>'
  744. cTotalReg+=' &nbsp;&nbsp;&nbsp;&nbsp;'
  745. cTotalReg+=' <label class="">Itens sem Desconto+Impostos&nbsp;</label>'
  746. cTotalReg+=' <input class="form-control text-right" id="TOTAL_NODESC_IMP" name="TOTAL_NODESC_IMP" placeholder="0,00" disabled="" type="text" value="'+Transform(nTVlrSDesc+nTImpostos,"@E 999,999,999,999.99")+'"></input>'
  747. cTotalReg+='</div>'
  748. cTotalReg+='<br>'
  749. cTotalReg+='<br>'
  750. cShowDesc := 'true'
  751. Endif
  752. //Retorna o HTML para construção da página
  753. cHtml := H_AddOrc()
  754. Web Extended End
  755. Return (cHTML)
  756. /*__________________________________________________________________________
  757. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  758. ¦¦+-----------------------------------------------------------------------+¦¦
  759. ¦¦¦Funçäo ¦ GetSaldoProd ¦ Autor ¦ Lucilene Mendes ¦ Data ¦ 17.10.23 ¦¦¦
  760. ¦¦+----------+------------------------------------------------------------¦¦¦
  761. ¦¦¦Descriçäo ¦ Busca saldo do item (mesma query GetEstDisp-addorc.apl) ¦¦¦
  762. ¦¦+-----------------------------------------------------------------------+¦¦
  763. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  764. ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯*/
  765. Static Function GetSaldoProd()
  766. //Armazéns considerados para busca do estoque
  767. Local cArmazem:= GetNewPar("PR_ARMZPR","'01','02','03'") //deve estar no formato '01','02'
  768. Local cQry:=""
  769. //Busca o saldo do produto
  770. cQry:= "With QRY AS( "
  771. cQry+= "Select SUM(B2_QATU) EST , SUM(CASE WHEN B2_QEMP >= 0 THEN B2_QEMP ELSE 0 END) + SUM(CASE WHEN B2_RESERVA >= 0 THEN B2_RESERVA ELSE 0 END) + SUM(CASE WHEN B2_QPEDVEN >= 0 THEN B2_QPEDVEN ELSE 0 END) EMPENHO " //adicionado reserva 07.02.20 - Lucilene
  772. cQry+= "From "+RetSqlName("SB2")+" SB2 "
  773. cQry+= "Where B2_FILIAL = '"+xFilial("SB2")+"' And B2_COD = '"+SCK->CK_PRODUTO+"' And SB2.D_E_L_E_T_ = ' ' "
  774. If !Empty(cArmazem)
  775. cQry+= "AND B2_LOCAL in ("+cArmazem+") "
  776. Endif
  777. cQry+= "UNION ALL "
  778. cQry+= "Select 0 EST , SUM(CK_QTDVEN) EMPENHO "
  779. cQry+= "From "+RetSqlName("SCJ")+" SCJ, "+RetSqlName("SCK")+" SCK "
  780. cQry+= "Where CJ_FILIAL = '"+xFilial("SB2")+"' AND CJ_XTPORC = '1' AND CJ_STATUS = 'A' AND SCJ.D_E_L_E_T_ = ' ' "
  781. cQry+= "and CK_FILIAL = CJ_FILIAL AND CK_NUM = CJ_NUM AND CK_PRODUTO = '"+SCK->CK_PRODUTO+"' and SCK.D_E_L_E_T_ = ' ' "
  782. If !Empty(cArmazem)
  783. cQry+= "AND CK_LOCAL in ("+cArmazem+") "
  784. Endif
  785. cQry+= ")"
  786. cQry+= "SELECT SUM(EST) -SUM(EMPENHO) SALDO FROM QRY "
  787. If Select("QRS") > 0
  788. QRS->(dbCloseArea())
  789. Endif
  790. APWExOpenQuery(cQry,'QRS',.T.)
  791. Return cvaltochar(QRS->SALDO)