Codex · III

বাই বাটন

বাই বাটন

বাই বাটন কয়েক লাইন HTML যা আপনি যেকোনো পৃষ্ঠায় পেস্ট করেন। কোনো ফ্রেমওয়ার্ক নেই, আপনার দিকে কোনো ইনস্টল ধাপ নেই। বাটনটি প্রথম পেইন্টে রেন্ডার হয়; প্রোভাইডার পিকার আর পেমেন্ট-প্রোভাইডার SDK-গুলো একজন ক্রেতা প্রথমবার ক্লিক করলে চাহিদামতো লোড হয়। এটি HTML রেন্ডার করে এমন যেকোনো সাইট বা ফ্রেমওয়ার্কে কাজ করে, যেসব নো-কোড সাইট বিল্ডার আপনাকে HTML এম্বেড পেস্ট করতে দেয় সেগুলো সহ।

যেগুলোর সাথে কাজ করা নিশ্চিত: Angular, Hugo, Jekyll, সাধারণ HTML, Webflow (Custom Code embed), Carrd (Embed element), Framer (HTML embed), Squarespace (Code Block), WordPress (Custom HTML block), Ghost, Notion সাইট (HTML embed widgets)। আপনার সাইট যদি কোনো পৃষ্ঠায় HTML পেস্ট করতে দেয়, তবে বাই বাটন সেখানে কাজ করে।

অ্যাট্রিবিউট রেফারেন্স

অ্যাট্রিবিউটপ্রয়োজনীয়এটি যা গ্রহণ করেনোট
endpointনাURL স্ট্রিংপ্রায় সবসময় এটি বাদ দিন। বাটনটি স্বয়ংক্রিয়ভাবে এর API বেস শনাক্ত করে: প্রোডাকশনে https://api.coinmoebius.com, localhost-এ http://localhost:8787। কেবল একটি অস্বাভাবিক সেটআপের জন্য (যেমন, API-এর সামনে একটি স্ব-হোস্টেড প্রক্সি) ওভাররাইড হিসেবে এটি নির্ধারণ করুন।
project-idহ্যাঁস্ট্রিং, proj_ উপসর্গ সহড্যাশবোর্ডে আপনার প্রজেক্ট পৃষ্ঠা থেকে। প্রকাশ্যে প্রকাশ করা নিরাপদ, এটি একটি শনাক্তকারী, কোনো ক্রেডেনশিয়াল নয়।
product-idহ্যাঁ (strict mode-এ) / সুপারিশকৃত (ad-hoc mode-এ)স্ট্রিং, আপনার বেছে নেওয়া যেকোনো ফরম্যাটআপনার অভ্যন্তরীণ পণ্য শনাক্তকারী। strict mode-এ (ডিফল্ট), worker এভাবেই আপনার ক্যাটালগ থেকে দাম খুঁজে নেয়। ad-hoc mode-এ, এটি এখনো metadata.productId-তে আপনার ওয়েবহুকে পার করা হয় যাতে আপনি লেনদেনগুলো ইনভেন্টরির সাথে মেলাতে পারেন। নিচের Strict mode vs ad-hoc mode বিভাগ দেখুন।
amountকেবল ad-hoc mode-এস্ট্রিং হিসেবে দশমিক সংখ্যাপ্রধান এককে দাম (যেমন, ডলার, সেন্ট নয়)। ধনাত্মক হতে হবে। strict mode-এ এটি বাদ দিন। worker আপনার ক্যাটালগ থেকে প্রামাণিক দাম পড়ে আর HTML-এ থাকা যেকোনো মান উপেক্ষা করে। কেবল তখনই প্রয়োজনীয় যখন প্রজেক্ট ad-hoc mode-এ থাকে আর product-id ক্যাটালগে নেই।
currencyকেবল ad-hoc mode-এতিন-অক্ষরের ISO 4217 কোড বা আপনার নিজের একক নামকার্ড / ক্রিপ্টো রেলের জন্য USD, EUR, ইত্যাদি। ডাকযোগে-অর্থ প্রোভাইডার যেকোনো স্ট্রিং গ্রহণ করে (যেমন, GBK) কারণ লেনদেনটি নিষ্পত্তি করেন মার্চেন্টই। amount-এর মতোই একই নিয়ম: strict mode-এ বাদ দিন, ক্যাটালগে নেই এমন পণ্যের জন্য ad-hoc mode-এ প্রয়োজনীয়।
labelনাস্ট্রিংবাটন টেক্সট। ডিফল্ট Buy। একই পৃষ্ঠায় বাটনগুলো আলাদা করতে এটি ব্যবহার করুন।
customer-refনাস্ট্রিং, আপনার বেছে নেওয়া যেকোনো ফরম্যাটআপনার নিজের সিস্টেমে ক্রেতার জন্য একটি অস্বচ্ছ শনাক্তকারী, যেমন একটি লগ-ইন করা ব্যবহারকারী আইডি। বাটনটি এটি metadata.customerRef হিসেবে worker-এ পাঠায়, আর worker এটি দিয়ে লেনদেনটি ট্যাগ করে। পরে আপনি কোনো আসল গ্রাহক ডেটা না রেখেই নিজের আইডি ব্যবহার করে জিজ্ঞেস করতে পারেন "আমার কোন ব্যবহারকারী অর্থ দিলেন?" বেনামি চেকআউটের জন্য বাদ দিন।
buyer-emailNoEmail addressWhere to send a digital download. Set this when your site already knows the buyer, like a members area or a logged-in app, and the button will not ask them for an email. When it is not set, the button asks the buyer for one at checkout if the product is a download on a provider that does not return the email itself. We use the address only to send the download and then delete it. We never store it.
themeনাdark বা lightবাটন আর পপআপের জন্য একসাথে বিল্ট-ইন রঙ স্কিম বেছে নেয়। ডিফল্ট dark। লাইট স্কিমের জন্য theme="light" নির্ধারণ করুন। আপনার CSS ভেরিয়েবল দুটোর যেকোনোটি ওভাররাইড করে। স্টাইলিং গাইড দেখুন।
editable-amountনাtrue বা falsetrue হলে, পপআপ একটি পরিমাণ ফিল্ড দেখায় যা ক্রেতা পূরণ করেন (টিপ, অনুদান, যত-খুশি-দিন)। ডিফল্ট false, যেখানে আপনার নির্ধারিত amount স্থির আর কোনো ফিল্ড দেখায় না। পরিমাণ একটি ধনাত্মক সংখ্যা না হওয়া পর্যন্ত পেমেন্ট বাটন নিষ্ক্রিয় থাকে।

