{"id":4335,"date":"2024-10-30T19:10:34","date_gmt":"2024-10-30T19:10:34","guid":{"rendered":"https:\/\/forestgreen-jay-845795.hostingersite.com\/?p=4335"},"modified":"2024-11-25T09:18:16","modified_gmt":"2024-11-25T09:18:16","slug":"%d0%bf%d0%be%d0%ba%d0%b0%d0%b7%d1%8b%d0%b2%d0%b0%d1%82%d1%8c-%d1%80%d0%b0%d0%b7%d0%bd%d1%8b%d0%b5-%d0%b2%d0%b8%d0%b4%d0%b6%d0%b5%d1%82%d1%8b-%d0%b4%d0%bb%d1%8f-%d1%80%d0%b0%d0%b7%d0%bd%d1%8b%d1%85-2","status":"publish","type":"post","link":"https:\/\/newsbee.blog\/wp-tips\/2024\/10\/30\/4335\/","title":{"rendered":"\u041f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u0432\u0438\u0434\u0436\u0435\u0442\u044b \u0434\u043b\u044f \u0440\u0430\u0437\u043d\u044b\u0445 \u0434\u0435\u0432\u0430\u0439\u0441\u043e\u0432"},"content":{"rendered":"<p>\u0414\u0430\u043d\u043d\u044b\u0439 \u0441\u043d\u0438\u043f\u043f\u0435\u0442 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u043a\u043b\u0430\u0441\u0441 \u0434\u0435\u0432\u0430\u0439\u0441\u0430 \u0434\u043b\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d \u0442\u043e\u0442 \u0438\u043b\u0438 \u0438\u043d\u043e\u0439 \u0432\u0438\u0434\u0436\u0435\u0442.<\/p>\n<p><strong>DISCLAMER:<\/strong> <strong>\u041c\u043e\u0436\u0435\u0442 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0432\u0438\u0434\u0436\u0435\u0442\u0430\u043c\u0438 \u0432 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0448\u0430\u0431\u043b\u043e\u043d\u0430\u0445 (\u0442\u0435\u043c\u0430\u0445) \u0432\u043d\u0435\u0448\u043d\u0435\u0433\u043e \u0432\u0438\u0434\u0430.<\/strong> \u042d\u0442\u043e \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043a\u043e \u043c\u043d\u043e\u0433\u0438\u043c \u0441\u043d\u0438\u043f\u043f\u0435\u0442\u0430\u043c \u0438 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430\u043c CSS, \u043a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e.<\/p>\n<pre id=\"code-snippet-source-26\" class=\"code-snippet-source\"><code class=\"language-php\">&lt;?php\n\n\/**\n * Snippet Name: Widget Device Visibility Controls\n * Description: Adds device visibility controls (Desktop\/Tablet\/Mobile) to all widgets\n * Version: 1.0\n * Author: newsbee\n * Author URI: https:\/\/newsbee.blog\/wp-tips\/\n * Snippet URI: https:\/\/newsbee.blog\/wp-tips\/snippets\/widget-classes.txt\n * License: GPLv2 or later\n * Network: false\n * \n * This snippet adds device visibility controls to WordPress widgets,\n * allowing you to control which devices each widget appears on.\n *\/\n\n\/\/ Exit if accessed directly\nif (!defined(&#039;ABSPATH&#039;)) {\n    exit;\n}\n\n\/\/ Add device visibility controls to widget form\nfunction widget_device_controls($widget, $return, $instance) {\n    $visibility = isset($instance[&#039;device_visibility&#039;]) ? $instance[&#039;device_visibility&#039;] : &#039;all&#039;;\n    ?&gt;\n    &lt;div class=&quot;widget-visibility-control&quot;&gt;\n        &lt;p&gt;\n            &lt;label for=&quot;&lt;?php echo $widget-&gt;get_field_id(&#039;device_visibility&#039;); ?&gt;&quot;&gt;\n                &lt;strong&gt;Display on:&lt;\/strong&gt;\n            &lt;\/label&gt;\n            &lt;select \n                class=&quot;widefat&quot; \n                id=&quot;&lt;?php echo $widget-&gt;get_field_id(&#039;device_visibility&#039;); ?&gt;&quot; \n                name=&quot;&lt;?php echo $widget-&gt;get_field_name(&#039;device_visibility&#039;); ?&gt;&quot;&gt;\n                &lt;option value=&quot;all&quot; &lt;?php selected($visibility, &#039;all&#039;); ?&gt;&gt;All Devices&lt;\/option&gt;\n                &lt;option value=&quot;desktop&quot; &lt;?php selected($visibility, &#039;desktop&#039;); ?&gt;&gt;Desktop Only&lt;\/option&gt;\n                &lt;option value=&quot;mobile&quot; &lt;?php selected($visibility, &#039;mobile&#039;); ?&gt;&gt;Mobile Only&lt;\/option&gt;\n                &lt;option value=&quot;tablet&quot; &lt;?php selected($visibility, &#039;tablet&#039;); ?&gt;&gt;Tablet Only&lt;\/option&gt;\n            &lt;\/select&gt;\n        &lt;\/p&gt;\n    &lt;\/div&gt;\n    &lt;?php\n    return $instance;\n}\nadd_action(&#039;in_widget_form&#039;, &#039;widget_device_controls&#039;, 10, 3);\n\n\/\/ Save widget visibility settings\nfunction save_widget_visibility($instance, $new_instance) {\n    $instance[&#039;device_visibility&#039;] = isset($new_instance[&#039;device_visibility&#039;]) ? $new_instance[&#039;device_visibility&#039;] : &#039;all&#039;;\n    return $instance;\n}\nadd_filter(&#039;widget_update_callback&#039;, &#039;save_widget_visibility&#039;, 10, 2);\n\n\/\/ Filter widget display based on device\nfunction filter_widget_visibility($instance, $widget) {\n    if (!isset($instance[&#039;device_visibility&#039;]) || $instance[&#039;device_visibility&#039;] === &#039;all&#039;) {\n        return $instance;\n    }\n\n    \/\/ Get current device type\n    $ua = $_SERVER[&#039;HTTP_USER_AGENT&#039;] ?? &#039;&#039;;\n    $current_device = &#039;desktop&#039;;\n    \n    if (preg_match(&#039;\/(android|bb\\d+|meego).+mobile|avantgo|bada\\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino\/i&#039;, $ua)) {\n        $current_device = &#039;mobile&#039;;\n    } elseif (preg_match(&#039;\/android|ipad|playbook|silk\/i&#039;, $ua)) {\n        $current_device = &#039;tablet&#039;;\n    }\n\n    \/\/ Hide widget if it doesn&#039;t match current device\n    if ($instance[&#039;device_visibility&#039;] !== $current_device) {\n        return false;\n    }\n\n    return $instance;\n}\nadd_filter(&#039;widget_display_callback&#039;, &#039;filter_widget_visibility&#039;, 10, 2);\n\n\/\/ Add device-specific CSS classes to widgets\nfunction add_device_visibility_classes($params) {\n    if (!isset($params[0][&#039;widget_id&#039;])) {\n        return $params;\n    }\n\n    \/\/ Get widget details\n    $widget_id = $params[0][&#039;widget_id&#039;];\n    $id_base = preg_replace(&#039;\/-[0-9]+$\/&#039;, &#039;&#039;, $widget_id);\n    $widget_number = (int) str_replace($id_base . &#039;-&#039;, &#039;&#039;, $widget_id);\n    $widget_obj = get_option(&#039;widget_&#039; . $id_base);\n\n    \/\/ Add device class if visibility is set\n    if (isset($widget_obj[$widget_number][&#039;device_visibility&#039;])) {\n        $params[0][&#039;before_widget&#039;] = preg_replace(\n            &#039;\/class=&quot;\/&#039;,\n            &#039;class=&quot;device-&#039; . $widget_obj[$widget_number][&#039;device_visibility&#039;] . &#039; &#039;,\n            $params[0][&#039;before_widget&#039;],\n            1\n        );\n    }\n\n    return $params;\n}\nadd_filter(&#039;dynamic_sidebar_params&#039;, &#039;add_device_visibility_classes&#039;);\n\n\/\/ Add CSS for device visibility\nfunction add_device_visibility_styles() {\n    ?&gt;\n    &lt;style&gt;\n        \/* Desktop *\/\n        @media (min-width: 1024px) {\n            .device-mobile, \n            .device-tablet {\n                display: none !important;\n            }\n        }\n        \n        \/* Tablet *\/\n        @media (min-width: 768px) and (max-width: 1023px) {\n            .device-desktop, \n            .device-mobile {\n                display: none !important;\n            }\n        }\n        \n        \/* Mobile *\/\n        @media (max-width: 767px) {\n            .device-desktop, \n            .device-tablet {\n                display: none !important;\n            }\n        }\n    &lt;\/style&gt;\n    &lt;?php\n}\nadd_action(&#039;wp_head&#039;, &#039;add_device_visibility_styles&#039;);<\/code><\/pre>\n<p>\u041a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0444\u0430\u0439\u043b\u0430 \u0438 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u043c \u0435\u0433\u043e \u0432 \u043d\u043e\u0432\u044b\u0439 \u0441\u043d\u0438\u043f\u043f\u0435\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043f\u043b\u0430\u0433\u0438\u043d\u0430 Code Snippets.<\/p>\n<p>\u041f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0441\u0442\u043e\u0438\u0442 All Devices, \u0442.\u0435. \u0432\u0441\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430, \u0430 \u043f\u043e\u0442\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u0442\u043e, \u0447\u0442\u043e \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u043e.<\/p>\n<p>Enjoy!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0414\u0430\u043d\u043d\u044b\u0439 \u0441\u043d\u0438\u043f\u043f\u0435\u0442 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u043a\u043b\u0430\u0441\u0441 \u0434\u0435\u0432\u0430\u0439\u0441\u0430 \u0434\u043b\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d \u0442\u043e\u0442 \u0438\u043b\u0438 \u0438\u043d\u043e\u0439 \u0432\u0438\u0434\u0436\u0435\u0442.<\/p>\n <a class=\"read-more-button\" href=\"https:\/\/newsbee.blog\/wp-tips\/2024\/10\/30\/4335\/\">\u0427\u0438\u0442\u0430\u0442\u044c \u0434\u0430\u043b\u0435\u0435<\/a>","protected":false},"author":1,"featured_media":4279,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[77],"tags":[39,37],"class_list":["post-4335","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-widgets","tag-snippets","tag-shortcodes"],"_links":{"self":[{"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/posts\/4335","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/comments?post=4335"}],"version-history":[{"count":7,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/posts\/4335\/revisions"}],"predecessor-version":[{"id":5166,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/posts\/4335\/revisions\/5166"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/media\/4279"}],"wp:attachment":[{"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/media?parent=4335"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/categories?post=4335"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/newsbee.blog\/wp-tips\/wp-json\/wp\/v2\/tags?post=4335"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}