উন্নত কাস্টমাইজেশন

ব্লকলি আপনাকে সংশ্লিষ্ট ব্লকলি ক্লাসগুলি প্রতিস্থাপন করে নির্দিষ্ট কার্যকারিতা কাস্টমাইজ করতে দেয়।

প্রতিস্থাপনযোগ্য ক্লাস

নিম্নলিখিত ব্লকলি ক্লাসগুলি প্রতিস্থাপন করা যেতে পারে:

ব্লকলি ক্লাস ইন্টারফেস রেজিস্ট্রি টাইপ নাম
Blockly.dragging.Dragger Blockly.IDragger blockDragger
Blockly.ConnectionChecker Blockly.IConnectionChecker connectionChecker
Blockly.InsertionMarkerPreviewer Blockly.IConnectionPreviewer connectionPreviewer
Blockly.HorizontalFlyout Blockly.IFlyout flyoutsHorizontalToolbox
Blockly.VerticalFlyout Blockly.IFlyout flyoutsVerticalToolbox
Blockly.MetricsManager Blockly.IMetricsManager metricsManager
Blockly.Toolbox Blockly.IToolbox toolbox
Blockly.VariableMap Blockly.IVariableMap variableMap
Blockly.VariableModel Blockly.IVariableModel --

কিভাবে একটি রেন্ডারার প্রতিস্থাপন করতে হয় সে সম্পর্কে তথ্যের জন্য, কাস্টম রেন্ডারার তৈরি করুন দেখুন।

একটি প্রতিস্থাপন ক্লাস তৈরি করুন

একটি প্রতিস্থাপন শ্রেণী তৈরি করতে, সংশ্লিষ্ট ইন্টারফেসে ফাংশনগুলি বাস্তবায়ন করুন। আপনি একটি নতুন ক্লাসে এই সমস্ত ফাংশন বাস্তবায়ন করতে পারেন, অথবা ব্লকলি ক্লাস প্রসারিত করতে পারেন এবং শুধুমাত্র আপনি যে ফাংশনগুলি পরিবর্তন করতে চান তা ওভাররাইড করতে পারেন। একমাত্র প্রয়োজন হল আপনি (বা বেস ক্লাস) ইন্টারফেসের সমস্ত ফাংশন বাস্তবায়ন করুন এবং ইন্টারফেসের মন্তব্যে বর্ণিত যেকোনো প্রয়োজনীয়তা মেনে চলুন।

আপনি একটি নির্দিষ্ট ইন্টারফেস প্রয়োগ করছেন এমন টাইপ চেকারকে নির্দেশ করতে, @implements {InterfaceName} JSDoc ট্যাগ (জাভাস্ক্রিপ্টে) বা implements কীওয়ার্ড (টাইপস্ক্রিপ্টে) দিয়ে আপনার ক্লাসটি টীকা করুন।

আপনার প্রতিস্থাপন ক্লাস সম্পর্কে Blockly বলুন

আপনার প্রতিস্থাপন শ্রেণী সম্পর্কে ব্লকলিকে বলার দুটি উপায় রয়েছে: এটিকে এর ধরণের (পছন্দের) ডিফল্ট শ্রেণী হিসাবে নিবন্ধন করুন বা plugins কনফিগারেশন বিকল্প ব্যবহার করে এটিকে ইনজেক্ট করুন।

ডিফল্ট হিসাবে আপনার প্রতিস্থাপন ক্লাস নিবন্ধন করুন

আপনার প্রতিস্থাপন শ্রেণী সম্পর্কে ব্লকলিকে বলার পছন্দের উপায় হল এটির প্রকারের জন্য ডিফল্ট হিসাবে নিবন্ধন করা। এটি করার জন্য, Blockly.registry.register Blockly.registry.DEFAULT করুন এবং opt_allowOverrides প্যারামিটারটিকে true সেট করুন।

Blockly.registry.register(
  Blockly.registry.Type.VARIABLE_MODEL,
  Blockly.registry.DEFAULT,
  CustomVariableModel,
  true,
);

আপনার প্রতিস্থাপন ক্লাস ইনজেকশন

আপনি plugins কনফিগারেশন বিকল্প ব্যবহার করে প্রতিস্থাপন ক্লাস ইনজেকশন করতে পারেন। এটি একটি অবজেক্ট যা রেজিস্ট্রি টাইপ নামগুলি সম্পত্তির নাম এবং প্রতিস্থাপন শ্রেণী বা নিবন্ধিত নামগুলি সম্পত্তি মান হিসাবে ব্যবহার করে।

( plugins সম্পত্তির নাম থাকা সত্ত্বেও, আপনার ক্লাসকে ব্লকলি প্রসারিত করতে ব্যবহৃত প্লাগইনগুলির মতো এনপিএম-এর মাধ্যমে প্যাকেজ এবং বিতরণ করার প্রয়োজন নেই।)

হয় Blockly.inject এ আপনার প্রতিস্থাপন ক্লাস পাস করুন:

Blockly.inject('blocklyDiv', {
  plugins: {
    'metricsManager': CustomMetricsManagerClass
  }
}

অথবা Blockly.registry.register ব্যবহার করে আপনার ক্লাস নিবন্ধন করুন এবং Blockly.inject এ নিবন্ধিত নাম পাস করুন। আপনি যদি আপনার কনফিগারেশন বিকল্পগুলিকে বিশুদ্ধ JSON হিসাবে সংরক্ষণ করেন তবে এটি কার্যকর।

Blockly.registry.register(Blockly.registry.Type.METRICS_MANAGER, 'YOUR_NAME', CustomMetricsManagerClass);

Blockly.inject('blocklyDiv', {
  plugins: {
    'metricsManager': 'YOUR_NAME'
  }
}