report_seller.xml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <template xml:space="preserve">
  3. <t t-name="ReportSeller">
  4. <div class="report_view">
  5. <div class="reporting_page_header">
  6. <h1 class="report_title">Venta/Costo/Utilidad por Vendedores</h1>
  7. </div>
  8. <div class="container search-form" style="border-bottom:1px solid #eee; width:95%;">
  9. <div class="row">
  10. <div class="col-lg-3 company filter-style">
  11. <label>Empresa</label>
  12. <select id="current-company" class="form-control form-control-sm"></select>
  13. </div>
  14. <div class="col-lg-3 store filter-style">
  15. <label>Sucursal</label>
  16. <select id="current-store" class="form-control form-control-sm">
  17. </select>
  18. </div>
  19. <div class="col-lg-3 journal filter-style">
  20. <label>Vendedor</label>
  21. <select id="current-journal" class="form-control form-control-sm">
  22. </select>
  23. </div>
  24. <div class="col-lg-3 filter-style">
  25. <label>Periodo</label>
  26. <select id="current-period" class="form-control form-control-sm">
  27. </select>
  28. </div>
  29. <div class="col-lg-3 filter-style">
  30. <label>Fechas</label>
  31. <select id="current-date" class="form-control form-control-sm">
  32. <option value="9999999">Sin fechas</option>
  33. <option value="today">Hoy</option>
  34. <option value="yesterday">Ayer</option>
  35. <option value="currentMonth">Mes Actual</option>
  36. <option value="lastMonth">Mes Pasado</option>
  37. <option value="range">Busqueda Avanzada</option>
  38. </select>
  39. </div>
  40. </div>
  41. <div class="row" >
  42. <div class="datepicker" style="display:none;">
  43. <div class="col-lg-3 filter-style col-md-offset-3">
  44. <div class="input-group">
  45. <span class="input-group-addon" id="basic-addon1">Desde</span>
  46. <input type="text" id="from" class="form-control" aria-describedby="basic-addon1"/>
  47. </div>
  48. </div>
  49. <div class="col-lg-3 filter-style">
  50. <div class="input-group">
  51. <span class="input-group-addon" id="basic-addon1">Hasta</span>
  52. <input type="text" id="to" class="form-control" aria-describedby="basic-addon1"/>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. <div class="row">
  58. <div class="text-center" style="padding-top:20px;">
  59. <button id="generate" class="myButton" aria-label="Left Align" style="color:#fff;display:none;">
  60. Generar
  61. </button>
  62. </div>
  63. <br/>
  64. </div>
  65. </div>
  66. <div class="report-form" style="display:none;">
  67. <div id="toolbar">
  68. <button class="oe_button oe_form_button myButton" value="pdf">Imprimir Informe</button>
  69. </div>
  70. <div class="container" style="width:95%;">
  71. <table id="table"
  72. data-pagination="true"
  73. data-toggle="table"
  74. data-toolbar="#toolbar"
  75. data-show-columns="true"
  76. data-height="auto"
  77. data-classes="table table-condensed table-no-bordered"
  78. data-row-style="rowStyle"
  79. data-search="true"
  80. data-show-export="true"
  81. data-show-toggle="true"
  82. data-pagination-detail-h-align="left"
  83. data-show-footer="true"
  84. data-footer-style="footerStyle"
  85. data-buttons-class="oe_button oe_form_button myButton"
  86. data-show-pagination-switch="true"
  87. data-page-size="10"
  88. data-search-on-enter-key="true"
  89. data-undefined-text=" "
  90. >
  91. <thead style="background:none;">
  92. <tr>
  93. <th data-field="name" data-footer-formatter="Totales" data-align="left">Nombre</th>
  94. <th data-field="total_cash" data-footer-formatter="totalCashFormatter" data-align="right">Total Contado</th>
  95. <th data-field="total_credit" data-footer-formatter="totalCreditFormatter" data-align="right">Total Credito</th>
  96. <th data-field="total_amount" data-footer-formatter="totalAmountFormatter" data-align="right">Total Ventas</th>
  97. <th data-field="total_cost" data-footer-formatter="totalCostFormatter" data-align="right">Costo Total</th>
  98. <th data-field="utility" data-footer-formatter="totalUtilityFormatter" data-align="right">Utilidad Ventas</th>
  99. <th data-field="cost_percent" data-footer-formatter="totalCostPercentFormatter" data-align="right">Rent. Costo %</th>
  100. <th data-field="sale_percent" data-footer-formatter="totalSalePercentFormatter" data-align="right">Rent. Venta %</th>
  101. </tr>
  102. </thead>
  103. </table>
  104. </div>
  105. </div>
  106. <script>
  107. <!--
  108. TOTAL CASH
  109. -->
  110. function totalCashFormatter(rowsTable) {
  111. var decimal_places = 0;
  112. var thousands_separator = '.';
  113. var decimal_separator = ',';
  114. if(rowsTable.length > 0){
  115. decimal_places = rowsTable[0].decimal_places;
  116. thousands_separator = rowsTable[0].thousands_separator;
  117. decimal_separator = rowsTable[0].decimal_separator;
  118. }
  119. var amount = _.reduce(_.map(rowsTable,function(item){
  120. return (item.total_cash_no_format);
  121. }), function(memo, num){
  122. return memo + num; },0)
  123. return accounting.formatNumber(amount,decimal_places,thousands_separator,decimal_separator);
  124. }
  125. <!--
  126. TOTAL CREDIT
  127. -->
  128. function totalCreditFormatter(rowsTable) {
  129. var decimal_places = 0;
  130. var thousands_separator = '.';
  131. var decimal_separator = ',';
  132. if(rowsTable.length > 0){
  133. decimal_places = rowsTable[0].decimal_places;
  134. thousands_separator = rowsTable[0].thousands_separator;
  135. decimal_separator = rowsTable[0].decimal_separator;
  136. }
  137. var amount = _.reduce(_.map(rowsTable,function(item){
  138. return (item.total_credit_no_format);
  139. }), function(memo, num){
  140. return memo + num; },0)
  141. return accounting.formatNumber(amount,decimal_places,thousands_separator,decimal_separator);
  142. }
  143. <!--
  144. TOTAL AMOUNT
  145. -->
  146. function totalAmountFormatter(rowsTable) {
  147. var decimal_places = 0;
  148. var thousands_separator = '.';
  149. var decimal_separator = ',';
  150. if(rowsTable.length > 0){
  151. decimal_places = rowsTable[0].decimal_places;
  152. thousands_separator = rowsTable[0].thousands_separator;
  153. decimal_separator = rowsTable[0].decimal_separator;
  154. }
  155. var amount = _.reduce(_.map(rowsTable,function(item){
  156. return (item.total_amount_no_format);
  157. }), function(memo, num){
  158. return memo + num; },0)
  159. return accounting.formatNumber(amount,decimal_places,thousands_separator,decimal_separator);
  160. }
  161. <!--
  162. TOTAL COST
  163. -->
  164. function totalCostFormatter(rowsTable) {
  165. var decimal_places = 0;
  166. var thousands_separator = '.';
  167. var decimal_separator = ',';
  168. if(rowsTable.length > 0){
  169. decimal_places = rowsTable[0].decimal_places;
  170. thousands_separator = rowsTable[0].thousands_separator;
  171. decimal_separator = rowsTable[0].decimal_separator;
  172. }
  173. var amount = _.reduce(_.map(rowsTable,function(item){
  174. return (item.total_cost_no_format);
  175. }), function(memo, num){
  176. return memo + num; },0)
  177. return accounting.formatNumber(amount,decimal_places,thousands_separator,decimal_separator);
  178. }
  179. <!--
  180. TOTAL UTILITY
  181. -->
  182. function totalUtilityFormatter(rowsTable) {
  183. var decimal_places = 0;
  184. var thousands_separator = '.';
  185. var decimal_separator = ',';
  186. if(rowsTable.length > 0){
  187. decimal_places = rowsTable[0].decimal_places;
  188. thousands_separator = rowsTable[0].thousands_separator;
  189. decimal_separator = rowsTable[0].decimal_separator;
  190. }
  191. var amount = _.reduce(_.map(rowsTable,function(item){
  192. return (item.utility_no_format);
  193. }), function(memo, num){
  194. return memo + num; },0)
  195. return accounting.formatNumber(amount,decimal_places,thousands_separator,decimal_separator);
  196. }
  197. <!--
  198. TOTAL COST PERCENT
  199. -->
  200. function totalCostPercentFormatter(rowsTable) {
  201. var decimal_places = 0;
  202. var thousands_separator = '.';
  203. var decimal_separator = ',';
  204. if(rowsTable.length > 0){
  205. decimal_places = rowsTable[0].decimal_places;
  206. thousands_separator = rowsTable[0].thousands_separator;
  207. decimal_separator = rowsTable[0].decimal_separator;
  208. }
  209. var totalUtility = _.reduce(_.map(rowsTable,function(item){
  210. return (item.utility_no_format);
  211. }), function(memo, num){
  212. return memo + num; },0)
  213. var totalCost = _.reduce(_.map(rowsTable,function(item){
  214. return (item.total_cost_no_format);
  215. }), function(memo, num){
  216. return memo + num; },0)
  217. var amount = totalUtility * 100 / totalCost;
  218. return accounting.formatNumber(amount,2,thousands_separator,decimal_separator) + ' %';
  219. }
  220. <!--
  221. TOTAL SALE PERCENT
  222. -->
  223. function totalSalePercentFormatter(rowsTable) {
  224. var decimal_places = 0;
  225. var thousands_separator = '.';
  226. var decimal_separator = ',';
  227. if(rowsTable.length > 0){
  228. decimal_places = rowsTable[0].decimal_places;
  229. thousands_separator = rowsTable[0].thousands_separator;
  230. decimal_separator = rowsTable[0].decimal_separator;
  231. }
  232. var totalUtility = _.reduce(_.map(rowsTable,function(item){
  233. return (item.utility_no_format);
  234. }), function(memo, num){
  235. return memo + num; },0)
  236. var totalSale = _.reduce(_.map(rowsTable,function(item){
  237. return (item.total_amount_no_format);
  238. }), function(memo, num){
  239. return memo + num; },0)
  240. var amount = totalUtility * 100 / totalSale;
  241. return accounting.formatNumber(amount,2,thousands_separator,decimal_separator)+' %';
  242. }
  243. <!--
  244. FOOTER STYLE
  245. -->
  246. function footerStyle(row, index) {
  247. return {
  248. css: {
  249. "font-weight": "bold"
  250. }
  251. };
  252. };
  253. </script>
  254. </div>
  255. </t>
  256. </template>