Advertisement
firoze

redux framework installation and usages

Jul 24th, 2016
124
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 8.96 KB | None | 0 0
  1. কিভাবে ওয়ার্ডপ্রেসে নিজের থিমে রিডাক্স ফ্রেমওয়ার্ক যোগ করব?
  2. https://hasin.me/2014/07/16/adding-redux-framework-in-your-wordpress-theme/
  3.  
  4.  
  5. ওয়ার্ডপ্রেসের যতগুলো অ্যাডমিন প্যানেল বা অপশন ফ্রেমওয়ার্ক আছে তাদের মাঝে রিডাক্স অন্যতম। অনেকগুলো চমৎকার ফিচার, প্রচুর ফিল্ডের সমারোহ এবং সহজ ব্যবহারোপযোগিতার কারনে রিডাক্স খুব দ্রুতই ওয়ার্ডপ্রেস থিম ডেভেলপার দের দৃষ্টি আকর্ষন করতে সক্ষম হয়েছে। এছাড়াও রিডাক্সে ডেভেলপাররা ক্রমাগত এটাকে আপডেট করে চলেছেন, যার ফলে আমরা মাঝেমাঝেই পাচ্ছি নিত্য নতুন ফিচার। আজকের এই আর্টিকেলে আমি দেখাবো কিভাবে আমরা আমাদের থিমে এই রিডাক্স ফ্রেমওয়ার্ক দিয়ে তৈরী অপশন প্যানেল যোগ করব
  6. ১. এজন্য প্রথমেই https://github.com/ReduxFramework/ReduxFramework/ এখানে ডানদিকের নিচে গিয়ে “Download zip” বাটনে ক্লিক করে রিডাক্স ফ্রেমওয়ার্ক ডাউনলোড করে নিন
  7. ২. ডাউনলোড করা জিপ ফাইলটি আনজিপ/এক্সট্রাক্ট করলে redux-framework-master নামে একটা ফোল্ডার পাবেন। সেটা ওপেন করে একমাত্র ReduxCore এবং sample নামের ফোল্ডার দুটো রাখুন, আর class.redux-plugin.php, index.php, license.txt, redux-framework.phpনামের ফাইলগুলো রেখে বাকি সবকিছু ডিলেট করে দিন। ডিলেট করার পরে redux-framework-master ফোল্ডার এর কনটেন্ট হবে নিচের মত
  8.  
  9. ৩. এবার আপনার থিমে libs নামে একটা ডিরেক্টরী তৈরী করে তার ভেতরে এই redux-framework-master ফোল্ডার পেস্ট করে দিন।
  10. ৪. এবার আপনার থিমের functions.php ফাইলে নিচের কোড টুকু যোগ করুন
  11. if(!class_exists("ReduxFrameworkPlugin")){
  12. require_once(get_template_directory()."/libs/redux-framework-master/redux-framework.php");
  13. require_once(get_template_directory()."/libs/redux-framework-master/sample/sample-config.php");
  14. }
  15.  
  16. ৫. এবার আপনার থিম অ্যাক্টিভেট করে ওয়ার্ডপ্রেস এর অ্যাডমিন প্যানেলে আসলেই বামপাশে দেখবেন “Sample Options” নামে একটা মেনু চলে এসেছে, যা আসলে রিডাক্সের স্যাম্পল ফাইল টির আউটপুট।
  17.  
  18. ব্যাস, আমাদের থিমে রিডাক্স ফ্রেমওয়ার্ক যোগ করা শেষ। একদম সহজ, তাই না? এখন আপনি sample-config.php ফাইলটি স্টাডি করে দেখতে পারেন কিভাবে বিভিন্ন ধরনের ফিল্ড যোগ করা হয়েছে। লাইন নম্বর ২৩৯ থেকে এই সেকশন এবং ফিল্ড গুলোর ডেফিনিশন শুরু হয়েছে। এখন একটা বিষয় খুবই জরুরী, আর সেটা হল এই যে আমাদের থিমের ইউজার রা রিডাক্সের সাহায্যে বিভিন্ন ডেটা ইনপুট দিবে – আমরা সেগুলো থিমে ব্যবহার করব কিভাবে। এর জন্য আমাদের দেখতে হবে ১৫৩৫ নম্বর লাইনে (বর্তমান আপডেট অনুযায়ী) এই লাইনটি আছে
  19. 'opt_name' => 'redux_demo',
  20. এখানে আপনি আপনার পছন্দ মতো ভ্যারিয়েবলের নাম লিখতে পারবেন। যেমন আপনার থিমের নাম যদি হয় FlyHigh তাহলে আপনি লিখতে পারেন
  21. 'opt_name' => 'flyhigh',
  22. এটা করা হয়ে গেলে আপনার থিমের ফাইলে সবার উপরে এই লাইনটি লিখবেন
  23. global $flyhigh;
  24. এর পর থেকে রিডাক্সের যেকোন ফিল্ডের ডেটা আপনি অ্যাক্সেস করতে পারবেন $flyhigh[‘fieldid’] এইভাবে। ফিল্ডের আইডি কিভাবে লিখতে হয় এটা জানতে হলে আপনি স্যাম্পল কনফিগ ফাইলে অনেক উদাহরণ পাবেন, যেমন ধরুন একটা ফিল্ডের ডেফিনিশন হল
  25. array(
  26. 'id' => 'my_text_field',
  27. 'type' => 'text',
  28. 'desc' => 'Add some awesome text here',
  29. 'default' => 'Oh WOW!',
  30. 'title' => 'My Awesome Text'
  31.  
  32. ),
  33. উপরের উদাহরণে ফিল্ডের আইডি হল my_text_field। আরেকটা জিনিশ, সেটা হল যে “Sample Options” নামের মেনুর নাম পরিবর্তন করতে চাইলে নিচের লাইনটি খুঁজে বের করে আপনার পছন্দ মত মেনু নাম দিন
  34. 'menu_title' => __('Sample Options', 'redux-framework-demo'),
  35. এই স্যাম্পল ফাইলটি আপনার জানার সুবিধার্থে রিডাক্স টিম করে দিয়েছে। এই ফাইলে পরিবর্তন না করে বরং একই ফোল্ডারে দেখবেন barebones-config.php নামে আরেকটা ফাইল রয়েছে, যেটাতে শুধু যেটুকু দরকার সেটুকুই কোড আছে। আপনি সেই ফাইলটি আপনার থিমের কোথাও কপি করে নিয়ে আপনার থিমের জন্য নিজের মত করে অ্যাডমিন প্যানেল বানাতে পারবেন।
  36.  
  37. https://hasin.me/2014/07/16/adding-redux-framework-in-your-wordpress-theme/
  38.  
  39. // have to stay the below and others have to delete
  40. class.redux-plugin.php
  41. index.php
  42. lincense.txt
  43. redux-framework.php
  44. ReduxCore
  45. sample
  46. Updating a CSS File Dynamically in Redux framework
  47.  
  48. // show style.css || file.php
  49. // Help link: https://docs.reduxframework.com/core/advanced/updating-a-css-file-dynamically/
  50. add_filter('redux/options/' . $opt_name . '/compiler', 'compiler_action', 10, 3);
  51. function compiler_action($options, $css, $changed_values) {
  52.  
  53. $css_dir = get_template_directory() . '/css/style.css';
  54. ob_start();
  55. require_once( get_template_directory().'/css/file.php' ); // you have to create file.php in css folder
  56. $css = ob_get_clean();
  57.  
  58. /** Write to options.css file **/
  59. global $wp_filesystem;
  60. WP_Filesystem();
  61. if ($wp_filesystem->put_contents( $css_dir, $css, FS_CHMOD_FILE ) ) {
  62. return true;
  63. }
  64.  
  65. }
  66.  
  67. /*
  68. array(
  69. 'id'=>'body_color_bg',
  70. 'type'=>'color',
  71. 'compiler'=>array('body_color_bg'), OR 'body_color_bg' // This is is id
  72. 'title'=>'Body Background Color',
  73. 'default'=>'#FFFFFF'
  74.  
  75. ),
  76. */
  77.  
  78. // Redux Dynamic css
  79. function reDux_dynamic_CSS() {
  80. /* ------------------------------------------------------------------------ */
  81. /* Register Stylesheets */
  82. /* ------------------------------------------------------------------------ */
  83. wp_register_style('redux-style', get_template_directory_uri() . '/css/style.css', 'style');
  84.  
  85. /* ------------------------------------------------------------------------ */
  86. /* Enqueue Styles */
  87. /* ------------------------------------------------------------------------ */
  88. wp_enqueue_style( 'redux-style');
  89. }
  90. add_action( 'wp_enqueue_scripts', 'reDux_dynamic_CSS', 1 );
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement