You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

340 lines
10 KiB

  1. context("Control Link", () => {
  2. before(() => {
  3. cy.login();
  4. cy.visit("/app/website");
  5. });
  6. beforeEach(() => {
  7. cy.visit("/app/website");
  8. cy.create_records({
  9. doctype: "ToDo",
  10. description: "this is a test todo for link",
  11. }).as("todos");
  12. });
  13. function get_dialog_with_link() {
  14. return cy.dialog({
  15. title: "Link",
  16. fields: [
  17. {
  18. label: "Select ToDo",
  19. fieldname: "link",
  20. fieldtype: "Link",
  21. options: "ToDo",
  22. },
  23. ],
  24. });
  25. }
  26. function get_dialog_with_gender_link() {
  27. return cy.dialog({
  28. title: "Link",
  29. fields: [
  30. {
  31. label: "Select Gender",
  32. fieldname: "link",
  33. fieldtype: "Link",
  34. options: "Gender",
  35. },
  36. ],
  37. });
  38. }
  39. it("should set the valid value", () => {
  40. get_dialog_with_link().as("dialog");
  41. cy.insert_doc(
  42. "Property Setter",
  43. {
  44. doctype: "Property Setter",
  45. doc_type: "ToDo",
  46. property: "show_title_field_in_link",
  47. property_type: "Check",
  48. doctype_or_field: "DocType",
  49. value: "0",
  50. },
  51. true
  52. );
  53. cy.intercept("POST", "/api/method/influxframework.desk.search.search_link").as("search_link");
  54. cy.get(".influxframework-control[data-fieldname=link] input").focus().as("input");
  55. cy.wait("@search_link");
  56. cy.get("@input").type("todo for link", { delay: 200 });
  57. cy.wait("@search_link");
  58. cy.get(".influxframework-control[data-fieldname=link]").findByRole("listbox").should("be.visible");
  59. cy.get(".influxframework-control[data-fieldname=link] input").type("{enter}", { delay: 100 });
  60. cy.get(".influxframework-control[data-fieldname=link] input").blur();
  61. cy.get("@dialog").then((dialog) => {
  62. cy.get("@todos").then((todos) => {
  63. let value = dialog.get_value("link");
  64. expect(value).to.eq(todos[0]);
  65. });
  66. });
  67. });
  68. it("should unset invalid value", () => {
  69. get_dialog_with_link().as("dialog");
  70. cy.intercept("POST", "/api/method/influxframework.client.validate_link").as("validate_link");
  71. cy.get(".influxframework-control[data-fieldname=link] input")
  72. .type("invalid value", { delay: 100 })
  73. .blur();
  74. cy.wait("@validate_link");
  75. cy.get(".influxframework-control[data-fieldname=link] input").should("have.value", "");
  76. });
  77. it("should be possible set empty value explicitly", () => {
  78. get_dialog_with_link().as("dialog");
  79. cy.intercept("POST", "/api/method/influxframework.client.validate_link").as("validate_link");
  80. cy.get(".influxframework-control[data-fieldname=link] input").type(" ", { delay: 100 }).blur();
  81. cy.wait("@validate_link");
  82. cy.get(".influxframework-control[data-fieldname=link] input").should("have.value", "");
  83. cy.window()
  84. .its("cur_dialog")
  85. .then((dialog) => {
  86. expect(dialog.get_value("link")).to.equal("");
  87. });
  88. });
  89. it("should route to form on arrow click", () => {
  90. get_dialog_with_link().as("dialog");
  91. cy.intercept("POST", "/api/method/influxframework.client.validate_link").as("validate_link");
  92. cy.intercept("POST", "/api/method/influxframework.desk.search.search_link").as("search_link");
  93. cy.get("@todos").then((todos) => {
  94. cy.get(".influxframework-control[data-fieldname=link] input").as("input");
  95. cy.get("@input").focus();
  96. cy.wait("@search_link");
  97. cy.get("@input").type(todos[0]).blur();
  98. cy.wait("@validate_link");
  99. cy.get("@input").focus();
  100. cy.wait(500); // wait for arrow to show
  101. cy.get(".influxframework-control[data-fieldname=link] .btn-open").should("be.visible").click();
  102. cy.location("pathname").should("eq", `/app/todo/${todos[0]}`);
  103. });
  104. });
  105. it("show title field in link", () => {
  106. cy.insert_doc(
  107. "Property Setter",
  108. {
  109. doctype: "Property Setter",
  110. doc_type: "ToDo",
  111. property: "show_title_field_in_link",
  112. property_type: "Check",
  113. doctype_or_field: "DocType",
  114. value: "1",
  115. },
  116. true
  117. );
  118. cy.clear_cache();
  119. cy.wait(500);
  120. get_dialog_with_link().as("dialog");
  121. cy.window()
  122. .its("influxframework")
  123. .then((influxframework) => {
  124. if (!influxframework.boot) {
  125. influxframework.boot = {
  126. link_title_doctypes: ["ToDo"],
  127. };
  128. } else {
  129. influxframework.boot.link_title_doctypes = ["ToDo"];
  130. }
  131. });
  132. cy.intercept("POST", "/api/method/influxframework.desk.search.search_link").as("search_link");
  133. cy.get(".influxframework-control[data-fieldname=link] input").focus().as("input");
  134. cy.wait("@search_link");
  135. cy.get("@input").type("todo for link");
  136. cy.wait("@search_link");
  137. cy.get(".influxframework-control[data-fieldname=link] ul").should("be.visible");
  138. cy.get(".influxframework-control[data-fieldname=link] input").type("{enter}", { delay: 100 });
  139. cy.get(".influxframework-control[data-fieldname=link] input").blur();
  140. cy.get("@dialog").then((dialog) => {
  141. cy.get("@todos").then((todos) => {
  142. let field = dialog.get_field("link");
  143. let value = field.get_value();
  144. let label = field.get_label_value();
  145. expect(value).to.eq(todos[0]);
  146. expect(label).to.eq("this is a test todo for link");
  147. });
  148. });
  149. });
  150. it("should update dependant fields (via fetch_from)", () => {
  151. cy.get("@todos").then((todos) => {
  152. cy.visit(`/app/todo/${todos[0]}`);
  153. cy.intercept("POST", "/api/method/influxframework.desk.search.search_link").as("search_link");
  154. cy.intercept("POST", "/api/method/influxframework.client.validate_link").as("validate_link");
  155. cy.get(".influxframework-control[data-fieldname=assigned_by] input").focus().as("input");
  156. cy.get("@input").type(cy.config("testUser"), { delay: 100 }).blur();
  157. cy.wait("@validate_link");
  158. cy.get(".influxframework-control[data-fieldname=assigned_by_full_name] .control-value").should(
  159. "contain",
  160. "InfluxFramework"
  161. );
  162. cy.window().its("cur_frm.doc.assigned_by").should("eq", cy.config("testUser"));
  163. // invalid input
  164. cy.get("@input").clear().type("invalid input", { delay: 100 }).blur();
  165. cy.get(".influxframework-control[data-fieldname=assigned_by_full_name] .control-value").should(
  166. "contain",
  167. ""
  168. );
  169. cy.window().its("cur_frm.doc.assigned_by").should("eq", null);
  170. // set valid value again
  171. cy.get("@input").clear().focus();
  172. cy.wait("@search_link");
  173. cy.get("@input").type(cy.config("testUser"), { delay: 100 }).blur();
  174. cy.wait("@validate_link");
  175. cy.window().its("cur_frm.doc.assigned_by").should("eq", cy.config("testUser"));
  176. // clear input
  177. cy.get("@input").clear().blur();
  178. cy.get(".influxframework-control[data-fieldname=assigned_by_full_name] .control-value").should(
  179. "contain",
  180. ""
  181. );
  182. cy.window().its("cur_frm.doc.assigned_by").should("eq", "");
  183. });
  184. });
  185. it("should set default values", () => {
  186. cy.insert_doc(
  187. "Property Setter",
  188. {
  189. doctype_or_field: "DocField",
  190. doc_type: "ToDo",
  191. field_name: "assigned_by",
  192. property: "default",
  193. property_type: "Text",
  194. value: "Administrator",
  195. },
  196. true
  197. );
  198. cy.reload();
  199. cy.new_form("ToDo");
  200. cy.fill_field("description", "new", "Text Editor");
  201. cy.intercept("POST", "/api/method/influxframework.desk.form.save.savedocs").as("save_form");
  202. cy.findByRole("button", { name: "Save" }).click();
  203. cy.wait("@save_form");
  204. cy.get(".influxframework-control[data-fieldname=assigned_by_full_name] .control-value").should(
  205. "contain",
  206. "Administrator"
  207. );
  208. // if user clears default value explicitly, system should not reset default again
  209. cy.get_field("assigned_by").clear().blur();
  210. cy.intercept("POST", "/api/method/influxframework.desk.form.save.savedocs").as("save_form");
  211. cy.findByRole("button", { name: "Save" }).click();
  212. cy.wait("@save_form");
  213. cy.get_field("assigned_by").should("have.value", "");
  214. cy.get(".influxframework-control[data-fieldname=assigned_by_full_name] .control-value").should(
  215. "contain",
  216. ""
  217. );
  218. });
  219. it("show translated text for Gender link field with language de with input in de", () => {
  220. cy.call("influxframework.tests.ui_test_helpers.insert_translations").then(() => {
  221. cy.window()
  222. .its("influxframework")
  223. .then((influxframework) => {
  224. cy.set_value("User", influxframework.user.name, { language: "de" });
  225. });
  226. cy.clear_cache();
  227. cy.wait(500);
  228. get_dialog_with_gender_link().as("dialog");
  229. cy.intercept("POST", "/api/method/influxframework.desk.search.search_link").as("search_link");
  230. cy.get(".influxframework-control[data-fieldname=link] input").focus().as("input");
  231. cy.wait("@search_link");
  232. cy.get("@input").type("Sonstiges", { delay: 100 });
  233. cy.wait("@search_link");
  234. cy.get(".influxframework-control[data-fieldname=link] ul").should("be.visible");
  235. cy.get(".influxframework-control[data-fieldname=link] input").type("{enter}", { delay: 100 });
  236. cy.get(".influxframework-control[data-fieldname=link] input").blur();
  237. cy.get("@dialog").then((dialog) => {
  238. let field = dialog.get_field("link");
  239. let value = field.get_value();
  240. let label = field.get_label_value();
  241. expect(value).to.eq("Other");
  242. expect(label).to.eq("Sonstiges");
  243. });
  244. });
  245. });
  246. it("show text for Gender link field with language en", () => {
  247. cy.window()
  248. .its("influxframework")
  249. .then((influxframework) => {
  250. cy.set_value("User", influxframework.user.name, { language: "en" });
  251. });
  252. cy.clear_cache();
  253. cy.wait(500);
  254. get_dialog_with_gender_link().as("dialog");
  255. cy.intercept("POST", "/api/method/influxframework.desk.search.search_link").as("search_link");
  256. cy.get(".influxframework-control[data-fieldname=link] input").focus().as("input");
  257. cy.wait("@search_link");
  258. cy.get("@input").type("Non-Conforming", { delay: 100 });
  259. cy.wait("@search_link");
  260. cy.get(".influxframework-control[data-fieldname=link] ul").should("be.visible");
  261. cy.get(".influxframework-control[data-fieldname=link] input").type("{enter}", { delay: 100 });
  262. cy.get(".influxframework-control[data-fieldname=link] input").blur();
  263. cy.get("@dialog").then((dialog) => {
  264. let field = dialog.get_field("link");
  265. let value = field.get_value();
  266. let label = field.get_label_value();
  267. expect(value).to.eq("Non-Conforming");
  268. expect(label).to.eq("Non-Conforming");
  269. });
  270. });
  271. it("show custom link option", () => {
  272. cy.window()
  273. .its("influxframework")
  274. .then((influxframework) => {
  275. influxframework.ui.form.ControlLink.link_options = (link) => {
  276. return [
  277. {
  278. html:
  279. "<span class='text-primary custom-link-option'>" +
  280. "<i class='fa fa-search' style='margin-right: 5px;'></i> " +
  281. "Custom Link Option" +
  282. "</span>",
  283. label: "Custom Link Option",
  284. value: "custom__link_option",
  285. action: () => {},
  286. },
  287. ];
  288. };
  289. get_dialog_with_link().as("dialog");
  290. cy.get(".influxframework-control[data-fieldname=link] input").focus().as("input");
  291. cy.get("@input").type("custom", { delay: 100 });
  292. cy.get(".custom-link-option").should("be.visible");
  293. });
  294. });
  295. });