View source
<?php
define('KWANALYSIS_CACHE_TIMEOUT', 1728000);
define('KWARESEARCH_STATS_REPORT_ITEM_LIMIT_DEFAULT', 50);
require_once './' . drupal_get_path('module', 'kwresearch') . "/includes/stats.inc";
require_once './' . drupal_get_path('module', 'kwresearch') . "/includes/contentanalysis.inc";
function kwresearch_menu() {
$items = array();
$items['admin/content/kwresearch'] = array(
'title' => t('Keyword research'),
'page callback' => 'kwresearch_keywords_list_page',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'type' => MENU_NORMAL_ITEM,
'file' => 'includes/site_report.inc',
);
$items['admin/content/kwresearch/keyword_list'] = array(
'title' => t('Keyword lists'),
'page callback' => 'kwresearch_keywords_list_page',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'file' => 'includes/site_report.inc',
'weight' => -8,
'type' => MENU_LOCAL_TASK,
);
$items['admin/content/kwresearch/keyword_list/all'] = array(
'title' => t('All keywords'),
'page callback' => 'kwresearch_keywords_list_page',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'file' => 'includes/site_report.inc',
'weight' => -10,
'type' => MENU_DEFAULT_LOCAL_TASK,
);
$items['admin/content/kwresearch/keyword_list/site'] = array(
'title' => t('Site keywords'),
'page callback' => 'kwresearch_keywords_list_page',
'page arguments' => array(
'site',
),
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'file' => 'includes/site_report.inc',
'weight' => -8,
'type' => MENU_LOCAL_TASK,
);
$items['admin/content/kwresearch/keyword_list/page'] = array(
'title' => t('Page keywords'),
'page callback' => 'kwresearch_keywords_list_page',
'page arguments' => array(
'page',
),
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'file' => 'includes/site_report.inc',
'weight' => -6,
'type' => MENU_LOCAL_TASK,
);
$items['admin/content/kwresearch/keyword_report'] = array(
'title' => t('Keyword stats'),
'page callback' => 'kwresearch_keyword_stats_report_page',
'access callback' => 'user_access',
'access arguments' => array(
'access content',
),
'type' => MENU_LOCAL_TASK,
'weight' => -6,
'file' => 'includes/stats_report.inc',
);
$items['admin/content/kwresearch/keyword_list/edit'] = array(
'title' => t('Add keyword'),
'page callback' => 'kwresearch_keywords_list_edit',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'type' => MENU_LOCAL_TASK,
'file' => 'kwresearch.admin.inc',
);
$items['admin/content/kwresearch/keyword_list/import'] = array(
'title' => t('Import keywords'),
'page callback' => 'kwresearch_site_keywords_import',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'type' => MENU_LOCAL_TASK,
'file' => 'kwresearch.admin.inc',
);
$items['admin/content/kwresearch/keyword_pages'] = array(
'title' => t('Page keyword list'),
'page callback' => 'kwresearch_keyword_pages_page',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin page keywords',
),
'type' => MENU_CALLBACK,
'file' => 'kwresearch.admin.inc',
);
$items['admin/content/kwresearch/page_keywords'] = array(
'title' => t('Page keyword list'),
'page callback' => 'kwresearch_page_keywords_page',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin page keywords',
),
'type' => MENU_CALLBACK,
'file' => 'includes/page_report.inc',
);
$items['node/%node/kwresearch'] = array(
'title' => 'Keywords',
'page callback' => 'kwresearch_page_keywords_page',
'page arguments' => array(
1,
'node',
),
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin page keywords',
),
'type' => MENU_LOCAL_TASK,
'weight' => 50,
'file' => 'includes/page_report.inc',
);
$items['admin/content/kwresearch/page_keywords_edit'] = array(
'title' => t('Add page keyword'),
'page callback' => 'kwresearch_page_keywords_edit',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin page keywords',
),
'type' => MENU_CALLBACK,
'file' => 'kwresearch.admin.inc',
);
$items['admin/content/kwresearch/clear_keywords'] = array(
'title' => t('Clear Keyword Reserach keywords'),
'page callback' => 'kwresearch_clear_keywords',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin page keywords',
),
'type' => MENU_CALLBACK,
'file' => 'kwresearch.admin.inc',
);
$items['admin/settings/kwresearch'] = array(
'title' => t('Keyword research'),
'description' => 'Analize keywords for search optimization.',
'page callback' => 'drupal_get_form',
'page arguments' => array(
'kwresearch_admin_settings',
),
'access callback' => 'user_access',
'access arguments' => array(
'administer page titles',
),
'type' => MENU_NORMAL_ITEM,
'file' => 'kwresearch.admin.inc',
);
$items['kwresearch/keyword_tax_report_js'] = array(
'title' => '',
'page callback' => 'kwresearch_keywords_tax_report_js',
'access callback' => 'user_access',
'access arguments' => array(
'perform content analysis',
),
'type' => MENU_CALLBACK,
'file' => 'includes/tax_report.inc',
);
$items['kwresearch/analyze_js'] = array(
'title' => '',
'page callback' => 'kwresearch_analyze_js',
'access callback' => 'user_access',
'access arguments' => array(
'perform content analysis',
),
'type' => MENU_CALLBACK,
);
$items['kwresearch/toggle_site_keyword_js'] = array(
'title' => '',
'page callback' => 'kwresearch_toggle_site_keyword_js',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'type' => MENU_CALLBACK,
);
$items['kwresearch/toggle_page_keyword_js'] = array(
'title' => '',
'page callback' => 'kwresearch_toggle_page_keyword_js',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin page keywords',
),
'type' => MENU_CALLBACK,
);
$items['kwresearch/delete_site_keyword_js'] = array(
'title' => '',
'page callback' => 'kwresearch_delete_site_keyword_js',
'access callback' => 'user_access',
'access arguments' => array(
'kwresearch admin site keywords',
),
'type' => MENU_CALLBACK,
);
return $items;
}
function kwresearch_perm() {
return array(
'kwresearch admin site keywords',
'kwresearch admin page keywords',
);
}
function kwresearch_save_site_keyword($keyword, $kid = NULL, $keyword_obj = NULL, $update_stats = FALSE) {
$keyword = strtolower($keyword);
$key = $kid ? $kid : $keyword;
if (!$key) {
return FALSE;
}
$keyword_obj0 = kwresearch_load_site_keyword($key);
if (!$kid && $keyword_obj0->kid) {
$kid = $keyword_obj0->kid;
}
if (!$keyword_obj->uid) {
$keyword_obj->uid = $keyword_obj0->uid ? $keyword_obj0->uid : $GLOBALS['user']->uid;
}
if (is_null($keyword_obj->priority)) {
$keyword_obj->priority = $keyword_obj0->priority ? $keyword_obj0->priority : -1;
}
if (!$keyword_obj->value) {
$keyword_obj->value = $keyword_obj0->value ? $keyword_obj0->value : -1;
}
if (!$kid) {
$sql = '
INSERT INTO {kwresearch_keyword}
(uid, keyword, word_count, priority, value)
VALUES (%d, "%s", %d, %d, %d)
';
db_query($sql, $keyword_obj->uid, $keyword, str_word_count($keyword), $keyword_obj->priority, $keyword_obj->value);
$kid = db_last_insert_id('kwresearch_keyword', 'kid');
}
else {
$sql = '
UPDATE {kwresearch_keyword}
SET
priority = %d,
value = %f,
uid = %d
WHERE kid = %d
';
db_query($sql, $keyword_obj->priority, $keyword_obj->value, $keyword_obj->uid, $kid);
}
if ($update_stats) {
$kw_stats = kwresearch_get_keyword_stats_data($keyword, $msgs);
if ($msgs) {
foreach ($msgs as $msg) {
drupal_set_message($msg['value'], $msg['status']);
}
}
}
return $kid;
}
function kwresearch_delete_site_keyword($key) {
if (is_numeric($key)) {
$kid = $key;
}
else {
$keyword_obj = kwresearch_load_site_keyword($key);
if ($keyword_obj->kid) {
$kid = $keyword_obj->kid;
}
else {
return FALSE;
}
}
$sql = '
DELETE FROM {kwresearch_keyword}
WHERE kid = %d
';
db_query($sql, $kid);
return TRUE;
}
function kwresearch_clear_site_keywords() {
$sql = '
DELETE FROM {kwresearch_keyword}
WHERE page_count = 0
AND (priority IS NULL || priority = 0)
';
db_query($sql);
drupal_set_message(t('Unused keywords have been cleared.'));
return t('OK');
}
function kwresearch_load_site_keyword($key) {
if ($key > 0) {
$sql = '
SELECT *
FROM {kwresearch_keyword}
WHERE kid = %d
';
$keyword_obj = db_fetch_object(db_query($sql, $key));
}
else {
$sql = '
SELECT *
FROM {kwresearch_keyword}
WHERE keyword = "%s"
';
$keyword_obj = db_fetch_object(db_query($sql, $key));
}
return $keyword_obj;
}
function kwresearch_load_filtered_keyword_result($filter = array(), $options = array(), $header = array(), $limit = 100, $offset = NULL) {
$sql = "\n SELECT k.*, u.name AS username \n FROM {kwresearch_keyword} k \n LEFT JOIN {users} u ON u.uid = k.uid\n ";
$count_sql = "\n SELECT COUNT(*) \n FROM {kwresearch_keyword} k\n ";
if (!empty($header)) {
$tablesort = tablesort_sql($header);
}
if (!empty($filter['where'])) {
$sql .= " WHERE " . ($options['mode'] == 'site' ? 'k.priority >= 0 AND ' : '') . $filter['where'];
$count_sql .= " WHERE " . ($options['mode'] == 'site' ? 'k.priority >= 0 AND ' : '') . $filter['where'];
}
else {
if ($options['mode'] == 'site') {
$sql .= ' WHERE k.priority >= 0';
$count_sql .= ' WHERE k.priority >= 0';
}
elseif ($options['mode'] == 'page') {
$sql .= ' WHERE k.page_count > 0';
$count_sql .= ' WHERE k.page_count > 0';
}
}
$sql .= $tablesort;
if ($offset) {
$filter['args'][] = $offset;
$filter['args'][] = $limit;
$sql .= '
LIMIT %d, %d';
$result = db_query($sql, $filter['args']);
}
else {
$result = pager_query($sql, $limit, 0, $count_sql, $filter['args']);
}
return $result;
}
function kwresearch_get_kid($keyword) {
$keyword_obj = kwresearch_load_site_keyword($keyword);
return $keyword_obj->kid;
}
function kwresearch_get_keyword($kid) {
$keyword_obj = kwresearch_load_site_keyword($kid);
return $keyword_obj->keyword;
}
function kwresearch_construct_pathnid_obj($pid, $msgs) {
if (!$pid) {
return FALSE;
}
$obj = new stdClass();
if ($pid > 0) {
$obj->nid = $pid;
$obj->path = 'node/' . $obj->nid;
$obj->external = 0;
}
else {
$item = array(
'link_path' => $pid,
);
kwresearch_parse_menu_item($item, $msgs);
if (is_array($msgs)) {
foreach ($msgs as $msg) {
form_set_error($msg['element'], $msg['message']);
if ($msg['status'] == 'error') {
return FALSE;
}
}
}
$obj->path = $item['link_path'];
$obj->external = $item['external'];
list($n, $nid, $e) = explode('/', $path);
if ($n == 'node' && is_numeric($nid)) {
$obj->nid = $nid;
}
}
return $obj;
}
function kwresearch_save_page_keyword($pid, $keyword, $kid = NULL, $page_keyword_obj = NULL, $update_stats = FALSE, $save_term = FALSE) {
if (!is_object($page_keyword_obj)) {
$page_keyword_obj = new stdClass();
}
$keyword = strtolower($keyword);
$key = $kid ? $kid : $keyword;
if (!$key) {
return FALSE;
}
$keyword_obj0 = kwresearch_load_site_keyword($key);
if (!$keyword_obj0->kid) {
$kid = kwresearch_save_site_keyword($keyword);
$keyword_obj0 = kwresearch_load_site_keyword($kid);
}
$kid = $keyword_obj0->kid;
$page_keyword_obj0 = kwresearch_load_page_keyword($pid, $kid);
if (!$page_keyword_obj->uid) {
$page_keyword_obj->uid = $page_keyword_obj0->uid ? $page_keyword_obj0->uid : $GLOBALS['user']->uid;
}
if (!is_numeric($page_keyword_obj->priority)) {
$page_keyword_obj->priority = $page_keyword_obj0->priority ? $page_keyword_obj0->priority : -1;
}
$pn = kwresearch_construct_pathnid_obj($pid, $msgs);
if (!$page_keyword_obj0->kid) {
$sql = '
INSERT INTO {kwresearch_page_keyword}
(kid, nid, path, priority, uid)
VALUES (%d, %d,"%s", %d, %d)
';
db_query($sql, $kid, $pn->nid, $pn->path, $page_keyword_obj->priority, $page_keyword_obj->uid);
}
else {
if ($page_keyword_obj->priority) {
$sql = '
UPDATE {kwresearch_page_keyword}
SET priority = %d
WHERE kid = %d
AND path="%s"
';
db_query($sql, $page_keyword_obj->priority, $kid, $pn->path);
}
else {
kwresearch_delete_page_keyword($kid, $pid);
}
}
kwresearch_update_keyword_page_counts($kid);
return $kid;
}
function kwresearch_delete_page_keyword($key, $pid) {
if (is_numeric($key)) {
$kid = $key;
}
else {
$keyword_obj = kwresearch_load_page_keyword($key);
if ($keyword_obj->kid) {
$kid = $keyword_obj->kid;
}
else {
return FALSE;
}
}
$pn = kwresearch_construct_pathnid_obj($pid, $msgs);
$sql = "\n DELETE FROM {kwresearch_page_keyword}\n WHERE \n kid = %d\n AND path = '%s'\n ";
db_query($sql, $kid, $pn->path);
return TRUE;
}
function kwresearch_delete_page_keywords_by_page($pid) {
$page_keywords = kwresearch_load_page_keywords_by_page($pid);
$pn = kwresearch_construct_pathnid_obj($pid, $msgs);
$sql = "\n DELETE FROM {kwresearch_page_keyword}\n WHERE path = '%s'\n ";
db_query($sql, $pn->path);
foreach ($page_keywords as $page_keyword) {
kwresearch_update_keyword_page_counts($page_keyword->kid);
}
}
function kwresearch_load_page_keyword($pid, $key) {
$site_keyword_obj = kwresearch_load_site_keyword($key);
$kid = $site_keyword_obj->kid;
$pn = kwresearch_construct_pathnid_obj($pid, $msgs);
$sql = "\n SELECT * \n FROM {kwresearch_page_keyword}\n WHERE kid = %d\n AND path = '%s'\n ";
$page_keyword_obj = db_fetch_object(db_query($sql, $kid, $pn->path));
$page_keyword_obj->site = $site_keyword_obj;
return $page_keyword_obj;
}
function kwresearch_load_page_keywords_by_keyword($key) {
if (!is_numeric($key) || $key <= 0) {
$keyword_obj = kwresearch_load_site_keyword($key);
$kid = $keyword_obj->kid;
}
else {
$kid = $key;
}
$sql = '
SELECT *
FROM {kwreserach_page_keyword}
WHERE kid = %d
';
$result = db_query($sql, $kid);
$page_keywords = array();
while ($row = db_fetch_object($result)) {
$page_keywords[] = $row;
}
return $page_keywords;
}
function kwresearch_load_page_keywords_by_page($pid) {
$pn = kwresearch_construct_pathnid_obj($pid, $msgs);
$sql = "\n SELECT pk.*, k.keyword, k.priority AS site_priority, k.value AS value \n FROM {kwresearch_page_keyword} pk\n JOIN {kwresearch_keyword} k ON pk.kid = k.kid\n WHERE path = '%s'\n ";
$result = db_query($sql, $pn->path);
$page_keywords = array();
while ($row = db_fetch_object($result)) {
$page_keywords[] = $row;
}
return $page_keywords;
}
function kwresearch_update_keyword_page_counts($kid) {
$sql = '
SELECT COUNT(*)
FROM {kwresearch_page_keyword}
WHERE kid = %d
';
$count = db_result(db_query($sql, $kid));
$sql = '
UPDATE {kwresearch_keyword}
SET page_count = %d
WHERE kid = %d
';
db_query($sql, $count, $kid);
return $count;
}
function kwresearch_get_priority_options() {
return array(
-1 => t('None'),
0 => t('TBD'),
10 => t('Very low'),
30 => t('Low'),
50 => t('Standard'),
70 => t('High'),
90 => t('Top'),
);
}
function kwresearch_toggle_site_keyword_js() {
global $user;
if (empty($_POST['token']) || !drupal_valid_token($_POST['token'], 'kwresearch')) {
drupal_access_denied();
drupal_exit();
}
$keyword = check_plain($_POST['kwresearch_keyword']);
$priority = check_plain($_POST['priority']);
$keyword_obj = new stdClass();
$keyword = strtolower(check_plain($_POST['kwresearch_keyword']));
$keyword_obj->priority = check_plain($_POST['priority']);
$kid = kwresearch_save_site_keyword($keyword, NULL, $keyword_obj);
$keyword_obj = kwresearch_load_site_keyword($kid);
if ($user->uid != $keyword_obj->uid) {
$theuser = user_load($keyword_obj->uid);
}
else {
$theuser = $user;
}
$site_priority_options = kwresearch_get_priority_options();
$output = array();
$output['data'] = array(
'kid' => (int) $keyword_obj->kid,
'keyword' => $keyword,
'priority' => (int) $keyword_obj->priority,
'priority_out' => $keyword_obj->priority >= 0 ? $site_priority_options[$keyword_obj->priority] : '-',
'value' => (double) $keyword_obj->value,
'value_out' => $keyword_obj->value >= 0 ? t('$') . number_format($keyword_obj->value, 2) : '-',
'user_out' => $theuser->uid ? l($theuser->name, 'user/' . $theuser->uid) : '-',
);
drupal_json($output);
}
function kwresearch_delete_site_keyword_js() {
if (empty($_POST['token']) || !drupal_valid_token($_POST['token'], 'kwresearch')) {
drupal_access_denied();
drupal_exit();
}
$keyword = check_plain($_POST['kwresearch_keyword']);
$kid = check_plain($_POST['kid']);
$deleted = kwresearch_delete_site_keyword($kid);
$site_priority_options = kwresearch_get_priority_options();
$output = array();
$output['data'] = array(
'kid' => (int) $kid,
'keyword' => $keyword,
'deleted' => (bool) $deleted,
);
drupal_json($output);
}
function kwresearch_toggle_page_keyword_js() {
if (empty($_POST['token']) || !drupal_valid_token($_POST['token'], 'kwresearch')) {
drupal_access_denied();
drupal_exit();
}
$keyword = strtolower(check_plain($_POST['kwresearch_keyword']));
$nid = check_plain($_POST['nid']);
$path = check_plain($_POST['path']);
$pid = !$nid ? $path : $nid;
$page_keyword_obj = new stdClass();
$page_keyword_obj->priority = check_plain($_POST['priority']);
kwresearch_save_page_keyword($pid, $keyword, NULL, $page_keyword_obj);
$output = array();
$output['data'] = array(
'keyword' => $keyword,
'priority' => (int) $page_keyword_obj->priority,
);
drupal_json($output);
}
function kwresearch_analyze_js() {
if (empty($_POST['kwresearch_token']) || !drupal_valid_token($_POST['kwresearch_token'], 'kwresearch')) {
drupal_access_denied();
drupal_exit();
}
require_once './' . drupal_get_path('module', 'kwresearch') . "/includes/stats_report.inc";
$analysis['inputs'] = array(
'keyword' => check_plain($_POST['kwresearch_keyword']),
'kwresearch_include_misspellings' => check_plain($_POST['kwresearch_include_misspellings']),
'kwresearch_include_plurals' => check_plain($_POST['kwresearch_include_plurals']),
'kwresearch_adult_filter' => check_plain($_POST['kwresearch_adult_filter']),
'nid' => check_plain($_POST['kwresearch_nid']),
);
if ($analysis['inputs']['nid'] == -1) {
$analysis['inputs']['nid'] = NULL;
}
$analysis['analysis'] = kwresearch_get_keyword_stats_data($analysis['inputs']['keyword'], $msgs, $analysis['inputs']);
if (!empty($msgs)) {
$analysis['messages'] = $msgs;
}
$output = array();
$output['report']['data'] = $analysis;
$output['report']['output'] = theme_keyword_stats_report($analysis);
drupal_json($output);
}
function kwresearch_nodeapi(&$node, $op, $a3 = NULL, $a4 = NULL) {
if ($op == 'insert' || $op == 'update') {
static $vocab_filtered = FALSE;
if (!($kw_vid = variable_get('kwresearch_keyword_sync_vocabulary', 0))) {
return;
}
$processed = array();
$page_keywords = kwresearch_load_page_keywords_by_page($node->nid);
foreach ($page_keywords as $page_keyword) {
$processed[$page_keyword->kid] = 0;
}
$terms_str = $node->taxonomy['tags'][$kw_vid];
$terms = explode(',', $terms_str);
$node_terms_str = '';
$needs_filtering = 1;
if (is_array($terms)) {
foreach ($terms as $term) {
$page_priority = $site_priority = $site_value = FALSE;
list($term, $args) = explode('[', $term);
if (substr($args, -1) == ']') {
$args = substr($args, 0, -1);
list($page_priority, $site_priority, $site_value) = explode(';', $args);
}
$term = trim($term);
if (!$page_keyword_obj) {
$page_keyword_obj = new stdClass();
if ($page_priority) {
$page_keyword_obj->priority = $page_priority;
$needs_filtering = 1;
}
else {
$page_keyword_obj->priority = 50;
}
}
$kid = kwresearch_save_page_keyword($node->nid, $term, NULL, $page_keyword_obj);
$processed[$kid] = 1;
$node_terms_str .= ($node_terms_str ? ',' : '') . $term;
}
}
if (!$vocab_filtered && $needs_filtering) {
$vocab_filtered = TRUE;
$node->taxonomy['tags'][$kw_vid] = $node_terms_str;
node_save($node);
}
$page_keyword_obj = new stdClass();
$page_keyword_obj->priority = 0;
foreach ($processed as $kid => $v) {
if (!$v) {
kwresearch_delete_page_keyword($kid, $node->nid);
}
}
}
elseif ($op == 'delete') {
kwresearch_delete_page_keywords_by_page($node->nid);
}
}
function kwresearch_form_alter(&$form, $form_state, $form_id) {
if (isset($form['type']['#value']) && $form['type']['#value'] . '_node_form' == $form_id) {
require_once './' . drupal_get_path('module', 'kwresearch') . "/includes/tax_report.inc";
drupal_add_css(drupal_get_path('module', 'kwresearch') . '/kwresearch.css');
drupal_add_js(drupal_get_path('module', 'kwresearch') . '/kwresearch.js');
$report_vocabs = variable_get('kwresearch_report_vocabulary', array());
$sync_vocab = variable_get('kwresearch_keyword_sync_vocabulary', '');
$weight = 0;
$img = base_path() . '/' . drupal_get_path('module', 'contentanalysis') . '/icons/refresh.png';
if (is_array($form['taxonomy']['tags'])) {
foreach ($form['taxonomy']['tags'] as $vid => $tf) {
$form['taxonomy']['tags'][$vid]['#weight'] = $weight++;
if ($report_vocabs[$vid]) {
$keywords = $tf['#default_value'];
$form['taxonomy']['tags']['kwresearch-tax-report-' . $vid] = array(
'#type' => 'item',
'#title' => t('Keyword report'),
'#value' => kwresearch_keywords_tax_report($keywords),
'#prefix' => '<div id="kwresearch-tax-report-' . $vid . '" class="kwresearch-tax-report kwresearch-tax-report-' . $vid . '">',
'#suffix' => '</div>',
'#weight' => $weight++,
);
}
if ($form['nid']['#value']) {
if ($sync_vocab == $vid) {
$terms = array();
$ts = explode(',', $form['taxonomy']['tags'][$vid]['#default_value']);
foreach ($ts as $term) {
$t = trim($term);
$terms[$t] = $t;
}
$page_keywords = kwresearch_load_page_keywords_by_page($form['nid']['#value']);
foreach ($page_keywords as $keyword_obj) {
if (!$terms[$keyword_obj->keyword]) {
$form['taxonomy']['tags'][$vid]['#default_value'] .= ($form['taxonomy']['tags'][$vid]['#default_value'] ? ', ' : '') . $keyword_obj->keyword;
}
}
}
}
}
}
drupal_add_js(array(
'kwresearch' => array(
'tax_report_callback' => base_path() . 'kwresearch/keyword_tax_report_js',
'tax_report_vocabs' => $report_vocabs,
'base_path' => base_path(),
'path_to_module' => base_path() . drupal_get_path('module', 'kwresearch'),
'post_token' => drupal_get_token('kwresearch'),
),
), 'setting');
}
}
function kwresearch_format_message($message, $type = 'status') {
return array(
'value' => $message,
'status' => $type,
);
}
function kwresearch_get_report_data_options($report = 'stats', $th = FALSE) {
if ($report == 'stats') {
$options = array(
'site_priority' => $th ? t('Site priority') : t('Keyword\'s priority for the site'),
'site_value' => $th ? t('Site value') : t('Keyword\'s value for the site'),
'total_dailyest' => $th ? t('Total daily') : t('Total daily estimated searches'),
'competition' => $th ? t('Competition') : t('Rating of competition for keyword'),
'bid' => $th ? t('Bid') : t('Recommended bid price for keyword'),
'google_dailyest' => $th ? t('Google daily') : t('Google daily estimated searches'),
'yahoo_dailyest' => $th ? t('Yahoo! daily') : t('Yahoo! daily estimated searches'),
'bing_dailyest' => $th ? t('Bing daily') : t('Bing daily estimated searches'),
);
}
elseif ($report == 'site') {
$options = array(
'daily_volume' => $th ? t('Total daily') : t('Total daily estimated searches'),
'competition' => $th ? t('Competition') : t('Rating of competition for keyword'),
'bid' => $th ? t('Bid') : t('Recommended bid price for keyword'),
'google_dailyest' => $th ? t('Google daily') : t('Google daily estimated searches'),
'yahoo_dailyest' => $th ? t('Yahoo! daily') : t('Yahoo! daily estimated searches'),
'bing_dailyest' => $th ? t('Bing daily') : t('Bing daily estimated searches'),
);
}
$sources = module_invoke_all('kwresearch_sources');
if (is_array($sources)) {
foreach ($sources as $aid => $source) {
if (is_array($source[$report . '_report_columns'])) {
foreach ($source[$report . '_report_columns'] as $k => $v) {
$options[$k] = $v;
}
}
}
}
return $options;
}
function kwresearch_format_report_data_value($values, $keyword = '', $type = 'term') {
switch ($type) {
case 'term':
$output = '<span class="kwresearch_keyword">' . $values['term'] . '</div>';
break;
case 'site_priority':
$output = '-';
if ($values['priority'] >= 0) {
$options = kwresearch_get_priority_options();
$output = $options[$values['priority']];
}
break;
case 'site_value':
$output = $values['value'] > 0 ? t('$') . number_format($values['value'], 2) : '-';
$type = 'value';
break;
case 'page_priority':
$output = '-';
if ($values['page_priority'] > 0) {
$options = kwresearch_get_priority_options();
$output = $options[$values['page_priority']];
}
break;
case 'daily_volume':
case 'total_dailyest':
$coefs = kwresearch_get_report_coefs();
if (is_null($values['_searches']) || $values['_searches'] < 0) {
$output = 'NA';
}
else {
$output = '<div class="stats-indicator">';
$output .= ' <div class="searches-indicator-bar" style="width: ' . 100 * $values['_searches'] / $values['_meta']['searches_max'] . '%;" title="' . number_format($values['_competition']) . '">';
$output .= ' <div class="stats-indicator-text">' . number_format($values['_searches']) . '</div>';
$output .= ' </div>';
$output .= '</div>';
}
break;
case 'competition':
if (is_null($values['_competition']) || $values['_competition'] < 0) {
$output = 'NA';
}
else {
$output = '<div class="stats-indicator">';
$output .= ' <div class="competition-indicator-bar" style="width: ' . $values['_competition'] . '%;" title="' . number_format($values['_competition']) . '">';
$output .= ' <div class="stats-indicator-text">' . number_format($values['_competition']) . '%</div>';
$output .= ' </div>';
$output .= '</div>';
}
break;
case 'bid':
$output = $values['_bid'] > 0 ? t('$') . number_format($values['_bid'], 2) : '-';
if (is_null($values['_bid']) || $values['_bid'] < 0) {
$output = 'NA';
}
elseif ($values['_bid'] == 0) {
$output = '-';
}
else {
$output = '<div class="stats-indicator">';
$output .= ' <div class="bid-indicator-bar" style="width: ' . 100 * $values['_bid'] / $values['_meta']['bid_max'] . '%;" title="' . number_format($values['_competition']) . '">';
$output .= ' <div class="stats-indicator-text">' . t('$') . number_format($values['_bid'], 2) . '</div>';
$output .= ' </div>';
$output .= '</div>';
}
break;
break;
case 'google_dailyest':
$coefs = kwresearch_get_report_coefs();
$v = $values['_searches'] == 0 ? 'NA' : number_format($values['_searches'] * $coefs['google_search_share']);
$output = l($v, 'http://www.google.com/search?btnG=Google+Search&q=' . $keyword, array(
'attributes' => array(
'target' => $type,
),
));
break;
case 'yahoo_dailyest':
$coefs = kwresearch_get_report_coefs();
$v = $values['_searches'] == 0 ? 'NA' : number_format($values['_searches'] * $coefs['yahoo_search_share']);
$output = l($v, 'http://search.yahoo.com/search?fr=ytff-&ei=UTF-8&rs=all&p=' . $keyword, array(
'attributes' => array(
'target' => $type,
),
));
break;
case 'bing_dailyest':
$coefs = kwresearch_get_report_coefs();
$v = $values['_searches'] == 0 ? 'NA' : number_format($values['_searches'] * $coefs['bing_search_share']);
$output = l($v, 'http://www.bing.com/search?q=' . $keyword, array(
'attributes' => array(
'target' => $type,
),
));
break;
default:
return FALSE;
}
$output = array(
'data' => $output,
'class' => $type,
);
return $output;
}
function kwresearch_get_report_coefs() {
return array(
'google_search_share' => 0.709,
'yahoo_search_share' => 0.2035,
'bing_search_share' => 0.0885,
);
}
function kwresearch_count_sort($a, $b) {
$a_count = is_array($a) && isset($a['_searches']) ? $a['_searches'] : 0;
$b_count = is_array($b) && isset($b['_searches']) ? $b['_searches'] : 0;
if ($a_count == $b_count) {
return 0;
}
return $a_count > $b_count ? -1 : 1;
}
function kwresearch_parse_menu_item(&$item, &$msgs = array()) {
if (!is_array($item)) {
$item = array(
'link_path' => $item,
);
}
$regex = '/^' . str_replace('/', '\\/', base_path()) . '/';
$item['link_path'] = preg_replace($regex, '', $item['link_path']);
$item['external'] = 0;
$normal_path = drupal_get_normal_path($item['link_path']);
if ($item['link_path'] != $normal_path) {
$msgs[] = array(
'message' => t('Keyword Research stores system paths only, but will use the URL alias in links. %link_path has been stored as %normal_path', array(
'%link_path' => $item['link_path'],
'%normal_path' => $normal_path,
)),
'status' => 'status',
);
$item['link_path'] = $normal_path;
}
if (!menu_path_is_external($item['link_path'])) {
$parsed_link = parse_url($item['link_path']);
if (isset($parsed_link['query'])) {
$item['options']['query'] = $parsed_link['query'];
}
else {
unset($item['options']['query']);
}
if (isset($parsed_link['fragment'])) {
$item['options']['fragment'] = $parsed_link['fragment'];
}
else {
unset($item['options']['fragment']);
}
if ($item['link_path'] != $parsed_link['path']) {
$item['link_path'] = $parsed_link['path'];
}
list($n, $nid, $e) = explode('/', $normal_path);
if ($n == 'node' && is_numeric($nid)) {
$item['nid'] = (int) $nid;
}
}
else {
$item['external'] = 1;
}
if (!trim($item['link_path']) || !menu_valid_path($item)) {
$msgs[] = array(
'message' => t("The path '@link_path' is either invalid or you do not have access to it.", array(
'@link_path' => $item['link_path'],
)),
'status' => 'error',
'element' => 'link_path',
);
return FALSE;
}
return $item;
}
function kwresearch_set_admin_theme() {
if (!($admin_theme = variable_get('admin_theme', '0'))) {
return;
}
if (arg(0) == 'node' && is_numeric(arg(1)) && !variable_get('node_admin_theme', '0')) {
return;
}
global $custom_theme;
$custom_theme = $admin_theme;
}