/** * mm_ddReadonly * @version 1.0.1 (2013-07-13) * * @desc Makes fields only readable. * * @uses ManagerManager plugin 0.5.1. * * @param $fields {comma separated string} - The name(s) of the document fields (or TVs) for which the widget is applying. @required * @param $roles {comma separated string} - The roles that the widget is applied to (when this parameter is empty then widget is applied to the all roles). Default: ''. * @param $templates {comma separated string} - Templates IDs for which the widget is applying (empty value means the widget is applying to all templates). Default: ''. * * @link http://code.divandesign.biz/modx/mm_ddreadonly/1.0.1 * * @copyright 2013, DivanDesign * http://www.DivanDesign.biz */ function mm_ddReadonly($fields = '', $roles = '', $templates = '') { global $modx, $mm_fields, $mm_current_page; $e =& $modx->Event; if (!useThisRule($roles, $templates)) { return; } //Перед сохранением документа if ($e->name == 'OnBeforeDocFormSave') { //Если создаётся новый документ, у него нет никакого id ещё, да и нам пофиг, т.к. никто ничего с ним всё равно не мог сделать до сохранения if ($e->params['mode'] == 'new') { return; } //ID документа $docId = $e->params['id']; //Если нужная переменная в сессии не определена, определим if (!is_array($_SESSION['mm_ddReadonly'])) { $_SESSION['mm_ddReadonly'] = array(); } //Разбиваем переданные поля в массивчик $fields = makeArray($fields); //Получаем id TV. TODO: Оптимизировать, чтобы всё было в один запрос $tvs = tplUseTvs($mm_current_page['template'], $fields, '', 'id,name'); //Результат $resultFields = array(); //Если что-то оплучили if (is_array($tvs) && count($tvs) > 0) { $tvsNames = array(); //Пробежимся, переделаем под удобный нам формат foreach ($tvs as $val) { $tvsNames[$val['id']] = $val['name']; } //Получаем значения TV $tvs = $modx->db->makeArray($modx->db->select('value,tmplvarid AS id', ddTools::$tables['site_tmplvar_contentvalues'], 'contentid=' . $docId . ' AND tmplvarid IN ' . makeSqlList(array_keys($tvsNames)))); //Если что-то нашлось if (count($tvs) > 0) { //Пробежимся foreach ($tvs as $val) { //Если значение не пустое if ($val['value'] != '') { //Запишем значения $resultFields[$tvsNames[$val['id']]] = $val['value']; } } } } //Перебираем поля foreach ($fields as $key => $val) { //Если такого поля нет или это TV if (!isset($mm_fields[$val]) || $mm_fields[$val]['tv'] == 1) { //Снесём unset($fields[$key]); } } if (count($fields) > 0) { //Получаем значения необходимых полей $fields = $modx->db->getRow($modx->db->select(implode(',', $fields), ddTools::$tables['site_content'], 'id=' . $docId)); //Переберём foreach ($fields as $key => $val) { if ($val != '') { $resultFields[$key] = $val; } } } //Если хоть что-то осталось if (count($resultFields) > 0) { //Сохраним значения в сессию, они нам ещё понадобятся $_SESSION['mm_ddReadonly'][$docId] = $resultFields; } //После сохранения документа } else { if ($e->name == 'OnDocFormSave') { //Если создаётся новый документ, у него нет никакого id ещё, да и нам пофиг, т.к. никто ничего с ним всё равно не мог сделать до сохранения if ($e->params['mode'] == 'new') { return; } //ID документа $docId = $e->params['id']; //Если данные о текущем документе есть if (is_array($_SESSION['mm_ddReadonly']) && is_array($_SESSION['mm_ddReadonly'][$docId]) && count($_SESSION['mm_ddReadonly'][$docId]) > 0) { //Обновляем данные документа в соответствии с тем, что было раньше ddTools::updateDocument($docId, $_SESSION['mm_ddReadonly'][$docId]); //Сносим за ненадобностью unset($_SESSION['mm_ddReadonly'][$docId]); } //При копировании документа } else { if ($e->name == 'OnDocDuplicate') { //Получаем id TV $tvs = tplUseTvs($mm_current_page['template'], $fields); //Если что-то оплучили if (is_array($tvs) && count($tvs) > 0) { $tvIds = array(); foreach ($tvs as $val) { $tvIds[] = $val['id']; } //Удаляем значение TV для данного документа $modx->db->delete(ddTools::$tables['site_tmplvar_contentvalues'], '`contentid` = ' . $e->params['new_id'] . ' AND `tmplvarid` IN(' . implode(',', $tvIds) . ')'); } //При рендере документа } else { if ($e->name == 'OnDocFormRender') { //Разбиваем переданные поля в массивчик $fields = makeArray($fields); //Если есть что-то if (count($fields) > 0) { $output = "// ---------------- mm_ddReadonly :: Begin ------------- \n"; $output .= 'var $mm_ddReadonly;'; //Получаем id TV $tvs = tplUseTvs($mm_current_page['template'], $fields); //Если что-то есть if (is_array($tvs) && count($tvs) > 0) { //Перебираем TV foreach ($tvs as $val) { //Вставляем значение перед оригиналом и сносим оригинал нафиг $output .= ' $mm_ddReadonly = $j("#tv' . $val['id'] . '"); $mm_ddReadonly.before($mm_ddReadonly.val()).hide(); '; } } if (count($fields) != count($tvs)) { //Перебираем поля foreach ($fields as $val) { //Если такое поле есть и это не TV if (isset($mm_fields[$val]) && $mm_fields[$val]['tv'] != 1) { $output .= ' $mm_ddReadonly = $j("' . $mm_fields[$val]['fieldtype'] . '[name=\\"' . $mm_fields[$val]['fieldname'] . '\\"]"); $mm_ddReadonly.before($mm_ddReadonly.val()).hide(); '; } } } $output .= "\n// ---------------- mm_ddReadonly :: End -------------"; $e->output($output . "\n"); } } } } } }
/** * mm_ddAutoFolders * @version 1.2 (2014-04-18) * * @desc Automatically move documents (OnBeforeDocFormSave event) based on their date (publication date; any date in tv) into folders of year and month (like 2012/02/). If folders (documents) of year and month doesn`t exist they are created automatically OnBeforeDocFormSave event. * * @uses ManagerManager plugin 0.5 * * @param $roles {comma separated string} - List of role IDs this should be applied to. Leave empty (or omit) for all roles. Default: ''. * @param $templates {comma separated string} - List of template IDs this should be applied to. Leave empty (or omit) for all templates. Default: ''. * @param $yearsParents {comma separated string} - IDs of ultimate parents (parents of the years). @required * @param $dateSource {string} - Name of template variable which contains the date. Default: 'pub_date'. * @param $yearFields {string: JSON} - Document fields and/or TVs that are required to be assigned to year documents. An associative array in JSON where the keys and values correspond field names and values respectively. Default: '{"template":0,"published":0}'. * @param $monthFields {string: JSON} - Document fields and/or TVs that are required to be assigned to month documents. An associative array in JSON where the keys and values correspond field names and values respectively. Default: '{"template":0,"published":0}'. * @param $yearPublished {0; 1} - Note this is a deprecated parameter, please, use “$yearFields”. Whether the year documents should be published? Default: —. * @param $monthPublished {0; 1} - Note this is a deprecated parameter, please, use “$monthFields”. Whether the month documents should be published? Default: —. * @param $numericMonth {boolean} - Numeric aliases for month documents. Default: false. * * @link http://code.divandesign.biz/modx/mm_ddautofolders/1.2 * * @copyright 2014, DivanDesign * http://www.DivanDesign.biz */ function mm_ddAutoFolders($roles = '', $templates = '', $yearsParents = '', $dateSource = 'pub_date', $yearFields = '{"template":0,"published":0}', $monthFields = '{"template":0,"published":0}', $yearPublished = NULL, $monthPublished = NULL, $numericMonth = false) { global $modx, $pub_date, $parent, $mm_current_page, $tmplvars, $modx_lang_attribute; $e =& $modx->Event; //$yearsParents is required if ($yearsParents != '' && $e->name == 'OnBeforeDocFormSave' && useThisRule($roles, $templates)) { $defaultFields = array('template' => 0, 'published' => 0); //Функция аналогична методу «$modx->getParentIds» за исключением того, что родитель = 0 тоже выставляется function getParentIds($id) { global $modx; $parents = $modx->getParentIds($id); //Если текущего id нет в массиве, значит его родитель = 0 if (!isset($parents[$id])) { $parents[$id] = 0; //Если текущий документ есть, а его родителя нет, значит родитель родителя = 0 } else { if (!isset($parents[$parents[$id]])) { $parents[$parents[$id]] = 0; } } return $parents; } //Получаем всех родителей текущего документа (или его родителя, если это новый документ) $allParents = getParentIds(is_numeric($e->params['id']) ? $e->params['id'] : $parent); $yearsParents = makeArray($yearsParents); //Перебираем переданных родителей foreach ($yearsParents as $key => $val) { //Если текущий документ не принадлежит к переданному родителю, значит этот родитель лишний if (!isset($allParents[$val])) { unset($yearsParents[$key]); } } //Если остался хоть один родитель (а остаться должен только один) if (count($yearsParents) > 0) { //Сбрасываем ключи $yearsParents = array_values($yearsParents); //Если документ не относится ни к одному переданному родителю, то ничего делать не нужно } else { return; } //Текущее правило $rule = array(); //Дата $ddDate = array(); //Если задано, откуда брать дату и это не дата публикации, пытаемся найти в tv`шках if ($dateSource && $dateSource != 'pub_date') { //Получаем tv с датой для данного шаблона $dateTv = tplUseTvs($mm_current_page['template'], $dateSource); //Если tv удалось получить, такая tv есть и есть её значение if ($dateTv && $dateTv[0]['id'] && $tmplvars[$dateTv[0]['id']] && $tmplvars[$dateTv[0]['id']][1]) { //Если дата в юникс-времени if (is_numeric($tmplvars[$dateTv[0]['id']][1])) { $ddDate['date'] = $tmplvars[$dateTv[0]['id']][1]; } else { //Пытаемся преобразовать в unix-время $ddDate['date'] = strtotime($tmplvars[$dateTv[0]['id']][1]); } } } else { $ddDate['date'] = $pub_date; } //Если не задана дата, выбрасываем if (!$ddDate['date']) { return; } //Псевдонимы родителей (какие должны быть) //Год в формате 4 цифры $ddDate['y'] = date('Y', $ddDate['date']); //Псевдоним месяца (порядковый номер номер с ведущим нолём или название на английском) $ddDate['m'] = $numericMonth ? date('m', $ddDate['date']) : strtolower(date('F', $ddDate['date'])); //Порядковый номер месяца $ddDate['n'] = date('n', $ddDate['date']); //Если язык админки — русский if (strtolower($modx_lang_attribute) == 'ru') { //Все месяцы на русском $ruMonthes = array('Январь', 'Февраль', 'Март', 'Апрель', 'Май', 'Июнь', 'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'); //Название месяца на русском $ddDate['mTitle'] = $ruMonthes[$ddDate['n'] - 1]; } else { //Просто запишем на английском $ddDate['mTitle'] = date('F', $ddDate['date']); } //Получаем список групп документов родителя (пригодится при создании годов и месяцев) $docGroups = $modx->db->getColumn('document_group', $modx->db->select('`document_group`', ddTools::$tables['document_groups'], '`document` = ' . $yearsParents[0])); $yearId = 0; $monthId = 0; //Получаем годы (непосредственных детей корневого родителя) $years = ddTools::getDocumentChildrenTVarOutput($yearsParents[0], array('id'), false, 'menuindex', 'ASC', '', 'alias'); if (isset($years[$ddDate['y']])) { //Получаем id нужного нам года $yearId = $years[$ddDate['y']]['id']; } //For backward compatibility if (is_numeric($yearFields)) { $yearFields = '{"template":' . $yearFields . ',"published":0}'; } if (is_numeric($monthFields)) { $monthFields = '{"template":' . $monthFields . ',"published":0}'; } $yearFields = json_decode($yearFields, true); $monthFields = json_decode($monthFields, true); if (!is_array($yearFields)) { $yearFields = $defaultFields; } if (!is_array($monthFields)) { $monthFields = $defaultFields; } //For backward compatibility too if ($yearPublished !== NULL) { $yearFields['published'] = $yearPublished; } if ($monthPublished !== NULL) { $monthFields['published'] = $monthPublished; } //Если нужный год существует if ($yearId != 0) { //Проставим году нужные параметры ddTools::updateDocument($yearId, array_merge($yearFields, array('isfolder' => 1))); //Получаем месяцы (непосредственных детей текущего года) $months = ddTools::getDocumentChildrenTVarOutput($yearId, array('id'), false, 'menuindex', 'ASC', '', 'alias'); if (isset($months[$ddDate['m']])) { //Получаем id нужного нам месяца $monthId = $months[$ddDate['m']]['id']; } //Если нужный год не существует } else { //Создадим его $yearId = ddTools::createDocument(array_merge($yearFields, array('pagetitle' => $ddDate['y'], 'alias' => $ddDate['y'], 'parent' => $yearsParents[0], 'isfolder' => 1, 'menuindex' => $ddDate['y'] - 2000)), $docGroups); } //Если нужный месяц существует if ($monthId != 0) { //Проставим месяцу нужные параметры ddTools::updateDocument($monthId, array_merge($monthFields, array('isfolder' => 1))); //Если нужный месяц не существует (на всякий случай проверим ещё и год) } else { if ($yearId) { $monthId = ddTools::createDocument(array_merge($monthFields, array('pagetitle' => $ddDate['mTitle'], 'alias' => $ddDate['m'], 'parent' => $yearId, 'isfolder' => 1, 'menuindex' => $ddDate['n'] - 1)), $docGroups); } } //Ещё раз на всякий случай проверим, что с месяцем всё хорошо if ($monthId && $monthId != $parent) { $parent = $monthId; } } }