feat: first+server list UI, ping/pswd unfonctional

This commit is contained in:
Fabian 2021-07-21 11:12:17 +02:00
parent 4846fbb589
commit ac615cd134
6 changed files with 371 additions and 118 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.5 KiB

View File

@ -20,6 +20,7 @@ import asyncio
import copy import copy
import gzip import gzip
import logging import logging
from multi_user.preferences import ServerPreset
import os import os
import queue import queue
import random import random
@ -57,7 +58,7 @@ from replication.repository import Repository
from . import bl_types, environment, shared_data, timers, ui, utils from . import bl_types, environment, shared_data, timers, ui, utils
from .handlers import on_scene_update, sanitize_deps_graph from .handlers import on_scene_update, sanitize_deps_graph
from .presence import SessionStatusWidget, renderer, view3d_find from .presence import SessionStatusWidget, renderer, view3d_find, refresh_sidebar_view
from .timers import registry from .timers import registry
background_execution_queue = Queue() background_execution_queue = Queue()
@ -928,20 +929,26 @@ class SessionPresetServerAdd(bpy.types.Operator):
bl_description = "add a server to the server preset list" bl_description = "add a server to the server preset list"
bl_options = {"REGISTER"} bl_options = {"REGISTER"}
target_server_name: bpy.props.StringProperty(default="None") server_name: bpy.props.StringProperty(default="")
server_ip: bpy.props.StringProperty(default="127.0.0.1")
server_port: bpy.props.IntProperty(default=5555)
use_server_password: bpy.props.BoolProperty(default=False)
server_server_password: bpy.props.StringProperty(default="", subtype = "PASSWORD")
use_admin_password: bpy.props.BoolProperty(default=False)
server_admin_password: bpy.props.StringProperty(default="", subtype = "PASSWORD")
@classmethod @classmethod
def poll(cls, context): def poll(cls, context):
return True return True
def invoke(self, context, event): def invoke(self, context, event):
settings = utils.get_preferences() self.server_name = ""
self.server_ip = "127.0.0.1"
settings.server_name = "" self.server_port = 5555
settings.ip = "127.0.0.1" self.use_server_password = False
settings.port = 5555 self.server_server_password = ""
settings.server_password = "" self.use_admin_password = False
settings.admin_password = "" self.server_admin_password = ""
assert(context) assert(context)
return context.window_manager.invoke_props_dialog(self) return context.window_manager.invoke_props_dialog(self)
@ -951,34 +958,45 @@ class SessionPresetServerAdd(bpy.types.Operator):
settings = utils.get_preferences() settings = utils.get_preferences()
row = layout.row() row = layout.row()
row.prop(settings, "server_name", text="Server name") row.prop(self, "server_name", text="Server name")
row = layout.row(align = True) row = layout.row(align = True)
row.prop(settings, "ip", text="IP+port") row.prop(self, "server_ip", text="IP+port")
row.prop(settings, "port", text="") row.prop(self, "server_port", text="")
row = layout.row() row = layout.row()
row.prop(settings, "server_password", text="Server password") col = row.column()
col.prop(self, "use_server_password", text="Server password:")
col = row.column()
col.enabled = True if self.use_server_password else False
col.prop(self, "server_server_password", text="")
row = layout.row() row = layout.row()
row.prop(settings, "admin_password", text="Admin password") col = row.column()
col.prop(self, "use_admin_password", text="Admin password:")
col = row.column()
col.enabled = True if self.use_admin_password else False
col.prop(self, "server_admin_password", text="")
def execute(self, context): def execute(self, context):
assert(context) assert(context)
settings = utils.get_preferences() settings = utils.get_preferences()
existing_preset = settings.get_server_preset(self.server_name)
existing_preset = settings.server_preset.get(settings.server_name)
new_server = existing_preset if existing_preset else settings.server_preset.add() new_server = existing_preset if existing_preset else settings.server_preset.add()
new_server.name = str(uuid4()) new_server.name = str(uuid4())
new_server.server_name = settings.server_name new_server.server_name = self.server_name
new_server.server_ip = settings.ip new_server.server_ip = self.server_ip
new_server.server_port = settings.port new_server.server_port = self.server_port
new_server.server_server_password = settings.server_password new_server.use_server_password = self.use_server_password
new_server.server_admin_password = settings.admin_password new_server.server_server_password = self.server_server_password
new_server.use_admin_password = self.use_admin_password
new_server.server_admin_password = self.server_admin_password
refresh_sidebar_view()
if new_server == existing_preset : if new_server == existing_preset :
self.report({'INFO'}, "Server '" + settings.server_name + "' override") self.report({'INFO'}, "Server '" + self.server_name + "' override")
else : else :
self.report({'INFO'}, "New '" + settings.server_name + "' server preset") self.report({'INFO'}, "New '" + self.server_name + "' server preset")
return {'FINISHED'} return {'FINISHED'}
@ -1020,9 +1038,17 @@ class SessionPresetServerEdit(bpy.types.Operator):
row.prop(settings, "ip", text="IP+port") row.prop(settings, "ip", text="IP+port")
row.prop(settings, "port", text="") row.prop(settings, "port", text="")
row = layout.row() row = layout.row()
row.prop(settings, "server_password", text="Server password") col = row.column()
col.prop(settings, "use_server_password", text="Server password:")
col = row.column()
col.enabled = True if settings.use_server_password else False
col.prop(settings, "server_password", text="")
row = layout.row() row = layout.row()
row.prop(settings, "admin_password", text="Admin password") col = row.column()
col.prop(settings, "use_admin_password", text="Admin password:")
col = row.column()
col.enabled = True if settings.use_admin_password else False
col.prop(settings, "admin_password", text="")
def execute(self, context): def execute(self, context):
assert(context) assert(context)
@ -1037,6 +1063,8 @@ class SessionPresetServerEdit(bpy.types.Operator):
server.server_server_password = settings.server_password server.server_server_password = settings.server_password
server.server_admin_password = settings.admin_password server.server_admin_password = settings.admin_password
refresh_sidebar_view()
self.report({'INFO'}, "Server '" + settings.server_name + "' override") self.report({'INFO'}, "Server '" + settings.server_name + "' override")
return {'FINISHED'} return {'FINISHED'}
@ -1064,6 +1092,37 @@ class SessionPresetServerRemove(bpy.types.Operator):
return {'FINISHED'} return {'FINISHED'}
class GetDoc(bpy.types.Operator):
"""Get the documentation of the addon"""
bl_idname = "doc.get"
bl_label = "Multi-user's doc"
bl_description = "Go to the doc of the addon"
@classmethod
def poll(cls, context):
return True
def execute(self, context):
assert(context)
bpy.ops.wm.url_open(url="https://multi-user.readthedocs.io/en/develop/index.html")
return {'FINISHED'}
class FirstLaunch(bpy.types.Operator):
"""First time lauching the addon"""
bl_idname = "firstlaunch.verify"
bl_label = "First launch"
bl_description = "First time lauching the addon"
@classmethod
def poll(cls, context):
return True
def execute(self, context):
assert(context)
settings = utils.get_preferences()
settings.is_first_launch = False
return {'FINISHED'}
def menu_func_import(self, context): def menu_func_import(self, context):
self.layout.operator(SessionLoadSaveOperator.bl_idname, text='Multi-user session snapshot (.db)') self.layout.operator(SessionLoadSaveOperator.bl_idname, text='Multi-user session snapshot (.db)')
@ -1090,6 +1149,8 @@ classes = (
SessionPresetServerAdd, SessionPresetServerAdd,
SessionPresetServerEdit, SessionPresetServerEdit,
SessionPresetServerRemove, SessionPresetServerRemove,
GetDoc,
FirstLaunch,
) )

