Hôm nay mình sẽ hướng dẫn các bạn tạo 1 plugin đơn giản để có thể tạo popup bằng việc sử dụng lightbox và ACF nhé.
Cái này khá là đơn giản nhưng các bạn newbie sẽ mất kha khá thời gian để tìm hiểu. Nếu các bạn đang tìm hiểu thì hay đọc ngay bài này của mình để biết cách thức hoạt động của ACF và lightbox.
Demo các bạn có thể xem tại đây. https://pttuan410.com/demo/
Các công việc và các yêu cầu cần có:
- Đầu tiên bạn phải đảm bảo theme của mình đã cài đặt plugin ACF (Advanced Custom Field).
- Tạo 1 theme option sử dụng plugin ACF. Tham khảo bài viết Cách tạo theme option bằng ACF.
- Tạo các field text, radio, và Relationship (Phần này các bạn có thể copy code của mình cũng được)
- Code phần hiển thị và các điều kiện kèm theo.
Bắt tay vào việc thôi.
Tạo các field Text, radio và Relationship
Các bạn tạo các field theo hình dưới này là được nhé. Nhớ đặt tên giống mình để dễ follow bài viết này nhé.
Trong field Lựa chọn hiển thị sẽ gồm có:
Tần suất hiển thị sẽ bao gồm
Hoặc các bạn có thể copy đoạn code này bỏ vào file function nhé.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 |
if( function_exists('acf_add_local_field_group') ): acf_add_local_field_group(array( 'key' => 'group_608a1c13df3ac', 'title' => 'Popup', 'fields' => array( array( 'key' => 'field_608a1d701f176', 'label' => 'Nội dung hiển thị', 'name' => 'nd', 'type' => 'text', 'instructions' => '', 'required' => 0, 'conditional_logic' => 0, 'wrapper' => array( 'width' => '', 'class' => '', 'id' => '', ), 'default_value' => '', 'placeholder' => '', 'prepend' => '', 'append' => '', 'maxlength' => '', ), array( 'key' => 'field_608a2224aa352', 'label' => 'Lựa chọn hiển thị', 'name' => 'lua_chon', 'type' => 'radio', 'instructions' => '', 'required' => 0, 'conditional_logic' => 0, 'wrapper' => array( 'width' => '', 'class' => '', 'id' => '', ), 'choices' => array( 'All' => 'Tất cả', 'chose' => 'Lựa chọn hiển thị', 'loai' => 'Loại trừ hiển thị', ), 'allow_null' => 0, 'other_choice' => 0, 'default_value' => '', 'layout' => 'horizontal', 'return_format' => 'value', 'save_other_choice' => 0, ), array( 'key' => 'field_608a1d8d1f177', 'label' => 'Trang hiển thị', 'name' => 'id_ht', 'type' => 'relationship', 'instructions' => '', 'required' => 0, 'conditional_logic' => array( array( array( 'field' => 'field_608a2224aa352', 'operator' => '!=', 'value' => 'All', ), ), ), 'wrapper' => array( 'width' => '', 'class' => '', 'id' => '', ), 'post_type' => '', 'taxonomy' => '', 'filters' => array( 0 => 'search', 1 => 'post_type', 2 => 'taxonomy', ), 'elements' => '', 'min' => '', 'max' => '', 'return_format' => 'object', ), array( 'key' => 'field_60bf27b9bb5bd', 'label' => 'Time', 'name' => 'time', 'type' => 'number', 'instructions' => '', 'required' => 0, 'conditional_logic' => 0, 'wrapper' => array( 'width' => '', 'class' => '', 'id' => '', ), 'default_value' => '', 'placeholder' => '', 'prepend' => '', 'append' => '', 'min' => '', 'max' => '', 'step' => '', ), array( 'key' => 'field_60bf27c5bb5be', 'label' => 'tần suất hiển thị', 'name' => 'ts', 'type' => 'radio', 'instructions' => '', 'required' => 0, 'conditional_logic' => 0, 'wrapper' => array( 'width' => '', 'class' => '', 'id' => '', ), 'choices' => array( 'once' => 'Once', 'always' => 'Always', ), 'allow_null' => 0, 'other_choice' => 0, 'default_value' => '', 'layout' => 'horizontal', 'return_format' => 'value', 'save_other_choice' => 0, ), ), 'location' => array( array( array( 'param' => 'options_page', 'operator' => '==', 'value' => 'theme-general-settings', ), ), ), 'menu_order' => 0, 'position' => 'normal', 'style' => 'default', 'label_placement' => 'top', 'instruction_placement' => 'label', 'hide_on_screen' => '', 'active' => true, 'description' => '', )); endif; |
Code phần hiển thị ra ngoài kèm các điều kiện
Để show được ra ngoài các bạn sử dụng các hàm get_the_filed() hoặc the_field() của ACF nhé. Các bạn phân tích đoạn code dưới đây để biết cách thức hoạt động.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
function show_popup(){ global $post; $noidung = get_field('nd','option'); $chose = get_field('lua_chon','option'); $id_posts = get_field('id_ht','option'); $auto = get_field('ts','option'); $time = get_field('time','option'); $id_array = array(); foreach( $id_posts as $id_post ): $id_array[] = $id_post->ID; endforeach; if($chose == 'All'){ $postarray = !empty($id_array); } if($chose == 'loai'){ $postarray = !(in_array((int)$post->ID, $id_array)); } if($chose == 'chose'){ $postarray = in_array((int)$post->ID, $id_array); } if ($postarray){; echo do_shortcode('[lightbox auto_open="true" auto_timer="'.$time.'" auto_show="'.$auto.'" id="pttuan-custom-popup" width="600px" padding="20px"] '.$noidung.' [/lightbox]'); } } add_action('wp_footer','show_popup'); |
Như vậy là xong, chúc các bạn thành công nhé, có gì không rõ cứ ib hoặc đặt comment hỏi mình.
Nguồn : https://pttuan410.com/huong-dan-tao-plugin-popup-don-gian-bang-lightbox-va-acf-danh-cho-flatsome