Beispiel #1
0
 public function validate_langid(Module_News $module, $langid)
 {
     if (!GWF_LangSelect::isValidLanguage($langid, false)) {
         return $this->module->lang('err_langid');
     }
     return false;
 }
Beispiel #2
0
 public function validate_langid(Module_Category $module, $langid)
 {
     if (!GWF_LangSelect::isValidLanguage($langid, true)) {
         $_POST['langid'] = 0;
         return $this->module->lang('err_invalid_langid');
     }
     if (self::$cat->getTranslation($langid) !== false) {
         $_POST['langid'] = 0;
         return $this->module->lang('err_dup_langid');
     }
     return false;
 }
Beispiel #3
0
 public function validate_langid2(Module_Account $module, $arg)
 {
     if (false === GWF_LangSelect::isValidLanguage($arg, true)) {
         return $this->module->lang('err_lang2');
     }
     return false;
 }
Beispiel #4
0
 public function execute()
 {
     $form = $this->formQuicksearch();
     # I like typehinting :S
     $module = $this->module;
     $module instanceof Module_PageBuilder;
     $user = GWF_User::getStaticOrGuest();
     $ulid = GWF_Language::getCurrentID();
     $table = GDO::table('GWF_Page');
     $joins = NULL;
     $tablename = $table->getTableName();
     # Build where clause
     $term = '';
     $where = '1';
     $language = '';
     $languaged = '1';
     if (isset($_GET['quicksearch'])) {
         # Termwhere
         if ('' !== ($term = Common::getGetString('term', ''))) {
             $fields = array('page_author_name', 'page_title', 'page_content');
             if (false === ($where = GWF_QuickSearch::getQuickSearchConditions($table, $fields, $term))) {
                 $where = '1';
             }
         }
         # Langwhere
         if (0 !== ($language = Common::getGetInt('lang', 0))) {
             if (GWF_LangSelect::isValidLanguage($language, false, GWF_Language::SUPPORTED)) {
                 $languaged = "(SELECT 1 FROM `{$tablename}` lt WHERE lt.page_otherid=t.page_otherid AND lt.page_lang={$language})";
             }
         }
     }
     $published = 'page_options&' . (GWF_Page::ENABLED | GWF_Page::LOCKED) . '=' . GWF_Page::ENABLED;
     $permquery = '1';
     # TODO: Check group permissions!
     $where = "({$permquery}) AND ({$where}) AND ({$published}) AND ({$languaged})";
     # Setup pagemenu
     $ipp = 25;
     $nItems = $table->selectVar('COUNT(DISTINCT(page_otherid))', $where, '', $joins);
     $nPages = GWF_PageMenu::getPagecount($ipp, $nItems);
     $page = Common::clamp(Common::getGetInt('page', 1), 1, $nPages);
     $from = GWF_PageMenu::getFrom($page, $ipp);
     # Setup order
     $by = Common::getGetString('by', 'page_id');
     $dir = Common::getGetString('dir', 'ASC');
     $orderby = $table->getMultiOrderby($by, $dir);
     # Now query only page_otherids
     if (false === ($pageids = $table->selectColumn('DISTINCT(page_otherid)', $where, $orderby, $joins, $ipp, $from))) {
         return GWF_HTML::err('ERR_DATABASE', array(__FILE__, __LINE__));
     }
     # Setup page array
     $pages = array();
     $languages = GWF_Language::getSupported();
     foreach ($pageids as $otherid) {
         $pagedata = $table->selectAll('page_id, page_lang, page_author_name, page_create_date, page_date, page_url, page_title', "page_otherid={$otherid}", "page_id={$otherid}");
         $title = '';
         $_langs = array();
         foreach ($pagedata as $data) {
             $pagelang = $data['page_lang'];
             // 				echo "$pagelang<br/>";
             # English 2nd choice
             if ($pagelang === '1' && $title === '') {
                 $title = $data['page_title'];
             } elseif ($data['page_lang'] === $ulid) {
                 $title = $data['page_title'];
             }
             # Store for next loop
             $_langs[$pagelang] = array($data['page_url']);
         }
         # Build output flags
         $langstring = '';
         foreach ($languages as $language) {
             $language instanceof GWF_Language;
             $lid = $language->getID();
             if (isset($_langs[$lid])) {
                 $langstring .= sprintf('<a href="%s%s">%s</a>', GWF_WEB_ROOT, $_langs[$lid][0], $language->displayFlag(), $lid);
             } else {
                 $langstring .= sprintf('<a href="%sindex.php?mo=PageBuilder&me=Translate&pageid=%s&to_lang_id=%s">%s</a>', GWF_WEB_ROOT, $otherid, $lid, GWF_Language::displayUnknownFlag($module->lang('translate_to', array($language->displayName()))));
             }
         }
         # Add as page row
         $pages[] = array('page_id' => $pagedata[0]['page_id'], 'page_otherid' => $otherid, 'page_title' => $title, 'page_url' => $pagedata[0]['page_url'], 'languages' => $langstring, 'page_date' => $pagedata[0]['page_date'], 'page_create_date' => $pagedata[0]['page_create_date'], 'page_author_name' => $pagedata[0]['page_author_name']);
     }
     # Display
     $tVars = array('quicksearch' => $form->templateX($this->module->lang('ft_search'), GWF_WEB_ROOT . 'index.php'), 'pages' => $pages, 'languages' => $languages, 'pagemenu' => GWF_PageMenu::display($page, $nPages, GWF_WEB_ROOT . 'index.php?mo=Lamb&me=Links&term=' . urlencode($term) . '&by=' . urlencode($by) . '&dir=' . urlencode($dir) . '&page=%PAGE%'), 'sort_url' => GWF_WEB_ROOT . 'index.php?mo=Lamb&me=Links&language=' . $language . '&term=' . urlencode($term) . '&by=%BY%&dir=%DIR%&page=' . $page);
     return $module->template('search.tpl', $tVars);
 }