Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GUI: Decoupling game GUIs from the engine #264

Closed
9 tasks done
stickgrinder opened this issue Aug 19, 2024 · 1 comment
Closed
9 tasks done

GUI: Decoupling game GUIs from the engine #264

stickgrinder opened this issue Aug 19, 2024 · 1 comment
Assignees
Milestone

Comments

@stickgrinder
Copy link
Collaborator

stickgrinder commented Aug 19, 2024

Benefit description

While documenting and reviewing the current GUI structure, we concluded that there is still a surface of strong coupling between the engine and the GUI logic. These bonds will prevent pushing updates to the structure of the components.

Also, a single base theme common to all GUI, with a small impact on the game graphics is preferable over the current "per-gui" styles, reminiscent of the original interfaces.

These changes are the last ones that are worth doing before releasing 2.0 stable because they will allow us to do more releases without introducing too many breaking changes.

Done when

Structural changes

  • Every component in the currently available GUIs is based on a Control root node, that exposes the custom script (see below). Every other component such as Panels or similar is child to the Control root node.
  • The script attached to a component is currently extending a base script in the engine folder. This base script must be copied over to the /game/graphical_interface folder (see below for a change to this naming). Every component will hold its copy of the script. The script attached to the Control root node of the component will extend the local copy and will be called <component_name>_custom.gd (ex system_text.gd and system_text_custom.gd)
  • The /addons/engine/objects/graphical_interface and /game/graphical_interface folders will be renamed to <dir>/gui to have a consistent naming across the whole plugin (nodes, scenes, editor UI, etc). Optionally the UI tab can be renamed GUI?
  • All the GUIs will be based on the theme that is now called popochiu_theme and was the base for the former simple click GUI (that was the only one available). The theme will be renamed as base_gui_theme and will be copied over into the /game/gui/resources.

Theme changes

  • All the GUI will use this base theme, with local customizations where necessary
  • The base theme will be updated to make use of semi-transparent panel and consistent fonts and sprites (see below)
  • The standard resolution for pixel art games will be changed to 356x200 or 384x216 to give a bit more real estate compared to the very retro resolution of 320x180. The GUIs must be checked to work at the new resolution and scale well above that one.
  • We'll change the current font (MonkeyIsland) which is good for dialogues, but not for interfaces, with another one (or a couple ones, probably). The font has to be chosen but will be - although pixelated - a bit more modern than the current one
  • All the sprites will be redesigned (if necessary) and made monochrome, with an accent color common to all of them (Popochiu purple, maybe?)

Implications

  • A migration will be needed to update the folder name to gui and make sure the resources point in the right place
  • We need to write clearly in the release notes that with the release of this stable, it is strongly advised to update the GUI of the project. Customizations need to be exported to a theme or they will be lost. Local customization will have to be redone by hand.
  • Release notes should also talk about the new resolution, despite it being not a constraint.
@stickgrinder stickgrinder added this to the v2.0 - Stable milestone Aug 19, 2024
stickgrinder added a commit that referenced this issue Aug 30, 2024
…nt style. Also added new "Minecraftia Regular" font.
stickgrinder added a commit that referenced this issue Aug 30, 2024
…esthetic matching everywhere, some small structural change to inventory grid.
stickgrinder added a commit that referenced this issue Aug 30, 2024
…hetic changes to the main elements. Some WIP on the popups.
@stickgrinder
Copy link
Collaborator Author

stickgrinder commented Aug 30, 2024

Leaving a note on what I'm doing to uplift the GUIs to a Popochiu-neutral style:

Base components

  1. Reset all themes assignments, but on the root nodes of each component scene (there are leftovers)
  2. Remove all colors customizations in panels and elements around the various interfaces elements
  3. All panels will be 70% black. Nested panels will have to be transparent so things won't add up
  4. Redesign all sprites to be consistent. Reuse the same sprite where it makes sense (save/load, quit game, inventory arrows, etc) - We are going to structure the GUIs as their original inspirations, not to copycat the same visuals (see note below)
    1. CheckButton theme icon can be smaller
    2. HSlider icon in the team needs a check and may require more states for reliability
    3. OptionButton down-arrow icon has been changed, but it may not be OK with the new theme (black on black?): check it
  5. Some texts that will appear over the scene may need outlines, test and add them as necessary

Popups

  • Redo point 1 to 4 above for all the popups in the various templates.
  • Make sure popups have an outer margin of 2px
  • Popups may or may not have a full-screen overlay. When they have, make it 50% white, so the 70% black on top won't become too dark. If it doesn't work during the tests, consider removing the overlay, since the popup is itself translucent.

Specific Templates

  • 9 Verbs
    • Move the settings icon in the bottom area (between the inventory arrows like in FoA?)
    • Make the whole 9Verbs + Inventory bottom panel a single 70% black area with separators
  • SimpleClick
    • Rework the top bar icons to be more readable
    • Compact all the text settings (speed and autoadvance) in the already available popup, reduce buttons count
    • Add a quit popup so that the user doesn't swear for a wrong click
    • Add hover and clicked state on the menu, to make it consistent with the other GUIs
  • Sierra
    • Rework the icons and cursors to make them a bit smaller and more modern (currently AGS ripoffs)
    • Rework the cursor to make it a bit smaller and reflect the new icons
    • Make only the last popup visible to support transparency
    • Toggle SierraBar and SierraMenu visibility to support transparency

Cleanup

  • Sierra
    • Remove separator.png and sierra_text_continue.png if they are not used
  • All GUIs
    • remove the local theme that have been left and is now useless
  • SimpleClick
    • Consider switching from an interface singleton to manage signals to the GUI itself, so that the Engine makes no assumption on GUI elements (to be discussed between @mapedorr and @stickgrinder)

stickgrinder added a commit that referenced this issue Aug 31, 2024
stickgrinder added a commit that referenced this issue Aug 31, 2024
stickgrinder added a commit that referenced this issue Sep 1, 2024
… in "exclusive mode", so when one is visible the other ones in the stack are hidden.
mapedorr added a commit that referenced this issue Sep 1, 2024
Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.
mapedorr added a commit that referenced this issue Sep 1, 2024
Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.
mapedorr added a commit that referenced this issue Sep 1, 2024
- **fix** Fix type infer bug in Dialog Overhead component.
mapedorr added a commit that referenced this issue Sep 1, 2024
* refs #264: Update scripts created for game GUI.

Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.

* refs #264: Fix path issues in some GUI components.

- **fix** Fix type infer bug in Dialog Overhead component.

* Fix GUI theme Panel overwrite issue in Dialog Menu component
mapedorr added a commit that referenced this issue Sep 1, 2024
- **fix** Change mouse_filter in Dialog Portrait component to "IGNORE".
- **fix** Remove unnecessary uses of preload in some GUI components.
- **upd** Improve inheritance of btn_dialog_speed in Simple Click GUI.
mapedorr added a commit that referenced this issue Sep 2, 2024
- **upd** Add I.deselect_active() and PopochiuInventoryItem.deselect()
  methods to make deselection easier.
