summaryrefslogtreecommitdiff
path: root/app/frontend/controls/UserSelection.php
diff options
context:
space:
mode:
Diffstat (limited to 'app/frontend/controls/UserSelection.php')
-rw-r--r--app/frontend/controls/UserSelection.php45
1 files changed, 45 insertions, 0 deletions
diff --git a/app/frontend/controls/UserSelection.php b/app/frontend/controls/UserSelection.php
new file mode 100644
index 0000000..233f0bf
--- /dev/null
+++ b/app/frontend/controls/UserSelection.php
@@ -0,0 +1,45 @@
+<?php
+
+Prado::using('Application.web.FacadeTemplateControl');
+Prado::using('Application.user.DbUser');
+Prado::using('Application.facades.CalendarFacade');
+
+class UserSelection extends FacadeTemplateControl {
+
+ public function getUserToDisplay() {
+ return $this->getControlState('user');
+ }
+
+ public function setUserToDisplay(DbUser $user = NULL) {
+ $this->setControlState('user', $user);
+ }
+
+ public function onPreRender($param) {
+ parent::onPreRender($param);
+ $this->Categories->setDataSource(
+ $this->_getUserSelection($this->UserToDisplay)
+ );
+ $this->Categories->dataBind();
+ }
+
+ public function categoryDataBind($sender, $param) {
+ $param->Item->Calendars->setDataSource($param->Item->Data->Calendars);
+ $param->Item->Calendars->dataBind();
+ }
+
+ public function removeFromSelection($sender, $param) {
+ if (!$this->UserToDisplay->IsGuest) {
+ return $this->getFacade()->removeFromPreference(
+ $this->UserToDisplay,
+ $param->CommandParameter
+ );
+ }
+ }
+
+ private function _getUserSelection(DbUser $user) {
+ return $this->getFacade()->getPreferenceList($user);
+ }
+
+}
+
+?>