Bin
2025-12-16 9e0b2ba2c317b1a86212f24cbae3195ad1f3dbfa
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
class ChoicesHelper {
  private get _baseRootSelector() {
    return ".lsf-choices";
  }
  private getСhoiceSelector() {
    return ".lsf-choice__item .ant-checkbox + span, .lsf-choice__item .ant-radio + span";
  }
 
  private getCheckedСhoiceSelector() {
    return ".lsf-choice__item .ant-checkbox-checked + span, .lsf-choice__item .ant-radio-checked + span";
  }
 
  private _rootSelector: string;
  constructor(rootSelector) {
    this._rootSelector = rootSelector.replace(/^\&/, this._baseRootSelector);
  }
 
  get root() {
    return cy.get(this._rootSelector);
  }
 
  get select() {
    return this.root.find("[data-testid*=select-trigger]");
  }
 
  findChoice(text: string) {
    return this.root.contains(this.getСhoiceSelector(), text);
  }
 
  findCheckedChoice(text: string) {
    return this.root.contains(this.getCheckedСhoiceSelector(), text);
  }
 
  hasCheckedChoice(text: string) {
    this.findCheckedChoice(text).scrollIntoView().should("be.visible");
  }
 
  toggleSelect() {
    this.select.click("right");
  }
 
  findOption(text: string) {
    const option = cy.get(`[data-testid*='select-option'][data-value="${text}"] [data-testid=choiceOptionText]`);
    return option;
  }
}
 
const Choices = new ChoicesHelper("&:eq(0)");
const useChoices = (rootSelector: string) => {
  return new ChoicesHelper(rootSelector);
};
 
export { Choices, useChoices };