- **fix** Update Sierra Inventory popup buttons' atlas texture sizes and positions in order to match the new 24x24 icons.
mapedorr added a commit that referenced this issue Sep 2, 2024
Now the button to open the Settings popup in the 9 Verb GUI is located
between the UP and DOWN arrows in its bottom panel.

- **upd** Create custom script for 9 Verb Inventory Grid.
mapedorr added a commit that referenced this issue Sep 5, 2024
This can be configured by devs with the export variable in the HoverText
component.

- **upd** Hide the GUI tab in Popochiu dock while we define how it
should work.
- **upd** Hide "Use translations" and "Dialog style" options in `Project
Settings > Popochiu > Dialogs`.
stickgrinder added a commit that referenced this issue Sep 7, 2024
mapedorr added a commit that referenced this issue Sep 8, 2024
We agreed to release Popochiu 2.0 with only 3 GUI options since enabling
the Empty (a.k.a. Custom) GUI will require more documentation to be done
so devs have a guide on how to create their GUIs from zero.
mapedorr added a commit that referenced this issue Sep 8, 2024
Progress in standarizing GUI templates

Set base_gui_theme.tres as default theme for all GUIs

- **upd** Update structure of some components to have a Control node as
  root (this is a way to standarize all the GUI components).
- Replace all the uses of 9_verb_theme and sierra_theme by
  base_gui_theme.

Make all Popochiu popups have a Control as root

Update base_gui_theme Buttons' style

Now the buttons have a simpler style.

- **upd** Create DialogLine script to wrap the DialogText nodes that
  will allow render dialog lines with different styles.

Progress on creating Popochiu GUI components for each dialog style

Separate logic for the different DialogText styles

Now each dialog style has its own scene and script so the specific logic
of each component relies in its own script.

Fix issues after testing GUI template selection

Fix issues in Simple Click GUI template

Now it is possible to make the inventory bar and the settings bar to
show when moving the mouse on top of the viewport.

- **fix** Fix wrong position calculation for DialogMenu component.

Standarize popups

Now all popups have the same structure and use a .tres file to define
the style of their PanelContainer node (the one that containts the
content of the popup).

Fix wrong calculations in DialogText component

Now the Overhead dialog works as expected.

- **fix** Fix closing PopochiuPopups by clicking the Overlay node.

Fix issues in Sierra GUI

The inventory wasn't working, and the DialogPortrait component was
having an unexpected behavior.

Add avatar background panels to DialogPortrait

refs #264: Some changes to the base GUI theme, with the news consistent style. Also added new "Minecraftia Regular" font.

refs #264: Components cleanup: redundant theme assignement removed, aesthetic matching everywhere, some small structural change to inventory grid.

refs #264: Aesthetic changes to 9Verbs template (missing popups).

refs #264: SimpleClick template redundant theme assignment cleanup.

refs #264: Sierra template cleanup from redundant themeing, plus aesthetic changes to the main elements. Some WIP on the popups.

refs #264: Inventory up and down buttons are referred to by unique names in script.

refs #264: All popup buttons are now coherent (OK, Back, Cancel), plus the quit popup is translucent.

refs #264: All overlays are now transparent (StyleBoxEmpty) to support translucent popups.

refs #264: NEEDS REVIEW by @carenalga! - Overlays are now always open in "exclusive mode", so when one is visible the other ones in the stack are hidden.

refs #264: New Sierra menu icons and cursors.

refs #264: Update GUI scripts creation and folder renaming (#270)

* refs #264: Update scripts created for game GUI.

Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.

* refs #264: Fix path issues in some GUI components.

- **fix** Fix type infer bug in Dialog Overhead component.

* Fix GUI theme Panel overwrite issue in Dialog Menu component

refs #264: Fix issues in Sierra and Simple Click GUIs

- **fix** Change mouse_filter in Dialog Portrait component to "IGNORE".
- **fix** Remove unnecessary uses of preload in some GUI components.
- **upd** Improve inheritance of btn_dialog_speed in Simple Click GUI.

refs #264: Deselect active inventory item with RMB in Sierra GUI

- **upd** Add I.deselect_active() and PopochiuInventoryItem.deselect()
  methods to make deselection easier.
- **fix** Update Sierra Inventory popup buttons' atlas texture sizes and positions in order to match the new 24x24 icons.

refs #264: Move Settings button to bottom panel in 9 Verb GUI

Now the button to open the Settings popup in the 9 Verb GUI is located
between the UP and DOWN arrows in its bottom panel.

- **upd** Create custom script for 9 Verb Inventory Grid.

refs #264: 9 Verbs GUI icons are done.

Fix click blocking when using DialogPortrait.

- **upd** Rename the idle animation in Popochiu's default cursor to
match the correct name ("normal").
- **upd** Reduce the custom minimum size of the Popochiud dock since all
those pixels are no longer needed.

refs #264: Padding for Sierra dialog panel.

refs #264: New inventory arrow icons for Sierra GUI.

refs #264: New toolbar icons for SimpleClick GUI.

refs #264: Fixed fonts and outlines for SimpleClick GUI.

refs #264: Add option to hide HoverText when a dialog line is shown

This can be configured by devs with the export variable in the HoverText
component.

- **upd** Hide the GUI tab in Popochiu dock while we define how it
should work.
- **upd** Hide "Use translations" and "Dialog style" options in `Project
Settings > Popochiu > Dialogs`.

refs #264: New icons for dialogue controls.

refs #264: SimpleClick GUI now opens text settings popup. Removed useless setting from the same popup.

refs #264: SimpleClick GUI now shows a confirmation popup before quitting the game.

refs #264: Fixed a visual glitch on Sierra toolbar buttons.

refs #264: Useless SimpleClick icons cleanup.

refs #264: SimpleClick GUI icons are now colored.

refs #264: Fix history button in Simple Click GUI

refs #264: Hide Custom button in Setup popup

We agreed to release Popochiu 2.0 with only 3 GUI options since enabling
the Empty (a.k.a. Custom) GUI will require more documentation to be done
so devs have a guide on how to create their GUIs from zero.

refs #264: SimpleClick GUI icons are now colored - Missing icons.

Fix double-click double-tap issue in DialogText component

refs #264: Update base retro resolution to 356x200
mapedorr added a commit that referenced this issue Sep 8, 2024
Progress in standarizing GUI templates

Set base_gui_theme.tres as default theme for all GUIs

- **upd** Update structure of some components to have a Control node as
  root (this is a way to standarize all the GUI components).
- Replace all the uses of 9_verb_theme and sierra_theme by
  base_gui_theme.

Make all Popochiu popups have a Control as root

Update base_gui_theme Buttons' style

Now the buttons have a simpler style.

- **upd** Create DialogLine script to wrap the DialogText nodes that
  will allow render dialog lines with different styles.

Progress on creating Popochiu GUI components for each dialog style