View File

@ -115,12 +115,14 @@ class ReplicatedDatablock(bpy.types.PropertyGroup):
auto_push: bpy.props.BoolProperty(default=True) auto_push: bpy.props.BoolProperty(default=True)
icon: bpy.props.StringProperty() icon: bpy.props.StringProperty()
class ServerPreset(bpy.types.PropertyGroup): # TODO: self.uuid = uuid if uuid else str(uuid4()) class ServerPreset(bpy.types.PropertyGroup):
server_name: bpy.props.StringProperty() server_name: bpy.props.StringProperty(default="")
server_ip: bpy.props.StringProperty() server_ip: bpy.props.StringProperty(default="127.0.0.1")
server_port: bpy.props.IntProperty(default=5555) server_port: bpy.props.IntProperty(default=5555)
use_server_password: bpy.props.BoolProperty(default=False)
server_server_password: bpy.props.StringProperty(default="", subtype = "PASSWORD") server_server_password: bpy.props.StringProperty(default="", subtype = "PASSWORD")
server_admin_password: bpy.props.StringProperty(default="admin", subtype = "PASSWORD") use_admin_password: bpy.props.BoolProperty(default=False)
server_admin_password: bpy.props.StringProperty(default="", subtype = "PASSWORD")
def set_sync_render_settings(self, value): def set_sync_render_settings(self, value):
self['sync_render_settings'] = value self['sync_render_settings'] = value
@ -198,17 +200,31 @@ class SessionPrefs(bpy.types.AddonPreferences):
name="server_index", name="server_index",
description="index of the server", description="index of the server",
) )
use_server_password: bpy.props.BoolProperty(
name="use_server_password",
description='Use session password',
default=False
)
server_password: bpy.props.StringProperty( server_password: bpy.props.StringProperty(
name="server_password", name="server_password",
description='Session password', description='Session password',
subtype='PASSWORD' subtype='PASSWORD'
) )
use_admin_password: bpy.props.BoolProperty(
name="use_admin_password",
description='Use admin password',
default=False
)
admin_password: bpy.props.StringProperty( admin_password: bpy.props.StringProperty(
name="admin_password", name="admin_password",
default=random_string_digits(),
description='Admin password', description='Admin password',
subtype='PASSWORD' subtype='PASSWORD'
) )
is_first_launch: bpy.props.BoolProperty(
name="is_first_launch",
description="First time lauching the addon",
default=True
)
sync_flags: bpy.props.PointerProperty( sync_flags: bpy.props.PointerProperty(
type=ReplicationFlags type=ReplicationFlags
) )
@ -354,6 +370,11 @@ class SessionPrefs(bpy.types.AddonPreferences):
description="sidebar_advanced_log_expanded", description="sidebar_advanced_log_expanded",
default=False default=False
) )
sidebar_advanced_hosting_expanded: bpy.props.BoolProperty(
name="sidebar_advanced_hosting_expanded",
description="sidebar_advanced_hosting_expanded",
default=False
)
sidebar_advanced_net_expanded: bpy.props.BoolProperty( sidebar_advanced_net_expanded: bpy.props.BoolProperty(
name="sidebar_advanced_net_expanded", name="sidebar_advanced_net_expanded",
description="sidebar_advanced_net_expanded", description="sidebar_advanced_net_expanded",
@ -431,10 +452,11 @@ class SessionPrefs(bpy.types.AddonPreferences):
grid = layout.column() grid = layout.column()
box = grid.box() box = grid.box()
row = box.row(align = True) row = box.row()
# USER SETTINGS # USER SETTINGS
row.prop(self, "username", text="User") split = row.split(factor=0.7, align=True)
row.prop(self, "client_color", text="") split.prop(self, "username", text="User")
split.prop(self, "client_color", text="")
row = box.row() row = box.row()
row.label(text="Hide settings:") row.label(text="Hide settings:")
@ -457,9 +479,17 @@ class SessionPrefs(bpy.types.AddonPreferences):
row.label(text="Init the session from:") row.label(text="Init the session from:")
row.prop(self, "init_method", text="") row.prop(self, "init_method", text="")
row = box.row() row = box.row()
row.prop(self, "server_password", text="Server password") col = row.column()
col.prop(self, "use_server_password", text="Server password:")
col = row.column()
col.enabled = True if self.use_server_password else False
col.prop(self, "server_password", text="")
row = box.row() row = box.row()
row.prop(self, "admin_password", text="Admin password") col = row.column()
col.prop(self, "use_admin_password", text="Admin password:")
col = row.column()
col.enabled = True if self.use_admin_password else False
col.prop(self, "admin_password", text="")
# NETWORKING # NETWORKING
box = grid.box() box = grid.box()
@ -467,7 +497,6 @@ class SessionPrefs(bpy.types.AddonPreferences):
self, "conf_session_net_expanded", text="Network", self, "conf_session_net_expanded", text="Network",
icon=get_expanded_icon(self.conf_session_net_expanded), icon=get_expanded_icon(self.conf_session_net_expanded),
emboss=False) emboss=False)
if self.conf_session_net_expanded: if self.conf_session_net_expanded:
row = box.row() row = box.row()
row.label(text="Timeout (ms):") row.label(text="Timeout (ms):")
@ -479,16 +508,12 @@ class SessionPrefs(bpy.types.AddonPreferences):
self, "conf_session_rep_expanded", text="Replication", self, "conf_session_rep_expanded", text="Replication",
icon=get_expanded_icon(self.conf_session_rep_expanded), icon=get_expanded_icon(self.conf_session_rep_expanded),
emboss=False) emboss=False)
if self.conf_session_rep_expanded: if self.conf_session_rep_expanded:
row = box.row()
row = box.row() row = box.row()
row.prop(self.sync_flags, "sync_render_settings") row.prop(self.sync_flags, "sync_render_settings")
row = box.row() row = box.row()
row.prop(self.sync_flags, "sync_active_camera") row.prop(self.sync_flags, "sync_active_camera")
row = box.row() row = box.row()
row.prop(self.sync_flags, "sync_during_editmode") row.prop(self.sync_flags, "sync_during_editmode")
row = box.row() row = box.row()
if self.sync_flags.sync_during_editmode: if self.sync_flags.sync_during_editmode:
@ -519,8 +544,6 @@ class SessionPrefs(bpy.types.AddonPreferences):
row.label(text="Log level:") row.label(text="Log level:")
row.prop(self, 'logging_level', text="") row.prop(self, 'logging_level', text="")
if self.category == 'UPDATE': if self.category == 'UPDATE':
from . import addon_updater_ops from . import addon_updater_ops
addon_updater_ops.update_settings_ui(self, context) addon_updater_ops.update_settings_ui(self, context)
@ -540,11 +563,19 @@ class SessionPrefs(bpy.types.AddonPreferences):
new_db.icon = impl.bl_icon new_db.icon = impl.bl_icon
new_db.bl_name = impl.bl_id new_db.bl_name = impl.bl_id
def get_server_preset(self, name):
existing_preset = None
for server_preset in self.server_preset :
if server_preset.server_name == name :
existing_preset = server_preset
return existing_preset
# custom at launch server preset # custom at launch server preset
def generate_default_presets(self): def generate_default_presets(self):
for preset_name, preset_data in DEFAULT_PRESETS.items(): for preset_name, preset_data in DEFAULT_PRESETS.items():
existing_preset = self.server_preset.get(preset_name) existing_preset = self.get_server_preset(preset_name)
if existing_preset : if existing_preset :
continue continue
new_server = self.server_preset.add() new_server = self.server_preset.add()

