X-Git-Url: http://git.onelab.eu/?p=sface.git;a=blobdiff_plain;f=sface%2Fsficreate.py;h=0405e3e2b22cd9b9c5fdf7d4f8943fdbec82d82e;hp=b3de732d824010bc79a8988c453aa1b7efa02f1f;hb=62dde09f684bc81e571f8c0d8439b39ec9b5cf2f;hpb=908ac46c4760618de030e0cad35479acc06dd22a;ds=sidebyside
diff --git a/sface/sficreate.py b/sface/sficreate.py
index b3de732..0405e3e 100644
--- a/sface/sficreate.py
+++ b/sface/sficreate.py
@@ -9,6 +9,7 @@ from PyQt4.QtCore import *
from PyQt4.QtGui import *
from sface.config import config
from sface.sfiprocess import SfiProcess
+from sface.screens.userscreen import UserView, UserModel
class CreateWindow(QDialog):
def __init__(self, parent=None):
@@ -23,12 +24,18 @@ class CreateWindow(QDialog):
self.hrnEdit = QLineEdit()
urlLabel = QLabel("Project URL:")
self.urlEdit = QLineEdit()
- descLabel = QLabel("Description")
+ descLabel = QLabel("Description:")
self.descEdit = QTextEdit()
+ self.descEdit.setMinimumWidth(400)
+ self.descEdit.setMaximumHeight(100)
+
+ self.userLabel = QLabel("Researchers:")
+ self.userView = UserView()
self.status = QLabel("")
self.buttonBox = QDialogButtonBox(QDialogButtonBox.Ok | QDialogButtonBox.Cancel)
+ self.buttonBox.addButton("refresh", QDialogButtonBox.ActionRole)
self.buttonBox.button(QDialogButtonBox.Ok).setDefault(True)
layout = QVBoxLayout()
@@ -38,12 +45,33 @@ class CreateWindow(QDialog):
layout.addWidget(self.urlEdit)
layout.addWidget(descLabel)
layout.addWidget(self.descEdit)
+ layout.addWidget(self.userLabel)
+ layout.addWidget(self.userView)
layout.addWidget(self.status)
layout.addWidget(self.buttonBox)
self.setLayout(layout)
+ self.userModel = UserModel(parent=self)
+
self.connect(self.buttonBox, SIGNAL("accepted()"), self, SLOT("accept()"))
self.connect(self.buttonBox, SIGNAL("rejected()"), self, SLOT("reject()"))
+ self.connect(self.buttonBox, SIGNAL("clicked(QAbstractButton *)"), self.clicked)
+
+ self.updateView()
+
+ if (self.userModel.rowCount() == 0):
+ self.refreshAuthority()
+
+ def clicked(self, button):
+ if button.text() == "refresh":
+ self.refreshAuthority()
+
+ def refreshAuthority(self):
+ self.refreshProcess = SfiProcess(self)
+ self.connect(self.refreshProcess, SIGNAL('finished()'), self.getAuthorityRecordFinished)
+
+ self.refreshProcess.listRecords(config.getAuthority(), "user", config.getAuthorityListFile())
+ self.setStatus("Refreshing user list...")
def accept(self):
auth = config.getAuthority()
@@ -52,6 +80,8 @@ class CreateWindow(QDialog):
type = "slice"
url = str(self.urlEdit.text())
+ researchers = self.userModel.getResearchers()
+
if not hrn.startswith(auth):
QMessageBox.warning(self, "Invalid HRN", "HRN must be within your current authority (%s)" % auth)
return
@@ -64,6 +94,10 @@ class CreateWindow(QDialog):
QMessageBox.warning(self, "Invalid Description", "Description is too short")
return
+ if not researchers:
+ QMessageBox.warning(self, "Invalid Researchers", "Please add at least one researcher by double-clicking on a researcher name")
+ return
+
self.setStatus("Registering Slice...")
self.createProcess = SfiProcess(self)
@@ -71,10 +105,16 @@ class CreateWindow(QDialog):
self.buttonBox.setEnabled(False)
+ researcherXml = "" + "".join(researchers) + ""
+
newSliceRecord = os.path.expanduser("~/.sfi/newslice.record")
- file(newSliceRecord, "w").write('' % (auth, desc, hrn, type, url))
+ file(newSliceRecord, "w").write('%s' % (auth, desc, hrn, type, url, researcherXml))
self.createProcess.addRecord(newSliceRecord)
+ def getAuthorityRecordFinished(self):
+ self.setStatus("User list refreshed.")
+ self.updateView()
+
def setStatus(self, x):
self.status.setText(x)
@@ -97,3 +137,10 @@ class CreateWindow(QDialog):
def getHrn(self):
return self.hrnEdit.text()
+ def updateView(self):
+ self.userModel.updateModel(None)
+
+ self.userView.setModel(self.userModel)
+ self.userView.hideUnusableColumns()
+ self.userView.resizeColumnToContents(0)
+