Separate logic for the different DialogText styles

Now each dialog style has its own scene and script so the specific logic
of each component relies in its own script.

Fix issues after testing GUI template selection

Fix issues in Simple Click GUI template

Now it is possible to make the inventory bar and the settings bar to
show when moving the mouse on top of the viewport.

- **fix** Fix wrong position calculation for DialogMenu component.

Standarize popups

Now all popups have the same structure and use a .tres file to define
the style of their PanelContainer node (the one that containts the
content of the popup).

Fix wrong calculations in DialogText component

Now the Overhead dialog works as expected.

- **fix** Fix closing PopochiuPopups by clicking the Overlay node.

Fix issues in Sierra GUI

The inventory wasn't working, and the DialogPortrait component was
having an unexpected behavior.

Add avatar background panels to DialogPortrait

refs #264: Some changes to the base GUI theme, with the news consistent style. Also added new "Minecraftia Regular" font.

refs #264: Components cleanup: redundant theme assignement removed, aesthetic matching everywhere, some small structural change to inventory grid.

refs #264: Aesthetic changes to 9Verbs template (missing popups).

refs #264: SimpleClick template redundant theme assignment cleanup.

refs #264: Sierra template cleanup from redundant themeing, plus aesthetic changes to the main elements. Some WIP on the popups.

refs #264: Inventory up and down buttons are referred to by unique names in script.

refs #264: All popup buttons are now coherent (OK, Back, Cancel), plus the quit popup is translucent.

refs #264: All overlays are now transparent (StyleBoxEmpty) to support translucent popups.

refs #264: NEEDS REVIEW by @carenalga! - Overlays are now always open in "exclusive mode", so when one is visible the other ones in the stack are hidden.

refs #264: New Sierra menu icons and cursors.

refs #264: Update GUI scripts creation and folder renaming (#270)

* refs #264: Update scripts created for game GUI.

Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.

* refs #264: Fix path issues in some GUI components.

- **fix** Fix type infer bug in Dialog Overhead component.

* Fix GUI theme Panel overwrite issue in Dialog Menu component

refs #264: Fix issues in Sierra and Simple Click GUIs

- **fix** Change mouse_filter in Dialog Portrait component to "IGNORE".
- **fix** Remove unnecessary uses of preload in some GUI components.
- **upd** Improve inheritance of btn_dialog_speed in Simple Click GUI.

refs #264: Deselect active inventory item with RMB in Sierra GUI

- **upd** Add I.deselect_active() and PopochiuInventoryItem.deselect()
  methods to make deselection easier.
- **fix** Update Sierra Inventory popup buttons' atlas texture sizes and positions in order to match the new 24x24 icons.

refs #264: Move Settings button to bottom panel in 9 Verb GUI

Now the button to open the Settings popup in the 9 Verb GUI is located
between the UP and DOWN arrows in its bottom panel.

- **upd** Create custom script for 9 Verb Inventory Grid.

refs #264: 9 Verbs GUI icons are done.

Fix click blocking when using DialogPortrait.

- **upd** Rename the idle animation in Popochiu's default cursor to
match the correct name ("normal").
- **upd** Reduce the custom minimum size of the Popochiud dock since all
those pixels are no longer needed.

refs #264: Padding for Sierra dialog panel.

refs #264: New inventory arrow icons for Sierra GUI.

refs #264: New toolbar icons for SimpleClick GUI.

refs #264: Fixed fonts and outlines for SimpleClick GUI.

refs #264: Add option to hide HoverText when a dialog line is shown

This can be configured by devs with the export variable in the HoverText
component.

- **upd** Hide the GUI tab in Popochiu dock while we define how it
should work.
- **upd** Hide "Use translations" and "Dialog style" options in `Project
Settings > Popochiu > Dialogs`.

refs #264: New icons for dialogue controls.

refs #264: SimpleClick GUI now opens text settings popup. Removed useless setting from the same popup.

refs #264: SimpleClick GUI now shows a confirmation popup before quitting the game.

refs #264: Fixed a visual glitch on Sierra toolbar buttons.

refs #264: Useless SimpleClick icons cleanup.

refs #264: SimpleClick GUI icons are now colored.

refs #264: Fix history button in Simple Click GUI

refs #264: Hide Custom button in Setup popup

We agreed to release Popochiu 2.0 with only 3 GUI options since enabling
the Empty (a.k.a. Custom) GUI will require more documentation to be done
so devs have a guide on how to create their GUIs from zero.

refs #264: SimpleClick GUI icons are now colored - Missing icons.

Fix double-click double-tap issue in DialogText component

refs #264: Update base retro resolution to 356x200
stickgrinder pushed a commit that referenced this issue Sep 8, 2024
Progress in standarizing GUI templates

Set base_gui_theme.tres as default theme for all GUIs

- **upd** Update structure of some components to have a Control node as
  root (this is a way to standarize all the GUI components).
- Replace all the uses of 9_verb_theme and sierra_theme by
  base_gui_theme.

Make all Popochiu popups have a Control as root

Update base_gui_theme Buttons' style

Now the buttons have a simpler style.

- **upd** Create DialogLine script to wrap the DialogText nodes that
  will allow render dialog lines with different styles.

Progress on creating Popochiu GUI components for each dialog style

Separate logic for the different DialogText styles

Now each dialog style has its own scene and script so the specific logic
of each component relies in its own script.

Fix issues after testing GUI template selection

Fix issues in Simple Click GUI template

Now it is possible to make the inventory bar and the settings bar to
show when moving the mouse on top of the viewport.

- **fix** Fix wrong position calculation for DialogMenu component.

Standarize popups

Now all popups have the same structure and use a .tres file to define
the style of their PanelContainer node (the one that containts the
content of the popup).

Fix wrong calculations in DialogText component

Now the Overhead dialog works as expected.

- **fix** Fix closing PopochiuPopups by clicking the Overlay node.

Fix issues in Sierra GUI

The inventory wasn't working, and the DialogPortrait component was
having an unexpected behavior.

Add avatar background panels to DialogPortrait

refs #264: Some changes to the base GUI theme, with the news consistent style. Also added new "Minecraftia Regular" font.

refs #264: Components cleanup: redundant theme assignement removed, aesthetic matching everywhere, some small structural change to inventory grid.

refs #264: Aesthetic changes to 9Verbs template (missing popups).

refs #264: SimpleClick template redundant theme assignment cleanup.

refs #264: Sierra template cleanup from redundant themeing, plus aesthetic changes to the main elements. Some WIP on the popups.

refs #264: Inventory up and down buttons are referred to by unique names in script.

refs #264: All popup buttons are now coherent (OK, Back, Cancel), plus the quit popup is translucent.

refs #264: All overlays are now transparent (StyleBoxEmpty) to support translucent popups.

refs #264: NEEDS REVIEW by @carenalga! - Overlays are now always open in "exclusive mode", so when one is visible the other ones in the stack are hidden.

