1
0
Fork 0
mirror of https://github.com/Orama-Interactive/Pixelorama.git synced 2025-02-07 10:59:49 +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"
msgstr ""
msgid "Copy from"
msgstr ""
msgid "Rename"
msgstr ""
msgid "Rename Layout"
msgid "Edit Layout"
msgstr ""
msgid "Are you sure you want to delete this layout?"

View file

@ -24,7 +24,7 @@ Files extracted from source:
## 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)
## SmartSlicer

View file

@ -23,15 +23,6 @@ enum { MARGIN_LEFT, MARGIN_RIGHT, MARGIN_TOP, MARGIN_BOTTOM, MARGIN_CENTER }
if value != _hidden_tabs:
_hidden_tabs = value
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 _first_leaf: DockableLayoutPanel
@ -70,12 +61,6 @@ func get_names() -> PackedStringArray:
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.
##
## _leaf_by_node_name = {

View file

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

View file

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

View file

@ -79,8 +79,6 @@ const OVERRIDE_FILE := "override.cfg"
const HOME_SUBDIR_NAME := "pixelorama"
## The name of folder that contains subdirectories for users to place brushes, palettes, patterns.
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 GRADIENT_EDIT_TSCN := preload("res://src/UI/Nodes/GradientEdit.tscn")
@ -111,11 +109,6 @@ var current_project_index := 0:
project_switched.emit()
project_switched.disconnect(current_project.change_project)
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
## 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:
Global.shrink = _get_auto_display_scale()
_handle_layout_files()
func _ready() -> void:
@ -97,24 +96,6 @@ func _get_auto_display_scale() -> float:
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:
var root := get_tree().root
root.content_scale_aspect = Window.CONTENT_SCALE_ASPECT_IGNORE
@ -421,7 +402,7 @@ func _on_backup_confirmation_visibility_changed() -> 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",

View file

