เมื่อใช้ Drupal 7 และ Views 3 เป็นวิธีที่ถูกต้องในการปรับเปลี่ยนค่าตัวกรอง Views เพื่อให้มีผลกับเนื้อหาที่กำลังจะแสดงผลอย่างไร
ฉันลองทุกอย่างที่กล่าวถึงที่นี่เพื่อ D6
แม้ว่าบางคนจะใช้งานได้ แต่ Merlin กล่าวว่าการปรับเปลี่ยน display_options เป็นวิธีที่ไม่ถูกต้องในการบรรลุเป้าหมายนี้ แต่เขาคลุมเครือในการตอบสนองต่อสิ่งที่ต้องทำ ( http://drupal.org/node/789710#comment-) 2927556 )
ฉันเหนื่อย:
function pages_views_pre_view($view){
$view = views_get_view('north_carolina');
$view->set_display('default');
$view->display_handler->options['filters']['province']['value'] = 'Georgia';
dsm($view->display_handler->options['filters']['province']);
}
หมายเหตุ:
1) ฉันมีมุมมองที่สร้างขึ้นเรียกnorth_carolina
ว่ามีจอแสดงผลสองประเภท - หน้าและบล็อก (หน้า 1 และบล็อก 1)
2) ตัวกรองของฉันเหมือนกันในทุกหน้าจอของฉันดังนั้นฉันจึงพยายามเปลี่ยนการแสดงผล 'เริ่มต้น' เพื่อให้มันมีผลกับตัวกรองทั้งหมด
3) ค่าเริ่มต้นของตัวกรองของฉันคือ 'North Carolina' (ซึ่งฉันตั้งไว้ใน Views UI) แต่สังเกตว่าฉันกำลังพยายามเปลี่ยนเป็น 'Georgia'
4) ถ้าฉันเรียกใช้ DSM ทันทีหลังจากนั้นฉันเห็นว่าตัวกรองได้รับการเปลี่ยนแปลงอย่างไรก็ตามผลลัพธ์ของฉันยังคงแสดงผลลัพธ์ 'North Carolina' การแคชถูกปิดใช้งานและฉันก็ยังคงเหมือนเดิมหลังจากใช้งาน drush cc ทั้งหมด
ฉันยังได้พยายามใช้รหัสเดียวกันกับที่ผ่านและhook_views_pre_build
hook_views_pre_execute
ข้อเสนอแนะใด ๆ
แก้ไข:
ตามที่แนะนำไว้อาจช่วยให้มีข้อมูลเพิ่มเติม นี่คือดัมพ์ของมุมมอง:
$view = new view();
$view->name = 'north_carolina';
$view->description = '';
$view->tag = 'default';
$view->base_table = 'node';
$view->human_name = 'North Carolina';
$view->core = 7;
$view->api_version = '3.0';
$view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */
/* Display: Master */
$handler = $view->new_display('default', 'Master', 'default');
$handler->display->display_options['title'] = 'test nc block';
$handler->display->display_options['use_more_always'] = FALSE;
$handler->display->display_options['access']['type'] = 'perm';
$handler->display->display_options['cache']['type'] = 'none';
$handler->display->display_options['query']['type'] = 'views_query';
$handler->display->display_options['exposed_form']['type'] = 'basic';
$handler->display->display_options['pager']['type'] = 'full';
$handler->display->display_options['style_plugin'] = 'default';
$handler->display->display_options['row_plugin'] = 'fields';
/* Field: Content: Title */
$handler->display->display_options['fields']['title']['id'] = 'title';
$handler->display->display_options['fields']['title']['table'] = 'node';
$handler->display->display_options['fields']['title']['field'] = 'title';
$handler->display->display_options['fields']['title']['label'] = '';
$handler->display->display_options['fields']['title']['alter']['word_boundary'] = FALSE;
$handler->display->display_options['fields']['title']['alter']['ellipsis'] = FALSE;
/* Sort criterion: Content: Post date */
$handler->display->display_options['sorts']['created']['id'] = 'created';
$handler->display->display_options['sorts']['created']['table'] = 'node';
$handler->display->display_options['sorts']['created']['field'] = 'created';
$handler->display->display_options['sorts']['created']['order'] = 'DESC';
/* Filter criterion: Content: Published */
$handler->display->display_options['filters']['status']['id'] = 'status';
$handler->display->display_options['filters']['status']['table'] = 'node';
$handler->display->display_options['filters']['status']['field'] = 'status';
$handler->display->display_options['filters']['status']['value'] = 1;
$handler->display->display_options['filters']['status']['group'] = 1;
$handler->display->display_options['filters']['status']['expose']['operator'] = FALSE;
/* Filter criterion: Location: Province */
$handler->display->display_options['filters']['province']['id'] = 'province';
$handler->display->display_options['filters']['province']['table'] = 'location';
$handler->display->display_options['filters']['province']['field'] = 'province';
$handler->display->display_options['filters']['province']['value'] = 'North Carolina';
$handler->display->display_options['filters']['province']['exposed'] = TRUE;
$handler->display->display_options['filters']['province']['expose']['operator_id'] = 'province_op';
$handler->display->display_options['filters']['province']['expose']['label'] = 'State';
$handler->display->display_options['filters']['province']['expose']['operator'] = 'province_op';
$handler->display->display_options['filters']['province']['expose']['identifier'] = 'province';
$handler->display->display_options['filters']['province']['expose']['remember_roles'] = array(
2 => '2',
1 => 0,
3 => 0,
4 => 0,
);
/* Display: Block */
$handler = $view->new_display('block', 'Block', 'block_1');
$handler->display->display_options['block_description'] = 'test nc block';
โปรดทราบว่าตัวจัดการเหล่านี้มีให้ในโมดูลสถานที่ โดยเฉพาะสำหรับตัวกรอง "สถานที่: จังหวัด" ฉันได้รับแบบฟอร์มการกรอกอัตโนมัติ เมื่อฉันพิมพ์ที่นอร์ ธ แคโรไลน่ามันก็ปรากฏขึ้นและฉันต้องเลือกมัน อย่างไรก็ตามการแจ้งเตือนในคำสั่ง SQL ที่มุมมองสร้างขึ้นจะใช้ตัวย่อสองตัวสำหรับสถานะ:
SELECT node.title AS node_title, node.nid AS nid, node.created AS node_created
FROM
{node} node
LEFT JOIN {location_instance} location_instance ON node.vid = location_instance.vid
LEFT JOIN {location} location ON location_instance.lid = location.lid
WHERE (( (node.status = '1') AND (location.province = 'NC') ))
ORDER BY node_created DESC
LIMIT 10 OFFSET 0