117
multi_user/temp.py Normal file
View File

@ -0,0 +1,117 @@
class SESSION_PT_network(bpy.types.Panel):
bl_idname = "MULTIUSER_SETTINGS_PT_network"
bl_label = "Network"
bl_space_type = 'VIEW_3D'
bl_region_type = 'UI'
bl_parent_id = 'MULTIUSER_SETTINGS_PT_network'
@classmethod
def poll(cls, context):
return not session \
or (session and session.state == 0)
def draw_header(self, context):
self.layout.label(text="", icon='LINKED')
def draw(self, context):
layout = self.layout
runtime_settings = context.window_manager.session
settings = get_preferences()
# Create a simple row.
row = layout.row()
box = row.box()
split = box.split(factor=0.35)
split.label(text="Server")
split = split.split(factor=0.3)
split.label(text="Online")
row = layout.row()
layout.template_list("SESSION_UL_network", "", settings,
"server_preset_interface", context.window_manager, "user_index")
class SESSION_UL_network(bpy.types.UIList):
def draw_item(self, context, layout, data, item, icon, active_data, active_propname, index, flt_flag):
settings = get_preferences()
server_name = '-'
server_status = 'BLANK1'
server_private = 'BLANK1'
if not session:
server_name = settings.server_name
# Session with/without password
if settings.server_password != None:
server_private = 'LOCKED'
split = layout.split(factor=0.35)
split.label(text=server_name, icon=server_private)
else:
split = layout.split(factor=0.35)
split.label(text=server_name)
# Session status
# if session online : vert else rouge
from multi_user import icons
server_status = icons.icons_col["session_status_offline"]
split.label(icon=server_status)
class SESSION_UL_users(bpy.types.UIList):
def draw_item(self, context, layout, data, item, icon, active_data, active_propname, index, flt_flag):
settings = get_preferences()
is_local_user = item.username == settings.username
ping = '-'
frame_current = '-'
scene_current = '-'
mode_current = '-'
mode_icon = 'BLANK1'
status_icon = 'BLANK1'
if session:
user = session.online_users.get(item.username)
if user:
ping = str(user['latency'])
metadata = user.get('metadata')
if metadata and 'frame_current' in metadata:
frame_current = str(metadata.get('frame_current','-'))
scene_current = metadata.get('scene_current','-')
mode_current = metadata.get('mode_current','-')
if mode_current == "OBJECT" :
mode_icon = "OBJECT_DATAMODE"
elif mode_current == "EDIT_MESH" :
mode_icon = "EDITMODE_HLT"
elif mode_current == 'EDIT_CURVE':
mode_icon = "CURVE_DATA"
elif mode_current == 'EDIT_SURFACE':
mode_icon = "SURFACE_DATA"
elif mode_current == 'EDIT_TEXT':
mode_icon = "FILE_FONT"
elif mode_current == 'EDIT_ARMATURE':
mode_icon = "ARMATURE_DATA"
elif mode_current == 'EDIT_METABALL':
mode_icon = "META_BALL"
elif mode_current == 'EDIT_LATTICE':
mode_icon = "LATTICE_DATA"
elif mode_current == 'POSE':
mode_icon = "POSE_HLT"
elif mode_current == 'SCULPT':
mode_icon = "SCULPTMODE_HLT"
elif mode_current == 'PAINT_WEIGHT':
mode_icon = "WPAINT_HLT"
elif mode_current == 'PAINT_VERTEX':
mode_icon = "VPAINT_HLT"
elif mode_current == 'PAINT_TEXTURE':
mode_icon = "TPAINT_HLT"
elif mode_current == 'PARTICLE':
mode_icon = "PARTICLES"
elif mode_current == 'PAINT_GPENCIL' or mode_current =='EDIT_GPENCIL' or mode_current =='SCULPT_GPENCIL' or mode_current =='WEIGHT_GPENCIL' or mode_current =='VERTEX_GPENCIL':
mode_icon = "GREASEPENCIL"
if user['admin']:
status_icon = 'FAKE_USER_ON'
split = layout.split(factor=0.35)
split.label(text=item.username, icon=status_icon)
split = split.split(factor=0.3)
split.label(icon=mode_icon)
split.label(text=frame_current)
split.label(text=scene_current)
split.label(text=ping)

