स्थिति
साझा एजेंट, CLI, Plugin क्षमता, और आउटबाउंड डिलीवरी सतहों के लिए लागू किया गया:ReplyPayload.presentationअर्थपूर्ण संदेश UI रखता है।ReplyPayload.delivery.pinभेजे गए संदेश को पिन करने के अनुरोध रखता है।- साझा संदेश क्रियाएं प्रदाता-नेटिव
components,blocks,buttons, याcardके बजायpresentation,delivery, औरpinउजागर करती हैं। - कोर Plugin-घोषित आउटबाउंड क्षमताओं के माध्यम से प्रस्तुति को रेंडर या अपने आप डीग्रेड करता है।
- Discord, Slack, Telegram, Mattermost, MS Teams, और Feishu रेंडरर सामान्य अनुबंध का उपयोग करते हैं।
- Discord चैनल कंट्रोल-प्लेन कोड अब Carbon-आधारित UI कंटेनर आयात नहीं करता।
समस्या
चैनल UI अभी कई असंगत सतहों में बंटा हुआ है:- कोर
buildCrossContextComponentsके माध्यम से Discord-आकार वाला क्रॉस-कॉन्टेक्स्ट रेंडरर हुक रखता है। - Discord
channel.tsDiscordUiContainerके माध्यम से नेटिव Carbon UI आयात कर सकता है, जो रनटाइम UI निर्भरताओं को चैनल Plugin कंट्रोल प्लेन में खींचता है। - एजेंट और CLI Discord
components, Slackblocks, Telegram या Mattermostbuttons, और Teams या Feishucardजैसे नेटिव पेलोड एस्केप हैच उजागर करते हैं। ReplyPayload.channelDataट्रांसपोर्ट संकेत और नेटिव UI एनवेलप दोनों रखता है।- सामान्य
interactiveमॉडल मौजूद है, लेकिन यह Discord, Slack, Teams, Feishu, LINE, Telegram, और Mattermost द्वारा पहले से उपयोग किए जा रहे समृद्ध लेआउट से संकरा है।
लक्ष्य
- कोर घोषित क्षमताओं से किसी संदेश के लिए सर्वोत्तम अर्थपूर्ण प्रस्तुति तय करता है।
- एक्सटेंशन क्षमताएं घोषित करते हैं और अर्थपूर्ण प्रस्तुति को नेटिव ट्रांसपोर्ट पेलोड में रेंडर करते हैं।
- वेब कंट्रोल UI चैट नेटिव UI से अलग रहता है।
- साझा एजेंट या CLI संदेश सतह के माध्यम से नेटिव चैनल पेलोड उजागर नहीं किए जाते।
- असमर्थित प्रस्तुति सुविधाएं अपने आप सर्वोत्तम टेक्स्ट प्रतिनिधित्व में डीग्रेड होती हैं।
- भेजे गए संदेश को पिन करने जैसा डिलीवरी व्यवहार सामान्य डिलीवरी मेटाडेटा है, प्रस्तुति नहीं।
गैर-लक्ष्य
buildCrossContextComponentsके लिए कोई पिछड़ा-संगतता शिम नहीं।components,blocks,buttons, याcardके लिए कोई सार्वजनिक नेटिव एस्केप हैच नहीं।- चैनल-नेटिव UI लाइब्रेरी का कोई कोर आयात नहीं।
- बंडल किए गए चैनलों के लिए कोई प्रदाता-विशिष्ट SDK सीम नहीं।
लक्ष्य मॉडल
ReplyPayload में कोर-स्वामित्व वाला presentation फ़ील्ड जोड़ें।
interactive, presentation का उपसमुच्चय बन जाता है:
interactiveटेक्स्ट ब्लॉकpresentation.blocks[].type = "text"पर मैप होता है।interactiveबटन ब्लॉकpresentation.blocks[].type = "buttons"पर मैप होता है।interactiveसेलेक्ट ब्लॉकpresentation.blocks[].type = "select"पर मैप होता है।
presentation का उपयोग करते हैं; interactive मौजूदा रिप्लाई उत्पादकों के लिए एक आंतरिक लेगेसी पार्सर/रेंडरिंग हेल्पर बना रहता है।
सार्वजनिक उत्पादक-मुखी API interactive को अप्रचलित मानता है। रनटाइम
समर्थन बना रहता है ताकि मौजूदा अनुमोदन हेल्पर और पुराने plugins काम करते
रहें, जबकि नया कोड presentation उत्सर्जित करे।
डिलीवरी मेटाडेटा
भेजने के ऐसे व्यवहार के लिए कोर-स्वामित्व वालाdelivery फ़ील्ड जोड़ें जो UI नहीं है।
delivery.pin = trueका अर्थ है पहले सफलतापूर्वक डिलीवर किए गए संदेश को पिन करना।notifyडिफ़ॉल्ट रूप सेfalseहोता है।requiredडिफ़ॉल्ट रूप सेfalseहोता है; असमर्थित चैनल या असफल पिनिंग डिलीवरी जारी रखते हुए अपने आप डीग्रेड होते हैं।- मौजूदा संदेशों के लिए मैनुअल
pin,unpin, औरlist-pinsसंदेश क्रियाएं बनी रहती हैं।
channelData.telegram.pin = true से delivery.pin = true पर जाना चाहिए।
रनटाइम क्षमता अनुबंध
प्रस्तुति और डिलीवरी रेंडर हुक रनटाइम आउटबाउंड अडैप्टर में जोड़ें, कंट्रोल-प्लेन चैनल Plugin में नहीं।- लक्ष्य चैनल और रनटाइम अडैप्टर रिज़ॉल्व करें।
- प्रस्तुति क्षमताओं के लिए पूछें।
- असमर्थित ब्लॉक डीग्रेड करें और रेंडरिंग से पहले सामान्य क्षमता सीमाएं लागू करें।
renderPresentationकॉल करें।- यदि कोई रेंडरर मौजूद नहीं है, तो प्रस्तुति को टेक्स्ट फॉलबैक में बदलें।
- सफल भेजने के बाद, जब
delivery.pinअनुरोध किया गया हो और समर्थित हो, तोpinDeliveredMessageकॉल करें।
चैनल मैपिंग
Discord:- रनटाइम-केवल मॉड्यूल में
presentationको components v2 और Carbon कंटेनर में रेंडर करें। - हल्के मॉड्यूल में एक्सेंट रंग हेल्पर रखें।
- चैनल Plugin कंट्रोल-प्लेन कोड से
DiscordUiContainerआयात हटाएं।
presentationको Block Kit में रेंडर करें।- एजेंट और CLI
blocksइनपुट हटाएं।
- टेक्स्ट, कॉन्टेक्स्ट, और डिवाइडर को टेक्स्ट के रूप में रेंडर करें।
- लक्ष्य सतह के लिए कॉन्फ़िगर और अनुमत होने पर क्रियाओं और सेलेक्ट को inline keyboards के रूप में रेंडर करें।
- inline buttons अक्षम होने पर टेक्स्ट फॉलबैक का उपयोग करें।
- ACP टॉपिक पिनिंग को
delivery.pinपर ले जाएं।
- जहां कॉन्फ़िगर किया गया हो, क्रियाओं को इंटरैक्टिव बटन के रूप में रेंडर करें।
- अन्य ब्लॉक को टेक्स्ट फॉलबैक के रूप में रेंडर करें।
presentationको Adaptive Cards में रेंडर करें।- मैनुअल pin/unpin/list-pins क्रियाएं रखें।
- यदि लक्ष्य बातचीत के लिए Graph समर्थन भरोसेमंद हो, तो वैकल्पिक रूप से
pinDeliveredMessageलागू करें।
presentationको इंटरैक्टिव कार्ड में रेंडर करें।- मैनुअल pin/unpin/list-pins क्रियाएं रखें।
- यदि API व्यवहार भरोसेमंद हो, तो भेजे गए संदेश की पिनिंग के लिए वैकल्पिक रूप से
pinDeliveredMessageलागू करें।
- जहां संभव हो,
presentationको Flex या template messages में रेंडर करें। - असमर्थित ब्लॉक के लिए टेक्स्ट पर फॉलबैक करें।
channelDataसे LINE UI पेलोड हटाएं।
- प्रस्तुति को संयमित फ़ॉर्मैटिंग के साथ टेक्स्ट में बदलें।
रिफैक्टर चरण
- वह Discord रिलीज़ फिक्स फिर से लागू करें जो
ui-colors.tsको Carbon-आधारित UI से अलग करता है औरextensions/discord/src/channel.tsसेDiscordUiContainerहटाता है। ReplyPayload, आउटबाउंड पेलोड नॉर्मलाइज़ेशन, डिलीवरी सारांश, और हुक पेलोड मेंpresentationऔरdeliveryजोड़ें।- संकरे SDK/रनटाइम सबपाथ में
MessagePresentationस्कीमा और पार्सर हेल्पर जोड़ें। - संदेश क्षमताओं
buttons,cards,components, औरblocksको अर्थपूर्ण प्रस्तुति क्षमताओं से बदलें। - प्रस्तुति रेंडर और डिलीवरी पिनिंग के लिए रनटाइम आउटबाउंड अडैप्टर हुक जोड़ें।
- क्रॉस-कॉन्टेक्स्ट कंपोनेंट निर्माण को
buildCrossContextPresentationसे बदलें। src/infra/outbound/channel-adapters.tsहटाएं और चैनल Plugin प्रकारों सेbuildCrossContextComponentsहटाएं।maybeApplyCrossContextMarkerको नेटिव params के बजायpresentationसंलग्न करने के लिए बदलें।- Plugin-डिस्पैच भेजने वाले पाथ अपडेट करें ताकि वे केवल अर्थपूर्ण प्रस्तुति और डिलीवरी मेटाडेटा का उपयोग करें।
- एजेंट और CLI नेटिव पेलोड params हटाएं:
components,blocks,buttons, औरcard। - नेटिव message-tool स्कीमा बनाने वाले SDK हेल्पर हटाएं, और उन्हें प्रस्तुति स्कीमा हेल्पर से बदलें।
channelDataसे UI/नेटिव एनवेलप हटाएं; हर शेष फ़ील्ड की समीक्षा होने तक केवल ट्रांसपोर्ट मेटाडेटा रखें।- Discord, Slack, Telegram, Mattermost, MS Teams, Feishu, और LINE रेंडरर माइग्रेट करें।
- संदेश CLI, चैनल पेज, Plugin SDK, और क्षमता कुकबुक के लिए दस्तावेज़ अपडेट करें।
- Discord और प्रभावित चैनल एंट्रीपॉइंट के लिए import fanout profiling चलाएं।
channelData ट्रांसपोर्ट एनवेलप के लिए अधिक गहरा आंतरिक क्लीनअप पास बना रहता है। यदि हमें प्रकार/टेस्ट गेट से आगे परिमाणित import-fanout संख्याएं चाहिए, तो चरण 15 फॉलो-अप सत्यापन बना रहता है।
टेस्ट
जोड़ें या अपडेट करें:- प्रस्तुति नॉर्मलाइज़ेशन टेस्ट।
- असमर्थित ब्लॉक के लिए प्रस्तुति ऑटो-डीग्रेड टेस्ट।
- Plugin डिस्पैच और कोर डिलीवरी पाथ के लिए क्रॉस-कॉन्टेक्स्ट मार्कर टेस्ट।
- Discord, Slack, Telegram, Mattermost, MS Teams, Feishu, LINE, और टेक्स्ट फॉलबैक के लिए चैनल रेंडर मैट्रिक्स टेस्ट।
- संदेश टूल स्कीमा टेस्ट जो साबित करें कि नेटिव फ़ील्ड हट गए हैं।
- CLI टेस्ट जो साबित करें कि नेटिव फ़्लैग हट गए हैं।
- Carbon को कवर करने वाला Discord एंट्रीपॉइंट import-laziness रिग्रेशन।
- Telegram और सामान्य फॉलबैक को कवर करने वाले डिलीवरी पिन टेस्ट।
खुले प्रश्न
- क्या
delivery.pinको पहले पास में Discord, Slack, MS Teams, और Feishu के लिए लागू किया जाना चाहिए, या पहले केवल Telegram? - क्या
deliveryको अंततःreplyToId,replyToCurrent,silent, औरaudioAsVoiceजैसे मौजूदा फ़ील्ड समाहित करने चाहिए, या पोस्ट-सेंड व्यवहारों पर केंद्रित रहना चाहिए? - क्या प्रस्तुति को सीधे इमेज या फ़ाइल संदर्भों का समर्थन करना चाहिए, या अभी मीडिया को UI लेआउट से अलग रहना चाहिए?