# ============================================================================
#
# Copyright (C) 2007-2016 Conceptive Engineering bvba.
# www.conceptive.be / info@conceptive.be
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# * Neither the name of Conceptive Engineering nor the
# names of its contributors may be used to endorse or promote products
# derived from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
# ============================================================================
import six
from ....core.qt import QtGui, QtWidgets, Qt
from ....admin.action import field_action
from .customeditor import CustomEditor, set_background_color_palette
from camelot.view.art import Icon
from camelot.view.controls.decorated_line_edit import DecoratedLineEdit
[docs]class FileEditor(CustomEditor):
"""Widget for editing File fields"""
document_pixmap = Icon( 'tango/16x16/mimetypes/x-office-document.png' )
def __init__(self, parent=None,
storage=None,
field_name='file',
remove_original=False,
actions = [field_action.DetachFile(),
field_action.OpenFile(),
field_action.UploadFile(),
field_action.SaveFile()],
**kwargs):
CustomEditor.__init__(self, parent)
self.setSizePolicy( QtGui.QSizePolicy.Preferred,
QtGui.QSizePolicy.Fixed )
self.setObjectName( field_name )
self.storage = storage
self.filename = None # the widget containing the filename
self.value = None
self.file_name = None
self.remove_original = remove_original
self.actions = actions
self.setup_widget()
def file_completion_activated(self, index):
from camelot.view.storage import create_stored_file
source_index = index.model().mapToSource( index )
if not self.completions_model.isDir( source_index ):
path = self.completions_model.filePath( source_index )
create_stored_file(
self,
self.storage,
self.stored_file_ready,
filter=self.filter,
remove_original=self.remove_original,
filename = path,
)
def set_value(self, value):
value = CustomEditor.set_value(self, value)
self.value = value
if value is not None:
self.filename.setText(value.verbose_name)
else:
self.filename.setText('')
self.update_actions()
return value
def get_value(self):
return CustomEditor.get_value(self) or self.value
def set_field_attributes(self, **kwargs):
super(FileEditor, self).set_field_attributes(**kwargs)
self.set_enabled(kwargs.get('editable', False))
if self.filename:
set_background_color_palette( self.filename, kwargs.get('background_color', None))
self.filename.setToolTip(six.text_type(kwargs.get('tooltip') or ''))
self.remove_original = kwargs.get('remove_original', False)
def set_enabled(self, editable=True):
self.filename.setEnabled(editable)
self.filename.setReadOnly(not editable)
self.document_label.setEnabled(editable)
self.setAcceptDrops(editable)
#
# Drag & Drop
#
def dragEnterEvent(self, event):
event.acceptProposedAction()
def dragMoveEvent(self, event):
event.acceptProposedAction()
def dropEvent(self, event):
from camelot.view.storage import create_stored_file
if event.mimeData().hasUrls():
url = event.mimeData().urls()[0]
filename = url.toLocalFile()
if filename:
create_stored_file(
self,
self.storage,
self.stored_file_ready,
filter=self.filter,
remove_original=self.remove_original,
filename = filename,
)