@ -3,25 +3,18 @@ extends AcceptDialog
var layout_selected := -1
var is_editing := false
@onready var layout_list := %SavedLayouts as ItemList
@onready var rename_layout := %RenameLayout as Button
@onready var delete_layout := %DeleteLayout as Button
@onready var layout_settings := $LayoutSettings as ConfirmationDialog
@onready var layout_name := %LayoutName as LineEdit
@onready var layout_from := %LayoutFrom as OptionButton
@onready var delete_confirmation := $DeleteConfirmation as ConfirmationDialog
@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())
@onready var layout_list: ItemList = find_child("SavedLayouts")
@onready var edit_layout: Button = find_child("EditLayout")
@onready var delete_layout: Button = find_child("DeleteLayout")
@onready var layout_settings: ConfirmationDialog = $LayoutSettings
@onready var layout_name: LineEdit = $LayoutSettings/LayoutName
@onready var delete_confirmation: ConfirmationDialog = $DeleteConfirmation
@onready var mimic_ui = find_child("LayoutPreview")
func _on_ManageLayouts_about_to_show() -> void:
for layout in Global.layouts:
layout_list.add_item(layout.resource_path.get_basename().get_file())
for layout in Global.top_menu_container.layouts:
layout_list.add_item(layout[0])
refresh_preview()
if layout_selected != -1:
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:
layout_selected = index
rename_layout.disabled = false
delete_layout.disabled = false
edit_layout.disabled = index < Global.top_menu_container.default_layout_size
delete_layout.disabled = index < Global.top_menu_container.default_layout_size
refresh_preview()
func _on_SavedLayouts_empty_clicked(_position: Vector2, _button_index: int) -> void:
rename_layout.disabled = true
edit_layout.disabled = true
delete_layout.disabled = true
@ -54,15 +47,13 @@ func _on_AddLayout_pressed() -> void:
is_editing = false
layout_name.text = "New Layout"
layout_settings.title = "Add Layout"
layout_from.get_parent().visible = true
layout_settings.popup_centered()
func _on_rename_layout_pressed() -> void:
func _on_EditLayout_pressed() -> void:
is_editing = true
layout_name.text = layout_list.get_item_text(layout_selected)
layout_settings.title = "Rename Layout"
layout_from.get_parent().visible = false
layout_settings.title = "Edit Layout"
layout_settings.popup_centered()
@ -72,62 +63,52 @@ func _on_DeleteLayout_pressed() -> void:
func _on_LayoutSettings_confirmed() -> void:
var file_name := layout_name.text + ".tres"
var path := Global.LAYOUT_DIR.path_join(file_name)
var layout: DockableLayout
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 path := "user://layouts/".path_join(file_name)
var layout: DockableLayout = Global.control.main_ui.layout
var err := ResourceSaver.save(layout, path)
if err != OK:
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:
Global.layouts.append(layout)
# Save the layout every time it changes
layout.save_on_change = true
Global.control.main_ui.layout = layout
layout_list.add_item(layout_name.text)
Global.layouts.sort_custom(
func(a: DockableLayout, b: DockableLayout): return (
a.resource_path.get_file() < b.resource_path.get_file()
)
)
var layout_index := Global.layouts.find(layout)
Global.top_menu_container.populate_layouts_submenu()
Global.top_menu_container.layouts_submenu.set_item_checked(layout_index + 1, true)
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.top_menu_container.layouts[layout_selected][0] = layout_name.text
Global.top_menu_container.layouts[layout_selected][1] = layout
layout_list.set_item_text(layout_selected, layout_name.text)
Global.top_menu_container.layouts_submenu.set_item_text(
layout_selected + 1, layout_name.text
)
else:
Global.top_menu_container.layouts.append([layout_name.text, layout])
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:
var dir := DirAccess.open(Global.LAYOUT_DIR)
var dir := DirAccess.open("user://layouts/")
if not is_instance_valid(dir):
return
dir.remove(Global.LAYOUT_DIR.path_join(file_name))
dir.remove("user://layouts/".path_join(file_name))
func _on_DeleteConfirmation_confirmed() -> void:
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)
Global.top_menu_container.populate_layouts_submenu()
layout_selected = -1
rename_layout.disabled = true
edit_layout.disabled = true
delete_layout.disabled = true
refresh_preview()
func refresh_preview() -> void:
func refresh_preview():
for tab in mimic_ui.get_tabs():
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()
box.name = item.name
box.text = item.name
@ -137,4 +118,4 @@ func refresh_preview() -> void:
mimic_ui.visible = false
return
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")
root = SubResource("1")
hidden_tabs = {}
save_on_change = false
[node name="ManageLayouts" type="AcceptDialog"]
title = "Manage Layouts"
size = Vector2i(500, 500)
exclusive = false
popup_window = true
script = ExtResource("1")
@ -32,7 +30,7 @@ anchor_bottom = 1.0
offset_left = 8.0
offset_top = 8.0
offset_right = -8.0
offset_bottom = -49.0
offset_bottom = -36.0
[node name="PreviewHeader" type="HBoxContainer" parent="VBoxContainer"]
layout_mode = 2
@ -56,7 +54,6 @@ layout_mode = 2
size_flags_vertical = 3
[node name="LayoutPreview" type="Container" parent="VBoxContainer/PreviewContainer"]
unique_name_in_owner = true
layout_mode = 2
size_flags_horizontal = 3
size_flags_vertical = 3
@ -82,7 +79,6 @@ layout_mode = 2
text = "Double click to set as new startup layout"
[node name="SavedLayouts" type="ItemList" parent="VBoxContainer"]
unique_name_in_owner = true
custom_minimum_size = Vector2(0, 100)
layout_mode = 2
@ -91,53 +87,38 @@ layout_mode = 2
[node name="AddLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
layout_mode = 2
size_flags_horizontal = 3
size_flags_horizontal = 0
mouse_default_cursor_shape = 2
text = "Add"
[node name="RenameLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
unique_name_in_owner = true
[node name="EditLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
layout_mode = 2
size_flags_horizontal = 3
size_flags_horizontal = 0
mouse_default_cursor_shape = 2
disabled = true
text = "Rename"
text = "Edit"
[node name="DeleteLayout" type="Button" parent="VBoxContainer/ButtonsContainer"]
unique_name_in_owner = true
layout_mode = 2
size_flags_horizontal = 3
size_flags_horizontal = 0
mouse_default_cursor_shape = 2
disabled = true
text = "Delete"
[node name="LayoutSettings" type="ConfirmationDialog" parent="."]
[node name="VBoxContainer" type="VBoxContainer" parent="LayoutSettings"]
offset_right = 40.0
offset_bottom = 40.0
[node name="LayoutName" type="LineEdit" parent="LayoutSettings/VBoxContainer"]
unique_name_in_owner = true
layout_mode = 2
[node name="LayoutName" type="LineEdit" parent="LayoutSettings"]
anchors_preset = 14
anchor_top = 0.5
anchor_right = 1.0
anchor_bottom = 0.5
offset_left = 8.0
offset_top = -26.0
offset_right = -8.0
offset_bottom = -2.0
size_flags_horizontal = 3
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="."]
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_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/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="confirmed" from="LayoutSettings" to="." method="_on_LayoutSettings_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")
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 zen_mode := false
@ -34,6 +39,8 @@ var zen_mode := false
func _ready() -> void:
var dir := DirAccess.open("user://")
dir.make_dir("user://layouts")
_setup_file_menu()
_setup_edit_menu()
_setup_view_menu()
@ -241,6 +248,19 @@ func _setup_panels_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.hide_on_checkable_item_selection = false
populate_layouts_submenu()
@ -249,14 +269,14 @@ func _setup_layouts_submenu(item: String) -> void:
window_menu.add_child(layouts_submenu)
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)
func populate_layouts_submenu() -> void:
layouts_submenu.clear() # Does not do anything if it's called for the first time
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()
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:
if Global.layouts.size() == 0:
return
if id >= Global.layouts.size():
if id >= layouts.size():
id = 0
selected_layout = id
main_ui.layout = Global.layouts[id]
for i in Global.layouts.size():
main_ui.layout = layouts[id].clone() # Clone is needed to avoid modifying premade layouts
for i in layouts.size():
var offset := i + 1
layouts_submenu.set_item_checked(offset, offset == (id + 1))

View file

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