refs #264: New Sierra menu icons and cursors.

refs #264: Update GUI scripts creation and folder renaming (#270)

* refs #264: Update scripts created for game GUI.

Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.

* refs #264: Fix path issues in some GUI components.

- **fix** Fix type infer bug in Dialog Overhead component.

* Fix GUI theme Panel overwrite issue in Dialog Menu component

refs #264: Fix issues in Sierra and Simple Click GUIs

- **fix** Change mouse_filter in Dialog Portrait component to "IGNORE".
- **fix** Remove unnecessary uses of preload in some GUI components.
- **upd** Improve inheritance of btn_dialog_speed in Simple Click GUI.

refs #264: Deselect active inventory item with RMB in Sierra GUI

- **upd** Add I.deselect_active() and PopochiuInventoryItem.deselect()
  methods to make deselection easier.
- **fix** Update Sierra Inventory popup buttons' atlas texture sizes and positions in order to match the new 24x24 icons.

refs #264: Move Settings button to bottom panel in 9 Verb GUI

Now the button to open the Settings popup in the 9 Verb GUI is located
between the UP and DOWN arrows in its bottom panel.

- **upd** Create custom script for 9 Verb Inventory Grid.

refs #264: 9 Verbs GUI icons are done.

Fix click blocking when using DialogPortrait.

- **upd** Rename the idle animation in Popochiu's default cursor to
match the correct name ("normal").
- **upd** Reduce the custom minimum size of the Popochiud dock since all
those pixels are no longer needed.

refs #264: Padding for Sierra dialog panel.

refs #264: New inventory arrow icons for Sierra GUI.

refs #264: New toolbar icons for SimpleClick GUI.

refs #264: Fixed fonts and outlines for SimpleClick GUI.

refs #264: Add option to hide HoverText when a dialog line is shown

This can be configured by devs with the export variable in the HoverText
component.

- **upd** Hide the GUI tab in Popochiu dock while we define how it
should work.
- **upd** Hide "Use translations" and "Dialog style" options in `Project
Settings > Popochiu > Dialogs`.

refs #264: New icons for dialogue controls.

refs #264: SimpleClick GUI now opens text settings popup. Removed useless setting from the same popup.

refs #264: SimpleClick GUI now shows a confirmation popup before quitting the game.

refs #264: Fixed a visual glitch on Sierra toolbar buttons.

refs #264: Useless SimpleClick icons cleanup.

refs #264: SimpleClick GUI icons are now colored.

refs #264: Fix history button in Simple Click GUI

refs #264: Hide Custom button in Setup popup

We agreed to release Popochiu 2.0 with only 3 GUI options since enabling
the Empty (a.k.a. Custom) GUI will require more documentation to be done
so devs have a guide on how to create their GUIs from zero.

refs #264: SimpleClick GUI icons are now colored - Missing icons.

Fix double-click double-tap issue in DialogText component

refs #264: Update base retro resolution to 356x200
mapedorr added a commit that referenced this issue Sep 8, 2024
Instead of relying on IGraphicInterface methods and signals, each GUI
handles local signals to decide which popup to open. This change
affected the Simple Click and the 9 Verb GUIs.

- **upd** Remove unused images in the Sierra GUI.
- **upd** Update button style for CheckBox Buttons in
  base_gui_theme.tres.
stickgrinder pushed a commit that referenced this issue Sep 8, 2024
Instead of relying on IGraphicInterface methods and signals, each GUI
handles local signals to decide which popup to open. This change
affected the Simple Click and the 9 Verb GUIs.

- **upd** Remove unused images in the Sierra GUI.
- **upd** Update button style for CheckBox Buttons in
  base_gui_theme.tres.
stickgrinder added a commit that referenced this issue Sep 14, 2024
* Fix #216 (#220)

Fix #216 by using `queue_free()` to delete rows in a **PopochiuGroup**, use `free()` so the name of the node is available.

* Fix #219 (#222)

Set `PopochiuRoom.state.visited_first_time` to `true` after the
`_on_room_transition_finished()` is executed.

- **fix** InventoryGrid slots were being deleted in the process of
adding items in the ProjectSettings.items_on_start array. This was
causing an issue in the 9 Verb and Sierra templates.
- **upd** Settings popup in 9 Verb and Sierra templates now close
automatically when a slot is selected for saving or loading.
- **upd** Slots in InventoryGrid are no longer deleted when removing an
item. Instead, only its name changes.
- **fix** Improve fix to avoid Godot printing a Warning related with
setting the size of dialog_text and hover_text during a `_ready()`
execution.

* Added information about default inventory icon sizes (#223)

* Fix #224 (#225)

Clean E.clicked when an inventory item is clicked and make sure items
are removed when clicking anywhere in the room only if there is no
PopochiuClickable hovered.

- **fix** The modified options in Project Settings > Popochiu were being
hidden.
- **upd** Cursor texture is properly rendered when the mouse enters and
exits the SettingsBar.
- **fea** (!) Inventory items fit the height of the inventory slot (in
case of InventoryGrid) or the InventoryBar. This was only available when
Experimental Scale GUI was on.

* Fix on adding inventory items on start

* Fix #59 - Update audio autoload (A) on file deletion (#226)

* Minor UX improvements

- **upd** Can't start the same dialog twice.
- **upd** PopochiuClickable clicks are ignored if a dialog is running.
- **upd** TransitionLayer now uses a Control node to block interactions
when a transition is playing.
- **upd** The GUI is hidden when a transition is playing.
- **upd** If a dialog is running when a game is loaded, the dialog
stops.
- **fea** Add properties to InventoryBar and SettingsBar so devs can
define if they should hide when the GUI is blocked.

* Fix #59

AudioCues that are inside a Popochiu object's folder (room, character,
etc.) or that are deleted from the FileSystem dock are properly removed
in the A autoload, so a Godot error triggers when trying to play those
cues from scripts.

