fix (WIP): work on quick fix for deselection

Related to #41.
This commit is contained in:
Swann Martinez 2019-11-22 18:32:39 +01:00
parent 805dd4f319
commit 12ba867ee1
No known key found for this signature in database
GPG Key ID: 414CCAFD8DA720E1
2 changed files with 86 additions and 86 deletions

View File

@ -7,30 +7,23 @@ from .. import presence
from .bl_datablock import BlDatablock from .bl_datablock import BlDatablock
from ..libs.replication.replication.constants import UP from ..libs.replication.replication.constants import UP
class BlUser(BlDatablock): class BlUser(BlDatablock):
def construct(self, name): def construct(self, name):
return presence.User() return presence.User()
def load(self, data, target):
target.name = data['name']
target.location = data['location']
target.selected_objects = data['selected_objects']
utils.dump_anything.load(target, data)
def apply(self): def apply(self):
for obj in bpy.data.objects:
if self.pointer: if obj.hide_select and obj.uuid not in self.data['selected_objects']:
self.load(data=self.data, target=self.pointer) obj.hide_select = False
elif not obj.hide_select and obj.uuid in self.data['selected_objects']:
obj.hide_select = True
presence.refresh_3d_view() presence.refresh_3d_view()
self.state = UP self.state = UP
def dump(self, pointer=None):
def dump(self,pointer=None):
data = utils.dump_anything.dump(pointer) data = utils.dump_anything.dump(pointer)
data['location'] = pointer.location data['location'] = pointer.location
data['color'] = pointer.color data['color'] = pointer.color
@ -42,20 +35,10 @@ class BlUser(BlDatablock):
def update(self): def update(self):
self.pointer.is_dirty = True self.pointer.is_dirty = True
# def diff(self):
# if not self.pointer:
# return False
# if self.pointer.is_dirty:
# self.pointer.is_dirty = False
# return True
# for i,coord in enumerate(self.pointer.location):
# if coord != self.data['location'][i]:
# return True
# return False
def is_valid(self): def is_valid(self):
return True return True
bl_id = "users" bl_id = "users"
bl_class = presence.User bl_class = presence.User
bl_rep_class = BlUser bl_rep_class = BlUser

View File

@ -74,74 +74,91 @@ class ApplyTimer(Timer):
try: try:
operators.client.apply(node) operators.client.apply(node)
except Exception as e: except Exception as e:
logger.error("fail to apply {}: {}".format(node_ref.uuid,e)) logger.error(
"fail to apply {}: {}".format(node_ref.uuid, e))
class DynamicRightSelectTimer(Timer): class DynamicRightSelectTimer(Timer):
def __init__(self, timout=.1): def __init__(self, timout=.1):
super().__init__(timout) super().__init__(timout)
self.last_selection = [] self._last_selection = []
self._user = None
self._user_node = None
self._right_strategy = RP_COMMON
def execute(self): def execute(self):
if operators.client: repo = operators.client
users = operators.client.list(filter=BlUser) if repo:
settings = bpy.context.window_manager.session
for user in users: # Find user
user_ref = operators.client.get(uuid=user) if self._user is None:
settings = bpy.context.window_manager.session users = repo.list(filter=BlUser)
# Local user for user in users:
if user_ref.pointer: user_node = repo.get(uuid=user)
current_selection = utils.get_selected_objects( if user_node.pointer:
bpy.context.scene) self._user = user_node.pointer
if current_selection != self.last_selection: self._user_node = user_node
right_strategy = operators.client.get_config()[
'right_strategy']
if right_strategy == RP_COMMON:
obj_common = [
o for o in self.last_selection if o not in current_selection]
obj_ours = [
o for o in current_selection if o not in self.last_selection]
# change new selection to our if self._right_strategy is None:
for obj in obj_ours: self._right_strategy = repo.get_config()[
node = operators.client.get(uuid=obj) 'right_strategy']
if node and node.owner == RP_COMMON: if self._user:
recursive = True current_selection = utils.get_selected_objects(
if node.data and 'instance_type' in node.data.keys(): bpy.context.scene)
recursive = node.data['instance_type'] != 'COLLECTION' if current_selection != self._last_selection:
if self._right_strategy == RP_COMMON:
obj_common = [
o for o in self._last_selection if o not in current_selection]
obj_ours = [
o for o in current_selection if o not in self._last_selection]
operators.client.change_owner( # change old selection right to common
node.uuid, for obj in obj_common:
settings.username, node = repo.get(uuid=obj)
recursive=recursive)
else:
return
self.last_selection = current_selection if node and (node.owner == settings.username or node.owner == RP_COMMON):
user_ref.pointer.update_selected_objects( recursive = True
bpy.context) if node.data and 'instance_type' in node.data.keys():
user_ref.update() recursive = node.data['instance_type'] != 'COLLECTION'
repo.change_owner(
node.uuid,
RP_COMMON,
recursive=recursive)
# change old selection right to common # change new selection to our
for obj in obj_common: for obj in obj_ours:
node = operators.client.get(uuid=obj) node = repo.get(uuid=obj)
if node and (node.owner == settings.username or node.owner == RP_COMMON): if node and node.owner == RP_COMMON:
recursive = True recursive = True
if node.data and 'instance_type' in node.data.keys(): if node.data and 'instance_type' in node.data.keys():
recursive = node.data['instance_type'] != 'COLLECTION' recursive = node.data['instance_type'] != 'COLLECTION'
operators.client.change_owner(
node.uuid, repo.change_owner(
RP_COMMON, node.uuid,
recursive=recursive) settings.username,
else: recursive=recursive)
for obj in bpy.data.objects: else:
if obj.hide_select and obj.uuid not in user_ref.data['selected_objects']: return
obj.hide_select = False
elif not obj.hide_select and obj.uuid in user_ref.data['selected_objects']: self._last_selection = current_selection
obj.hide_select = True self._user.update_selected_objects(
bpy.context)
repo.push(self._user_node.uuid)
# Fix deselection until right managment refactoring (with Roles concepts)
if len(current_selection) == 0 and self._right_strategy == RP_COMMON:
owned_keys = repo.list(filter_owner=settings.username)
for key in owned_keys:
node = repo.get(uuid=key)
if not isinstance(node, BlUser):
repo.change_owner(
key,
RP_COMMON,
recursive=recursive)
class Draw(Delayable): class Draw(Delayable):