এক পৃষ্ঠায় একাধিক বাটন

স্ক্রিপ্টটি বাটনটি একবার রেজিস্টার করে, তারপর যেকোনো সংখ্যক ইনস্ট্যান্স একটি পৃষ্ঠায় রেন্ডার হতে পারে। প্রতিটি ইনস্ট্যান্স স্বাধীন। নিচের উদাহরণটি strict mode (ডিফল্ট) ব্যবহার করে: HTML-এ কোনো amount বা currency নেই, কারণ worker আপনার ক্যাটালগের প্রতিটি পণ্য থেকে দাম খুঁজে নেয়।

<coin-moebius-buy
  project-id="proj_YOUR_ID"
  product-id="t-shirt-medium"
  label="T-shirt (medium)">
</coin-moebius-buy>

<coin-moebius-buy
  project-id="proj_YOUR_ID"
  product-id="mug-blue"
  label="Blue mug">
</coin-moebius-buy>

আপনার প্রজেক্ট ad-hoc mode-এ থাকলে (ডোনেশন উইজেট, টিপ জার), প্রতিটি বাটনে amountcurrency-ও থাকে। সম্পূর্ণ চিত্রের জন্য Strict mode vs ad-hoc mode দেখুন।

বাটন থিমিং

বাই বাটন একটি Shadow DOM-এর ভেতরে রেন্ডার হয়, যার মানে আপনার পৃষ্ঠার বিদ্যমান কোনো CSS এর ভেতরে পৌঁছায় না। এটি ইচ্ছাকৃত: এটি প্রতিটি সাইটে বাটনটিকে একই রকম দেখায়, আর একটি ভবঘুরে * { box-sizing: ... } নিয়ম পিকার মোডাল ভাঙা থেকে আটকায়। আপনি আপনার নিজের স্টাইলশিট থেকে দুটি পৃষ্ঠের মাধ্যমে এটি সাজান: রঙ, ফন্ট, ও আকৃতির জন্য CSS কাস্টম প্রপার্টি, আর বাকি সবকিছুর জন্য ::part() সিলেক্টর। কোনো JavaScript জড়িত নেই।

প্রতিটি ভেরিয়েবল ও পার্ট স্টাইলিং গাইডে নথিবদ্ধ, ক্লিক ও কপি করার মতো লাইভ উদাহরণ সহ:

ইন্টারঅ্যাক্টিভ স্টাইলিং গাইড খুলুন →

সাকসেস ও ক্যানসেল URL

ড্যাশবোর্ডের Providers ট্যাবে আপনি Stripe বা NOWPayments যুক্ত করলে, আপনি দুটি URL নির্ধারণ করেন:

  • সাকসেস URL, যেখানে একটি সফল পেমেন্টের পর ক্রেতা পৌঁছান। Stripe ও NOWPayments একটি কোয়েরি প্যারামিটার যোগ করে (Stripe-এর জন্য ?session_id=..., NOWPayments-এর জন্য ?NP_id=...) যাতে আপনার সাকসেস পৃষ্ঠা কোন লেনদেন সম্পন্ন হলো তা শনাক্ত করতে পারে। বেশিরভাগ স্ট্যাটিক সাইট শুধু একটি সাধারণ "ধন্যবাদ, আপনার পেমেন্ট প্রক্রিয়াধীন" বার্তা দেখায় আর সত্যের উৎসের জন্য ড্যাশবোর্ডের উপর নির্ভর করে।
  • ক্যানসেল URL, যেখানে ক্রেতা পৌঁছান যদি তাঁরা অর্থ দেওয়ার আগে পিছিয়ে যান। প্রায়ই আপনার কার্ট পৃষ্ঠার মতোই।

উভয় URL ড্যাশবোর্ডে প্রতি-প্রোভাইডার কনফিগার করা, এলিমেন্টের সেগুলো সম্পর্কে জানার দরকার নেই।

যুক্ত করতে প্রস্তুত?

ফ্রি টিয়ার বেশিরভাগ সাইট কভার করে আর কখনো কার্ড চায় না।