* .gitignore update (#228)

* Updating .gitignore

* Reset cache

* addons/ is not ignored anymore

* Popochiu (E) refactor (#229)

* Move camera, room and character logic out of popochiu.gd

- Now the camera has its own script.
- PopochiuIRoom is now in charge of changing rooms.
- Create PopochiuCharactersHelper script to take care of player
initialization and executing strings inside E.queue([]) calls.

* Remove code that should be handled by other classes

Now the rooms_states are in PopochiuIRoom.

- **upd** Remove some unused variables.
- **upd** Add @deprecated note to moved properties and methods.
- **upd** Add code comments to moved properties and methods so they
point devs in the right direction when reading the Documentation.
- **fix** Sometimes the Popochiu dock show nothing inside its groups
despite having rooms, characters, inventory items and dialogs in the
project.
- **upd** Minor refactor to `popochiu_dock.gd` for better code
readability.

* Add removed methods with the corresponding @deprecated note

To avoid breaking old projects

* Add deleted methods with the corresponding @deprecated annotation

* Fix in room changing.

Replace calls to E.main_camera by E.camera.

* Fix error in storing room data

This happened only when the room was changed by using R.current =
R.AnotherRoom.

- **fix** Add some code validations to stop error messages appearing in
the Output when debugging.
- **upd** Update remaining calls/mentions to "E.goto_room".

* Some improvements based on code review.

* Improve RegEx for dialog lines

Now the emotion and the time can be send in any order.

- **upd** Typos and logic improved based on the PR review comments.
- **fix** Inventory items should call `set_active()` by default in their
`_on_click()` function.

* Last improvements after last code review

Now instances of objects inside interface classes are all stored in a
Dictionary, to avoid using a for over an Array.

- **upd** Now the GUI has methods to react to saving and loading the
game, instead of the fixed behavoir of showing a text in the SystemText
component.

* Add `get_instance` method to PopochiuIRoom

This is in order to homogenize all the interface classes.

* Fix #230 (#231)

Now the Cursor is not in charge of changing its texture based on GUI
blocking. It's the GUI's responsibility to determine what happens to the
cursor when it's locked or unlocked.

- **upd** Clean E.clicked and I.clicked once the interaction is handled.
- **fix** Sierra GUI inventory item use was not behaving as expected.
- **fix** Rollback call to E.command_fallback() as the default call for
the _on_click() function in inventory_item_template.gd.

* fixes #192: As suggested by @mapedorr, the v_frames property is now ignored when a the room default state is loaded at scene start. (#237)

* refs #232: gizmos working for PopochiuClickables. (#235)

* refs #232: gizmos working for PopochiuClickables.

* refs #232: editor settings refactoring.

* refs #232: initialization and clean-up.

* refs #232: gizmo sub-plugin enable/disable.

* refs #232 #134: old node-based helpers removed.

* refs #232: updating documentation to reflect the new gizmos

* refs #232: interaction polygon button visibility follows node selection, updated look at point init code.

* refs #232: restored correct default values for baseline and walk_to_point for PopochiuProp. See: #235 (comment)

* refs #232: removed _exit_tree(). See: #235 (comment)

* refs #232: _try_grab_gizmo restricted to InputEventMouseButton. See: #235 (comment)

* refs #232: added/edited code regions. See: #235 (comment)

* refs #232: updated plugin.cfg. See: #235 (comment)

---------

Co-authored-by: Paolo Pustorino <[email protected]>

* Refactor popochiu_object_row and remove dependencies to popochiu_dock (#236)

* Refactor scripts and classes in the Editor side

Remove main dock dependency in PopochiuObjectRow and PopochiuAudioRow

Create script that will serve as a signal bus to communicate components
in the Editor side of Popochiu

The DeleteConfirmation popup is created in runtime by PopochiuObjectRow
and PopochiuAudioRow when needed.

Improve use of DeleteConfirmation dialog

- **fix** issue when assigning the PC from popochiu_data.cfg.
- **fix** issue when clearing the inventory.
- **fix** deleting object rooms was not saving the .tscn file of the
room.

Separate the script of popochiu_object_row into several

Now popochiu_audio_row inherits from popochiu_row.

- **fea** Create popochiu_object_row specific scripts for rooms,
character, inventory item, and room object (props, hotspots, walkable
areas, regions and markers).
- **fea** Create Project Settings section for Popochiu audio. Here devs
we'll be able to define the prefix for audio cues.
- **upd** Remove main_dock dependency in TabAudio.
- **upd** Create folders for TabAudio and TabRoom.

Fix issue with character rows in Room tab

Also makes the Play button in popochiu_room_row visible.

- **upd** Update some calls to String.find() by `"TheStringToLookFor" in
String`.
- Audio tab now takes into account the prefixes in the audio section of
the Project Settings to clasify new audio cues.

Remove main_dock dependency in factories and creation popups

Remove non used functions

Remove `main_dock` dependency in Aseprite importer scripts

Separate the Main tab from the Popochiu dock. Now it has its own scene
and script.

Remove preload of PopochiuResources in Constants var

Now scripts access PopochiuResources directly.

- **upd** Minor flow improvement when removing main objects in
popochiu_object_row.

Add wait for popochiu_dock.ready signal

This makes a better flow for the plugin start, and avoid the use of
timers to assure everything is ready to show project data in the dock.

- **upd** Now the Setup popup is shown by calling a method in
PopochiuEditorHelper.
- **upd** The Audio tab connects directly to the signal needed to update
the list of audio files and cues, instead of the popochiu_plugin script
doing that.

Fix in Creation popup for room objects

- **fix** Fix Tab audio when deleting files from FileSystem.
- **upd** Change inheritance of Loading popup to AcceptDialog.
- **upd** Now Popochiu Editor popups are added to the dock, not to the
EditorInterface.
- **upd** Deleting a Popochiu Audio Cue now also deletes the audio file
if the checkbox is marked.

Remove popochiu_types_helper script

Now those functions are in PopochiuEditorHelper.

- **upd** Refactor Audio tab to separate the search for deleted audio
cues from the assignation of audio cues to their corresponding groups.
The deletion is a bit cleaner now.
- **fea** In the Popochiu/Audio section of the Project Settings devs can
specify the character that will be used to define the prefixes to
categorize audio files. Additionally, devs can now define different
prefixes for each category separating them by comma.

Progress on making popups work on Linux

Create scenes to put the content of some popups

Now instead of having a scene that inherits from ConfirmationDialog, the content of each dialog has its own scene, and the dialog is created by Popochiu when needed, putting the scene of said popup inside the created node. This improves the behavior of windows when shown.

Refactor for more object creation dialogs

Now characters, inventory items, dialogs, hotspots and markers are
created using the new dialogs.

- **upd** Improve the behavior of the creation dialog when its content
changes.

Refactor creation dialogs to remove repeated code

This makes each script shorter and specific.

Show error message when trying to create an existing object

When the path of the object to create is already in the FileSystem, the
Create Object Confirmation shows an error message and disables the OK
button of the dialog.

Update Loading and Setup dialogs to the new flow

Now the scenes for those popups only define the content of the popup, and it is added to the popup when it is created.

Fix Setup popup dissappearing on first GUI template copy process

Update folder and file names.

Apply suggestions from code review

Co-authored-by: Paolo Pustorino <[email protected]>

Progress in PR review

Simplify the logic of playing/pausing audio rows.

Improve code based on PR review

Rename `show_add_to_core()` to `show_as_not_in_core()`

Remove the option to create the state script since this is no longer a
problem since version 1.9 or 1.10.

Refactor how is_main and is_pc are set.

This apply for popochiu_room_row and popochiu_character_row
correspondingly

- **upd** Remove type looking in popochiu_group by creating a public
function in popochiu_row that calls a virtual function so each row knows
if it should or not do something with clearing its tag icon.

Remove unnecessary editor validation in Audio tab

Fix an issue that was causing the PC not to be set properly when it was
selected in Popochiu's dock.

* Update to match defaults pattern of editor_config.gd

* 9 verbs interface: working GIVE command (#242)

* 9 verbs interface: working GIVE command

* give() and use() calls _give_or_use() to reduce duplidate code

* refs #232: added dialog_pos management with gizmo. (#241)

* refs #232: added dialog_pos management with gizmo.

* refs #232: gizmo buttons visibility refactor (WIP).

* refs #134: WIP: All room objects now contain their own colliders/polygons, which are no more exposed in the room.

* refs #134 #232: Complete refactoring of the toolbar menu buttons. Now they work as visibility toggles, and the polygon selection button is toggleable to switch back and forth from parent to child.

* refs #232: partially addressed PR comments.

* refs #232: added editing_polygon flag to WA.

* refs #134: Added an editor option to always show interaction polygons for Popochiu clickables, regions and WAs.

* refs #134: Changed the previous commit so that only the WAs may be always visible.

* refs #232: Walkable Areas perimeter should now be saved when the scene is saved.

* refs #232: Walkable Areas perimeter are now correctly saved + some polishing in former code.

* refs #232: Saving and baking interaction polygons is now more efficent, since it happens at node saving, not every frame.

* refs #134: Popochiu object polygons are now identified by groups, instead of meta. Also, there is no need for editing_polygon boolean anymore, since the polygons are saved only when the scene is saved from the editor.

* refs #134: New icons for toolbar buttons, SVG format and in line with Godot interface.

* refs #134: Added check to avoid errors when called in scene different from rooms.

* refs #134: Popochiu toolbar gizmos icons are now colored if the user so prefer. Also addressed regression about button visibility and make things more robust.

* refs #134: Popochiu toolbar now sports a label to make clear what you are looking at.

* refs #134: SVG icons optimized as per Godot docs. Removed leftovers.

* refs #134: Icons have been renamed to make it clear they are toolbar buttons.

* Removed excessive indentation

Co-authored-by: Carenalga <[email protected]>

* refs #134: Added type hinting in virtual method.

Co-authored-by: Carenalga <[email protected]>

* refs #134: Added type hinting on another virtual method.

Co-authored-by: Carenalga <[email protected]>

* refs #134: Last type hinting addition.

Co-authored-by: Carenalga <[email protected]>

* refs #134: Icons resource references fixed in toolbar scene.

* refs #134: All polygons are marked as such at runtime, not in the base scenes. This makes things easier to change on future projects (no need for migrations).

* refs #134: Addressed all the last bug reports by @mapedorr.

---------

Co-authored-by: Paolo Pustorino <[email protected]>
Co-authored-by: Paolo Pustorino <[email protected]>
Co-authored-by: Carenalga <[email protected]>

* refs #134: polygon disappears when selecting another object on scene. (#247)

* Migration tool (#246)

* add initial migration framework support

* update files to have less then 100 characters

* in progress work pushed for others to look at

* Migration tool for Popochiu release.

Change spaces to tabs

Progress on formating code

Refactor some code to make it cleaner

Create migration scripts for new migration steps

- Migration 2 is intended to update changes between beta 1 and beta 2 to
beta 3.
- Migration 3 is intended to update changes between beta 3 to 2.0
release.
- **upd** Minor refactor of the PopochiuMigration class.

Finish code for PopochiuMigration1

This allows to update the project structure and file/folder naming from
versions prior to Beta 1.

It also assigns the SimpleClick as the default GUI template.

- **upd** Setup popup resizes each time a template button is clicked.

Add PopochiuCharacter voices update

Progress on making a Popup window to show the migration progress.

Fix scene linking in Props created in alpha 1

Assign script for non clickable props (which didn't have one prior to
beta 1).

- **upd** Migration 1 also updates the radius of WalkableArea's
Perimeter node.

Update prop update task to store interaction polygon's polygon

Refactor code to take into account Hotspots and Regions.

Update props and hotspots in Migration 1

Finish migration of PopochiuRegion and PopochiuWalkableArea objects

Replace calls to old methods in scripts.

Add Migrations popup to show migration progress

Closing the Migrations popup will restart the engine.

Update InventoryItem root nodes to PascalCase

Update visual style of Migrations popup.

Finish Migration 1 with node additions to PopochiuCharacter

Now this migration doesn't stops if the `res://popochiu/` folder doesn't
exists in the project.
- **fea** AnimationPlayer and ScalingPolygon nodes are added to
PopochiuCharacter scenes if needed.
- **upd** Refactor code to make it simplier and clearer.
- **upd** Now MigrationTab shows the steps and the migration progress
using CheckBox buttons instead of BBcode.

Update the way migrations notify their steps completion

Now a migration step can be completed as: FAILED, DONE or IGNORED

- **upd** Ignored migration steps are rendered different in the
Migrations dialog.
- **fix** Check if a PopochiuProp or PopochiuHotspot has an
InteractionPolygon or InteractionPolygon2 node before trying to store
its `polygon` property.

Progress on improving Migration 1 behavior for projects in beta

Can run Migration 1 in projects made in beta-3

A new function was added to **PopochiuUtils** in order to perform an
improved `Array.any()` that doesn't stops early.

- **fix** Don't update `PopochiuClickable.interaction_polygon` value if
the object already has a scene with an **InteractionPolygon** child.

Start coding for Migration 2

Now the process of adding the ScalingPolygon node to PopochiuCharacters
is done by Migration 2.

- **upd** Rename Migrations to MigrationsPanel for better understanding.
- **upd** Add comments to some functions in PopochiuMigrationHelper.
- **upd** Add constants and sample code to
popochiu_migration_template.gd.

Fix on checking if migrations are needed

The version in PopochiuMigrationHelper is no longer needed since we're
gonna take into account the number of files (migrations) in the
migration_files folder.

- **upd** Migration 2 first step working.

Make each migration to ask for an Engine reload

Instead of assuming an Engine reload is required each time a Migration
is executed, each Migration can set to `true` the
`PopochiuMigrationHelper.is_reload_required` property in order to make
the popup restart the Engine when clicking OK.

Progress on fixing and improving Migration 1

Moving values from old popochiu_settings.tres to Project Settings will
need extra steps since the PopochiuSettings script changed since beta-3.

Fix PopochiuSettings issue for Migration 2

Migration 1 now iterates through all possible children of each group to
obtain objects of that type, instead of assuming that each group only
has children of its specific type (e.g., if there are props grouped
within a node).

Migration 2 deletes helper nodes in PopochiuClickables

Update Migration 2 with changes done to SettingsBar

In beta-3 the SettingsBar GUI component changed to improve how the text
speed options are defined.

- **fix** Ignore room objects that already have a scene and a script in
the step that updates the room in Migration 1 so devs don't lose their
changes.

Add step to update DialogMenu component in Migration 2

Add code update step for deprecated properties and methods

Add step to update properties from the old popochiu_settings.tres into
InventoryBar and SettingsBar GUI components.

Fix on deprecated camera functions replacement

Calls to functions in PopochiuMainCamera changed their names compared to
those used before in the **E** autoload.

- **fix** On moving inventory items on start from old
popochiu_settings.tres to Popochiu Project Settings.
- **upd** Inventory items on start are now stored as an array of String
in Project Settings.

Create Markers scenes in Migration 1

Update Migrations process to be started by the user

Instead of triggering the migrations automatically, the Migrations popup
asks devs to start the migrations by pressing the Run migrations button.

- **fix** Updating room objects wasn't working properly due to an issue
in Godot when appending elements to an Array inside a Dictionary.

Fix an issue found when running migration 2 in Alpha projects

- **upd** Execution pauses in popochiu_plugin.gd if Migrations are
required until dev run the migrations.
- **fix** Other issues found when running migrations in alpha projects
after adding Migration 2.

Update Migration 1 and 2 related to PopochiuCharacter

In Migration 1, now the "Sprite2D:texture" track is removed from
AnimationPlayer nodes (something that affected characters imported from
Aseprite prior Beta 1). In Migration 2 the coordinates of the
**DialogPos** node are stored in the `dialog_pos` property before
deleting the node.

- **fix** Enable the Remove button in Room objects context menu in Room
tab.

Fix issue after snake_case renaming

Changing file and folder names in the snake_case renaming process
required to update the references to the new names inside .gd, .tscn,
.tres, and .cfg files.

Restore code that shows the confirmation dialog in Setup popup

- **upd** Rename function to more descriptive name.

Fix PopochiuDialog deletion (after refactor)

Update Migration 2 to take into account the changes made to autoloads
after refactor

Fix setting PC character in Create character popup

Improve visual feedback of migrations progress

- **fix** Closing the Migrations tool popup doesn't stops the execution
in `popochiu_plugin.gd`.

* Remove not needed nodes in PopochiuRegion and PopochiuWalkableArea

This is because in the release version these objects won't need a node
in the room to define their InteractionPolygon and Perimeter nodes.

- **upd** Remove the old DialogPos node in PopochiuCharacter and store
its position in the new `@export var dialog_pos` property.

* Add check for lacking nodes in room objects

Ignore "graphic_interface" folder in code updates for Migration 1.

* Fix for WalkableAreas not working until room save

- **fix** Send `hint_string` parameter when creating settings in
  config.gd.
- **upd** Minor refactor in **PopochiuWalkableArea** to avoid duplicated
  code.

* Apply suggestions from code review

Co-authored-by: Paolo Pustorino <[email protected]>

* Make changes based in PR comments

* Enable gizmos plugin when Popochiu dock is ready

This happens only if the plugin is not already enabled.

- **upd** Add comments to some functions with the help of Copilot.

* Add lacking comments to Migration 2 functions

* Check custom script in Room object

If a room object created during migration has a script attached that is not in
the "addons" folder, assume it is a custom script and copy its
properties to the new instance of the object.

* Add comments for better understanding

Co-authored-by: Paolo Pustorino <[email protected]>

* Fix getting custom vars in walkable area

- **upd** Add a $Sprite2D check in PopochiuProp.
- **upd** Set specific steps in Migration 1 to ask for an engine
  restart.

* Fix polygon assignation when adding nodes to Walkable Area

- **fix** Change code order to first assign custom script properties on
  Migration 1.

* Move room objects update to Migration 2

- **upd** Add validation to ignore Migration 1 in project done since
  beta 1.

---------

Co-authored-by: Anthony Irwin <[email protected]>
Co-authored-by: Paolo Pustorino <[email protected]>

* Add virtual method for character when they stop moving (#253)

* Create virtual function in PopochiuCharacter to know when movement ended

* Add _on_move_ended virtual to character template

* Fix changing PopochiuClickable.clickable in runtime (#254)

Now it has a setter method that changes the `Area2D.input_pickable`
value based on the `clickable` property.

- **fix** Set right path to **PopochiuGroup** icon.

* Fix #239 by auto-enabling WAV looping. (#255)

* Update message when trying to loop read-only WAV

* Change LoopMode in imported WAV files

Popochiu now sets the loop mode for WAV files to FORWARD or DISABLED
based on the type of the PopochiuAudioCue. This will save developers
from having to manually re-import these files to enable looping.

- **fix** Do not connect to the finished signal when playing audio files
  in the Audio tab.

* Added RFC issue template; updated label to reflect changes in the board.

* Update how camera limits are defined for rooms (#257)

* Update camera limits definition for PopochiuRoom

Now these limits are calculated by Popochiu based on the `width` and
`height` of the room.

* Update Migration 2 to update rooms' width and height

Camera limits in rooms are now calculated based on their `width` and
`height` properties, so this new migration step takes into account the
deprecated camera limits properties to define the values of the new
properties in rooms created prior 2.0.

* Update camera limits only when room size exceeds the viewport size

* Update code comments for clarity

* Godot 4.3 fixes (#265)

* Progress on adding resources scan to improve UX in Godot 4.3

* Move function _remove_object to its corresponding region

* refs #267: Mildly unrelated, I added Mermaid and Font-Awesome support to the docs, plus some more useful automation.

* refs #267: New theme and new assets, ready for version 2.0 release.

* refs #267: Added site Favicon, removed unnecessary class from home banner.

* refs 217: added option for change spoken text or dialog option to gibberish (#218)

* added option for change spoken text or dialog option to gibberish

* updated some code and added documentation

* typos

* images location fix

* Fix issues in config.gd

---------

Co-authored-by: carenalga <[email protected]>

* refs #40: Documentation section for the GUIs. (#261)

* refs #40: WIP on the documentation section for the GUIs.
* WIP fixed a mistyped warning block.
* refs #40: Small rephrasing.
* refs #40: "Getting Started" section on GUIs is complete and should introduce new users to the main concepts.

* GUI templates structure and appearance update (#271)

Progress in standarizing GUI templates

Set base_gui_theme.tres as default theme for all GUIs

- **upd** Update structure of some components to have a Control node as
  root (this is a way to standarize all the GUI components).
- Replace all the uses of 9_verb_theme and sierra_theme by
  base_gui_theme.

Make all Popochiu popups have a Control as root

Update base_gui_theme Buttons' style

Now the buttons have a simpler style.

- **upd** Create DialogLine script to wrap the DialogText nodes that
  will allow render dialog lines with different styles.

Progress on creating Popochiu GUI components for each dialog style

Separate logic for the different DialogText styles

Now each dialog style has its own scene and script so the specific logic
of each component relies in its own script.

Fix issues after testing GUI template selection

Fix issues in Simple Click GUI template

Now it is possible to make the inventory bar and the settings bar to
show when moving the mouse on top of the viewport.

- **fix** Fix wrong position calculation for DialogMenu component.

Standarize popups

Now all popups have the same structure and use a .tres file to define
the style of their PanelContainer node (the one that containts the
content of the popup).

Fix wrong calculations in DialogText component

Now the Overhead dialog works as expected.

- **fix** Fix closing PopochiuPopups by clicking the Overlay node.

Fix issues in Sierra GUI

The inventory wasn't working, and the DialogPortrait component was
having an unexpected behavior.

Add avatar background panels to DialogPortrait

refs #264: Some changes to the base GUI theme, with the news consistent style. Also added new "Minecraftia Regular" font.

refs #264: Components cleanup: redundant theme assignement removed, aesthetic matching everywhere, some small structural change to inventory grid.

refs #264: Aesthetic changes to 9Verbs template (missing popups).

refs #264: SimpleClick template redundant theme assignment cleanup.

refs #264: Sierra template cleanup from redundant themeing, plus aesthetic changes to the main elements. Some WIP on the popups.

refs #264: Inventory up and down buttons are referred to by unique names in script.

refs #264: All popup buttons are now coherent (OK, Back, Cancel), plus the quit popup is translucent.

refs #264: All overlays are now transparent (StyleBoxEmpty) to support translucent popups.

refs #264: NEEDS REVIEW by @carenalga! - Overlays are now always open in "exclusive mode", so when one is visible the other ones in the stack are hidden.

refs #264: New Sierra menu icons and cursors.

refs #264: Update GUI scripts creation and folder renaming (#270)

* refs #264: Update scripts created for game GUI.

Now the original script attached to a component is copied to the game
folder, and a *_custom.gd is created so that devs can easily modify the
default behavior.

- **upd** Now the `graphic_interface` folder inside the plugin's folder is
  named `gui`.

* refs #264: Fix path issues in some GUI components.

- **fix** Fix type infer bug in Dialog Overhead component.

* Fix GUI theme Panel overwrite issue in Dialog Menu component

refs #264: Fix issues in Sierra and Simple Click GUIs

- **fix** Change mouse_filter in Dialog Portrait component to "IGNORE".
- **fix** Remove unnecessary uses of preload in some GUI components.
- **upd** Improve inheritance of btn_dialog_speed in Simple Click GUI.

refs #264: Deselect active inventory item with RMB in Sierra GUI

- **upd** Add I.deselect_active() and PopochiuInventoryItem.deselect()
  methods to make deselection easier.
- **fix** Update Sierra Inventory popup buttons' atlas texture sizes and positions in order to match the new 24x24 icons.

refs #264: Move Settings button to bottom panel in 9 Verb GUI

Now the button to open the Settings popup in the 9 Verb GUI is located
between the UP and DOWN arrows in its bottom panel.

- **upd** Create custom script for 9 Verb Inventory Grid.

refs #264: 9 Verbs GUI icons are done.

Fix click blocking when using DialogPortrait.

- **upd** Rename the idle animation in Popochiu's default cursor to
match the correct name ("normal").
- **upd** Reduce the custom minimum size of the Popochiud dock since all
those pixels are no longer needed.

refs #264: Padding for Sierra dialog panel.

refs #264: New inventory arrow icons for Sierra GUI.

refs #264: New toolbar icons for SimpleClick GUI.

refs #264: Fixed fonts and outlines for SimpleClick GUI.

refs #264: Add option to hide HoverText when a dialog line is shown

This can be configured by devs with the export variable in the HoverText
component.

- **upd** Hide the GUI tab in Popochiu dock while we define how it
should work.
- **upd** Hide "Use translations" and "Dialog style" options in `Project
Settings > Popochiu > Dialogs`.

refs #264: New icons for dialogue controls.

refs #264: SimpleClick GUI now opens text settings popup. Removed useless setting from the same popup.

refs #264: SimpleClick GUI now shows a confirmation popup before quitting the game.

refs #264: Fixed a visual glitch on Sierra toolbar buttons.

refs #264: Useless SimpleClick icons cleanup.

refs #264: SimpleClick GUI icons are now colored.

refs #264: Fix history button in Simple Click GUI

refs #264: Hide Custom button in Setup popup

We agreed to release Popochiu 2.0 with only 3 GUI options since enabling
the Empty (a.k.a. Custom) GUI will require more documentation to be done
so devs have a guide on how to create their GUIs from zero.

refs #264: SimpleClick GUI icons are now colored - Missing icons.

Fix double-click double-tap issue in DialogText component

refs #264: Update base retro resolution to 356x200

* refs #264: Make ALL GUIs open their popups the same way. (#272)

Instead of relying on IGraphicInterface methods and signals, each GUI
handles local signals to decide which popup to open. This change
affected the Simple Click and the 9 Verb GUIs.

- **upd** Remove unused images in the Sierra GUI.
- **upd** Update button style for CheckBox Buttons in
  base_gui_theme.tres.

* refs #273: Fix Room tab not working as expected (#274)

If there are no opened scenes in the Editor, now the PopochiuDock
listens to a node selection (EditorSelection.selection_changed) in order
to ensure that the Room tab continues to function as expected.

* Various fixes related (mostly) to visual issues (#275)

- **fix** Make 9VerbHoverText component render its text properly without
cutting the first letter of the string.
- **fix** Take into account the size of the continue icon in the
DialogOverhead component so it is not rendered out of screen when it
exceeds the size of the viewport.
- **fix** Add null validation in Room tab when importing Aseprite rooms.
- **fix** Remove the Key string from the `items_on_start` property in
project.godot.
- **fix** Update path of TextSpeedOption script in Migration 2 script.

* Update TransitionLayer background to match the new 356x200 resolution (#278)

* Update transition layer background image.

Now it has the size of the default resolution (356x200), and its
animations were updated to fix positioning. Also, the scene scales by
default instead of depending on the `PopochiuSettings.scale_gui` property.

* Update position of sprite for Fade in and Fade out transitions

* Fix characters not updating their walk_to_point property (#280)

Now the property is stored as part of the room data so it is not lost
when the room is loaded.

- **upd** Move characters position and scale calculation
  operations from PopochiuRoom to PopochiuCharacter.
- **fix** Add validations to remove Output error messages when
  inspecting nodes in Remote.

* Added a Task issue type for maintainers.

* refs #276: "Getting started" index updated and fixed broken links. (#283)

* Remove GUI related steps from migrations

* Add release notes for 2.0.0

* refs #282: final release notes + changed author of Popochiu to mentions a dev team.

* Add section about removing the old GUI folder

* refs #282: Added notes about the GUI folder.

* refs #267: New readme files and project branding (#281)

* Updated project and default icon to the new branding.

* Updated README files for branding and content.

* Updated README files in both languages, with new branding and an updatet text.

* Minor adjustments

* refs #267: Cover image has a better sizing.

* refs #267: readability improvement.

---------

Co-authored-by: carenalga <[email protected]>

---------

Co-authored-by: Carenalga <[email protected]>
Co-authored-by: Anthony Irwin <[email protected]>
Co-authored-by: drbb <[email protected]>
Co-authored-by: Artur Maciąg <[email protected]>
Co-authored-by: Filip Motyczka <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants