MntOrc.apl 56 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320
  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 MntOrc()
  17. Local cHtml
  18. Local cItem := ""
  19. Local nPosFrete := 0
  20. Local nPerCom := 0
  21. Local nValCom := 0
  22. Local nValDesc := 0
  23. Local nVlrProd := 0
  24. Local nTotValor := 0
  25. Local nOpc := 0
  26. Local nLin := 0
  27. Local f := 0
  28. Local lMoeda := .F.
  29. Local lNumber := .F.
  30. Local lVencido := .F.
  31. Local aTpFrete := {}
  32. Local nRecSCJ := 0
  33. private cLisPar := ""
  34. private cParUs := ""
  35. Private cFilVen := ""
  36. Private cCodLogin := ""
  37. Private cVendLogin := ""
  38. Private cVendedor := ""
  39. Private cSite := "u_PortalLogin.apw"
  40. Private cPagina := "Orçamento de Venda"
  41. Private cTitle := "Portal SMS"
  42. Private cMenus := ""
  43. Private cAnexos := ""
  44. Private cDirOrc := "\anexosPortal\orcamentos\"
  45. Private cDirPortal := ""
  46. Private cEndServ := "" // Endereço do servidor da pagina de Portal
  47. Private cOrcCabec := ""
  48. Private cOrcItens := ""
  49. Private cItensHid := ""
  50. Private cBotoes := ""
  51. Private cBtnItens := ""
  52. Private cOptUF := ""
  53. Private cOptMun := ""
  54. Private cOptProd := ""
  55. Private cOptCond := ""
  56. Private cOptModal := ""
  57. Private cTblDesc := ""
  58. Private cCodOrc := ""
  59. Private cTabela := ""
  60. Private cCliente := ""
  61. Private cContato := ""
  62. Private cContDDD := ""
  63. Private cContTel := ""
  64. Private cTpCliente := ""
  65. Private cGrpTrib := ""
  66. Private cCondPag := ""
  67. Private cLocalEnt := ""
  68. Private cObra := ""
  69. Private cStatusObra := ""
  70. Private cIntermed := ""
  71. Private cOport := ""
  72. Private cRevOpt := ""
  73. Private cRegional := ""
  74. Private cTpFrete := ""
  75. Private cValFre := ""
  76. Private cPrazoEmb := ""
  77. Private cEstudo := ""
  78. Private cNumEst := ""
  79. Private cPrevFecha := ""
  80. Private cMargemCont := ""
  81. Private cTransp := ""
  82. Private cOptCli := ""
  83. Private cOptInter := ""
  84. Private cTotalReg := ""
  85. Private cLisPar := ""
  86. Private cParUs := ""
  87. Private cMgItens := ""
  88. //Private cEntrega := ""
  89. //Private cValidade := ""
  90. Private nTVlrUnit := 0
  91. Private nTVlrSDesc := 0
  92. Private nTQtdItem := 0
  93. Private nTTotal := 0
  94. Private nTComiss := 0
  95. Private nTImpostos := 0
  96. Private nTAcresc := 0
  97. Private nTFrete := 0
  98. Private nItens := 0
  99. Private nMargem := 0
  100. Private nMLuminaria := 0
  101. Private nMEquipa := 0
  102. Private nMPainel := 0
  103. Private lNewOrc := .F.
  104. Private lEdit := .F.
  105. Private lCopy := .F.
  106. Private cShowDesc := "false"
  107. Private aItens := {}
  108. Private aAnexos := {}
  109. Web Extended Init cHtml Start U_inSite()
  110. cVendLogin := u_GetUsrPR()
  111. cCodLogin := U_SetParPR(cVendLogin)
  112. If Empty(HttpSession->CodVend)
  113. cHtml:= '<META HTTP-EQUIV="Refresh" CONTENT="0 ; URL='+cSite+'">'
  114. Return cHtml
  115. Else
  116. If !Empty(HttpSession->Superv) .and. HttpSession->Superv <> HttpSession->CodVend
  117. HttpSession->CodVend:= HttpSession->Superv
  118. Endif
  119. Endif
  120. // Pega do parâmetro com o Titulo do Portal
  121. cTitle := SuperGetMV("PS_TITLE", .T., "Portal SMS")
  122. // Define a funcao a ser chama no link
  123. cSite := "u_SMSPortal.apw?PR="+cCodLogin
  124. // Monta o cabeçalho para a pagina
  125. cHeader := U_PSHeader(cTitle, cSite)
  126. //Função que atualiza os menus
  127. cMenus := U_GetMenus(AllTrim(Upper(Procname())), cVendLogin)
  128. //Atualiza as variáveis
  129. cEndServ := GetMv('MV_WFBRWSR')
  130. cCodVend := cVendLogin
  131. cNomeVend:= HttpSession->Nome
  132. cItem := StrZero(1,TamSX3("CK_ITEM")[1])
  133. cOpcao := HttpGet->opc
  134. cParUs := GetMv('LC_FA074G1')
  135. if !empty(HttpGet->rec)
  136. nRecSCJ := val(HttpGet->rec)
  137. EndIf
  138. lEdit := .F.
  139. lDele := .F.
  140. Do Case
  141. Case cOpcao == "view"
  142. nOpc:= 2
  143. cPagina += " - Visualizar"
  144. Case cOpcao == "edit"
  145. nOpc:= 4
  146. cPagina += " - Alterar"
  147. lEdit := .T.
  148. Case cOpcao == "dele"
  149. nOpc:= 5
  150. cPagina += " - Excluir"
  151. lDele := .T.
  152. Case cOpcao == "copy"
  153. nOpc = 3
  154. cPagina += " - Copiar"
  155. lEdit := .T.
  156. lCopy := .T.
  157. EndCase
  158. //Posiciona no Orçamento
  159. If !Empty(nRecSCJ)
  160. dbSelectArea("SCJ")
  161. SCJ->(dbGoTo(nRecSCJ))
  162. //Troca de filial
  163. u_PTChgFil(SCJ->CJ_FILIAL)
  164. dbSelectArea("SCJ")
  165. SCJ->(dbGoTo(nRecSCJ))
  166. dbSelectArea("SCK")
  167. SCK->(DbSetOrder(1))
  168. SCK->(dbgotop())
  169. SCK->(dbSeek(xFilial("SCK")+SCJ->CJ_NUM))
  170. dbSelectArea("SA1")
  171. SA1->(DbSetOrder(1))
  172. SA1->(dbgotop())
  173. SA1->(dbSeek(xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA))
  174. Endif
  175. cLisPar:='<select class="form-control" name="parceiro" id="cmbParceiro"> '
  176. cLisPar+= '<option value="">Selecione...</option>'
  177. cLisPar+= U_GETPARC()
  178. cLisPar+='</select>'
  179. cFilOrc:= '<div class="row form-group">'
  180. cFilOrc+= ' <div class="col-lg-2">'
  181. cFilOrc+= ' <label class="control-label">Filial</label>'
  182. cFilOrc+= ' <input id="CJ_FILIAL" name="CJ_FILIAL" class="form-control" value="'+SCJ->CJ_FILIAL+'" disabled >'
  183. //cFilOrc+= ' <input id="CJ_VEND" name="CJ_VEND" type="hidden" value="'+SCJ->CJ_VEND+'">'
  184. cFilOrc+= ' </div>'
  185. cCodOrc:= ' <div class="col-lg-2">'
  186. cCodOrc+= ' <label class="control-label">Número</label>'
  187. cCodOrc+= ' <input id="CJ_NUM" name="CJ_NUM" class="form-control" value="'+SCJ->CJ_NUM+'" disabled >'
  188. cCodOrc+= ' <input type="hidden" id="RECCJANT" name="RECCJANT" value="" >'
  189. cCodOrc+= ' </div>'
  190. cCodOrc+= '</div>'
  191. //Cliente
  192. If lEdit .or. lCopy
  193. cCliente:=' <div class="flexContainer">
  194. cCliente+=' <input type="text" class="form-control smsediticon" placeholder="Digite o código, CPF/CNPJ ou Razão Social..." '
  195. cCliente+=' name="CJ_CLIENTE" id="CJ_CLIENTE"'
  196. cCliente+=' aria-required="true" data-live-search="true" '
  197. cCliente+=' autocomplete="off" value="'+SCJ->CJ_CLIENTE+'/'+SCJ->CJ_LOJA+' - '+Alltrim(Posicione("SA1",1,xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA,"A1_NOME"))+'" />'
  198. cCliente+=' <button class="btSearchCli" id="btSearchCli">'
  199. cCliente+=' <i class="fa fa-search" alt="Pesquisar"></i>'
  200. cCliente+=' </button>
  201. cCliente+=' </div>
  202. cOptCli+= u_ListaCli(cVendLogin,"",'S')
  203. HttpSession->Cliente:= SCJ->CJ_CLIENTE+SCJ->CJ_LOJA
  204. Else
  205. cCliente:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  206. cCliente+='{ "placeholder": "Selecione um Cliente", "allowClear": false }'+"'"+' name="CJ_CLIENTE" id="CJ_CLIENTE" '
  207. cCliente+=' disabled >' //value='+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA+'
  208. 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>'
  209. cCliente+='</select>'
  210. Endif
  211. //Oportunidade
  212. cOport:= '<input id="CJ_NROPOR" name="CJ_NROPOR" class="form-control" value="'+SCJ->CJ_NROPOR+'" disabled >'
  213. cRevOpt:= '<input id="CJ_REVISA" name="CJ_REVISA" class="form-control" value="'+SCJ->CJ_REVISA+'" disabled>'
  214. //Combo da tabela de preço
  215. cTabPadrao:= GetNewPar("PR_TABPADR","001")
  216. cTabela:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  217. cTabela+='{ "placeholder": "Selecione", "allowClear": false }'+"'"+' name="CJ_TABELA" id="CJ_TABELA" '
  218. cTabela+='</select>'
  219. //Tabela de preço por filial
  220. cQry:= "SELECT DA0_CODTAB, DA0_DESCRI "
  221. cQry+= "FROM "+RetSqlName("DA0")+" DA0 "
  222. cQry+= "WHERE DA0_FILIAL = '"+xFilial("DA0")+"'
  223. cQry+= "AND DA0_ATIVO = '1' "
  224. cQry+= "AND (DA0_DATATE = '' OR DA0_DATATE >= '"+dtos(dDataBase)+"') "
  225. cQry+= "AND DA0.D_E_L_E_T_ = ' ' "
  226. If Select("QFIL") > 0
  227. QFIL->(dbCloseArea())
  228. Endif
  229. TcQuery cQry New Alias "QFIL"
  230. While QFIL->(!Eof())
  231. cTabela+=' <option value="'+Alltrim(QFIL->DA0_CODTAB)+'" '+Iif(QFIL->DA0_CODTAB == SCJ->CJ_TABELA,'selected','')+'>'+Alltrim(QFIL->DA0_CODTAB)+' - '+Alltrim(QFIL->DA0_DESCRI)+'</option>'
  232. QFIL->(dbSkip())
  233. End
  234. cTabela+='</select>'
  235. //Tipo de cliente
  236. Posicione("SA1",1,xFilial("SA1")+SCJ->CJ_CLIENTE+SCJ->CJ_LOJA,"A1_TIPO")
  237. cTpCliente:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  238. cTpCliente+='{ "placeholder": "Selecione um Cliente", "allowClear": false }'+"'"+' name="CJ_TIPOCLI" id="A1_TIPOCLI" '
  239. cTpCliente+=' disabled >'
  240. cTpCliente+=' <option value="'+SA1->A1_TIPO+'">'+X3COMBO("A1_TIPO",SA1->A1_TIPO)+'</option>'
  241. cTpCliente+='</select>'
  242. //Grupo de tributação do cliente
  243. cGrpTrib:= '<input id="CJ_GRPTRIB" name="CJ_GRPTRIB" class="form-control" value="'+SCJ->CJ_GRPTRIB+'" disabled>'
  244. //Contato
  245. 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')+' >'
  246. 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')+' >'
  247. 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')+' >'
  248. //Cliente de Entrega
  249. cCliEntr:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  250. cCliEntr+='{ "placeholder": "Selecione um Cliente", "allowClear": false }'+"'"
  251. cCliEntr+='name="CJ_CLIENT" id="CJ_CLIENT" '
  252. If lEdit .or. lCopy
  253. cCliEntr+='onchange="javascript:atuLocEnt();" '
  254. Else
  255. cCliEntr+='disabled'
  256. Endif
  257. cCliEntr+='>'
  258. If lEdit .or. lCopy
  259. cCliEntr+=' <option data-hidden="true"></option>'
  260. Endif
  261. // Localiza os clientes
  262. cCliEntr+= u_ListaCli(cVendLogin,"QRY->A1_COD+QRY->A1_LOJA==SCJ->CJ_CLIENT+SCJ->CJ_LOJAENT",'N')
  263. cCliEntr+='</select>'
  264. //Local de entrega
  265. cLocalEnt:= '<div class="flexContainer">'
  266. cLocalEnt+= ' <input id="CJ_UFENT" name="CJ_UFENT" class="form-control" value="'+Alltrim(SCJ->CJ_UFENT)+'" disabled>' //onchange="javascript:atuVlrFrete();"
  267. cLocalEnt+=' <button class="btEndEntrega" id="btEndEntrega">'
  268. cLocalEnt+=' <i class="fa fa-exchange" title="Alterar endereço"></i>'
  269. cLocalEnt+=' </button>'
  270. cLocalEnt+='</div>'
  271. //Alimenta os estados
  272. cOptUF:= u_ListaUF()
  273. //Nome da obra
  274. 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')+' >'
  275. //cStatusObra:= ' <input id="CJ_VEND6" name="CJ_VEND6" class="form-control" value="'+Upper(X3COMBO("CJ_VEND6",SCJ->CJ_VEND6))+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  276. aStObra:= RetSx3Box(Posicione('SX3',2,'CJ_VEND6','X3CBox()'),,,1)
  277. cStatusObra:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  278. cStatusObra+=' name="CJ_VEND6" id="CJ_VEND6" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  279. cStatusObra+='<option value=""></option>'
  280. For f:= 1 to Len(aStObra)
  281. cStatusObra+=' <option value="'+Left(aStObra[f,1],2)+'" '+Iif(Left(aStObra[f,1],2)==Alltrim(SCJ->CJ_VEND6),'selected','')+'>'+aStObra[f,1]+'</option>'
  282. Next
  283. cStatusObra+='</select>'
  284. //Tipo da Obra
  285. cTpObra:='<select data-plugin-selectTwo class="form-control poulate mb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  286. cTpObra+=' name="CJ_YOBRATP" id="CJ_YOBRATP" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  287. cTpObra+='<option value=""></option>'
  288. //Alimenta os tipos de obra
  289. cTpObra+= u_ListaObra(SCJ->CJ_YOBRATP)
  290. cTpObra+='</select>'
  291. //Seleciona as condições de pagamento disponíveis no combo
  292. cCondPag:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  293. cCondPag+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_CONDPAG" id="CJ_CONDPAG" '
  294. cCondPag+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+' onchange="javascript:vldCond()">'
  295. cCondPag+=' <option value="'+SCJ->CJ_CONDPAG+'">'+SCJ->CJ_CONDPAG+" - "+Posicione("SE4",1,xFilial("SE4")+SCJ->CJ_CONDPAG,"E4_DESCRI")+'</option>'
  296. If lEdit
  297. //Verifica a tabela cadastrada no cliente
  298. SE4->(dbSeek(xFilial("SE4")+SA1->A1_COND))
  299. //Seleciona as condições de pagamento disponíveis no combo
  300. cQry:= " Select E4_CODIGO, E4_DESCRI, E4_ACRSFIN"
  301. cQry+= " From "+RetSqlName("SE4")+" SE4 "
  302. cQry+= " Where E4_FILIAL = '"+xFilial("SE4")+"' "
  303. cQry+= " And E4_MSBLQL <> '1' "
  304. cQry+= " And E4_CODIGO NOT IN ('"+SCJ->CJ_CONDPAG+"') "
  305. cQry+= " And SE4.D_E_L_E_T_ = ' ' "
  306. If Select("QRP") > 0
  307. QRP->(dbCloseArea())
  308. Endif
  309. TcQuery cqry New Alias "QRP"
  310. While QRP->(!Eof())
  311. 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>'
  312. QRP->(dbSkip())
  313. End
  314. QRP->(dbCloseArea())
  315. Endif
  316. cCondPag+='</select>'
  317. //Previsão Fechamento
  318. aPrevisao:= {{"B","Balizador"},{"A","30/120 dias"},{"V","Em 30 dias"},{"M","Após 4 meses"},{"C","Concorrência"}}
  319. //cPrevFecha:= ' <input id="CJ_TERMOME" name="CJ_TERMOME" class="form-control" value="'+cPrevisao+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  320. cPrevFecha:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  321. cPrevFecha+=' name="CJ_TERMOME" id="CJ_TERMOME" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  322. cPrevFecha+='<option value=""></option>'
  323. For f:= 1 to Len(aPrevisao)
  324. cPrevFecha+=' <option value="'+aPrevisao[f,1]+'" '+Iif(aPrevisao[f,1]==SCJ->CJ_TERMOME,'selected','')+'>'+aPrevisao[f,2]+'</option>'
  325. Next
  326. cPrevFecha+='</select>'
  327. //Intermediador
  328. If !(lEdit .or. lCopy)
  329. cIntermed:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  330. cIntermed+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' disabled '
  331. Else
  332. cIntermed:='<select class="form-control populate selectpicker" data-live-search="true" '
  333. cIntermed+='title="Selecione..." '
  334. Endif
  335. cIntermed+=' name="CJ_CLIINTE" id="CJ_CLIINTE" >'
  336. cIntermed+='<option data-hidden="true"></option>'
  337. //Busca a lista de clientes
  338. cIntermed+= u_ListaCli(cVendLogin,"QRY->A1_COD==SCJ->CJ_CLIINTE",'S')
  339. cIntermed+='</select>'
  340. //Retorno
  341. nDiasVal:= 0
  342. cRetorno:='<input type="text" id="CJ_RETORNO" name="CJ_RETORNO" data-plugin-datepicker data-plugin-options='+"'"+'{ "startDate": "+'+cvaltochar(nDiasVal)+'d", "language": "pt-BR",'
  343. cRetorno+='"daysOfWeekDisabled": "[0]","daysOfWeekHighlighted":"[0]","autoclose": "true","disabled":"true"}'+"'"+' class="form-control only-numbers" placeholder="__/__/____" '
  344. cRetorno+='value="'+dtoc(SCJ->CJ_RETORNO)+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  345. //Estudo Luminotécnico
  346. //cEstudo:= ' <input id="CJ_LUMINOT" name="CJ_LUMINOT" class="form-control" value="'+Upper(X3COMBO("CJ_LUMINOT",SCJ->CJ_LUMINOT))+'" '+Iif(lCopy .or. lEdit,'','disabled')+' >'
  347. aEstd:= RetSx3Box(Posicione('SX3',2,'CJ_LUMINOT','X3CBox()'),,,1)
  348. aSort(aEstd)
  349. cEstudo:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  350. cEstudo+=' name="CJ_LUMINOT" id="CJ_LUMINOT" '+Iif(lCopy .or. lEdit,'','disabled')+' onchange="javascript:vldEstudo()">'
  351. cEstudo+='<option value=""></option>'
  352. For f:= 1 to Len(aEstd)
  353. cEstudo+=' <option value="'+aEstd[f,2]+'" '+Iif(AllTrim(aEstd[f,2]) == AllTrim(SCJ->CJ_LUMINOT),'selected','')+'>'+Upper(aEstd[f,3])+'</option>'
  354. Next
  355. cEstudo+='</select>'
  356. 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')+' >'
  357. //Segmento
  358. aSegmen:= RetSx3Box(Posicione('SX3',2,'CJ_SEGMENT','X3CBox()'),,,1)
  359. cSegmento:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...","minimumResultsForSearch": "-1"}'+"'"'
  360. cSegmento+=' name="CJ_SEGMENT" id="CJ_SEGMENT" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  361. cSegmento+=' <option value=""></option>'
  362. For f:= 1 to Len(aSegmen)
  363. cSegmento+=' <option value="'+aSegmen[f,1]+'" '+Iif(aSegmen[f,1]==Alltrim(SCJ->CJ_SEGMENT),'selected','')+'>'+aSegmen[f,1]+'</option>'
  364. Next
  365. cSegmento+='</select>'
  366. //Prospecção
  367. aProsp:= RetSx3Box(Posicione('SX3',2,'CJ_PROPECC','X3CBox()'),,,1)
  368. aSort(aProsp)
  369. cProsp:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...", "minimumResultsForSearch": "-1"}'+"'"'
  370. cProsp+=' name="CJ_PROPECC" id="CJ_PROPECC" onchange="javascript:vldProspec()" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  371. cProsp+='<option value=""></option>'
  372. For f:= 1 to Len(aProsp)
  373. cProsp+=' <option value="'+aProsp[f,2]+'" '+Iif(aProsp[f,2]==SCJ->CJ_PROPECC,'selected','')+'>'+Upper(aProsp[f,3])+'</option>'
  374. Next
  375. cProsp+='</select>'
  376. //Prospectado por
  377. aProsp:= RetSx3Box(Posicione('SX3',2,'CJ_PROSCOD','X3CBox()'),,,1)
  378. cProspPor:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"placeholder": "Selecione...","minimumResultsForSearch": "-1"}'+"'"'
  379. cProspPor+=' name="CJ_PROSCOD" id="CJ_PROSCOD" '+Iif(lCopy .or. lEdit /*.or. !Empty(SCJ->CJ_PROSCOD)*/,'','disabled')+'>'
  380. cProspPor+=' <option value=""></option>'
  381. For f:= 1 to Len(aProsp)
  382. cProspPor+=' <option value="'+aProsp[f,1]+'" '+Iif(aProsp[f,1]==Alltrim(SCJ->CJ_PROSCOD),'selected','')+'>'+aProsp[f,1]+'</option>'
  383. Next
  384. cProspPor+='</select>'
  385. //Regional
  386. cRegional:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  387. cRegional+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_REGIAO" id="CJ_REGIAO" '
  388. cRegional+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  389. If lCopy .or. lEdit
  390. cRegional+= u_ListaVend(.T.,SCJ->CJ_REGIAO)
  391. Else
  392. cRegional+='<option value="'+SCJ->CJ_REGIAO+'">'+SCJ->CJ_REGIAO+" - "+Posicione("SA3",1,xFilial("SA3")+SCJ->CJ_REGIAO,"A3_NOME")+'</option>'
  393. Endif
  394. cRegional+='</select>'
  395. //Vendedor do cliente
  396. cVend2:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  397. cVend2+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_VEND" id="CJ_VEND" '
  398. cVend2+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  399. If lCopy .or. lEdit
  400. cVend2+= u_ListaVend(.F.,SCJ->CJ_VEND)
  401. Else
  402. cVend2+='<option value="'+SCJ->CJ_VEND+'">'+SCJ->CJ_VEND+" - "+Posicione("SA3",1,xFilial("SA3")+SCJ->CJ_VEND,"A3_NOME")+'</option>'
  403. Endif
  404. cVend2+='</select>'
  405. //Vendedor da oportunidade
  406. cVend3:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-live-search="true" data-plugin-options='+"'"
  407. cVend3+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"
  408. cVend3+=' name="CJ_VEND3" id="CJ_VEND3" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  409. If lCopy .or. lEdit
  410. cVend3+= u_ListaVend(.F.,SCJ->CJ_VEND3)
  411. Else
  412. cVend3+='<option value="'+SCJ->CJ_VEND3+'">'+SCJ->CJ_VEND3+" - "+Posicione("SA3",1,xFilial("SA3")+SCJ->CJ_VEND3,"A3_NOME")+'</option>'
  413. Endif
  414. cVend3+='</select>'
  415. //Vendedor 4
  416. cVend4:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  417. cVend4+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_VEND4" id="CJ_VEND4" '
  418. cVend4+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  419. cVend4+= u_Vend04(SCJ->CJ_VEND4)
  420. cVend4+='</select>'
  421. //Especificado por
  422. cEspecif:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  423. cEspecif+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_CODESP" id="CJ_CODESP" '
  424. cEspecif+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  425. cEspecif+= u_ListaEsp(SCJ->CJ_CODESP)
  426. cEspecif+='</select>'
  427. //Negociadora
  428. cNegociad:= '<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  429. cNegociad+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_VEND7" id="CJ_VEND7" '
  430. cNegociad+='required="" aria-required="true" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  431. cNegociad+= u_ListaNeg(SCJ->CJ_VEND7)
  432. cNegociad+='</select>'
  433. //Validade do Orçamento
  434. nDiasVal:= GetNewPar("PR_DTVALID",10)
  435. cValidade:='<input type="text" id="CJ_VALIDA" name="CJ_VALIDA" data-plugin-datepicker data-plugin-options='+"'"+'{ "startDate": "+'+cvaltochar(nDiasVal)+'d", "language": "pt-BR",'
  436. cValidade+='"daysOfWeekDisabled": "[0]","daysOfWeekHighlighted":"[0]","autoclose": "true","disabled":"true"}'+"'"+' class="form-control only-numbers" placeholder="__/__/____" '
  437. cValidade+='value="'+dtoc(SCJ->CJ_VALIDA)+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  438. //Prazo de embarque
  439. 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')+' >'
  440. //Tipo de frete
  441. aTpFrete:= {{"S","Sem Frete"},{"C","CIF"},{"F","FOB"}}
  442. cTpFrete:='<select data-plugin-selectTwo class="form-control poulatemb-md" data-plugin-options='+"'"+'{"minimumResultsForSearch": "-1"}'+"'"'
  443. cTpFrete+=' name="CJ_TPFRETE" id="CJ_TPFRETE" onchange="javascript:VldFrete()" '
  444. //cTpFrete:='<select class="form-control mb-md" name="CJ_TPFRETE" id="CJ_TPFRETE" onchange="javascript:VldFrete()" value="'+SCJ->CJ_TPFRETE+'"'
  445. cTpFrete+= Iif(!lEdit,'disabled','')+'>'
  446. If lEdit
  447. For f:= 1 to Len(aTpFrete)
  448. cTpFrete+=' <option value="'+aTpFrete[f,1]+'" '+Iif(AllTrim(aTpFrete[f,1]) == AllTrim(SCJ->CJ_TPFRETE),'selected','')+'>'+aTpFrete[f,2]+'</option>'
  449. Next
  450. Else
  451. nPosFrete:= aScan(aTpFrete,{|x|x[1]==SCJ->CJ_TPFRETE})
  452. If nPosFrete = 0
  453. nPosFrete:= 1
  454. Endif
  455. cTpFrete+=' <option value="'+SCJ->CJ_TPFRETE+'">'+aTpFrete[nPosFrete,2]+'</option>'
  456. Endif
  457. cTpFrete+='</select>'
  458. 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)+'" '
  459. cPFrete+= 'value="'+TransForm(SCJ->CJ_PERCFRT,"@E 999.99")+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  460. cValFre:= '<input id="CJ_FRETE" name="CJ_FRETE" class="form-control money text-right" placeholder="0,00" '
  461. cValFre+= 'value="'+Transform(SCJ->CJ_FRETE,"@E 999,999,999,999.99")+'" '
  462. cValFre+= Iif((!lCopy .and. !lEdit) .or. SCJ->CJ_TPFRETE = "S" ,'disabled','')+'>'
  463. nTFrete+= SCJ->CJ_FRETE
  464. //% RT
  465. 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)+'" '
  466. cComRT+= 'value="'+Transform(SCJ->CJ_COMISTR,PesqPict("SCJ","CJ_COMISTR"))+'" '+Iif(lCopy .or. lEdit,'','disabled')+'>'
  467. //Observação Comercial
  468. cObsCom:= SCJ->CJ_OBS
  469. //Margem de Contribuição
  470. If HttpSession->Tipo <> "R" //Representante
  471. cMargemCont:= ' <div class="col-lg-2"> '
  472. cMargemCont+= ' <label class="control-label">MC</label> '
  473. cMargemCont+= ' <input id="MARGEM" name="MARGEM" class="form-control" value="'+u_getMCOrc() + "%"+'" disabled >'
  474. cMargemCont+= ' </div>'
  475. Endif
  476. /*
  477. //Transportadora
  478. cTransp:='<select data-plugin-selectTwo class="form-control populate placeholder mb-md" data-plugin-options='+"'" '
  479. cTransp+='{ "placeholder": "Selecione uma Transportadora", "allowClear": false }'+"'"+' name="CJ_XTRANSP" id="CJ_XTRANSP" '
  480. cTransp+='required="" aria-required="true" '
  481. cTransp+= Iif(!lEdit .or. SCJ->CJ_TPFRETE = 'S','disabled','')+'>'
  482. cTransp+=' <option value="'+SCJ->CJ_XTRANSP+'">'+Alltrim(Posicione("SA4",1,xFilial("SA4")+SCJ->CJ_XTRANSP,"A4_NOME"))+'</option>'
  483. If lEdit
  484. //Transportadora do cadastro do cliente
  485. If !Empty(SA1->A1_TRANSP)
  486. cNome:= Alltrim(Posicione("SA4",1,xFilial("SA4")+SA1->A1_TRANSP,"A4_NOME"))
  487. cTransp+=' <option value="'+Alltrim(cTransp)+'">'+cNome+'</option>'
  488. Endif
  489. //Seleciona as transportadoras disponíveis no combo
  490. cQry:= " Select A4_COD COD, A4_NOME NOME"
  491. cQry+= " From "+RetSqlName("SA4")+" SA4 "
  492. cQry+= " Where A4_FILIAL = '"+xFilial("SA4")+"' "
  493. cQry+= " And A4_COD NOT IN ('"+SA1->A1_TRANSP+"','"+SCJ->CJ_XTRANSP+"') "
  494. cQry+= " And SA4.D_E_L_E_T_ = ' ' "
  495. If Select("QRT")> 0
  496. QRT->(dbCloseArea())
  497. Endif
  498. APWExOpenQuery(ChangeQuery(cQry),'QRT',.T.)
  499. While QRT->(!Eof())
  500. cTransp+=' <option value="'+Alltrim(QRT->COD)+'">'+Alltrim(QRT->NOME)+'</option>'
  501. QRT->(dbSkip())
  502. End
  503. Endif
  504. cTransp+='</select>'
  505. */
  506. /*
  507. //Validade do Orçamento
  508. nDiasVal:= GetNewPar("PR_DTVALID",3)
  509. cValidade:='<input type="text" id="CJ_VALIDA" name="CJ_VALIDA" data-plugin-datepicker data-plugin-options='+"'"+'{ "startDate": "+'+cvaltochar(nDiasVal)+'d", "language": "pt-BR",'
  510. cValidade+='"daysOfWeekDisabled": "[0]","daysOfWeekHighlighted":"[0]","autoclose": "true","disabled":"true"}'+"'"+' class="form-control only-numbers" placeholder="__/__/____" '
  511. cValidade+='value="'+Iif(lCopy,dtoc(date()+nDiasVal),dtoc(SCJ->CJ_VALIDA))+'" disabled>'
  512. //Peso
  513. cPeso:= '<input type="text" id="CJ_XPESO" name="CJ_XPESO" class="form-control text-right only-numbers" placeholder="0" '
  514. cPeso+= 'value="'+cvaltochar(SCJ->CJ_XPESO)+'" '+Iif(lCopy .or. lEdit,'',' disabled')+'>'
  515. //Volume
  516. cVolume:= '<input type="text" id="CJ_XVOLUME" name="CJ_XVOLUME" class="form-control text-right only-numbers" placeholder="0" '
  517. cVolume+= 'value="'+cvaltochar(SCJ->CJ_XVOLUME)+'"'+Iif(lCopy .or. lEdit,'',' disabled')+'>'
  518. //Espécie
  519. cEspecie:= '<input type="text" id="CJ_XESPECI" name="CJ_XESPECI" class="form-control" placeholder="" '
  520. cEspecie+= 'value="'+cvaltochar(SCJ->CJ_XESPECI)+'"'+Iif(lCopy .or. lEdit,'',' disabled')+' maxlength="10">'
  521. //Combo da tabela de preço
  522. cTabela:='<select data-plugin-selectTwo class="form-control populate placeholder" data-plugin-options='+"'"
  523. cTabela+='{ "placeholder": "Selecione...", "allowClear": false }'+"'"+' name="CJ_TABELA" id="CJ_TABELA" '
  524. cTabela+='onchange="javascript:selProd()" disabled >'
  525. cTabela+=' <option value='+SCJ->CJ_TABELA+'>'+Alltrim(Posicione("DA0",1,xFilial("DA0")+SCJ->CJ_TABELA,"DA0_DESCRI"))+'</option>'
  526. cTabela+='</select>'
  527. HttpSession->Tabela:= SCJ->CJ_TABELA
  528. */
  529. //Preenchimento dos itens
  530. /*
  531. aItens - array que define o cabeçalho da tabela de produtos
  532. [1] - Nome da coluna
  533. [2] - Nome do campo
  534. [3] - Tamanho
  535. [4] - Alinhamento
  536. [5] - Tipo
  537. [6] - Editável
  538. [7] - Obrigatório
  539. [8] - Moeda
  540. [9] - Placeholder
  541. [10]- Hidden
  542. [11] - MaxLength
  543. */
  544. aAdd(aItens, {"Item","CK_ITEM","*","text-left","C",.F.,.F.,.F.,"",.F.,""})
  545. aAdd(aItens, {"Produto","CK_PRODUTO","300px"," text-left","C",lEdit,.T.,.F.,"Selecione...",.F.,""})
  546. aAdd(aItens, {"Quant.","CK_QTDVEN","*"," text-right","N",lEdit,.T.,.F.,"0",.F.,""})
  547. aAdd(aItens, {"Observação","CK_OBS","*"," text-left","C",lEdit,.F.,.F.,"",.F.,"80"})
  548. aAdd(aItens, {"Prazo de Embarque","CK_PRZEMB","70px","text-right","N",lEdit,.F.,.F.,"",.F.,"3"})
  549. aAdd(aItens, {"Vlr Unitário","CK_PRCVEN","*"," text-right","N",lEdit,.F.,.T.,"0,00",.F.,""})
  550. aAdd(aItens, {"Vlr c/ Impostos","CK_XPRCIMP","*","text-right","N",.F.,.F.,.T.,"0,00",.T.,""})
  551. aAdd(aItens, {"Vlr de Venda","iCK_PRCVEN","*"," text-right myformato","N",.F.,.T.,.T.,"0,00",.T.,""})
  552. aAdd(aItens, {"Custo","CK_CUSTO","*"," text-right myformato","N",.F.,.F.,.T.,"0,00",.T.,""})
  553. aAdd(aItens, {"IPI","CK_XVALIPI","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  554. aAdd(aItens, {"ICMS","CK_XVALICM","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  555. aAdd(aItens, {"ICMS ST","CK_XICMST","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  556. aAdd(aItens, {"% Desconto","CK_DESCONT","*"," text-right percentual","N",lEdit,.F.,.T.,"0,00",Iif(HttpSession->Tipo <> "R",.F.,.T.) ,"7"})
  557. aAdd(aItens, {"Diretor","CK_NOMDIRE","*"," text-left","C",.T.,.F.,.T.,"",.T.,"12"})
  558. aAdd(aItens, {"% Comissão","PER_COM","*"," text-right ","N",.F.,.F.,.T.,"0,00",.T.,""})
  559. aAdd(aItens, {"Vlr Comissão","VAL_COM","*"," text-right","N",lEdit,.F.,.T.,"0,00",.T.,""})
  560. aAdd(aItens, {"Total","CK_VALOR","150px"," text-right","N",.F.,.F.,.T.,"0,00",.F.,""})
  561. aAdd(aItens, {"","ACAO","*"," text-center","X",lEdit,.F.,.F.,"",.F.,""})
  562. // Cria o cabeçalho dos Itens
  563. For nLin := 1 to Len(aItens)
  564. cOrcCabec += '<th'+Iif(aItens[nLin,2] == "CK_VALOR",' width="'+aItens[nLin,3]+'"',Iif(aItens[nLin,2] == "CK_PRODUTO",' width="'+aItens[nLin,3]+'"',''))
  565. cOrcCabec+= Iif(aItens[nLin,10],' hidden','')+'>'+aItens[nLin][1]+'</th>'
  566. Next
  567. dbSelectArea("SCK")
  568. SCK->(dbSeek(SCJ->CJ_FILIAL+SCJ->CJ_NUM))
  569. While SCK->(!Eof()) .and. SCK->CK_FILIAL == SCJ->CJ_FILIAL .and. SCK->CK_NUM == SCJ->CJ_NUM
  570. nItens++
  571. cItem := StrZero(nItens,TamSX3("CK_ITEM")[1])
  572. Posicione("SB1",1,xFilial("SB1")+SCK->CK_PRODUTO,"B1_DESC")
  573. If SB5->(MsSeek(xFilial("SB5")+SCK->CK_PRODUTO))
  574. If SB5->B5_DTVLESP + 30 < dDataBase
  575. lVencido:= .T.
  576. Endif
  577. Endif
  578. cOrcItens += '<tr class="odd" id="linha'+StrZero(nItens,2)+'">'
  579. lProdBloq:= .F.
  580. SB1->(dbSetOrder(1))
  581. SB1->(dbSeek(xFilial("SB1")+SCK->CK_PRODUTO))
  582. If SB1->B1_MSBLQL = '1'
  583. lProdBloq:= .T.
  584. Endif
  585. DA1->(dbSetOrder(1))
  586. DA1->(dbSeek(xFilial("DA1")+SCJ->CJ_TABELA+SCK->CK_PRODUTO))
  587. // gera os produtos de acordo com o Cliente e Tabela
  588. //cOptProd := u_GetProdOrc(SCJ->CJ_CLIENTE, SCJ->CJ_TABELA, "")
  589. For nLin := 1 to Len(aItens)
  590. If aItens[nLin,2] == "ACAO"
  591. cOrcItens += '<td class="actions">'
  592. If lEdit .or. lCopy //!lDele
  593. //cOrcItens += ' <a href="#" id="btnRemItm" name="btnRemItm" class="on-default remove-row"><i class="fa fa-times-circle"></i></a>'
  594. //cOrcItens += ' <i class="fa fa-info fa-lg" data-toggle="tooltip" data-original-title="Detalhes da linha" onclick="detalheOrc('+"'"+cItem+"'"+');"></i>'
  595. If lEdit .or. lCopy
  596. cOrcItens += ' <i class="fa fa-times-circle fa-lg" data-toggle="tooltip" data-original-title="Remover a linha" onclick="removeItem('+"'"+cItem+"'"+');"></i>
  597. Endif
  598. Endif
  599. If !lDele
  600. cOrcItens += ' <i class="fa fa-info fa-lg" data-toggle="tooltip" data-original-title="Detalhes da linha" onclick="detalheOrc('+"'"+cItem+"'"+');"></i>'
  601. Endif
  602. cOrcItens += '</td>
  603. Else
  604. If aItens[nLin,2] == "CK_PRODUTO"
  605. cOrcItens += '<td>' //class="form-group row pb-4"
  606. Else
  607. cOrcItens += '<td'+Iif(!Empty(aItens[nLin][4]),' align="'+aItens[nLin][4]+'"',"")+Iif(aItens[nLin,10],'hidden','')+'>'
  608. Endif
  609. lMoeda:= aItens[nLin,8] //Indica se é Moeda
  610. lNumber:= aItens[nLin,5] = "N" //Indica que é numérico
  611. xValue:= ""
  612. Do Case
  613. Case aItens[nLin][5] == 'C'
  614. If aItens[nLin,2] == "CK_PRODUTO"
  615. xValue := AllTrim(SCK->&(aItens[nLin][2]))+' - '+Alltrim(SB1->B1_DESC)
  616. Else
  617. //Verifica se o produto está bloqueado
  618. If aItens[nLin,2] == "CK_ITEM" .and. lEdit .and. lProdBloq //lCopy .and. SB1->B1_MSBLQL = '1'
  619. xValue := 'xx'
  620. //lProdBloq:= .T.
  621. Else
  622. xValue := AllTrim(SCK->&(aItens[nLin][2]))
  623. Endif
  624. Endif
  625. Case aItens[nLin][5] == 'N'
  626. If aItens[nLin,2] == "CK_QTDVEN"
  627. xValue := Iif(lNewOrc,"",Alltrim(cvaltochar(SCK->&(aItens[nLin][2]))))
  628. ElseIf aItens[nLin,2] == "PER_COM"
  629. xValue := Iif(lNewOrc,"",Alltrim(PadR(TransForm(nPerCom,PesqPict("SD2","D2_COMIS1")),TamSX3("D2_COMIS1")[1])))
  630. ElseIf aItens[nLin,2] == "VAL_COM"
  631. xValue := Iif(lNewOrc,"",Alltrim(PadR(TransForm(nValCom,PesqPict("SCK","CK_PRCVEN")),TamSX3("CK_PRCVEN")[1])))
  632. ElseIf aItens[nLin,2] == "iCK_PRCVEN"
  633. //xValue := Iif(lNewOrc,"",Alltrim(cvaltochar(SCK->CK_PRCVEN)))
  634. If lEdit
  635. nVlrProd:= u_getValProd(SCJ->CJ_COMISTR,SCJ->CJ_PERCFRT)
  636. xValue := Alltrim(TransForm(nVlrProd,PesqPict("DA1","DA1_PRCVEN")))
  637. Else
  638. xValue := Iif(lNewOrc,"",Alltrim(TransForm(SCK->CK_PRCVEN,PesqPict("SCK","CK_PRCVEN"))))
  639. Endif
  640. Elseif aItens[nLin,2] == "CK_PRCVEN"
  641. If lEdit
  642. nVlrProd:= u_getValProd(SCJ->CJ_COMISTR,SCJ->CJ_PERCFRT)
  643. xValue := Alltrim(TransForm(nVlrProd,PesqPict("DA1","DA1_PRCVEN")))
  644. nVlrCDesc:= nVlrProd
  645. Else
  646. xValue := Alltrim(TransForm(SCK->CK_PRUNIT,PesqPict("SCK","CK_PRUNIT")))
  647. nVlrCDesc:= SCK->CK_PRUNIT
  648. Endif
  649. Elseif aItens[nLin,2] == "CK_DESCONT"
  650. xValue:= Alltrim(TransForm(SCK->CK_DESCACM,PesqPict("SCK","CK_DESCONT")))
  651. Elseif aItens[nLin,2] == "CK_VALOR"
  652. If lEdit
  653. nVlrProd:= u_getValProd(SCJ->CJ_COMISTR,SCJ->CJ_PERCFRT)
  654. xValue := Alltrim(TransForm(nVlrProd*SCK->CK_QTDVEN,PesqPict("SCK",aItens[nLin,2])))
  655. nTotValor:= nVlrProd*SCK->CK_QTDVEN
  656. Else
  657. xValue := Alltrim(TransForm(SCK->(CK_VALOR/*+CK_XVALIPI+CK_XICMST*/),PesqPict("SCK",aItens[nLin,2])))
  658. nTotValor:=SCK->CK_VALOR
  659. Endif
  660. Else
  661. If SCK->(FieldPos(aItens[nLin][2])) > 0
  662. xValue := Alltrim(TransForm(SCK->&(aItens[nLin][2]),PesqPict("SCK",aItens[nLin,2])))
  663. Else
  664. xValue := ""
  665. Endif
  666. Endif
  667. EndCase
  668. If aItens[nLin,6] //Campo Editável
  669. If aItens[nLin,2] == "CK_PRODUTO"
  670. //Cria o select para o produto
  671. If (lEdit .or. lCopy) .and. SB1->B1_MSBLQL <> '1'
  672. cOrcItens +='<div class="form-group">'
  673. cOrcItens +=' <div class="col-md-12">
  674. cOrcItens +=' <div class="flexContainer">
  675. cOrcItens +=' <input type="text" class="form-control smsediticon" placeholder="Digite o código ou descrição..." '
  676. cOrcItens +=' name="CK_PRODUTO'+cItem+'" id="CK_PRODUTO'+cItem+'"'
  677. cOrcItens += Iif(aItens[nLin][7],'required="" aria-required="true" ','')+' data-live-search="true" autocomplete="off" '
  678. cOrcItens +=' value="'+Alltrim(SCK->CK_PRODUTO)+' -- '+Alltrim(SB1->B1_DESC)+'" >'
  679. cOrcItens +=' <button class="btSearch" id="btSearch"'+cItem+' >'
  680. cOrcItens +=' <i class="fa fa-search" alt="Pesquisar"></i>'
  681. cOrcItens +=' </button>
  682. cOrcItens +=' </div>
  683. cOrcItens +=' </div>
  684. cOrcItens +='</div>
  685. Else
  686. cOrcItens +='<select class="selectpicker" name="CK_PRODUTO'+cItem+'" id="CK_PRODUTO'+cItem+'" '
  687. cOrcItens += Iif(aItens[nLin][7],'required="" aria-required="true" ','')+' data-live-search="true" '
  688. cOrcItens +=' data-width="569px" title="Produto bloqueado" disabled >' //style="size:4" data-width="90%" style="height:90%"
  689. cOrcItens += U_GetProdOrc(SCJ->CJ_CLIENTE, SCJ->CJ_TABELA, SCK->CK_PRODUTO)
  690. cOrcItens +='</select>'
  691. Endif
  692. Else
  693. cOrcItens += '<input id="'+aItens[nLin][2]+cItem+'" data-prop="'+aItens[nLin][2]+'" name="'+aItens[nLin][2]+cItem+'" class="form-control '
  694. cOrcItens += Iif(lNumber, aItens[nLin][4], "")
  695. cOrcItens +=If(lMoeda," ",If(lNumber," only-numbers",""))+'" type="text" '
  696. cOrcItens += 'placeholder="'+aItens[nLin,9]+'" '
  697. //Atribui as funções javascript
  698. If aItens[nLin,2] == "CK_QTDVEN"
  699. cOrcItens+='onblur="javascript:VldQtd('+"'"+cItem+"'"+') "'
  700. Endif
  701. If aItens[nLin,2] == "iCK_PRCVEN"
  702. cOrcItens+='onblur="javascript:VldValor('+"'"+cItem+"'"+') " '
  703. Endif
  704. If aItens[nLin,2] == "CK_DESCONT"
  705. cVldDesc:= Iif(GetMv("LC_OR1012A",,.F.),'S','N')
  706. cOrcItens+='onblur="javascript:VldValor('+"'"+cItem+"'"+','+"'"+cVldDesc+"'"+')" maxlength="7" '
  707. Endif
  708. If aItens[nLin,2] $ ("CK_QTDVEN|iCK_PRCVEN|CK_DESCONT")
  709. cOrcItens+='onkeyup="javascript:TotalItem('+"'"+cItem+"'"+') "'
  710. Endif
  711. //Campo obrigatório
  712. cOrcItens += Iif(aItens[nLin][7],'required="" aria-required="true" ','')
  713. If (lEdit .or. lCopy) .and. !lProdBloq//Inicia todos os campos desabilitados caso não for para editar ou copiar
  714. If !(aItens[nLin,2] $ "CK_QTDVEN|CK_DESCONT|CK_OBS|CK_PRZEMB") //.And. aItens[nLin,2] <> "CK_XPEDCLI" .And. aItens[nLin,2] <> "CK_XITEMCL"
  715. cOrcItens += 'disabled '
  716. EndIf
  717. Else
  718. cOrcItens += 'disabled '
  719. EndIf
  720. cOrcItens += 'value="'+Alltrim(xValue)+'">'
  721. Endif
  722. Else
  723. cOrcItens += '<input id="'+aItens[nLin][2]+cItem+'" data-prop="'+aItens[nLin][2]+'" name="'+aItens[nLin][2]+cItem+'" '
  724. cOrcItens += 'class="form-control input-block '+Iif(lNumber, aItens[nLin][4], "")+'" '
  725. cOrcItens += 'type="text" disabled width="" '
  726. If aItens[nLin,2] $ "CK_PRODUTO|CK_OBS"
  727. cOrcItens += 'title="'+Alltrim(xValue)+'" '
  728. Endif
  729. cOrcItens += 'value="'+Alltrim(xValue)+'">'
  730. Endif
  731. Endif
  732. cOrcItens += '</td>'
  733. Next
  734. //Inputs Hidden
  735. cItensHid += '<input type="hidden" class="" id="ALIQ_ICMS'+cItem+'" name="ALIQ_ICMS'+cItem+'" value="'+cValtochar(SCK->CK_XALIICM)+'">'
  736. cItensHid += '<input type="hidden" class="" id="ALIQ_IPI'+cItem+'" name="ALIQ_IPI'+cItem+'" value="'+cValtochar(SCK->CK_XALIIPI)+'">'
  737. cItensHid += '<input type="hidden" class="" id="ALIQ_ST'+cItem+'" name="ALIQ_ST'+cItem+'" value="'+cValtochar(SCK->CK_XALIST)+'">'
  738. cItensHid += '<input type="hidden" class="" id="VAL_ICMS'+cItem+'" name="VAL_ICMS'+cItem+'" value="'+Alltrim(Transform(SCK->CK_ICMS,PesqPict("SCK","CK_ICMS")))+'">'
  739. cItensHid += '<input type="hidden" class="" id="VAL_IPI'+cItem+'" name="VAL_IPI'+cItem+'" value="'+Alltrim(Transform(SCK->CK_IPI,PesqPict("SCK","CK_IPI")))+'">'
  740. cItensHid += '<input type="hidden" class="" id="VAL_ST'+cItem+'" name="VAL_ST'+cItem+'" value="'+Alltrim(Transform(SCK->CK_ST,PesqPict("SCK","CK_ST")))+'">'
  741. cItensHid += '<input type="hidden" class="" id="BASE_ICMS'+cItem+'" name="BASE_ICMS'+cItem+'" value="0">'
  742. cItensHid += '<input type="hidden" class="" id="BASE_ST'+cItem+'" name="BASE_ST'+cItem+'" value="0">'
  743. cItensHid += '<input type="hidden" class="" id="BASE_IPI'+cItem+'" name="BASE_IPI'+cItem+'" value="0">'
  744. cItensHid += '<input type="hidden" class="" id="IMP_PRCTAB'+cItem+'" name="IMP_PRCTAB'+cItem+'" value="0">'
  745. cItensHid += '<input type="hidden" class="" id="QTD_EMB'+cItem+'" name="QTD_EMB'+cItem+'" value="'+cValtochar(SB1->B1_QE)+'">'
  746. cItensHid += '<input type="hidden" class="" id="CK_TES'+cItem+'" name="CK_TES'+cItem+'" value="'+SCK->CK_TES+'">'
  747. cItensHid += '<input type="hidden" class="" id="QTDMIN'+cItem+'" name="QTDMIN'+cItem+'" value="">'
  748. cItensHid += '<input type="hidden" class="" id="GRUPO'+cItem+'" name="GRUPO'+cItem+'" value="'+SB1->B1_GRUPO+'">'
  749. cItensHid += '<input type="hidden" class="" id="VENCIMENTO'+cItem+'" name="VENCIMENTO'+cItem+'" value="'+Iif(lVencido,'1','0')+'">'
  750. cItensHid += '<input type="hidden" class="" id="B1_COMIS'+cItem+'" name="B1_COMIS'+cItem+'" value="'+cvaltochar(SB1->B1_COMIS)+'">'
  751. cItensHid += '<input type="hidden" class="" id="CK_COMIS1'+cItem+'" name="CK_COMIS1'+cItem+'" value="'+cvaltochar(SCK->CK_COMIS1)+'">'
  752. cItensHid += '<input type="hidden" class="" id="CK_COMIS3'+cItem+'" name="CK_COMIS3'+cItem+'" value="'+cvaltochar(SCK->CK_COMIS3)+'">'
  753. cOrcItens+=cItensHid
  754. //Totais
  755. nTImpostos += SCK->(CK_ST+CK_IPI)
  756. nTVlrUnit += nTotValor //total do item c/desconto
  757. nTTotal += nTotValor + SCK->(CK_IPI+CK_ST) //total com desconto + impostos
  758. nTQtdItem += SCK->CK_QTDVEN
  759. nValDesc += nTotValor * (SCK->CK_DESCACM/100)
  760. //nValDesc += nTotValor * (SCK->CK_DESCONT/100)
  761. nTVlrSDesc += nTotValor + (nTotValor * (SCK->CK_DESCACM/100)) //Total sem desconto
  762. //nTVlrSDesc += nTotValor + (nTotValor * (SCK->CK_DESCONT/100)) //Total sem desconto
  763. nPerCom:= SCK->CK_COMIS1
  764. nValCom:= SCK->CK_COMISSA //(SCK->CK_QTDVEN * SCK->CK_PRCVEN) * (nPerCom/100)
  765. nTComiss+= nValCom
  766. SCK->(dbSkip())
  767. End
  768. //nTAcresc:= Round(nTTotal*(nAcresc/100),2)
  769. nTTotal+= nTFrete
  770. //nTTotal+= nTFrete+nTAcresc
  771. cOrcItens += '<input type="hidden" name="QtdItens" id="QtdItens" value="'+cValtoChar(nItens)+'"/>'
  772. cOrcItens += '<input type="hidden" id="PROXIMO" name="PROXIMO" value="'+StrZero(nItens,2)+'"/>
  773. cOrcItens += '<input type="hidden" class="" name="CJ_NUM" id="CJ_NUM" value="'+IIf(lCopy, "", SCJ->CJ_NUM)+'" />'
  774. cOrcItens += '<input type="hidden" name="OPCAO" id="OPCAO" value="'+cValtoChar(nOpc)+'" />'
  775. cOrcItens += '<input type="hidden" name="DESCCOND" id="DESCCOND" value="" />'
  776. cOrcItens += '<input type="hidden" name="CJ_DSDIRET" id="CJ_DSDIRET" value="'+IIf(lCopy, "", cvaltochar(SCJ->CJ_DSDIRET))+'" />'
  777. cOrcItens += '<input type="hidden" name="FRETEMIN" id="FRETEMIN" value="'+cvaltochar(GetMv("MV_FRETMIN"))+'" />'
  778. cOrcItens += '</tr>'
  779. //Adiciona os botões de ações na tabela de itens
  780. If lEdit
  781. cBtnItens+='<div class="row form-group">'
  782. cBtnItens+=' <div class="col-sm-2">'
  783. cBtnItens+=' <button class="btn btn-primary" id="btAddItm" name="btAddItm">' //onclick="javascript:newItem()" >'
  784. cBtnItens+=' <i class="fa fa-plus-square"></i> Novo Item</button>'
  785. cBtnItens+=' </div>'
  786. cBtnItens+='</div>'
  787. Endif
  788. //Adiciona os botões da página
  789. If lEdit
  790. //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>'
  791. cBotoes+='<input class="btn btn-primary" type="button" id="btSalvar" name="btSalvar" value="Salvar"/>'+chr(13)+chr(10)
  792. Elseif lDele
  793. cBotoes+='<input class="btn btn-primary " type="button" id="btExcluir" name="btExcluir" value="Excluir"/>'+chr(13)+chr(10)
  794. Endif
  795. 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)
  796. //Totalizador disponível apenas para regional
  797. If HttpSession->Tipo <> "R"
  798. cTotalReg:='<div class="col-sm-12">'
  799. cTotalReg+=' <label class="">Itens sem Desconto&nbsp;</label>'
  800. 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>'
  801. cTotalReg+=' &nbsp;&nbsp;&nbsp;&nbsp;'
  802. cTotalReg+=' <label class="">Itens sem Desconto+Impostos&nbsp;</label>'
  803. 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>'
  804. cTotalReg+='</div>'
  805. cTotalReg+='<br>'
  806. cTotalReg+='<br>'
  807. cShowDesc := 'true'
  808. Endif
  809. //Retorna o HTML para construção da página
  810. cHtml := H_AddOrc()
  811. Web Extended End
  812. Return (cHTML)
  813. /*__________________________________________________________________________
  814. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  815. ¦¦+-----------------------------------------------------------------------+¦¦
  816. ¦¦¦Funçäo ¦ ExcOrc ¦ Autor ¦ Anderson Zelenski ¦ Data ¦10.12.17 ¦¦¦
  817. ¦¦+----------+------------------------------------------------------------¦¦¦
  818. ¦¦¦Descriçäo ¦ Exclui o Orçamento de Venda ¦¦¦
  819. ¦¦+-----------------------------------------------------------------------+¦¦
  820. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  821. ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯*/
  822. User Function ExcOrc()
  823. Local cHtml
  824. Local nOpc := 5 // 3- Incluir / 4- Alterar / 5- Excluir
  825. Local cCliente := ""
  826. Local cLoja := ""
  827. Local cNumOrc := ""
  828. Local cDirErro := "erro\"
  829. Private cReturn
  830. Private aCabSCJ :={}
  831. Private aItemSCJ:={}
  832. Private aLinhaSCJ:={}
  833. Private lMsErroAuto:= .F.
  834. Private cCodLogin := ""
  835. Private cVendLogin:= ""
  836. Private INCLUI := .F.
  837. Private ALTERA := .F.
  838. Web Extended Init cHtml Start U_inSite()
  839. //Verifica se não perdeu a sessão
  840. If type("HttpSession->CodVend") = "U" .or. Empty(HttpSession->CodVend)
  841. conout(Procname()+"("+ltrim(str(procline()))+") *** Portal "+"Sessao encerrada")
  842. cHtml:= '<META HTTP-EQUIV="Refresh" CONTENT="0 ; URL=U_SMSPortal.apw">'
  843. return cHtml
  844. Endif
  845. cVendLogin := u_GetUsrPR()
  846. cCodLogin := U_SetParPR(cVendLogin)
  847. //Variáveis do cabeçalho
  848. cCliente:= Left(HttpPost->CJ_CLIENTE,6)
  849. cLoja:= Right(HttpPost->CJ_CLIENTE,6)
  850. cNumOrc:= HttpPost->CJ_NUM
  851. nModulo:= 5
  852. //Posiciona nas tabelas
  853. If !Empty(cCliente)
  854. Posicione("SA1",1,xFilial("SA1")+Alltrim(HttpPost->CJ_CLIENTE),"A1_COD")
  855. Endif
  856. //Posiciona no orçamento
  857. Posicione("SCJ",1,xFilial("SCJ")+cNumOrc,"CJ_NUM")
  858. cFilOrc:= SCJ->CJ_FILIAL
  859. //Monta o cabeçalho
  860. aadd(aCabSCJ,{"CJ_NUM",cNumOrc,Nil})
  861. aadd(aCabSCJ,{"CJ_CLIENTE",SA1->A1_COD,Nil})
  862. aadd(aCabSCJ,{"CJ_LOJA", SA1->A1_LOJA ,Nil})
  863. aLinhaSCJ:={}
  864. //Monta os itens
  865. lMsErroAuto:= .F.
  866. //Chama execauto para inclusão do orçamento
  867. If Len(aCabSCJ) > 0
  868. MATA415(aCabSCJ,aItemSCJ,nOpc)
  869. Else
  870. conout(Procname()+"("+ltrim(str(procline()))+") *** Portal "+"FALHA AO EXCLUIR O ORÇAMENTO!")
  871. lMsErroAuto:= .T.
  872. Endif
  873. If lMsErroAuto
  874. If !ExistDir(cDirErro)
  875. MakeDir(cDirErro)
  876. Endif
  877. cDirErro+=dtos(date())
  878. If !ExistDir(cDirErro)
  879. MakeDir(cDirErro)
  880. Endif
  881. //Grava o erro
  882. MostraErro(cDirErro,"erro_orcto_"+strtran(time(),":","")+".txt")
  883. cHtml:= "erro"
  884. Else
  885. SCJ->(dbGoBottom())
  886. cHtml:= SCJ->CJ_NUM
  887. EndIf
  888. Web Extended End
  889. Return (cHTML)
  890. /*__________________________________________________________________________
  891. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  892. ¦¦+-----------------------------------------------------------------------+¦¦
  893. ¦¦¦Funçäo ¦ GetProdOrc ¦ Autor ¦ Anderson Zelenski ¦ Data ¦ 10.12.17 ¦¦¦
  894. ¦¦+----------+------------------------------------------------------------¦¦¦
  895. ¦¦¦Descriçäo ¦ Função para retornar os produtos da tabela e esta no Orç. ¦¦¦
  896. ¦¦+-----------------------------------------------------------------------+¦¦
  897. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  898. ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯*/
  899. User Function GetProdOrc(cOrcCli, cOrcTab, cOrcProd)
  900. Local cHtml
  901. Local cProds := ""
  902. Local cGrupo := ""
  903. //Atualiza a variável de sessão
  904. HttpSession->TABELA := cOrcTab
  905. //Busca os itens da tabela de preço
  906. cQry:="Select DA1_CODTAB, B1_GRUPO, BM_DESC, DA1_CODPRO, B1_DESC "
  907. cQry+=" From "+RetSqlName("DA1")+" DA1"
  908. cQry+=" INNER JOIN "+RetSqlName("DA0")+" DA0 ON DA0_FILIAL = DA1_FILIAL AND DA0_CODTAB = DA1_CODTAB AND DA0_ATIVO = '1' AND DA0.D_E_L_E_T_ = ' ' "
  909. cQry+=" INNER JOIN "+RetSqlName("SB1")+" SB1 ON B1_FILIAL = '"+xFilial("SB1")+"' AND B1_COD = DA1_CODPRO AND SB1.D_E_L_E_T_ = ' ' " //AND B1_MSBLQL <> '1'
  910. cQry+=" LEFT JOIN "+RetSqlName("SBM")+" SBM ON BM_FILIAL = '"+xFilial("SBM")+"' AND B1_GRUPO = BM_GRUPO AND SBM.D_E_L_E_T_ = ' ' "
  911. cQry+=" Where DA1_FILIAL = '"+xFilial("DA1")+"' "
  912. cQry+=" And DA1_CODTAB = '"+cOrcTab+"' "
  913. //cQry+=" AND DA1_ATIVO = '1' "
  914. If !Empty(cOrcProd)
  915. cQry+=" AND DA1_CODPRO = '"+cOrcProd+"' "
  916. Endif
  917. cQry+=" AND DA1_PRCVEN > 0 "
  918. cQry+=" AND DA1.D_E_L_E_T_ = ' ' "
  919. cQry+=" Order by DA1_CODTAB, B1_GRUPO, B1_COD "
  920. CONOUT(CQRY)
  921. If Select("QRP") > 0
  922. QRP->(dbCloseArea())
  923. Endif
  924. APWExOpenQuery(ChangeQuery(cQry),'QRP',.T.)
  925. //Preenche o select de produtos
  926. While QRP->(!Eof())
  927. If Empty(cGrupo)
  928. cProds+= '<optgroup label="'+Alltrim(StrTran(QRP->BM_DESC,"'",""))+'">
  929. Elseif !Empty(cGrupo) .and. cGrupo <> QRP->B1_GRUPO
  930. cProds+= '</optgroup>'
  931. cProds+= '<optgroup label="'+Alltrim(StrTran(QRP->BM_DESC,"'",""))+'">
  932. Endif
  933. cProds+=' <option value="'+Alltrim(QRP->DA1_CODPRO)+'" '+Iif(Alltrim(QRP->DA1_CODPRO) == AllTrim(cOrcProd), 'selected','')+'>'+Alltrim(QRP->DA1_CODPRO)+' - '+Alltrim(StrTran(QRP->B1_DESC,"'",""))+'</option>'
  934. cGrupo:= QRP->B1_GRUPO
  935. QRP->(dbSkip())
  936. End
  937. If !Empty(cProds)
  938. cProds+= '</optgroup>'
  939. Endif
  940. cHtml:= cProds
  941. Return cHtml
  942. /*__________________________________________________________________________
  943. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  944. ¦¦+-----------------------------------------------------------------------+¦¦
  945. ¦¦¦Funçäo ¦ GetMCOrc ¦ Autor ¦ Anderson Zelenski ¦ Data ¦ 02.12.23 ¦¦¦
  946. ¦¦+----------+------------------------------------------------------------¦¦¦
  947. ¦¦¦Descriçäo ¦ Função para calcular a margem de contribuição do orçamento.¦¦¦
  948. ¦¦+-----------------------------------------------------------------------+¦¦
  949. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  950. ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯*/
  951. User Function GetMCOrc()
  952. Local cMargem := ""
  953. Local cQry := ""
  954. Local cLinha := "00"
  955. Local nMkt := 0
  956. Local nMktP := 0
  957. Local nMC := 0
  958. Local nMC_T := 0
  959. Local nMCTotIt := 0
  960. Local nCusto := 0
  961. Local nICMS := 0
  962. Local nComis2 := 0
  963. Local nComis3 := 0
  964. Local nPIS := 0
  965. Local nCofins := 0
  966. Local nComissao := 0
  967. Local nRT := 0
  968. Local nIPI := 0
  969. Local nFrete := 0
  970. Local nSubsTrb := 0
  971. Local nSubsCus := 0
  972. Local nST := 0
  973. Local nINSSP := 0
  974. Local nRecLiq := 0
  975. Local nMC_L := 0
  976. Local nMCTotIt_L:= 0
  977. Local nMC_E := 0
  978. Local nMCTotIt_E:= 0
  979. Local nMC_P := 0
  980. Local nMCTotIt_P:= 0
  981. Local cAcessorio:= GetNewPar("PR_ACESSOR","ACS-LHT44BC/ACS-LHT44PT/ACS-LHT45BC/ACS-LHT45PT")
  982. cQry:= "Select * From "+RetSqlName("SCK")+" SCK "
  983. cQry+= "Inner Join "+RetSqlName("SB1")+" SB1 ON B1_FILIAL = '"+xFilial("SB1")+"' AND B1_COD = CK_PRODUTO AND SB1.D_E_L_E_T_ = ' ' "
  984. cQry+= "Where CK_FILIAL = '"+SCJ->CJ_FILIAL+"' "
  985. cQry+= "AND CK_NUM = '"+SCJ->CJ_NUM+"' "
  986. cQry+= "AND SCK.D_E_L_E_T_ = ' ' "
  987. If Select("TMP1") > 0
  988. TMP1->(dbCloseArea())
  989. Endif
  990. TcQuery cQry New Alias "TMP1"
  991. // passa por todos os itens do orcamento
  992. While !TMP1->(EOF())
  993. cLinha := soma1(cLinha)
  994. cTipo := Alltrim(TMP1->B1_TIPO)
  995. cGrupo := Alltrim(TMP1->B1_GRUPO)
  996. nMkt := 0
  997. nCusto := TMP1->CK_CUSTO
  998. nICMS := TMP1->CK_ICMS
  999. nComis2 := TMP1->CK_COMIS1
  1000. nComis3 := TMP1->CK_COMIS3
  1001. nPIS := TMP1->CK_PIS
  1002. nCofins := TMP1->CK_COFINS
  1003. nComissao := TMP1->CK_COMISSA
  1004. nRT := TMP1->CK_RT
  1005. nIPI := TMP1->CK_IPI
  1006. nFrete := TMP1->CK_FRETE
  1007. nSubsTrb := TMP1->CK_SUBSTRB
  1008. nSubsCus := TMP1->CK_SUBSCUS
  1009. nST := TMP1->CK_ST
  1010. nINSSP := TMP1->CK_INSSP
  1011. // calcula receita liquida
  1012. nRecLiq := TMP1->CK_VALOR - nICMS - nPIS - nCofins - nINSSP
  1013. // se existe o campo de % do mkt
  1014. If TMP1->(FieldPos("CK_MKTP")) > 0
  1015. nMktP:= TMP1->CK_MKTP
  1016. Endif
  1017. // se existe o campo de vlr de mkt
  1018. If TMP1->(FieldPos("CK_MKT")) > 0
  1019. nMkt:= TMP1->CK_MKT
  1020. Endif
  1021. // calcula o valor da margem
  1022. nMC:= ((TMP1->CK_VALOR - nCusto - nICMS - nPIS - nCofins - nFrete - nComissao - nINSSP - nRT - nMkt) + nSubsTrb + nSubsCus)
  1023. //Cria o grid da tabela de margem
  1024. cMgItens+= '<tr class="odd" id="linha'+cLinha+'">'
  1025. cMgItens+= ' <td align="text-left">'
  1026. cMgItens+= ' <input id="ITEM'+cLinha+'" name="CK_ITEM'+cLinha+'" class="form-control input-block " type="text" disabled value="'+TMP1->CK_ITEM+'">'
  1027. cMgItens+= ' </td>'
  1028. cMgItens+= ' <td align="text-left">'
  1029. cMgItens+= ' <input id="CODIGO'+cLinha+'" name="CODIGO'+cLinha+'" class="form-control input-block " type="text" width="*" disabled value="'+Alltrim(TMP1->CK_PRODUTO)+' - '+Alltrim(TMP1->CK_DESCRI)+'">'
  1030. cMgItens+= ' </td>'
  1031. cMgItens+= ' <td align="text-left">'
  1032. cMgItens+= ' <input id="GRUPO'+cLinha+'" name="GRUPO'+cLinha+'" class="form-control input-block " type="text" width="*" disabled value="'+cTipo+' - '+cGrupo+'">'
  1033. cMgItens+= ' </td>'
  1034. cMgItens+= ' <td align="text-left">'
  1035. cMgItens+= ' <input id="MARKUP'+cLinha+'" name="MARKUP'+cLinha+'" class="form-control input-block " type="text" width="*" disabled value="'+Transform(TMP1->B1_MARKUP,"@E 999.99")+'">'
  1036. cMgItens+= ' </td>'
  1037. cMgItens+= ' <td align="text-left">'
  1038. cMgItens+= ' <input id="MC'+cLinha+'" name="MC'+cLinha+'" class="form-control input-block " type="text" width="*" disabled value="'+Transform((nMC / TMP1->CK_VALOR)*100,"@E 999,999,999.9999")+'">'
  1039. cMgItens+= ' </td>'
  1040. cMgItens+= '</tr>'
  1041. // Carrega as Variaveis Totalizador Orçamento, Luminarias e Equipamentos.
  1042. If cTipo == "CO" .AND. cGrupo== "ELEV"
  1043. // soma a margem total
  1044. nMC_T := nMC_T + (TMP1->CK_VALOR * -1)
  1045. // soma o valor total
  1046. nMCTotIt := nMCTotIt + TMP1->CK_VALOR
  1047. Else
  1048. // se nao é do grupo pan e nao são acessorios de painel de led
  1049. If cGRUPO <> 'PAN' .and. !(AllTrim(TMP1->CK_PRODUTO) $ cAcessorio)
  1050. // soma a margem total
  1051. nMC_T := nMC_T + nMC
  1052. // soma o valor total
  1053. nMCTotIt := nMCTotIt + TMP1->CK_VALOR
  1054. EndIf
  1055. EndIf
  1056. //Margem total do orçamento
  1057. nMargem:= ((nMC_T / nMCTotIt)*100)
  1058. //Luminarias
  1059. If cTipo == "PA"
  1060. If cGRUPO == "C" .OR. cGRUPO == "C-EX" .OR. cGRUPO == "F" .OR. cGRUPO == "F-EX" .OR. cGRUPO == "PE" .OR. cGRUPO == "DEC" .OR. cGRUPO == "DECV" .OR. cGRUPO == "PED" .OR. cGRUPO == "TEC" .OR.;
  1061. cGRUPO == "LED" .OR. cGRUPO == "LEDC" .OR. cGRUPO == "LEDD" .OR. cGRUPO == "LEDT" .OR. cGRUPO == "PEL" .OR. cGRUPO == "REIL" .OR. cGRUPO == "REIO" .OR. cGRUPO == "REAB"
  1062. nMC_L := nMC_L + nMc
  1063. nMCTotIt_L := nMCTotIt_L + TMP1->CK_VALOR
  1064. ElseIf cGrupo == "IMP" .AND. Substr(TMP1->CK_PRODUTO,1,2) <> "AC"
  1065. nMC_L := nMC_L + nMc
  1066. nMCTotIt_L := nMCTotIt_L + TMP1->CK_VALOR
  1067. EndIf
  1068. nMLuminaria:= (nMC_L / nMCTotIt_L)*100
  1069. ElseIf cTipo == "RE" .AND. cGrupo == "RELU"
  1070. nMC_L := nMC_L + nMc
  1071. nMCTotIt_L := nMCTotIt_L + TMP1->CK_VALOR
  1072. nMLuminaria:= (nMC_L / nMCTotIt_L)*100
  1073. EndIf
  1074. // Acessorios e Equipamentos.
  1075. If cTipo == "PA"
  1076. If cGRUPO == "ACES" .OR. cGRUPO == "PI" .OR. cGRUPO == "E040" .OR. cGRUPO == "E041" .OR. cGRUPO == "E042" .OR. cGRUPO == "E043" .OR. cGRUPO == "E044" .OR. cGRUPO == "E045" .OR.;
  1077. cGRUPO == "E046" .OR. cGRUPO == "E047" .OR. cGRUPO == "E048" .OR. cGRUPO == "E049"
  1078. // Acessorios PAN 23.01.2023 sao contabilizados junto do grupo pan
  1079. If !(AllTrim(TMP1->CK_PRODUTO) $ cAcessorio)
  1080. nMC_E := nMC_E + nMc
  1081. nMCTotIt_E := nMCTotIt_E + TMP1->CK_VALOR
  1082. Endif
  1083. ElseIf cGrupo == "IMP" .AND. Substr(TMP1->CK_PRODUTO,1,2) = "AC"
  1084. nMC_E := nMC_E + nMc
  1085. nMCTotIt_E := nMCTotIt_E + TMP1->CK_VALOR
  1086. EndIf
  1087. nMEquipa:= (nMC_E / nMCTotIt_E)*100
  1088. ElseIf (cTipo == "MP" .OR. cTipo == "RE")
  1089. If cGRUPO <> "RELU"
  1090. nMC_E := nMC_E + nMc
  1091. nMCTotIt_E := nMCTotIt_E + TMP1->CK_VALOR
  1092. nMEquipa:= (nMC_E / nMCTotIt_E)*100
  1093. EndIf
  1094. EndIf
  1095. // Grupo PAN
  1096. IF cGrupo == "PAN" .or. (AllTrim(TMP1->CK_PRODUTO) $ cAcessorio)
  1097. nMC_P := nMC_P + nMc
  1098. nMCTotIt_P := nMCTotIt_P + TMP1->CK_VALOR
  1099. nMPainel:= (nMC_P / nMCTotIt_P)*100
  1100. EndIf
  1101. TMP1->(dbSkip())
  1102. End
  1103. cMargem:= Transform(((nMC_T / nMCTotIt)*100),"@E 9999.99")
  1104. Return cMargem
  1105. /*__________________________________________________________________________
  1106. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  1107. ¦¦+-----------------------------------------------------------------------+¦¦
  1108. ¦¦¦Funçäo ¦ GetSaldoProd ¦ Autor ¦ Lucilene Mendes ¦ Data ¦ 17.10.23 ¦¦¦
  1109. ¦¦+----------+------------------------------------------------------------¦¦¦
  1110. ¦¦¦Descriçäo ¦ Busca saldo do item (mesma query GetEstDisp-addorc.apl) ¦¦¦
  1111. ¦¦+-----------------------------------------------------------------------+¦¦
  1112. ¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
  1113. ¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯*/
  1114. Static Function GetSaldoProd()
  1115. //Armazéns considerados para busca do estoque
  1116. Local cArmazem:= GetNewPar("PR_ARMZPR","'01','02','03'") //deve estar no formato '01','02'
  1117. Local cQry:=""
  1118. //Busca o saldo do produto
  1119. cQry:= "With QRY AS( "
  1120. 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
  1121. cQry+= "From "+RetSqlName("SB2")+" SB2 "
  1122. cQry+= "Where B2_FILIAL = '"+xFilial("SB2")+"' And B2_COD = '"+SCK->CK_PRODUTO+"' And SB2.D_E_L_E_T_ = ' ' "
  1123. If !Empty(cArmazem)
  1124. cQry+= "AND B2_LOCAL in ("+cArmazem+") "
  1125. Endif
  1126. cQry+= "UNION ALL "
  1127. cQry+= "Select 0 EST , SUM(CK_QTDVEN) EMPENHO "
  1128. cQry+= "From "+RetSqlName("SCJ")+" SCJ, "+RetSqlName("SCK")+" SCK "
  1129. cQry+= "Where CJ_FILIAL = '"+xFilial("SB2")+"' AND CJ_XTPORC = '1' AND CJ_STATUS = 'A' AND SCJ.D_E_L_E_T_ = ' ' "
  1130. cQry+= "and CK_FILIAL = CJ_FILIAL AND CK_NUM = CJ_NUM AND CK_PRODUTO = '"+SCK->CK_PRODUTO+"' and SCK.D_E_L_E_T_ = ' ' "
  1131. If !Empty(cArmazem)
  1132. cQry+= "AND CK_LOCAL in ("+cArmazem+") "
  1133. Endif
  1134. cQry+= ")"
  1135. cQry+= "SELECT SUM(EST) -SUM(EMPENHO) SALDO FROM QRY "
  1136. If Select("QRS") > 0
  1137. QRS->(dbCloseArea())
  1138. Endif
  1139. APWExOpenQuery(cQry,'QRS',.T.)
  1140. Return cvaltochar(QRS->SALDO)