summaryrefslogtreecommitdiff
path: root/app/frontend/controls/UrlBasedCalendarControl.php
diff options
context:
space:
mode:
authoremkael <emkael@tlen.pl>2016-06-07 15:17:49 +0200
committeremkael <emkael@tlen.pl>2016-06-10 11:46:41 +0200
commit823d71ced9b4947b1a5a5ade7245d521ed490061 (patch)
treea9a6c7cb0de74ff705e8320c284de423a698f5b5 /app/frontend/controls/UrlBasedCalendarControl.php
parentdf401552aac363655ab8f056a6c910a7611954d6 (diff)
* renaming php directory
Diffstat (limited to 'app/frontend/controls/UrlBasedCalendarControl.php')
-rw-r--r--app/frontend/controls/UrlBasedCalendarControl.php40
1 files changed, 40 insertions, 0 deletions
diff --git a/app/frontend/controls/UrlBasedCalendarControl.php b/app/frontend/controls/UrlBasedCalendarControl.php
new file mode 100644
index 0000000..a5be82e
--- /dev/null
+++ b/app/frontend/controls/UrlBasedCalendarControl.php
@@ -0,0 +1,40 @@
+<?php
+
+Prado::using('Application.web.FacadeTemplateControl');
+Prado::using('Application.facades.CalendarFacade');
+
+class UrlBasedCalendarControl extends FacadeTemplateControl {
+
+ public function setCalendarUrl(string $url = NULL) {
+ if ($url) {
+ $calendar = $this->getFacade()->resolveUrl($url);
+ if ($calendar) {
+ $this->setControlState('Calendar', $calendar);
+ return;
+ }
+ }
+ if ($this->getRaiseException()) {
+ throw new THttpException(
+ 404,
+ Prado::localize('Page not found')
+ );
+ } else {
+ $this->Visible = FALSE;
+ }
+ }
+
+ public function getCalendar() {
+ return $this->getControlState('Calendar');
+ }
+
+ public function setRaiseException($value) {
+ $this->setControlState('RaiseException', TPropertyValue::ensureBoolean($value));
+ }
+
+ public function getRaiseException() {
+ return $this->getControlState('RaiseException', FALSE);
+ }
+
+}
+
+?>