Uploaded image for project: 'Qt Design Studio'
  1. Qt Design Studio
  2. QDS-12140

Connecting the panel to code might be a bit challenging for users

    XMLWordPrintable

Details

    • QDS Berlin - 2024 Week 9/10, QDS Berlin - 2024 Week 11/12, QDS Berlin - 2024 Week 13/14, QDS Berlin - 2024 Week 15/16, QDS Berlin - 2024 Week 17/18, QDS Berlin - 2024 Week 19/20, QDS Berlin - 2024 Week 21/22, QDS Berlin - 2024 Week 23/24, QDS Berlin - 2024 Week 25/26, QDS Berlin - 2024 Week 27/28, QDS Berlin - 2024 Week 29/30

    Description

      Summary:

      It is difficult to understand just by looking at the panel; understanding the code is necessary to grasp the panel settings.

      There is confusion because the order of the code in the lower code editor, generated by the connection panel, is displayed differently from the dropdown values at the top of the connection panel.

      --
      In the code, the if (switchButton.state === "On") part checks if the switch button's state is 'On' first. However, when configuring using the panel's dropdown, 'Off' is selected first, and then 'On' is added as a condition. This discrepancy, where the code checks for 'On' first while the panel requires selecting 'Off' first, can cause confusion.

       

      ------------------------------------------------------------------------------------------

       

       

      The connection in the mouse area of the switch has the following conditions: if the current state of the switchButton is "On," it should change to "Off," otherwise, it should change to "On."

      The default state is currently set to "Off," and when the code is written directly, the panel displays the following configuration: when the mouse area's click signal is received, the change state action occurs. The state group associated with the switch button has the state set to "Off." Additionally, the condition is set as "if off, change to On, otherwise change to On."

      I expected the panel to display the following:

      • The state should be selected as "On."
      • The condition should be set to "Off."
      • The else statement should be set to "On."

      Do I have a misunderstanding, or is this the expected behavior in the panel?

       

       

      [In cases where a Change State action is applied without conditions] 

      -When creating a toggle button

       

       

       

      ------------------------------------------------------------------------------------------------------

       

       

      [In cases where a Change State action is applied with specific conditions] 

      -In the case of creating a state for a single button click


       

      Typically, when applying the Change State action without conditions, the panel is labeled as 'State2' because, during a click event, the default State1 transitions to State2.

       

      However, in the case of a bug report inquiry, when a click event with conditions is used to transition from the default 'Off' state to 'On,' the expected behavior is for the panel to display 'State' as 'On.' The condition should be that switchButton.state is equal to 'Off,' and the else condition should be 'On.'

       

      I find the usage a bit confusing in this context.

       

      ------------------------------------------------------------------------------------------------------

       

       

      I'm working on a connection in the mouse area of a general switch.

      /Code 1/
      if (switchButton.state === "On")

      { switchButton.state = "Off" }

      else

      { switchButton.state = "On" }

      /Code 2/
      if (switchButton.state === "Off")

      { switchButton.state = "On"; }

      else

      { switchButton.state = "Off"; }

      The results of both codes are the same.

      Result of Code 1:
      When the state is "On", it changes the state to "Off". Otherwise (i.e., when the state is not "On", in this case, when it is "Off"), it changes the state to "On".

      Result of Code 2:
      When the state is "Off", it changes the state to "On". Otherwise (i.e., when the state is not "Off", in this case, when it is "On"), it changes the state to "Off".

      What I want is a toggle function, and the default state of the switch is Off. Therefore, I understand that Code 2 is logically more suitable. However, since I initially wrote Code 1 in the code edit area, it was difficult to understand because the panel was automatically set.

      So, what I'm curious about is the approach when adding the first dropdown and condition, and because of the order of the code, it is not easy to understand.

      Assuming I don't know the code, I asked a developer who is proficient in code if they can understand the panel based on it. However, I was told that it is difficult to understand the usage just by looking at the panel, and it would be understood through inference.

      To create this code in the panel, the condition `switchButton.state === "Off"` is added in the middle of the panel, indicating that it occurs when the state changes to "On." However, in the code, the condition is placed at the very beginning. I understand it now, but it's still not easy to use.

       

       

      Attachments

        1. image-2024-03-04-02-19-29-429.png
          982 kB
          Sophie Lee
        2. image-2024-03-04-02-20-52-062.png
          413 kB
          Sophie Lee
        3. image-2024-03-05-15-51-56-446.png
          255 kB
          Sophie Lee
        4. image-2024-03-05-16-48-26-674.png
          314 kB
          Sophie Lee
        5. image-2024-03-05-17-00-31-007.png
          252 kB
          Sophie Lee
        6. image-2024-03-05-17-00-58-609.png
          252 kB
          Sophie Lee
        7. image-2024-03-05-17-07-02-078.png
          247 kB
          Sophie Lee
        8. image-2024-03-05-17-07-18-123.png
          247 kB
          Sophie Lee
        9. image-2024-03-06-10-47-23-333.png
          132 kB
          Sophie Lee
        10. image-2024-07-30-20-15-33-072.png
          159 kB
          Sophie Lee
        11. SwitchTest.zip
          927 kB
          Sophie Lee

        Issue Links

          No reviews matched the request. Check your Options in the drop-down menu of this sections header.

          Activity

            People

              brook_cronin_qt Brook Cronin
              sophie_lee Sophie Lee
              Brook Cronin Brook Cronin
              Votes:
              0 Vote for this issue
              Watchers:
              3 Start watching this issue

              Dates

                Created:
                Updated:

                Gerrit Reviews

                  There are no open Gerrit changes