generic_expression.js 57 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304
  1. import { Types } from "../types";
  2. import * as Models from "../ivprog_elements";
  3. import { LocalizedStrings } from "../../services/localizedStringsService";
  4. import * as VariableValueMenuManagement from "./variable_value_menu";
  5. import { registerUserEvent, ActionTypes } from "../../services/userLog";
  6. import WatchJS from "melanke-watchjs";
  7. window.timer = false;
  8. export function renderExpression (
  9. command,
  10. function_obj,
  11. div_to_render,
  12. expression_array
  13. ) {
  14. div_to_render.empty();
  15. WatchJS.unwatch(command, "expression");
  16. WatchJS.watch(
  17. command,
  18. "expression",
  19. function () {
  20. if (window.timer) return;
  21. const m = div_to_render
  22. .find(".single_element_expression")
  23. .not(".mouse_distance")
  24. .not(".add_parentheses");
  25. let s = "";
  26. m.each(function (e) {
  27. if ($(this).hasClass("parentheses_in_expression")) {
  28. s += $(this).text() + " ";
  29. } else {
  30. s += $(this)
  31. .find(".text")
  32. .text();
  33. s += $(this)
  34. .find(".var_name")
  35. .text();
  36. s += $(this)
  37. .find(".parameters_function_called")
  38. .text();
  39. s += $(this)
  40. .find(".value_rendered")
  41. .text();
  42. s += " ";
  43. }
  44. });
  45. if (s) {
  46. window.timer = true;
  47. } else {
  48. return;
  49. }
  50. registerUserEvent(
  51. function_obj.name,
  52. ActionTypes.CHANGE_COMMAND_EXP,
  53. command.type,
  54. "/",
  55. s
  56. );
  57. setTimeout(function () {
  58. window.timer = false;
  59. }, 200);
  60. },
  61. 20,
  62. true
  63. );
  64. if (command.type === Models.COMMAND_TYPES.attribution) {
  65. WatchJS.unwatch(command.variable);
  66. WatchJS.watch(
  67. command.variable,
  68. function () {
  69. renderExpression(
  70. command,
  71. function_obj,
  72. div_to_render,
  73. expression_array
  74. );
  75. },
  76. 0
  77. );
  78. if (command.variable.content) {
  79. const types_included = [];
  80. if (
  81. command.variable.content.type == Types.INTEGER ||
  82. command.variable.content.type == Types.REAL
  83. ) {
  84. types_included.push(Models.EXPRESSION_TYPES.exp_arithmetic);
  85. } else if (command.variable.content.type == Types.BOOLEAN) {
  86. types_included.push(Models.EXPRESSION_TYPES.exp_conditional);
  87. types_included.push(Models.EXPRESSION_TYPES.exp_logic);
  88. types_included.push(Models.EXPRESSION_TYPES.exp_arithmetic);
  89. } else if (command.variable.content.type == Types.TEXT) {
  90. types_included.push(Models.EXPRESSION_TYPES.exp_conditional);
  91. types_included.push(Models.EXPRESSION_TYPES.exp_logic);
  92. types_included.push(Models.EXPRESSION_TYPES.exp_arithmetic);
  93. } else {
  94. //console.log("NÃO RECONHECI! VEJA: ", command.variable.content.type);
  95. }
  96. renderElements(
  97. command,
  98. function_obj,
  99. div_to_render,
  100. expression_array,
  101. types_included
  102. );
  103. } else {
  104. div_to_render.text(
  105. LocalizedStrings.getUI("var_menu_select_var").toLowerCase()
  106. );
  107. }
  108. } else {
  109. const types_included = [];
  110. types_included.push(Models.EXPRESSION_TYPES.exp_conditional);
  111. types_included.push(Models.EXPRESSION_TYPES.exp_logic);
  112. if (command.type === Models.COMMAND_TYPES.writer)
  113. types_included.push(Models.EXPRESSION_TYPES.write_sep);
  114. types_included.push(Models.EXPRESSION_TYPES.exp_arithmetic);
  115. renderElements(
  116. command,
  117. function_obj,
  118. div_to_render,
  119. expression_array,
  120. types_included
  121. );
  122. }
  123. div_to_render.children(".mouse_distance").addClass("mouse_distance_hidden");
  124. div_to_render.children(".higher_element").on("mousemove", function (evt) {
  125. if (!window.open_or_close) {
  126. $(this).css("position", "relative", "!important");
  127. $(this)
  128. .children(".mouse_distance")
  129. .css("opacity", "1");
  130. }
  131. });
  132. div_to_render.children(".higher_element").on("mouseout", function (evt) {
  133. if (!window.open_or_close) {
  134. $(this).css("position", "absolute", "!important");
  135. $(this)
  136. .children(".mouse_distance")
  137. .css("opacity", "0");
  138. }
  139. });
  140. const lixeira = $('<div class="lixeira" draggable="true"></div>');
  141. div_to_render
  142. .find(".single_element_expression")
  143. .on("mousedown", function (evt) {
  144. window.posX = evt.clientX;
  145. window.posY = evt.clientY;
  146. });
  147. Sortable.create(div_to_render[0], {
  148. animation: 100,
  149. ghostClass: "ghost",
  150. group: {
  151. name: "shared",
  152. put: false, // Do not allow items to be put into this list
  153. },
  154. draggable: ".single_element_expression",
  155. sort: false,
  156. filter: ".not_allowed",
  157. onStart: function () {
  158. $("body").append(lixeira);
  159. lixeira.css("display", "block");
  160. lixeira.css("top", window.posY + 70, "!important");
  161. lixeira.css("left", window.posX - 20, "!important");
  162. },
  163. onMove: function () {
  164. lixeira.addClass("color_test");
  165. },
  166. onEnd: function () {
  167. lixeira.remove();
  168. div_to_render.find(".ghost").removeClass("ghost");
  169. },
  170. });
  171. new Sortable(lixeira[0], {
  172. group: "shared",
  173. animation: 150,
  174. onAdd: function (evt) {
  175. lixeira.css("display", "none");
  176. lixeira.find(".single_element_expression").remove();
  177. lixeira.css("background-color", "");
  178. lixeira.remove();
  179. removeElement(evt, expression_array);
  180. renderExpression(command, function_obj, div_to_render, expression_array);
  181. },
  182. });
  183. }
  184. function removeElement (event, expression_array) {
  185. const indice = $(event.item).data("index");
  186. const first = expression_array[0];
  187. if (expression_array[indice].type) {
  188. // if is alone in expression:
  189. if (expression_array.length == 1) {
  190. //function_obj.commands.splice(function_obj.commands.indexOf(command), 1);
  191. expression_array.splice(0, 1);
  192. } else if (expression_array.length > 1) {
  193. if (indice > 0 && expression_array[indice - 1].type_op) {
  194. if (
  195. indice < expression_array.length &&
  196. expression_array[indice - 2] == "(" &&
  197. expression_array[indice + 1].type_op
  198. ) {
  199. expression_array.splice(indice + 1, 1);
  200. }
  201. expression_array.splice(indice, 1);
  202. expression_array.splice(indice - 1, 1);
  203. if (
  204. indice - 2 < expression_array.length &&
  205. expression_array[indice - 2] == "(" &&
  206. expression_array[indice - 1] == ")"
  207. ) {
  208. expression_array.splice(indice - 1, 1);
  209. expression_array.splice(indice - 2, 1);
  210. if (
  211. indice - 3 >= 0 &&
  212. indice - 3 < expression_array.length &&
  213. expression_array[indice - 3].type_op
  214. ) {
  215. expression_array.splice(indice - 3, 1);
  216. }
  217. }
  218. } else if (
  219. indice < expression_array.length - 1 &&
  220. expression_array[indice + 1].type_op
  221. ) {
  222. expression_array.splice(indice + 1, 1);
  223. expression_array.splice(indice, 1);
  224. } else if (
  225. indice < expression_array.length - 1 &&
  226. indice > 0 &&
  227. expression_array[indice - 1] == "(" &&
  228. expression_array[indice + 1] == ")"
  229. ) {
  230. if (indice > 1 && expression_array[indice - 2].type_op) {
  231. expression_array.splice(indice + 1, 1);
  232. expression_array.splice(indice, 1);
  233. expression_array.splice(indice - 1, 1);
  234. expression_array.splice(indice - 2, 1);
  235. } else if (
  236. indice < expression_array.length - 2 &&
  237. expression_array[indice + 2].type_op
  238. ) {
  239. expression_array.splice(indice + 1, 1);
  240. expression_array.splice(indice, 1);
  241. expression_array.splice(indice - 1, 1);
  242. } else {
  243. expression_array.splice(indice + 1, 1);
  244. expression_array.splice(indice, 1);
  245. expression_array.splice(indice - 1, 1);
  246. }
  247. }
  248. }
  249. } else if (expression_array[indice].type_op) {
  250. // iVProg doesn't support operator remove
  251. } else {
  252. let opening = -1;
  253. let closing = -1;
  254. if (expression_array[indice] == "(") {
  255. opening = indice;
  256. for (var i = indice + 1; i < expression_array.length; i++) {
  257. if (expression_array[i] == ")") {
  258. closing = i;
  259. break;
  260. }
  261. }
  262. } else {
  263. closing = indice;
  264. for (var i = indice - 1; i >= 0; i--) {
  265. if (expression_array[i] == "(") {
  266. opening = i;
  267. break;
  268. }
  269. }
  270. }
  271. if (expression_array[opening + 1].type_op) {
  272. expression_array.splice(closing, 1);
  273. expression_array.splice(opening + 1, 1);
  274. expression_array.splice(opening, 1);
  275. } else {
  276. expression_array.splice(closing, 1);
  277. expression_array.splice(opening, 1);
  278. }
  279. }
  280. // if expression is empty, add a new var value:
  281. if (expression_array.length == 0) {
  282. expression_array.push(
  283. new Models.VariableValueMenu(
  284. VariableValueMenuManagement.VAR_OR_VALUE_TYPES.all,
  285. null,
  286. null,
  287. null,
  288. true
  289. )
  290. );
  291. }
  292. if (first != expression_array[0] && expression_array[0].type_op) {
  293. expression_array.splice(0, 1);
  294. }
  295. }
  296. function renderElements (
  297. command,
  298. function_obj,
  299. div_to_render,
  300. expression_array,
  301. types_included
  302. ) {
  303. /*if (expression_array.length > 0) {
  304. if (!expression_array[0].type_op) {
  305. renderStartAddOperator(div_to_render, types_included, expression_array, command, function_obj, 0);
  306. }
  307. }*/
  308. let i = 0;
  309. for (i = 0; i < expression_array.length; i++) {
  310. if (expression_array[i].type == "var_value") {
  311. const div_temp = $(
  312. '<div class="single_element_expression" data-index="' + i + '"></div>'
  313. );
  314. if (i == 0) {
  315. if (expression_array.length > 0 && !expression_array[0].type_op) {
  316. //renderStartAddOperator(div_to_render, types_included, expression_array, command, function_obj, 0);
  317. }
  318. }
  319. VariableValueMenuManagement.renderMenu(
  320. command,
  321. expression_array[i],
  322. div_temp,
  323. function_obj
  324. );
  325. div_to_render.append(div_temp);
  326. } else if (expression_array[i] == "(" || expression_array[i] == ")") {
  327. if (expression_array[i] == ")") {
  328. renderFinalAddElements(
  329. div_to_render,
  330. types_included,
  331. expression_array,
  332. command,
  333. function_obj,
  334. i
  335. );
  336. renderParenthesis(
  337. div_to_render,
  338. expression_array[i],
  339. command,
  340. function_obj,
  341. i,
  342. expression_array
  343. );
  344. } else if (
  345. expression_array[i] == "(" &&
  346. !expression_array[i + 1].type_op
  347. ) {
  348. renderParenthesis(
  349. div_to_render,
  350. expression_array[i],
  351. command,
  352. function_obj,
  353. i,
  354. expression_array
  355. );
  356. renderStartAddOperator(
  357. div_to_render,
  358. types_included,
  359. expression_array,
  360. command,
  361. function_obj,
  362. i + 1
  363. );
  364. } else {
  365. renderParenthesis(
  366. div_to_render,
  367. expression_array[i],
  368. command,
  369. function_obj,
  370. i,
  371. expression_array
  372. );
  373. }
  374. } else {
  375. if (i == 0) {
  376. } else if (expression_array[i - 1] == "(") {
  377. }
  378. renderOperatorMenu(
  379. command,
  380. function_obj,
  381. div_to_render,
  382. expression_array[i],
  383. types_included,
  384. i,
  385. expression_array
  386. );
  387. }
  388. }
  389. renderFinalAddElements(
  390. div_to_render,
  391. types_included,
  392. expression_array,
  393. command,
  394. function_obj,
  395. i,
  396. true
  397. );
  398. renderAddParenthesis(
  399. command,
  400. function_obj,
  401. div_to_render,
  402. expression_array,
  403. types_included
  404. );
  405. }
  406. window.parentheses_activate = false;
  407. window.open_or_close = null;
  408. function renderAddParenthesis (
  409. command,
  410. function_obj,
  411. div_to_render,
  412. expression_array,
  413. types_included
  414. ) {
  415. const addParentheses = $(
  416. '<div class="single_element_expression add_parentheses not_allowed"><img style="width: 15px; position: relative; top: 3px; left: 1px; height: 15px;" src=""></div>'
  417. );
  418. div_to_render.append(addParentheses);
  419. addParentheses.popup({
  420. content: "Adicionar parênteses",
  421. delay: {
  422. show: 750,
  423. hide: 0,
  424. },
  425. });
  426. addParentheses.on("click", function (mouse_event) {
  427. // verificar se já está ativado
  428. if (window.parentheses_activate) {
  429. return;
  430. }
  431. div_to_render.find(".usepointer").off("click");
  432. window.parentheses_activate = true;
  433. window.open_or_close = "open";
  434. div_to_render.find(".dropdown").addClass("disabled");
  435. div_to_render.find(".ghost_element").addClass("temp_class");
  436. div_to_render.find(".ghost_element").removeClass("ghost_element");
  437. const floatingObject = $('<div class="floating_parenthesis"> ( </div>');
  438. floatingObject.draggable().appendTo("body");
  439. floatingObject.css("position", "absolute");
  440. mouse_event.type = "mousedown.draggable";
  441. mouse_event.target = floatingObject[0];
  442. floatingObject.css("left", mouse_event.pageX + 10);
  443. floatingObject.css("top", mouse_event.pageY + 10);
  444. floatingObject.trigger(mouse_event);
  445. div_to_render.on("mousemove", function (evt) {
  446. let actual_target = null;
  447. if ($(evt.target).hasClass("single_element_expression")) {
  448. actual_target = $(evt.target);
  449. } else {
  450. actual_target = $(evt.target).closest(".single_element_expression");
  451. }
  452. if (
  453. $(evt.target).hasClass("temp_class") ||
  454. actual_target.length < 1 ||
  455. actual_target.hasClass("add_parentheses") ||
  456. actual_target.hasClass("rendered_parentheses") ||
  457. $(evt.target).hasClass("expression_elements")
  458. ) {
  459. return;
  460. }
  461. renderGhostParentheses(
  462. actual_target,
  463. command,
  464. function_obj,
  465. div_to_render,
  466. expression_array
  467. );
  468. });
  469. div_to_render.on("mouseleave", function () {
  470. /*window.open_parentheses.remove();
  471. window.close_parentheses.remove();*/
  472. });
  473. let floating;
  474. $("body").on("mouseup", function (evt) {
  475. if (window.open_or_close == "open") {
  476. window.open_or_close = "close";
  477. floatingObject.remove();
  478. var comando_que_esta = $(evt.target).closest(".command_container");
  479. var comando_certo = div_to_render.closest(".command_container");
  480. if (!comando_que_esta.is(comando_certo)) {
  481. window.parentheses_activate = false;
  482. div_to_render.find(".temp_class").addClass("ghost_element");
  483. div_to_render.find(".temp_class").removeClass("temp_class");
  484. div_to_render.off("mousemove");
  485. div_to_render.off("mouseleave");
  486. $("body").off("mouseup");
  487. window.open_parentheses.remove();
  488. window.close_parentheses.remove();
  489. window.inserir_open = -1;
  490. window.inserir_close = -1;
  491. window.open_or_close = null;
  492. renderExpression(
  493. command,
  494. function_obj,
  495. div_to_render,
  496. expression_array
  497. );
  498. return;
  499. }
  500. window.open_parentheses.addClass("parentheses_fixed");
  501. floating = $('<div class="floating_parenthesis"> ) </div>');
  502. floating.draggable().appendTo("body");
  503. floating.css("position", "absolute");
  504. floating.css("left", evt.pageX + 10);
  505. floating.css("top", evt.pageY + 10);
  506. $("body").on("mousemove", function (evts) {
  507. floating.css("left", evts.pageX + 10);
  508. floating.css("top", evts.pageY + 10);
  509. });
  510. } else {
  511. floating.remove();
  512. window.open_parentheses.removeClass("parentheses_fixed");
  513. div_to_render.off("mousemove");
  514. div_to_render.off("mouseleave");
  515. $("body").off("mouseup");
  516. setTimeout(function () {
  517. window.parentheses_activate = false;
  518. }, 50);
  519. var comando_que_esta = $(evt.target).closest(".command_container");
  520. var comando_certo = div_to_render.closest(".command_container");
  521. let is_correct = false;
  522. if (comando_que_esta.is(comando_certo)) {
  523. is_correct = true;
  524. }
  525. if (is_correct) {
  526. expression_array.splice(window.inserir_open, 0, "(");
  527. expression_array.splice(window.inserir_close, 0, ")");
  528. }
  529. window.inserir_open = -1;
  530. window.inserir_close = -1;
  531. window.open_or_close = null;
  532. renderExpression(
  533. command,
  534. function_obj,
  535. div_to_render,
  536. expression_array
  537. );
  538. }
  539. });
  540. });
  541. }
  542. window.open_parentheses = $('<div class="parentheses_ghost">(</div>');
  543. window.close_parentheses = $('<div class="parentheses_ghost">)</div>');
  544. window.inserir_open = -1;
  545. window.inserir_close = -1;
  546. function renderGhostParentheses (
  547. actual_target,
  548. command,
  549. function_obj,
  550. div_to_render,
  551. expression_array
  552. ) {
  553. /*window.open_parentheses.remove();
  554. window.close_parentheses.remove();*/
  555. const index_in_array = actual_target.data("index");
  556. if (
  557. expression_array[index_in_array] == "(" ||
  558. expression_array[index_in_array] == ")"
  559. ) {
  560. return;
  561. }
  562. if (window.open_or_close == "close") {
  563. if (index_in_array < window.inserir_open) {
  564. return;
  565. }
  566. }
  567. // Tratando a situação quando é na primeira posição:
  568. if (index_in_array == 0) {
  569. if (expression_array[index_in_array].type == "var_value") {
  570. if (window.open_or_close == "open") {
  571. window.open_parentheses.insertBefore(actual_target);
  572. window.inserir_open = index_in_array;
  573. }
  574. /*if (expression_array.length == 1) {
  575. if (window.open_or_close == "close") {
  576. window.close_parentheses.insertAfter(actual_target);
  577. window.inserir_close = index_in_array + 2;
  578. }*/
  579. //} else {
  580. var count_opened = 0;
  581. var count_closed = 0;
  582. for (var i = 0; i < expression_array.length; i++) {
  583. if (expression_array[i] == "(") {
  584. count_opened++;
  585. }
  586. if (expression_array[i] == ")") {
  587. count_closed++;
  588. }
  589. if (count_opened != count_closed) {
  590. } else {
  591. if (count_opened > 0) {
  592. if (window.open_or_close == "close") {
  593. window.close_parentheses.insertAfter(
  594. div_to_render.find(
  595. '.single_element_expression[data-index="' + i + '"]'
  596. )
  597. );
  598. window.inserir_close = i + 2;
  599. }
  600. break;
  601. } else {
  602. if (expression_array[i].type == "var_value") {
  603. if (window.open_or_close == "close") {
  604. window.close_parentheses.insertAfter(
  605. div_to_render.find(
  606. '.single_element_expression[data-index="' + i + '"]'
  607. )
  608. );
  609. window.inserir_close = i + 2;
  610. }
  611. break;
  612. }
  613. }
  614. }
  615. }
  616. //}
  617. } else if (expression_array[index_in_array].type_op) {
  618. if (window.open_or_close == "open") {
  619. window.open_parentheses.insertBefore(actual_target);
  620. window.inserir_open = index_in_array;
  621. }
  622. var count_opened = 0;
  623. var count_closed = 0;
  624. for (var i = 1; i < expression_array.length; i++) {
  625. // $('.slide-link[data-slide="0"]')
  626. if (expression_array[i] == "(") {
  627. count_opened++;
  628. }
  629. if (expression_array[i] == ")") {
  630. count_closed++;
  631. }
  632. if (count_opened != count_closed) {
  633. } else {
  634. if (count_opened > 0) {
  635. if (expression_array[i].type == "var_value") {
  636. window.close_parentheses.insertAfter(
  637. div_to_render.find(
  638. '.single_element_expression[data-index="' + i + '"]'
  639. )
  640. );
  641. window.inserir_close = i + 2;
  642. }
  643. break;
  644. } else {
  645. if (expression_array[i].type == "var_value") {
  646. if (expression_array[i].type == "var_value") {
  647. window.close_parentheses.insertAfter(
  648. div_to_render.find(
  649. '.single_element_expression[data-index="' + i + '"]'
  650. )
  651. );
  652. window.inserir_close = i + 2;
  653. }
  654. break;
  655. }
  656. }
  657. }
  658. }
  659. }
  660. return;
  661. }
  662. // Tratando quando não é no índice 0:
  663. if (expression_array[index_in_array].type == "var_value") {
  664. if (window.open_or_close == "open") {
  665. window.open_parentheses.insertBefore(actual_target);
  666. window.inserir_open = index_in_array;
  667. }
  668. if (window.open_or_close == "close") {
  669. window.close_parentheses.insertAfter(actual_target);
  670. window.inserir_close = index_in_array + 2;
  671. }
  672. return;
  673. }
  674. if (expression_array[index_in_array].type_op) {
  675. // buscar para a esquerda primeiro:
  676. if (expression_array[index_in_array - 1] == "(") {
  677. if (window.open_or_close == "open") {
  678. window.open_parentheses.insertBefore(actual_target);
  679. window.inserir_open = index_in_array;
  680. }
  681. } else if (expression_array[index_in_array - 1] == ")") {
  682. // buscar a abertura
  683. var count_opened = 0;
  684. var count_closed = 0;
  685. for (var j = index_in_array - 1; j >= 0; j--) {
  686. if (expression_array[j] == "(") {
  687. count_opened++;
  688. }
  689. if (expression_array[j] == ")") {
  690. count_closed++;
  691. }
  692. if (count_opened != count_closed) {
  693. } else {
  694. if (count_closed > 0) {
  695. if (window.open_or_close == "open") {
  696. window.open_parentheses.insertBefore(
  697. div_to_render.find(
  698. '.single_element_expression[data-index="' + j + '"]'
  699. )
  700. );
  701. window.inserir_open = j;
  702. }
  703. break;
  704. }
  705. }
  706. }
  707. } else if (expression_array[index_in_array - 1].type == "var_value") {
  708. if (window.open_or_close == "open") {
  709. window.open_parentheses.insertBefore(
  710. div_to_render.find(
  711. '.single_element_expression[data-index="' +
  712. (index_in_array - 1) +
  713. '"]'
  714. )
  715. );
  716. window.inserir_open = index_in_array - 1;
  717. }
  718. }
  719. // buscar para a direita agora:
  720. if (expression_array[index_in_array + 1] == "(") {
  721. // buscar o fechamento:
  722. var count_opened = 0;
  723. var count_closed = 0;
  724. for (var j = index_in_array + 1; j < expression_array.length; j++) {
  725. if (expression_array[j] == "(") {
  726. count_opened++;
  727. }
  728. if (expression_array[j] == ")") {
  729. count_closed++;
  730. }
  731. if (count_opened != count_closed) {
  732. } else {
  733. if (count_opened > 0) {
  734. if (window.open_or_close == "close") {
  735. window.close_parentheses.insertAfter(
  736. div_to_render.find(
  737. '.single_element_expression[data-index="' + j + '"]'
  738. )
  739. );
  740. window.inserir_close = j + 2;
  741. }
  742. break;
  743. }
  744. }
  745. }
  746. } else if (expression_array[index_in_array + 1].type == "var_value") {
  747. if (window.open_or_close == "close") {
  748. window.close_parentheses.insertAfter(
  749. div_to_render.find(
  750. '.single_element_expression[data-index="' +
  751. (index_in_array + 1) +
  752. '"]'
  753. )
  754. );
  755. window.inserir_close = index_in_array + 3;
  756. }
  757. }
  758. }
  759. }
  760. function renderParenthesis (
  761. div_to_render,
  762. expression_content,
  763. command,
  764. function_obj,
  765. position,
  766. expression_array
  767. ) {
  768. const ghost_parenthesis = $(
  769. '<div class="single_element_expression parentheses_in_expression" data-index="' +
  770. position +
  771. '">' +
  772. expression_content +
  773. "</div>"
  774. );
  775. div_to_render.append(ghost_parenthesis);
  776. }
  777. function renderStartAddOperator (
  778. div_to_render,
  779. types_included,
  780. expression_array,
  781. command,
  782. function_obj,
  783. position
  784. ) {
  785. let menu_final =
  786. '<div class="ui dropdown disabled usepointer"><div class="text"> + </div><i class="dropdown icon"></i><div class="menu">';
  787. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_arithmetic) >= 0) {
  788. if (types_included.length > 1) {
  789. menu_final +=
  790. '<div class="item"><i class="dropdown icon"></i>' +
  791. LocalizedStrings.getUI("text_arithmetic_expression") +
  792. '<div class="menu">';
  793. menu_final += getArithmeticOperators();
  794. menu_final += "</div></div>";
  795. } else {
  796. menu_final += getArithmeticOperators();
  797. }
  798. }
  799. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_logic) >= 0) {
  800. if (types_included.length > 1) {
  801. menu_final +=
  802. '<div class="item"><i class="dropdown icon"></i>' +
  803. LocalizedStrings.getUI("text_logic_expression") +
  804. '<div class="menu">';
  805. menu_final += getLogicOperators();
  806. menu_final += "</div></div>";
  807. } else {
  808. menu_final += getLogicOperators();
  809. }
  810. }
  811. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_conditional) >= 0) {
  812. if (types_included.length > 1) {
  813. menu_final +=
  814. '<div class="item"><i class="dropdown icon"></i>' +
  815. LocalizedStrings.getUI("text_relational_expression") +
  816. '<div class="menu">';
  817. menu_final += getRelationalOperators();
  818. menu_final += "</div></div>";
  819. } else {
  820. menu_final += getRelationalOperators();
  821. }
  822. }
  823. menu_final += "</div></div>";
  824. menu_final = $(menu_final);
  825. const div_temp = $(
  826. '<div class="single_element_expression ghost_element mouse_distance"></div>'
  827. );
  828. div_temp.append(menu_final);
  829. const div_higher = $('<div class="higher_element"></div>');
  830. div_higher.append(div_temp);
  831. div_to_render.append(div_higher);
  832. menu_final.dropdown("set selected", Models.ARITHMETIC_TYPES.minus);
  833. div_temp.on("click", function () {
  834. if (!window.open_or_close) {
  835. const sera = position;
  836. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_arithmetic) >= 0) {
  837. expression_array.splice(
  838. sera,
  839. 0,
  840. new Models.ExpressionOperator(
  841. Models.EXPRESSION_TYPES.exp_arithmetic,
  842. Models.ARITHMETIC_TYPES.minus
  843. )
  844. );
  845. } else if (
  846. types_included.indexOf(Models.EXPRESSION_TYPES.exp_logic) >= 0
  847. ) {
  848. expression_array.splice(
  849. sera,
  850. 0,
  851. new Models.ExpressionOperator(
  852. Models.EXPRESSION_TYPES.exp_logic,
  853. Models.LOGIC_COMPARISON.equals_to
  854. )
  855. );
  856. } else if (
  857. types_included.indexOf(Models.EXPRESSION_TYPES.exp_conditional) >= 0
  858. ) {
  859. expression_array.splice(
  860. sera,
  861. 0,
  862. new Models.ExpressionOperator(
  863. Models.EXPRESSION_TYPES.exp_conditional,
  864. Models.ARITHMETIC_COMPARISON.greater_than
  865. )
  866. );
  867. }
  868. renderExpression(command, function_obj, div_to_render, expression_array);
  869. }
  870. });
  871. }
  872. function renderFinalAddElements (
  873. div_to_render,
  874. types_included,
  875. expression_array,
  876. command,
  877. function_obj,
  878. position,
  879. is_last = false
  880. ) {
  881. let menu_final =
  882. '<div class="ui dropdown disabled usepointer"><div class="text"> + </div><i class="dropdown icon"></i><div class="menu">';
  883. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_arithmetic) >= 0) {
  884. if (types_included.length > 1) {
  885. menu_final +=
  886. '<div class="item"><i class="dropdown icon"></i>' +
  887. LocalizedStrings.getUI("text_arithmetic_expression") +
  888. '<div class="menu">';
  889. menu_final += getArithmeticOperators();
  890. menu_final += "</div></div>";
  891. } else {
  892. menu_final += getArithmeticOperators();
  893. }
  894. }
  895. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_logic) >= 0) {
  896. if (types_included.length > 1) {
  897. menu_final +=
  898. '<div class="item"><i class="dropdown icon"></i>' +
  899. LocalizedStrings.getUI("text_logic_expression") +
  900. '<div class="menu">';
  901. menu_final += getLogicOperators();
  902. menu_final += "</div></div>";
  903. } else {
  904. menu_final += getLogicOperators();
  905. }
  906. }
  907. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_conditional) >= 0) {
  908. if (types_included.length > 1) {
  909. menu_final +=
  910. '<div class="item"><i class="dropdown icon"></i>' +
  911. LocalizedStrings.getUI("text_relational_expression") +
  912. '<div class="menu">';
  913. menu_final += getRelationalOperators();
  914. menu_final += "</div></div>";
  915. } else {
  916. menu_final += getRelationalOperators();
  917. }
  918. }
  919. menu_final += "</div></div>";
  920. menu_final = $(menu_final);
  921. const div_temp = $('<div class="simple_add mouse_distance"></div>');
  922. const div_higher = $('<div class="higher_element"></div>');
  923. const button = $(
  924. '<button class="ui button green add_expression"><i class="plus circle inverted icon"></i></button>'
  925. );
  926. div_temp.append(button);
  927. if (!is_last) {
  928. div_higher.append(div_temp);
  929. div_to_render.append(div_higher);
  930. //div_temp.append(menu_final);
  931. div_temp.css("opacity", "0", "!important");
  932. } else {
  933. div_temp.removeClass("mouse_distance");
  934. div_temp.css("opacity", "1", "!important");
  935. //div_temp.append(menu_final);
  936. div_to_render.append(div_temp);
  937. }
  938. menu_final.dropdown("set selected", Models.ARITHMETIC_TYPES.plus);
  939. div_temp.on("click", function () {
  940. const sera = position;
  941. if (expression_array[sera] == ")" && expression_array[sera - 1] == "(") {
  942. expression_array.splice(
  943. sera,
  944. 0,
  945. new Models.VariableValueMenu(
  946. VariableValueMenuManagement.VAR_OR_VALUE_TYPES.all,
  947. null,
  948. null,
  949. null,
  950. true
  951. )
  952. );
  953. renderExpression(command, function_obj, div_to_render, expression_array);
  954. return;
  955. }
  956. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_arithmetic) >= 0) {
  957. expression_array.splice(
  958. sera,
  959. 0,
  960. new Models.ExpressionOperator(
  961. Models.EXPRESSION_TYPES.exp_arithmetic,
  962. Models.ARITHMETIC_TYPES.plus
  963. )
  964. );
  965. expression_array.splice(
  966. sera + 1,
  967. 0,
  968. new Models.VariableValueMenu(
  969. VariableValueMenuManagement.VAR_OR_VALUE_TYPES.all,
  970. null,
  971. null,
  972. null,
  973. true
  974. )
  975. );
  976. } else if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_logic) >= 0) {
  977. expression_array.splice(
  978. sera,
  979. 0,
  980. new Models.ExpressionOperator(
  981. Models.EXPRESSION_TYPES.exp_logic,
  982. Models.LOGIC_COMPARISON.equals_to
  983. )
  984. );
  985. expression_array.splice(
  986. sera + 1,
  987. 0,
  988. new Models.VariableValueMenu(
  989. VariableValueMenuManagement.VAR_OR_VALUE_TYPES.all,
  990. null,
  991. null,
  992. null,
  993. true
  994. )
  995. );
  996. } else if (
  997. types_included.indexOf(Models.EXPRESSION_TYPES.exp_conditional) >= 0
  998. ) {
  999. expression_array.splice(
  1000. sera,
  1001. 0,
  1002. new Models.ExpressionOperator(
  1003. Models.EXPRESSION_TYPES.exp_conditional,
  1004. Models.ARITHMETIC_COMPARISON.greater_than
  1005. )
  1006. );
  1007. expression_array.splice(
  1008. sera + 1,
  1009. 0,
  1010. new Models.VariableValueMenu(
  1011. VariableValueMenuManagement.VAR_OR_VALUE_TYPES.all,
  1012. null,
  1013. null,
  1014. null,
  1015. true
  1016. )
  1017. );
  1018. }
  1019. renderExpression(command, function_obj, div_to_render, expression_array);
  1020. });
  1021. }
  1022. function renderOperatorMenu (
  1023. command,
  1024. function_obj,
  1025. div_to_render,
  1026. expression_element,
  1027. types_included,
  1028. position,
  1029. expression_array
  1030. ) {
  1031. let menu_final =
  1032. '<div class="ui dropdown"><div class="text"> + </div><i class="dropdown icon"></i><div class="menu">';
  1033. if (types_included.indexOf(Models.EXPRESSION_TYPES.write_sep) >= 0) {
  1034. menu_final += getSeparator();
  1035. }
  1036. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_arithmetic) >= 0) {
  1037. if (types_included.length > 1) {
  1038. menu_final +=
  1039. '<div class="item"><i class="dropdown icon"></i>' +
  1040. LocalizedStrings.getUI("text_arithmetic_expression") +
  1041. '<div class="menu">';
  1042. menu_final += getArithmeticOperators();
  1043. menu_final += "</div></div>";
  1044. } else {
  1045. menu_final += getArithmeticOperators();
  1046. }
  1047. }
  1048. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_logic) >= 0) {
  1049. if (types_included.length > 1) {
  1050. menu_final +=
  1051. '<div class="item"><i class="dropdown icon"></i>' +
  1052. LocalizedStrings.getUI("text_logic_expression") +
  1053. '<div class="menu">';
  1054. menu_final += getLogicOperators();
  1055. menu_final += "</div></div>";
  1056. } else {
  1057. menu_final += getLogicOperators();
  1058. }
  1059. }
  1060. if (types_included.indexOf(Models.EXPRESSION_TYPES.exp_conditional) >= 0) {
  1061. if (types_included.length > 1) {
  1062. menu_final +=
  1063. '<div class="item"><i class="dropdown icon"></i>' +
  1064. LocalizedStrings.getUI("text_relational_expression") +
  1065. '<div class="menu">';
  1066. menu_final += getRelationalOperators();
  1067. menu_final += "</div></div>";
  1068. } else {
  1069. menu_final += getRelationalOperators();
  1070. }
  1071. }
  1072. menu_final += "</div></div>";
  1073. menu_final = $(menu_final);
  1074. menu_final.find(".ivprog-write-sep").popup({
  1075. content: LocalizedStrings.getUI("write_seprator_menu_tooltip"),
  1076. delay: {
  1077. show: 500,
  1078. hide: 0,
  1079. },
  1080. });
  1081. const div_temp = $(
  1082. '<div class="single_element_expression not_allowed" data-index="' +
  1083. position +
  1084. '"></div>'
  1085. );
  1086. div_temp.append(menu_final);
  1087. div_to_render.append(div_temp);
  1088. menu_final.dropdown({
  1089. onChange: function (_value, _text, $selectedItem) {
  1090. expression_element.item = $selectedItem.data("value");
  1091. expression_element.type_op = $selectedItem.data("type");
  1092. },
  1093. });
  1094. menu_final.dropdown("set selected", expression_element.item);
  1095. }
  1096. function getArithmeticOperators () {
  1097. let arithmetic_operators;
  1098. arithmetic_operators =
  1099. '<div class="item" data-type="' +
  1100. Models.EXPRESSION_TYPES.exp_arithmetic +
  1101. '" data-value="' +
  1102. Models.ARITHMETIC_TYPES.plus +
  1103. '">+</div>';
  1104. arithmetic_operators +=
  1105. '<div class="item" data-type="' +
  1106. Models.EXPRESSION_TYPES.exp_arithmetic +
  1107. '" data-value="' +
  1108. Models.ARITHMETIC_TYPES.minus +
  1109. '">-</div>';
  1110. arithmetic_operators +=
  1111. '<div class="item" data-type="' +
  1112. Models.EXPRESSION_TYPES.exp_arithmetic +
  1113. '" data-value="' +
  1114. Models.ARITHMETIC_TYPES.multiplication +
  1115. '">*</div>';
  1116. arithmetic_operators +=
  1117. '<div class="item" data-type="' +
  1118. Models.EXPRESSION_TYPES.exp_arithmetic +
  1119. '" data-value="' +
  1120. Models.ARITHMETIC_TYPES.division +
  1121. '">/</div>';
  1122. arithmetic_operators +=
  1123. '<div class="item" data-type="' +
  1124. Models.EXPRESSION_TYPES.exp_arithmetic +
  1125. '" data-value="' +
  1126. Models.ARITHMETIC_TYPES.module +
  1127. '">%</div>';
  1128. return arithmetic_operators;
  1129. }
  1130. function getLogicOperators () {
  1131. let logic_operators;
  1132. logic_operators =
  1133. '<div class="item" data-type="' +
  1134. Models.EXPRESSION_TYPES.exp_logic +
  1135. '" data-value="' +
  1136. Models.LOGIC_COMPARISON.equals_to +
  1137. '">==</div>';
  1138. logic_operators +=
  1139. '<div class="item" data-type="' +
  1140. Models.EXPRESSION_TYPES.exp_logic +
  1141. '" data-value="' +
  1142. Models.LOGIC_COMPARISON.not_equals_to +
  1143. '">!=</div>';
  1144. logic_operators +=
  1145. '<div class="item" data-type="' +
  1146. Models.EXPRESSION_TYPES.exp_logic +
  1147. '" data-value="' +
  1148. Models.LOGIC_COMPARISON.and +
  1149. '">' +
  1150. LocalizedStrings.getUI("logic_operator_and") +
  1151. "</div>";
  1152. logic_operators +=
  1153. '<div class="item" data-type="' +
  1154. Models.EXPRESSION_TYPES.exp_logic +
  1155. '" data-value="' +
  1156. Models.LOGIC_COMPARISON.or +
  1157. '">' +
  1158. LocalizedStrings.getUI("logic_operator_or") +
  1159. "</div>";
  1160. logic_operators +=
  1161. '<div class="item" data-type="' +
  1162. Models.EXPRESSION_TYPES.exp_logic +
  1163. '" data-value="' +
  1164. Models.LOGIC_COMPARISON.not +
  1165. '">' +
  1166. LocalizedStrings.getUI("logic_operator_not") +
  1167. "</div>";
  1168. return logic_operators;
  1169. }
  1170. function getRelationalOperators () {
  1171. let relational_operators;
  1172. relational_operators =
  1173. '<div class="item" data-type="' +
  1174. Models.EXPRESSION_TYPES.exp_conditional +
  1175. '" data-value="' +
  1176. Models.ARITHMETIC_COMPARISON.greater_than +
  1177. '">></div>';
  1178. relational_operators +=
  1179. '<div class="item" data-type="' +
  1180. Models.EXPRESSION_TYPES.exp_conditional +
  1181. '" data-value="' +
  1182. Models.ARITHMETIC_COMPARISON.less_than +
  1183. '"><</div>';
  1184. relational_operators +=
  1185. '<div class="item" data-type="' +
  1186. Models.EXPRESSION_TYPES.exp_conditional +
  1187. '" data-value="' +
  1188. Models.ARITHMETIC_COMPARISON.equals_to +
  1189. '">==</div>';
  1190. relational_operators +=
  1191. '<div class="item" data-type="' +
  1192. Models.EXPRESSION_TYPES.exp_conditional +
  1193. '" data-value="' +
  1194. Models.ARITHMETIC_COMPARISON.not_equals_to +
  1195. '">!=</div>';
  1196. relational_operators +=
  1197. '<div class="item" data-type="' +
  1198. Models.EXPRESSION_TYPES.exp_conditional +
  1199. '" data-value="' +
  1200. Models.ARITHMETIC_COMPARISON.greater_than_or_equals_to +
  1201. '">>=</div>';
  1202. relational_operators +=
  1203. '<div class="item" data-type="' +
  1204. Models.EXPRESSION_TYPES.exp_conditional +
  1205. '" data-value="' +
  1206. Models.ARITHMETIC_COMPARISON.less_than_or_equals_to +
  1207. '"><=</div>';
  1208. return relational_operators;
  1209. }
  1210. function getSeparator () {
  1211. return `<div class="item ivprog-write-sep" data-type="${
  1212. Models.EXPRESSION_TYPES.write_sep
  1213. }" data-value="${Models.EXPRESSION_TYPES.write_sep}">${LocalizedStrings.getUI(
  1214. "write_seprator_menu_text"
  1215. )}</div>`;
  1216. }