Bocian.php.addItemToRaport.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. const createReactClass = window.p5VendorJs.createReactClass;
  2. const h = window.p5VendorJs.React.createElement;
  3. const ReactDOM = window.p5VendorJs.ReactDOM;
  4. const AsyncTypeahead = window.p5VendorJs.AsyncTypeahead;
  5. const swal = window.swal;
  6. const DBG = 1;
  7. var P5UI_AddItemToReport_BazaMenuItem = createReactClass({
  8. // this.props: { key: option.ID, baza: selectedBaza, data: option }
  9. render: function () {
  10. return h('div', {}, this.props.data.label);
  11. }
  12. })
  13. var P5UI_AddItemToReport = createReactClass({
  14. getInitialState: function () {
  15. return {
  16. baza: null,
  17. newItemBaza: null,
  18. isSearching: false,
  19. selected: null,
  20. };
  21. },
  22. _handleSelectBaza: function (baza) {
  23. this.setState({ baza: baza, newItemBaza: null });
  24. },
  25. _handleSelectNewItem: function (baza) {
  26. this.setState({ baza: null, newItemBaza: baza });
  27. },
  28. _handleSelected: function (selected) {
  29. this.setState({ selected: (selected.length > 0) ? selected[0] : null });
  30. },
  31. _handleSearch: function (query) {
  32. this.setState({ isSearching: true });
  33. var _setState = this.setState.bind(this);
  34. var baza = this.state.baza;
  35. var options= [];
  36. window.fetch(URL_FETCH_FROM_BAZA, {
  37. method: 'POST',
  38. header: {
  39. 'contentType': 'applications/json'
  40. },
  41. credentials: 'same-origin',
  42. body: JSON.stringify({
  43. baza: baza,
  44. query: query,
  45. })
  46. })
  47. .then(function(response) {
  48. return response.text();
  49. })
  50. .then(function(responseText) {
  51. try {
  52. return JSON.parse(responseText);
  53. } catch (e) {
  54. throw responseText;
  55. }
  56. })
  57. .then(function(result) {
  58. if (result.type == 'success') {
  59. p5UI__notifyAjaxCallback(result);
  60. if (result.body && result.body.items && result.body.items.length > 0) {
  61. return result.body.items;
  62. } else {
  63. p5UI__notifyAjaxCallback({ type: 'warning', msg: "Brak danych pasujących do kryteriów wyszukiwania" });
  64. }
  65. }
  66. })
  67. .then(function(items) {
  68. DBG && console.log('items fetched:', items);
  69. _setState({ isSearching: false, options: items });
  70. })
  71. .catch(function(error) {
  72. DBG && console.log('request failed', error);
  73. })
  74. },
  75. componentWillUnmount: function () {
  76. DBG && console.log("DBG: conponentDidUnmount...");
  77. },
  78. shouldComponentUpdate: function (nextProps, nextState) {
  79. DBG && console.log("DBG: shouldComponentUpdate...", { nextProps, nextState });
  80. return true;
  81. },
  82. render: function () {
  83. // '<div>' +
  84. // '<p style="text-align:center">' + 'Wybierz bazę' + '</p>' +
  85. // '<div>' + .join(' ') + '</div>' +
  86. // +
  87. // '</div>',
  88. var bazaBtns = [];
  89. bazaBtns.push({ baza: "default_db/BI_audit_KRS/BI_audit_KRS", title: "KRS - Firmy", label: "KRS" });
  90. bazaBtns.push({ baza: "default_db/BI_audit_KRS_person/BI_audit_KRS_person", title: "KRS - Osoby", label: "KRS/p" });
  91. bazaBtns.push({ baza: "default_db/BI_audit_MSIG/BI_audit_MSIG", title: "MSIG - Firmy", label: "MSIG" });
  92. bazaBtns.push({ baza: "default_db/BI_audit_MSIG_person/BI_audit_MSIG_person", title: "KRS - Osoby", label: "MSIG/p" });
  93. bazaBtns.push({ baza: "default_db/BI_audit_taxpayer/BI_audit_taxpayer", title: "VAT - Aktywni płatnicy", label: "VATp" });
  94. bazaBtns.push({ baza: "default_db/BI_audit_CEIDG/BI_audit_CEIDG", title: "CEIDG", label: "CEIDG" });
  95. // bazaBtns.push({ baza: "default_db/BI_audit_ENERGA_RUM_UMOWY/BI_audit_ENERGA_RUM_UMOWY", title: "RUM Umowy", label: "RUM/u" });
  96. // bazaBtns.push({ baza: "default_db/BI_audit_ENERGA_RUM_KONTRAHENCI/BI_audit_ENERGA_RUM_KONTRAHENCI", title: "RUM Kontrahenci", label: "RUM/k" });
  97. // bazaBtns.push({ baza: "default_db/BI_audit_ENERGA_FAKTURY/BI_audit_ENERGA_FAKTURY", title: "Faktury - do imoportowania", label: "Faktury" });
  98. var newItemBtns = [];
  99. newItemBtns.push({ baza: "default_db/BI_audit_ENERGA_PRACOWNICY/BI_audit_ENERGA_PRACOWNICY", title: "Nowa osoba", label: "Nowa osoba" });
  100. newItemBtns.push({ baza: "default_db/BI_audit_ENERGA_RUM_KONTRAHENCI/BI_audit_ENERGA_RUM_KONTRAHENCI", title: "Nowy podmiot", label: "Nowy podmiot" });
  101. function generateBazaBtn(btn, opts) {
  102. return h('button', {
  103. title: btn.title,
  104. className: "btn btn-success" + (opts.selected ? " active" : ""),
  105. style: { margin: "3px" },
  106. onClick: function () {
  107. opts.onClick(btn.baza)
  108. },
  109. }, btn.label)
  110. }
  111. function generateNewItemBtn(btn, opts) {
  112. return h('button', {
  113. title: btn.title,
  114. className: "btn btn-success" + (opts.selected ? " active" : ""),
  115. style: { margin: "3px" },
  116. onClick: function () {
  117. opts.onClick(btn.baza)
  118. },
  119. }, btn.label)
  120. }
  121. var handleSelectBaza = this._handleSelectBaza.bind(this);
  122. var handleSelectNewItem = this._handleSelectNewItem.bind(this);
  123. var selectedBaza = this.state.baza;
  124. var selectedNewItem = this.state.newItemBaza;
  125. var selectedLabel = '';
  126. if (selectedBaza) {
  127. var selBazaBtn = bazaBtns.filter(function (btn) { return btn.baza === selectedBaza; })
  128. if (selBazaBtn) {
  129. selBazaBtn[0].title
  130. }
  131. }
  132. var handleSearch = this._handleSearch.bind(this);
  133. var handleSelected = this._handleSelected.bind(this);
  134. DBG && console.log('DBG: render this.state.options', this.state.options);
  135. return h('div', {}, [
  136. h('p', { style: { textAlign: "center" } }, "Wybierz bazę"),
  137. h('div', { style: { marginBottom: '22px' } },
  138. bazaBtns.map(function (btn) {
  139. return generateBazaBtn(btn, {
  140. onClick: handleSelectBaza,
  141. selected: (selectedBaza === btn.baza),
  142. });
  143. }).concat(
  144. newItemBtns.map(function (btn) {
  145. return generateNewItemBtn(btn, {
  146. onClick: handleSelectNewItem,
  147. selected: (selectedNewItem === btn.baza),
  148. });
  149. })
  150. )
  151. ),
  152. selectedBaza && h(AsyncTypeahead, {
  153. isLoading: this.state.isSearching,
  154. allowNew: false,
  155. multiple: false,
  156. options: this.state.options,
  157. // labelKey: "searchLabel",
  158. labelKey: function (option) {
  159. return [
  160. option.nazwa.replace('"', ''),
  161. option.nip,
  162. option.krs,
  163. option.regon,
  164. option.S_miejscowosc,
  165. ].join(' ')
  166. },
  167. minLength: 3,
  168. onSearch: handleSearch,
  169. placeholder: "Wyszukaj...",
  170. onChange: handleSelected,
  171. autoFocus: true,
  172. filterBy: function (option, text) {
  173. console.log('TODO: filterBy...', {option, text});
  174. return true;
  175. },
  176. renderMenuItemChildren: function (option, props) {
  177. return h(P5UI_AddItemToReport_BazaMenuItem, { key: option.ID, baza: selectedBaza, data: option });
  178. }
  179. }),
  180. (selectedNewItem==="default_db/BI_audit_ENERGA_PRACOWNICY/BI_audit_ENERGA_PRACOWNICY") && h('div', { className: 'form-group' }, [
  181. h('input',{
  182. className:'form-control required',
  183. id:'personName',
  184. placeholder:'Imię'
  185. }),
  186. h('input',{
  187. className:'form-control required',
  188. id:'personSurname',
  189. placeholder:'Nazwisko'
  190. }),
  191. h('input',{
  192. className:'form-control required',
  193. id:'personPesel',
  194. placeholder:'Pesel'
  195. }),
  196. h('input',{
  197. className:'form-control required',
  198. id:'personNip',
  199. placeholder:'NIP'
  200. })
  201. ]),
  202. (selectedNewItem==="default_db/BI_audit_ENERGA_RUM_KONTRAHENCI/BI_audit_ENERGA_RUM_KONTRAHENCI") && h('div', { className: 'form-group' }, [
  203. h('input',{
  204. className:'form-control required',
  205. id:'companyName',
  206. placeholder:'Nazwa'
  207. }),
  208. h('input',{
  209. className:'form-control required',
  210. id:'comapanyRegon',
  211. placeholder:'REGON'
  212. }),
  213. h('input',{
  214. className:'form-control required',
  215. id:'companyNip',
  216. placeholder:'NIP'
  217. })
  218. ]),
  219. // '' === selectedNewItem && h
  220. (selectedBaza && this.state.selected) && h('div', { style: { marginTop: '22px' } }, [
  221. h('button', {
  222. className: "btn btn-success active",
  223. onClick: function () {
  224. this.props.onSelect(this.state.baza, this.state.selected);
  225. ReactDOM.unmountComponentAtNode(document.getElementById('createPracownikAjax__searchBaza'));
  226. swal.close()
  227. }
  228. }, "Dodaj")
  229. ])
  230. ])
  231. }
  232. })
  233. function getWindowWidth() {
  234. var w = window, d = document,
  235. e = d.documentElement,
  236. g = d.getElementsByTagName('body')[0];
  237. return w.innerWidth || e.clientWidth || g.clientWidth;
  238. }
  239. function createPracownikAjax(event) {
  240. // default_db/BI_audit_KRS/BI_audit_KRS
  241. // default_db/BI_audit_KRS_person/BI_audit_KRS_person
  242. // default_db/BI_audit_MSIG/BI_audit_MSIG
  243. // default_db/BI_audit_MSIG_person/BI_audit_MSIG_person
  244. // default_db/BI_audit_taxpayer/BI_audit_taxpayer
  245. // default_db/BI_audit_CEIDG/BI_audit_CEIDG
  246. // default_db/BI_audit_ENERGA_RUM_UMOWY/BI_audit_ENERGA_RUM_UMOWY
  247. // default_db/BI_audit_ENERGA_RUM_KONTRAHENCI/BI_audit_ENERGA_RUM_KONTRAHENCI
  248. // default_db/BI_audit_ENERGA_FAKTURY/BI_audit_ENERGA_FAKTURY
  249. swal({
  250. title: "Dodaj osobę lub podmiot",
  251. width: (getWindowWidth() * 0.8),
  252. html: '<div id="createPracownikAjax__searchBaza" style="padding:0 24px 24px 24px; min-height:400px"></div>',
  253. animation: false,
  254. showConfirmButton: false,
  255. showCancelButton: false,
  256. showCloseButton: true,
  257. onOpen: function () {
  258. ReactDOM.render(
  259. h(P5UI_AddItemToReport, {
  260. onSelect: function (baza, selected) {
  261. //insert do tabeli BI_audit_ENERGA_PRACOWNICY
  262. console.log('TODO: selected ', { baza, selected });
  263. }
  264. }),
  265. document.getElementById('createPracownikAjax__searchBaza')
  266. )
  267. }
  268. }).catch(function (err) {
  269. DBG && console.log('err', err)
  270. })
  271. }
  272. global.createPracownikAjax = createPracownikAjax;
  273. // module.exports = {
  274. // P5UI_AddItemToReport_BazaMenuItem,
  275. // P5UI_AddItemToReport,
  276. // createPracownikAjax
  277. // }