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
54
55
56
57
58
59
60
61
Feature("Readonly Annotation");
 
const imageExamples = new DataTable(["example", "regionName"]);
 
imageExamples.add([require("../../../examples/timeseries-url-indexed"), "Walk"]);
 
Data(imageExamples).Scenario(
  "Timeseries Readonly Annotations",
  async ({ I, current, LabelStudio, AtOutliner, AtLabels, Tools }) => {
    I.amOnPage("/");
    const { config, result, data } = current.example;
    const regions = result.filter((r) => {
      return r.type.match("labels");
    });
 
    const params = {
      annotations: [
        {
          id: "test",
          readonly: true,
          result,
        },
      ],
      config,
      data,
    };
 
    LabelStudio.init(params);
 
    I.waitForElement(".htx-timeseries-channel", 60);
 
    I.say("TimeSeries loaded");
 
    I.say("Check region is selectable");
    AtOutliner.seeRegions(regions.length);
    AtOutliner.clickRegion(current.regionName);
 
    I.say("Results are equal after deletion attempt");
    I.pressKey("Backspace");
    await LabelStudio.resultsNotChanged(result);
 
    const wrapperPosition = await Tools.getElementPosition(".htx-timeseries-channel");
 
    AtLabels.clickLabel("Run");
 
    I.say("Can't draw new shape");
    I.pressKey("1");
    await I.dragAndDropMouse(
      {
        x: wrapperPosition.x + 100,
        y: wrapperPosition.y + wrapperPosition.height / 2,
      },
      {
        x: wrapperPosition.x + 150,
        y: wrapperPosition.y + wrapperPosition.height / 2,
      },
    );
 
    AtOutliner.seeRegions(regions.length);
  },
);