View File

@ -97,10 +97,32 @@ class SESSION_PT_settings(bpy.types.Panel):
def draw(self, context): def draw(self, context):
layout = self.layout layout = self.layout
row = layout.row()
runtime_settings = context.window_manager.session runtime_settings = context.window_manager.session
settings = get_preferences() settings = get_preferences()
if settings.is_first_launch:
# USER SETTINGS
row = layout.row()
row.label(text="1. Enter your username and color:")
row = layout.row()
split = row.split(factor=0.7, align=True)
split.prop(settings, "username", text="")
split.prop(settings, "client_color", text="")
# DOC
row = layout.row()
row.label(text="2. New here ? See the doc:")
row = layout.row()
row.operator("doc.get", text="Documentation", icon="HELP")
# START
row = layout.row()
row.label(text="3: Start the Multi-user:")
row = layout.row()
row.scale_y = 2
row.operator("firstlaunch.verify", text="Continue")
if not settings.is_first_launch:
if hasattr(context.window_manager, 'session'): if hasattr(context.window_manager, 'session'):
# STATE INITIAL # STATE INITIAL
if not session \ if not session \
@ -112,7 +134,7 @@ class SESSION_PT_settings(bpy.types.Panel):
active_server_name = server_preset[selected_server].name if len(server_preset)>=1 else "" active_server_name = server_preset[selected_server].name if len(server_preset)>=1 else ""
is_server_selected = True if active_server_name else False # TODO : issues when removing the lowest server in the list is_server_selected = True if active_server_name else False # TODO : issues when removing the lowest server in the list
# Create a simple row. # SERVER LIST
row = layout.row() row = layout.row()
box = row.box() box = row.box()
split = box.split(factor=0.7) split = box.split(factor=0.7)
@ -120,7 +142,7 @@ class SESSION_PT_settings(bpy.types.Panel):
split.label(text="Online") split.label(text="Online")
row = layout.row() row = layout.row()
layout.template_list("SESSION_UL_network", "", settings, "server_preset", context.window_manager, "server_index") # TODO: change port to server_index layout.template_list("SESSION_UL_network", "", settings, "server_preset", context.window_manager, "server_index")
row = layout.row() # TODO : active server in template row = layout.row() # TODO : active server in template
row.operator("session.preset_server_add", text="Add") # TODO : add conditions (need a name, etc..) + add a checkbox for password without creating preferences row.operator("session.preset_server_add", text="Add") # TODO : add conditions (need a name, etc..) + add a checkbox for password without creating preferences
@ -136,6 +158,7 @@ class SESSION_PT_settings(bpy.types.Panel):
col = row.column() col = row.column()
col.enabled =is_server_selected col.enabled =is_server_selected
col.operator("session.connect", text="Connect") col.operator("session.connect", text="Connect")
else: else:
progress = session.state_progress progress = session.state_progress
row = layout.row() row = layout.row()
@ -143,6 +166,7 @@ class SESSION_PT_settings(bpy.types.Panel):
current_state = session.state current_state = session.state
info_msg = None info_msg = None
# STATE IN SESSION
if current_state in [STATE_ACTIVE]: if current_state in [STATE_ACTIVE]:
row = row.grid_flow(row_major=True, columns=0, even_columns=True, even_rows=False, align=True) row = row.grid_flow(row_major=True, columns=0, even_columns=True, even_rows=False, align=True)
row.prop(settings.sync_flags, "sync_render_settings",text="",icon_only=True, icon='SCENE') row.prop(settings.sync_flags, "sync_render_settings",text="",icon_only=True, icon='SCENE')
@ -160,7 +184,7 @@ class SESSION_PT_settings(bpy.types.Panel):
info_box = row.box() info_box = row.box()
info_box.row().label(text=info_msg,icon='INFO') info_box.row().label(text=info_msg,icon='INFO')
# Progress bar # PROGRESS BAR
if current_state in [STATE_SYNCING, STATE_SRV_SYNC, STATE_WAITING]: if current_state in [STATE_SYNCING, STATE_SRV_SYNC, STATE_WAITING]:
info_box = row.box() info_box = row.box()
info_box.row().label(text=printProgressBar( info_box.row().label(text=printProgressBar(
@ -184,17 +208,40 @@ class SESSION_PT_advanced_settings(bpy.types.Panel):
settings = get_preferences() settings = get_preferences()
return not session \ return not session \
or (session and session.state == 0) \ or (session and session.state == 0) \
and not settings.sidebar_advanced_shown and not settings.sidebar_advanced_shown \
and not settings.is_first_launch
def draw_header(self, context): def draw_header(self, context):
self.layout.label(text="", icon='PREFERENCES') self.layout.label(text="", icon='PREFERENCES')
def draw(self, context): def draw(self, context):
layout = self.layout layout = self.layout
runtime_settings = context.window_manager.session
settings = get_preferences() settings = get_preferences()
#ADVANCED HOST
host_selection = layout.row().box()
host_selection.prop(
settings, "sidebar_advanced_hosting_expanded", text="Hosting",
icon=get_expanded_icon(settings.sidebar_advanced_hosting_expanded),
emboss=False)
if settings.sidebar_advanced_hosting_expanded:
host_selection_row = host_selection.row()
host_selection_row.label(text="Init the session from:")
host_selection_row.prop(settings, "init_method", text="")
host_selection_row = host_selection.row()
host_selection_col = host_selection_row.column()
host_selection_col.prop(settings, "use_server_password", text="Server password:")
host_selection_col = host_selection_row.column()
host_selection_col.enabled = True if settings.use_server_password else False
host_selection_col.prop(settings, "server_password", text="")
host_selection_row = host_selection.row()
host_selection_col = host_selection_row.column()
host_selection_col.prop(settings, "use_admin_password", text="Admin password:")
host_selection_col = host_selection_row.column()
host_selection_col.enabled = True if settings.use_admin_password else False
host_selection_col.prop(settings, "admin_password", text="")
#ADVANCED NET
net_section = layout.row().box() net_section = layout.row().box()
net_section.prop( net_section.prop(
settings, settings,
@ -202,12 +249,12 @@ class SESSION_PT_advanced_settings(bpy.types.Panel):
text="Network", text="Network",
icon=get_expanded_icon(settings.sidebar_advanced_net_expanded), icon=get_expanded_icon(settings.sidebar_advanced_net_expanded),
emboss=False) emboss=False)
if settings.sidebar_advanced_net_expanded: if settings.sidebar_advanced_net_expanded:
net_section_row = net_section.row() net_section_row = net_section.row()
net_section_row.label(text="Timeout (ms):") net_section_row.label(text="Timeout (ms):")
net_section_row.prop(settings, "connection_timeout", text="") net_section_row.prop(settings, "connection_timeout", text="")
#ADVANCED REPLICATION
replication_section = layout.row().box() replication_section = layout.row().box()
replication_section.prop( replication_section.prop(
settings, settings,
@ -215,16 +262,12 @@ class SESSION_PT_advanced_settings(bpy.types.Panel):
text="Replication", text="Replication",
icon=get_expanded_icon(settings.sidebar_advanced_rep_expanded), icon=get_expanded_icon(settings.sidebar_advanced_rep_expanded),
emboss=False) emboss=False)
if settings.sidebar_advanced_rep_expanded: if settings.sidebar_advanced_rep_expanded:
replication_section_row = replication_section.row()
replication_section_row = replication_section.row() replication_section_row = replication_section.row()
replication_section_row.prop(settings.sync_flags, "sync_render_settings") replication_section_row.prop(settings.sync_flags, "sync_render_settings")
replication_section_row = replication_section.row() replication_section_row = replication_section.row()
replication_section_row.prop(settings.sync_flags, "sync_active_camera") replication_section_row.prop(settings.sync_flags, "sync_active_camera")
replication_section_row = replication_section.row() replication_section_row = replication_section.row()
replication_section_row.prop(settings.sync_flags, "sync_during_editmode") replication_section_row.prop(settings.sync_flags, "sync_during_editmode")
replication_section_row = replication_section.row() replication_section_row = replication_section.row()
if settings.sync_flags.sync_during_editmode: if settings.sync_flags.sync_during_editmode:
@ -233,7 +276,7 @@ class SESSION_PT_advanced_settings(bpy.types.Panel):
replication_section_row = replication_section.row() replication_section_row = replication_section.row()
replication_section_row.prop(settings, "depsgraph_update_rate", text="Apply delay") replication_section_row.prop(settings, "depsgraph_update_rate", text="Apply delay")
#ADVANCED CACHE
cache_section = layout.row().box() cache_section = layout.row().box()
cache_section.prop( cache_section.prop(
settings, settings,
@ -251,6 +294,8 @@ class SESSION_PT_advanced_settings(bpy.types.Panel):
cache_section_row.prop(settings, "clear_memory_filecache", text="") cache_section_row.prop(settings, "clear_memory_filecache", text="")
cache_section_row = cache_section.row() cache_section_row = cache_section.row()
cache_section_row.operator('session.clear_cache', text=f"Clear cache ({get_folder_size(settings.cache_directory)})") cache_section_row.operator('session.clear_cache', text=f"Clear cache ({get_folder_size(settings.cache_directory)})")
#ADVANCED LOG
log_section = layout.row().box() log_section = layout.row().box()
log_section.prop( log_section.prop(
settings, settings,
@ -258,7 +303,6 @@ class SESSION_PT_advanced_settings(bpy.types.Panel):
text="Logging", text="Logging",
icon=get_expanded_icon(settings.sidebar_advanced_log_expanded), icon=get_expanded_icon(settings.sidebar_advanced_log_expanded),
emboss=False) emboss=False)
if settings.sidebar_advanced_log_expanded: if settings.sidebar_advanced_log_expanded:
log_section_row = log_section.row() log_section_row = log_section.row()
log_section_row.label(text="Log level:") log_section_row.label(text="Log level:")
@ -273,7 +317,8 @@ class SESSION_PT_user(bpy.types.Panel):
@classmethod @classmethod
def poll(cls, context): def poll(cls, context):
return session and session.state in [STATE_ACTIVE, STATE_LOBBY] return session \
and session.state in [STATE_ACTIVE, STATE_LOBBY]
def draw_header(self, context): def draw_header(self, context):
self.layout.label(text="", icon='USER') self.layout.label(text="", icon='USER')
@ -285,9 +330,8 @@ class SESSION_PT_user(bpy.types.Panel):
settings = get_preferences() settings = get_preferences()
active_user = online_users[selected_user] if len( active_user = online_users[selected_user] if len(
online_users)-1 >= selected_user else 0 online_users)-1 >= selected_user else 0
runtime_settings = context.window_manager.session
# Create a simple row. #USER LIST
row = layout.row() row = layout.row()
box = row.box() box = row.box()
split = box.split(factor=0.35) split = box.split(factor=0.35)
@ -302,6 +346,7 @@ class SESSION_PT_user(bpy.types.Panel):
layout.template_list("SESSION_UL_users", "", context.window_manager, layout.template_list("SESSION_UL_users", "", context.window_manager,
"online_users", context.window_manager, "user_index") "online_users", context.window_manager, "user_index")
#OPERATOR ON USER
if active_user != 0 and active_user.username != settings.username: if active_user != 0 and active_user.username != settings.username:
row = layout.row() row = layout.row()
user_operations = row.split() user_operations = row.split()
@ -387,7 +432,6 @@ class SESSION_UL_users(bpy.types.UIList):
def draw_property(context, parent, property_uuid, level=0): def draw_property(context, parent, property_uuid, level=0):
settings = get_preferences() settings = get_preferences()
runtime_settings = context.window_manager.session
item = session.repository.graph.get(property_uuid) item = session.repository.graph.get(property_uuid)
type_id = item.data.get('type_id') type_id = item.data.get('type_id')
area_msg = parent.row(align=True) area_msg = parent.row(align=True)
@ -584,7 +628,7 @@ class SESSION_UL_network(bpy.types.UIList):
# TODO : if session online : vert else rouge # TODO : if session online : vert else rouge
# TODO : ping # TODO : ping
from multi_user import icons from multi_user import icons
server_status = icons.icons_col["session_status_offline"] server_status = icons.icons_col["server_offline"]
split.label(icon_value=server_status.icon_id) split.label(icon_value=server_status.icon_id)
classes = ( classes = (