1
0
Fork 0
mirror of https://github.com/Orama-Interactive/Pixelorama.git synced 2025-02-12 08:43:08 +00:00

Compare commits

..

No commits in common. "9a842ad33e2b0a4519ccff50e8fee93ff870a459" and "ffd729486f7e99690eb81ea8f592a7cec7cd17cd" have entirely different histories.

11 changed files with 85 additions and 156 deletions

View file

@ -289,13 +289,7 @@ msgstr ""
msgid "Add Layout" msgid "Add Layout"
msgstr "" msgstr ""
msgid "Copy from" msgid "Edit Layout"
msgstr ""
msgid "Rename"
msgstr ""
msgid "Rename Layout"
msgstr "" msgstr ""
msgid "Are you sure you want to delete this layout?" msgid "Are you sure you want to delete this layout?"

View file

@ -24,7 +24,7 @@ Files extracted from source:
## godot-dockable-container ## godot-dockable-container
- Upstream: https://github.com/gilzoide/godot-dockable-container - Upstream: https://github.com/gilzoide/godot-dockable-container
- Version: Based on [274ea7264440003071bcd024f31e130c984df3c6](https://github.com/gilzoide/godot-dockable-container/pull/27/commits/274ea7264440003071bcd024f31e130c984df3c6) (PR #27), but with changes in layout.gd that add a `save_on_change` variable and a `save()` method. - Version: [274ea7264440003071bcd024f31e130c984df3c6](https://github.com/gilzoide/godot-dockable-container/pull/27/commits/274ea7264440003071bcd024f31e130c984df3c6) (PR #27)
- License: [CC0-1.0](https://github.com/gilzoide/godot-dockable-container/blob/main/LICENSE) - License: [CC0-1.0](https://github.com/gilzoide/godot-dockable-container/blob/main/LICENSE)
## SmartSlicer ## SmartSlicer

View file

@ -23,15 +23,6 @@ enum { MARGIN_LEFT, MARGIN_RIGHT, MARGIN_TOP, MARGIN_BOTTOM, MARGIN_CENTER }
if value != _hidden_tabs: if value != _hidden_tabs:
_hidden_tabs = value _hidden_tabs = value
changed.emit() changed.emit()
@export var save_on_change := false:
set(value):
save_on_change = value
if value:
if not changed.is_connected(save):
changed.connect(save)
else:
if changed.is_connected(save):
changed.disconnect(save)
var _changed_signal_queued := false var _changed_signal_queued := false
var _first_leaf: DockableLayoutPanel var _first_leaf: DockableLayoutPanel
@ -70,12 +61,6 @@ func get_names() -> PackedStringArray:
return _root.get_names() return _root.get_names()
func save(path := resource_path) -> void:
if path.is_empty():
return
ResourceSaver.save(self, path)
## Add missing nodes on first leaf and remove nodes outside indices from leaves. ## Add missing nodes on first leaf and remove nodes outside indices from leaves.
## ##
## _leaf_by_node_name = { ## _leaf_by_node_name = {

View file

@ -165,7 +165,7 @@ first = SubResource("Resource_atmme")
second = SubResource("Resource_2qk0j") second = SubResource("Resource_2qk0j")
[resource] [resource]
resource_name = "Default" resource_name = "Layout"
script = ExtResource("3_bjjec") script = ExtResource("3_bjjec")
root = SubResource("Resource_msuil") root = SubResource("Resource_msuil")
hidden_tabs = { hidden_tabs = {
@ -176,4 +176,3 @@ hidden_tabs = {
"Reference Images": true, "Reference Images": true,
"Second Canvas": true "Second Canvas": true
} }
save_on_change = false

View file

@ -137,7 +137,7 @@ first = SubResource("Resource_otntk")
second = SubResource("Resource_1xpva") second = SubResource("Resource_1xpva")
[resource] [resource]
resource_name = "Tallscreen" resource_name = "Layout"
script = ExtResource("3_ox7l5") script = ExtResource("3_ox7l5")
root = SubResource("Resource_6dytr") root = SubResource("Resource_6dytr")
hidden_tabs = { hidden_tabs = {
@ -145,4 +145,3 @@ hidden_tabs = {
"Recorder": true, "Recorder": true,
"Second Canvas": true "Second Canvas": true
} }
save_on_change = false

View file

@ -79,8 +79,6 @@ const OVERRIDE_FILE := "override.cfg"
const HOME_SUBDIR_NAME := "pixelorama" const HOME_SUBDIR_NAME := "pixelorama"
## The name of folder that contains subdirectories for users to place brushes, palettes, patterns. ## The name of folder that contains subdirectories for users to place brushes, palettes, patterns.
const CONFIG_SUBDIR_NAME := "pixelorama_data" const CONFIG_SUBDIR_NAME := "pixelorama_data"
## The path of the directory where the UI layouts are being stored.
const LAYOUT_DIR := "user://layouts"
const VALUE_SLIDER_V2_TSCN := preload("res://src/UI/Nodes/ValueSliderV2.tscn") const VALUE_SLIDER_V2_TSCN := preload("res://src/UI/Nodes/ValueSliderV2.tscn")
const GRADIENT_EDIT_TSCN := preload("res://src/UI/Nodes/GradientEdit.tscn") const GRADIENT_EDIT_TSCN := preload("res://src/UI/Nodes/GradientEdit.tscn")
@ -111,11 +109,6 @@ var current_project_index := 0:
project_switched.emit() project_switched.emit()
project_switched.disconnect(current_project.change_project) project_switched.disconnect(current_project.change_project)
cel_switched.emit() cel_switched.emit()
var default_layouts: Array[DockableLayout] = [
preload("res://assets/layouts/Default.tres"),
preload("res://assets/layouts/Tallscreen.tres"),
]
var layouts: Array[DockableLayout] = []
# Canvas related stuff # Canvas related stuff
## Tells if the user allowed to draw on the canvas. Usually it is temporarily set to ## Tells if the user allowed to draw on the canvas. Usually it is temporarily set to

View file

@ -17,7 +17,6 @@ var cursor_image := preload("res://assets/graphics/cursor.png")
func _init() -> void: func _init() -> void:
Global.shrink = _get_auto_display_scale() Global.shrink = _get_auto_display_scale()
_handle_layout_files()
func _ready() -> void: func _ready() -> void:
@ -97,24 +96,6 @@ func _get_auto_display_scale() -> float:
return 1.0 return 1.0
func _handle_layout_files() -> void:
if not DirAccess.dir_exists_absolute(Global.LAYOUT_DIR):
DirAccess.make_dir_absolute(Global.LAYOUT_DIR)
var dir := DirAccess.open(Global.LAYOUT_DIR)
var files := dir.get_files()
if files.size() == 0:
for layout in Global.default_layouts:
var file_name := layout.resource_path.get_basename().get_file() + ".tres"
ResourceSaver.save(layout, Global.LAYOUT_DIR.path_join(file_name))
files = dir.get_files()
for file in files:
var layout := ResourceLoader.load(Global.LAYOUT_DIR.path_join(file))
if layout is DockableLayout:
Global.layouts.append(layout)
# Save the layout every time it changes
layout.save_on_change = true
func _setup_application_window_size() -> void: func _setup_application_window_size() -> void:
var root := get_tree().root var root := get_tree().root
root.content_scale_aspect = Window.CONTENT_SCALE_ASPECT_IGNORE root.content_scale_aspect = Window.CONTENT_SCALE_ASPECT_IGNORE
@ -421,7 +402,7 @@ func _on_backup_confirmation_visibility_changed() -> void:
func _exit_tree() -> void: func _exit_tree() -> void:
Global.config_cache.set_value("window", "layout", Global.layouts.find(main_ui.layout)) Global.config_cache.set_value("window", "layout", Global.top_menu_container.selected_layout)
Global.config_cache.set_value("window", "screen", get_window().current_screen) Global.config_cache.set_value("window", "screen", get_window().current_screen)
Global.config_cache.set_value( Global.config_cache.set_value(
"window", "window",

View file

@ -3,25 +3,18 @@ extends AcceptDialog
var layout_selected := -1 var layout_selected := -1
var is_editing := false var is_editing := false
@onready var layout_list := %SavedLayouts as ItemList @onready var layout_list: ItemList = find_child("SavedLayouts")
@onready var rename_layout := %RenameLayout as Button @onready var edit_layout: Button = find_child("EditLayout")
@onready var delete_layout := %DeleteLayout as Button @onready var delete_layout: Button = find_child("DeleteLayout")
@onready var layout_settings := $LayoutSettings as ConfirmationDialog @onready var layout_settings: ConfirmationDialog = $LayoutSettings
@onready var layout_name := %LayoutName as LineEdit @onready var layout_name: LineEdit = $LayoutSettings/LayoutName
@onready var layout_from := %LayoutFrom as OptionButton @onready var delete_confirmation: ConfirmationDialog = $DeleteConfirmation
@onready var delete_confirmation := $DeleteConfirmation as ConfirmationDialog @onready var mimic_ui = find_child("LayoutPreview")
@onready var mimic_ui := %LayoutPreview as DockableContainer
func _ready() -> void:
# Fill the copy layout from option button with the default layouts
for layout in Global.default_layouts:
layout_from.add_item(layout.resource_path.get_basename().get_file())
func _on_ManageLayouts_about_to_show() -> void: func _on_ManageLayouts_about_to_show() -> void:
for layout in Global.layouts: for layout in Global.top_menu_container.layouts:
layout_list.add_item(layout.resource_path.get_basename().get_file()) layout_list.add_item(layout[0])
refresh_preview() refresh_preview()
if layout_selected != -1: if layout_selected != -1:
layout_list.select(layout_selected) layout_list.select(layout_selected)
@ -40,13 +33,13 @@ func _on_SavedLayouts_item_activated(index: int) -> void:
func _on_SavedLayouts_item_selected(index: int) -> void: func _on_SavedLayouts_item_selected(index: int) -> void:
layout_selected = index layout_selected = index
rename_layout.disabled = false edit_layout.disabled = index < Global.top_menu_container.default_layout_size
delete_layout.disabled = false delete_layout.disabled = index < Global.top_menu_container.default_layout_size
refresh_preview() refresh_preview()
func _on_SavedLayouts_empty_clicked(_position: Vector2, _button_index: int) -> void: func _on_SavedLayouts_empty_clicked(_position: Vector2, _button_index: int) -> void:
rename_layout.disabled = true edit_layout.disabled = true
delete_layout.disabled = true delete_layout.disabled = true
@ -54,15 +47,13 @@ func _on_AddLayout_pressed() -> void:
is_editing = false is_editing = false
layout_name.text = "New Layout" layout_name.text = "New Layout"
layout_settings.title = "Add Layout" layout_settings.title = "Add Layout"
layout_from.get_parent().visible = true
layout_settings.popup_centered() layout_settings.popup_centered()
func _on_rename_layout_pressed() -> void: func _on_EditLayout_pressed() -> void:
is_editing = true is_editing = true
layout_name.text = layout_list.get_item_text(layout_selected) layout_name.text = layout_list.get_item_text(layout_selected)
layout_settings.title = "Rename Layout" layout_settings.title = "Edit Layout"
layout_from.get_parent().visible = false
layout_settings.popup_centered() layout_settings.popup_centered()
@ -72,62 +63,52 @@ func _on_DeleteLayout_pressed() -> void:
func _on_LayoutSettings_confirmed() -> void: func _on_LayoutSettings_confirmed() -> void:
var file_name := layout_name.text + ".tres" var file_name := layout_name.text + ".tres"
var path := Global.LAYOUT_DIR.path_join(file_name) var path := "user://layouts/".path_join(file_name)
var layout: DockableLayout var layout: DockableLayout = Global.control.main_ui.layout
if layout_from.selected == 0:
layout = Global.control.main_ui.layout.clone()
else:
layout = Global.default_layouts[layout_from.selected - 1].clone()
layout.resource_name = layout_name.text
layout.resource_path = path
var err := ResourceSaver.save(layout, path) var err := ResourceSaver.save(layout, path)
if err != OK: if err != OK:
print(err) print(err)
return
if is_editing:
var old_file_name: String = layout_list.get_item_text(layout_selected) + ".tres"
if old_file_name != file_name:
delete_layout_file(old_file_name)
Global.layouts[layout_selected] = layout
layout_list.set_item_text(layout_selected, layout_name.text)
else: else:
Global.layouts.append(layout) if is_editing:
# Save the layout every time it changes var old_file_name: String = layout_list.get_item_text(layout_selected) + ".tres"
layout.save_on_change = true if old_file_name != file_name:
Global.control.main_ui.layout = layout delete_layout_file(old_file_name)
layout_list.add_item(layout_name.text) Global.top_menu_container.layouts[layout_selected][0] = layout_name.text
Global.layouts.sort_custom( Global.top_menu_container.layouts[layout_selected][1] = layout
func(a: DockableLayout, b: DockableLayout): return ( layout_list.set_item_text(layout_selected, layout_name.text)
a.resource_path.get_file() < b.resource_path.get_file() Global.top_menu_container.layouts_submenu.set_item_text(
) layout_selected + 1, layout_name.text
) )
var layout_index := Global.layouts.find(layout) else:
Global.top_menu_container.populate_layouts_submenu() Global.top_menu_container.layouts.append([layout_name.text, layout])
Global.top_menu_container.layouts_submenu.set_item_checked(layout_index + 1, true) layout_list.add_item(layout_name.text)
Global.top_menu_container.populate_layouts_submenu()
var n: int = Global.top_menu_container.layouts_submenu.get_item_count()
Global.top_menu_container.layouts_submenu.set_item_checked(n - 1, true)
func delete_layout_file(file_name: String) -> void: func delete_layout_file(file_name: String) -> void:
var dir := DirAccess.open(Global.LAYOUT_DIR) var dir := DirAccess.open("user://layouts/")
if not is_instance_valid(dir): if not is_instance_valid(dir):
return return
dir.remove(Global.LAYOUT_DIR.path_join(file_name)) dir.remove("user://layouts/".path_join(file_name))
func _on_DeleteConfirmation_confirmed() -> void: func _on_DeleteConfirmation_confirmed() -> void:
delete_layout_file(layout_list.get_item_text(layout_selected) + ".tres") delete_layout_file(layout_list.get_item_text(layout_selected) + ".tres")
Global.layouts.remove_at(layout_selected) Global.top_menu_container.layouts.remove_at(layout_selected)
layout_list.remove_item(layout_selected) layout_list.remove_item(layout_selected)
Global.top_menu_container.populate_layouts_submenu() Global.top_menu_container.populate_layouts_submenu()
layout_selected = -1 layout_selected = -1
rename_layout.disabled = true edit_layout.disabled = true
delete_layout.disabled = true delete_layout.disabled = true
refresh_preview() refresh_preview()
func refresh_preview() -> void: func refresh_preview():
for tab in mimic_ui.get_tabs(): for tab in mimic_ui.get_tabs():
mimic_ui.remove_child(tab) mimic_ui.remove_child(tab)
for item in Global.control.main_ui.get_tabs(): for item in Global.top_menu_container.main_ui.get_tabs():
var box := TextEdit.new() var box := TextEdit.new()
box.name = item.name box.name = item.name
box.text = item.name box.text = item.name
@ -137,4 +118,4 @@ func refresh_preview() -> void:
mimic_ui.visible = false mimic_ui.visible = false
return return
mimic_ui.visible = true mimic_ui.visible = true
mimic_ui.set_layout(Global.layouts[layout_selected].clone()) mimic_ui.set_layout(Global.top_menu_container.layouts[layout_selected][1].clone())

View file

@ -16,11 +16,9 @@ resource_name = "Layout"
script = ExtResource("3") script = ExtResource("3")
root = SubResource("1") root = SubResource("1")
hidden_tabs = {} hidden_tabs = {}
save_on_change = false
[node name="ManageLayouts" type="AcceptDialog"] [node name="ManageLayouts" type="AcceptDialog"]
title = "Manage Layouts" title = "Manage Layouts"
size = Vector2i(500, 500)
exclusive = false exclusive = false
popup_window = true popup_window = true
script = ExtResource("1") script = ExtResource("1")
@ -32,7 +30,7 @@ anchor_bottom = 1.0
offset_left = 8.0 offset_left = 8.0
offset_top = 8.0 offset_top = 8.0
offset_right = -8.0 offset_right = -8.0
offset_bottom = -49.0 offset_bottom = -36.0
[node name="PreviewHeader" type="HBoxContainer" parent="VBoxContainer"] [node name="PreviewHeader" type="HBoxContainer" parent="VBoxContainer"]
layout_mode = 2 layout_mode = 2
@ -56,7 +54,6 @@ layout_mode = 2
size_flags_vertical = 3 size_flags_vertical = 3
[node name="LayoutPreview" type="Container" parent="VBoxContainer/PreviewContainer"] [node name="LayoutPreview" type="Container" parent="VBoxContainer/PreviewContainer"]
unique_name_in_owner = true
layout_mode = 2 layout_mode = 2
size_flags_horizontal = 3 size_flags_horizontal = 3
size_flags_vertical = 3 size_flags_vertical = 3
@ -82,7 +79,6 @@ layout_mode = 2
text = "Double click to set as new startup layout" text = "Double click to set as new startup layout"
[node name="SavedLayouts" type="ItemList" parent="VBoxContainer"] [node name="SavedLayouts" type="ItemList" parent="VBoxContainer"]
unique_name_in_owner = true
custom_minimum_size = Vector2(0, 100) custom_minimum_size = Vector2(0, 100)
layout_mode = 2 layout_mode = 2
@ -91,53 +87,38 @@ layout_mode = 2
[node name="AddLayout" type="Button" parent="VBoxContainer/ButtonsContainer"] [node name="AddLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
layout_mode = 2 layout_mode = 2
size_flags_horizontal = 3 size_flags_horizontal = 0
mouse_default_cursor_shape = 2 mouse_default_cursor_shape = 2
text = "Add" text = "Add"
[node name="RenameLayout" type="Button" parent="VBoxContainer/ButtonsContainer"] [node name="EditLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
unique_name_in_owner = true
layout_mode = 2 layout_mode = 2
size_flags_horizontal = 3 size_flags_horizontal = 0
mouse_default_cursor_shape = 2 mouse_default_cursor_shape = 2
disabled = true disabled = true
text = "Rename" text = "Edit"
[node name="DeleteLayout" type="Button" parent="VBoxContainer/ButtonsContainer"] [node name="DeleteLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
unique_name_in_owner = true
layout_mode = 2 layout_mode = 2
size_flags_horizontal = 3 size_flags_horizontal = 0
mouse_default_cursor_shape = 2 mouse_default_cursor_shape = 2
disabled = true disabled = true
text = "Delete" text = "Delete"
[node name="LayoutSettings" type="ConfirmationDialog" parent="."] [node name="LayoutSettings" type="ConfirmationDialog" parent="."]
[node name="VBoxContainer" type="VBoxContainer" parent="LayoutSettings"] [node name="LayoutName" type="LineEdit" parent="LayoutSettings"]
offset_right = 40.0 anchors_preset = 14
offset_bottom = 40.0 anchor_top = 0.5
anchor_right = 1.0
[node name="LayoutName" type="LineEdit" parent="LayoutSettings/VBoxContainer"] anchor_bottom = 0.5
unique_name_in_owner = true offset_left = 8.0
layout_mode = 2 offset_top = -26.0
offset_right = -8.0
offset_bottom = -2.0
size_flags_horizontal = 3 size_flags_horizontal = 3
placeholder_text = "Insert name" placeholder_text = "Insert name"
[node name="HBoxContainer" type="HBoxContainer" parent="LayoutSettings/VBoxContainer"]
layout_mode = 2
[node name="LayoutFromLabel" type="Label" parent="LayoutSettings/VBoxContainer/HBoxContainer"]
layout_mode = 2
text = "Copy from"
[node name="LayoutFrom" type="OptionButton" parent="LayoutSettings/VBoxContainer/HBoxContainer"]
unique_name_in_owner = true
layout_mode = 2
item_count = 1
selected = 0
popup/item_0/text = "Current layout"
popup/item_0/id = 0
[node name="DeleteConfirmation" type="ConfirmationDialog" parent="."] [node name="DeleteConfirmation" type="ConfirmationDialog" parent="."]
dialog_text = "Are you sure you want to delete this layout?" dialog_text = "Are you sure you want to delete this layout?"
@ -147,7 +128,7 @@ dialog_text = "Are you sure you want to delete this layout?"
[connection signal="item_activated" from="VBoxContainer/SavedLayouts" to="." method="_on_SavedLayouts_item_activated"] [connection signal="item_activated" from="VBoxContainer/SavedLayouts" to="." method="_on_SavedLayouts_item_activated"]
[connection signal="item_selected" from="VBoxContainer/SavedLayouts" to="." method="_on_SavedLayouts_item_selected"] [connection signal="item_selected" from="VBoxContainer/SavedLayouts" to="." method="_on_SavedLayouts_item_selected"]
[connection signal="pressed" from="VBoxContainer/ButtonsContainer/AddLayout" to="." method="_on_AddLayout_pressed"] [connection signal="pressed" from="VBoxContainer/ButtonsContainer/AddLayout" to="." method="_on_AddLayout_pressed"]
[connection signal="pressed" from="VBoxContainer/ButtonsContainer/RenameLayout" to="." method="_on_rename_layout_pressed"] [connection signal="pressed" from="VBoxContainer/ButtonsContainer/EditLayout" to="." method="_on_EditLayout_pressed"]
[connection signal="pressed" from="VBoxContainer/ButtonsContainer/DeleteLayout" to="." method="_on_DeleteLayout_pressed"] [connection signal="pressed" from="VBoxContainer/ButtonsContainer/DeleteLayout" to="." method="_on_DeleteLayout_pressed"]
[connection signal="confirmed" from="LayoutSettings" to="." method="_on_LayoutSettings_confirmed"] [connection signal="confirmed" from="LayoutSettings" to="." method="_on_LayoutSettings_confirmed"]
[connection signal="confirmed" from="DeleteConfirmation" to="." method="_on_DeleteConfirmation_confirmed"] [connection signal="confirmed" from="DeleteConfirmation" to="." method="_on_DeleteConfirmation_confirmed"]

View file

@ -10,6 +10,11 @@ const PIXELORAMA_ICON := preload("res://assets/graphics/icons/icon_16x16.png")
const HEART_ICON := preload("res://assets/graphics/misc/heart.svg") const HEART_ICON := preload("res://assets/graphics/misc/heart.svg")
var recent_projects := [] var recent_projects := []
var layouts: Array[DockableLayout] = [
preload("res://assets/layouts/Default.tres"),
preload("res://assets/layouts/Tallscreen.tres"),
]
var default_layout_size := layouts.size()
var selected_layout := 0 var selected_layout := 0
var zen_mode := false var zen_mode := false
@ -34,6 +39,8 @@ var zen_mode := false
func _ready() -> void: func _ready() -> void:
var dir := DirAccess.open("user://")
dir.make_dir("user://layouts")
_setup_file_menu() _setup_file_menu()
_setup_edit_menu() _setup_edit_menu()
_setup_view_menu() _setup_view_menu()
@ -241,6 +248,19 @@ func _setup_panels_submenu(item: String) -> void:
func _setup_layouts_submenu(item: String) -> void: func _setup_layouts_submenu(item: String) -> void:
var path := "user://layouts"
var dir := DirAccess.open(path)
if DirAccess.get_open_error() == OK:
dir.list_dir_begin()
var file_name = dir.get_next()
while file_name != "":
if !dir.current_is_dir():
var layout := ResourceLoader.load(path.path_join(file_name))
if layout is DockableLayout:
layouts.append(layout)
file_name = dir.get_next()
dir.list_dir_end()
layouts_submenu.set_name("layouts_submenu") layouts_submenu.set_name("layouts_submenu")
layouts_submenu.hide_on_checkable_item_selection = false layouts_submenu.hide_on_checkable_item_selection = false
populate_layouts_submenu() populate_layouts_submenu()
@ -249,14 +269,14 @@ func _setup_layouts_submenu(item: String) -> void:
window_menu.add_child(layouts_submenu) window_menu.add_child(layouts_submenu)
window_menu.add_submenu_item(item, layouts_submenu.get_name()) window_menu.add_submenu_item(item, layouts_submenu.get_name())
var saved_layout: int = Global.config_cache.get_value("window", "layout", 0) var saved_layout = Global.config_cache.get_value("window", "layout", 0)
set_layout(saved_layout) set_layout(saved_layout)
func populate_layouts_submenu() -> void: func populate_layouts_submenu() -> void:
layouts_submenu.clear() # Does not do anything if it's called for the first time layouts_submenu.clear() # Does not do anything if it's called for the first time
layouts_submenu.add_item("Manage Layouts", 0) layouts_submenu.add_item("Manage Layouts", 0)
for layout in Global.layouts: for layout in layouts:
var layout_name := layout.resource_path.get_basename().get_file() var layout_name := layout.resource_path.get_basename().get_file()
layouts_submenu.add_radio_check_item(layout_name) layouts_submenu.add_radio_check_item(layout_name)
@ -550,13 +570,11 @@ func _layouts_submenu_id_pressed(id: int) -> void:
func set_layout(id: int) -> void: func set_layout(id: int) -> void:
if Global.layouts.size() == 0: if id >= layouts.size():
return
if id >= Global.layouts.size():
id = 0 id = 0
selected_layout = id selected_layout = id
main_ui.layout = Global.layouts[id] main_ui.layout = layouts[id].clone() # Clone is needed to avoid modifying premade layouts
for i in Global.layouts.size(): for i in layouts.size():
var offset := i + 1 var offset := i + 1
layouts_submenu.set_item_checked(offset, offset == (id + 1)) layouts_submenu.set_item_checked(offset, offset == (id + 1))

View file

@ -204,7 +204,6 @@ hidden_tabs = {
"Recorder": true, "Recorder": true,
"Second Canvas": true "Second Canvas": true
} }
save_on_change = false
[sub_resource type="ShaderMaterial" id="2"] [sub_resource type="ShaderMaterial" id="2"]
shader = ExtResource("9") shader = ExtResource("9")
@ -254,7 +253,6 @@ script = ExtResource("35")
tabs_visible = false tabs_visible = false
tabs_visible_if_more_than_one = true tabs_visible_if_more_than_one = true
layout = SubResource("Resource_b6o2t") layout = SubResource("Resource_b6o2t")
clone_layout_on_ready = false
[node name="Tools" parent="DockableContainer" instance=ExtResource("1")] [node name="Tools" parent="DockableContainer" instance=ExtResource("1")]
layout_mode = 2 layout_mode = 2