{"id":91414,"date":"2025-01-05T19:27:10","date_gmt":"2025-01-05T15:57:10","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/"},"modified":"2025-01-05T19:27:10","modified_gmt":"2025-01-05T15:57:10","slug":"build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/","title":{"rendered":"\u0628\u0627 Prompt API Chrome \u062f\u0631 Angular \u06cc\u06a9 \u0637\u0628\u0642\u0647\u200c\u0628\u0646\u062f\u06cc \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0628\u0633\u0627\u0632\u06cc\u062f"},"content":{"rendered":"<div data-article-id=\"2190114\" id=\"article-body\">\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0648\u0628\u0644\u0627\u06af\u060c \u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0637\u0628\u0642\u0647 \u0628\u0646\u062f\u06cc \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Chrome&#39;s Built-In Prompt API \u0648 Angular \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u0645\u06cc \u062f\u0647\u0645. \u0628\u0631\u0646\u0627\u0645\u0647 Angular \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644 \u0632\u0628\u0627\u0646\u060c Prompt API \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 Gemini Nano \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0645\u062b\u0628\u062a \u06cc\u0627 \u0645\u0646\u0641\u06cc \u0631\u0627 \u0637\u0628\u0642\u0647 \u0628\u0646\u062f\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0645\u0632\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0647\u0648\u0634 \u0645\u0635\u0646\u0648\u0639\u06cc \u062f\u0627\u062e\u0644\u06cc \u06a9\u0631\u0648\u0645 \u0647\u0632\u06cc\u0646\u0647 \u0635\u0641\u0631 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0632 \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u0645\u062d\u0644\u06cc Chrome Canary \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f. \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0632 Chrome Dev \u06cc\u0627 Chrome Canary \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f\u060c \u0627\u06cc\u0646 \u0645\u0633\u06cc\u0631 \u062e\u0648\u0634\u062d\u0627\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0627\u0633\u062a. \u0627\u06af\u0631 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0632 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627\u06cc \u063a\u06cc\u0631 \u06a9\u0631\u0648\u0645 \u06cc\u0627 \u0642\u062f\u06cc\u0645\u06cc \u06a9\u0631\u0648\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u06cc\u06a9 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0645\u062c\u062f\u062f \u0628\u0627\u06cc\u062f \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0628\u0627\u0634\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u062a\u0645\u0627\u0633 \u0628\u0627 \u062c\u0645\u0627 \u06cc\u0627 \u062c\u0645\u06cc\u0646\u06cc \u062f\u0631 Vertex AI \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u0627\u062d\u0633\u0627\u0633 \u0635\u062d\u06cc\u062d.  <\/p>\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_84 counter-hierarchy ez-toc-counter-rtl ez-toc-grey ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0641\u0647\u0631\u0633\u062a \u0645\u0637\u0627\u0644\u0628<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#Gemini_Nano_%D8%B1%D8%A7_%D8%B1%D9%88%DB%8C_%DA%A9%D8%B1%D9%88%D9%85_%D9%86%D8%B5%D8%A8_%DA%A9%D9%86%DB%8C%D8%AF\" >Gemini Nano \u0631\u0627 \u0631\u0648\u06cc \u06a9\u0631\u0648\u0645 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D8%BA%DB%8C%D8%B1%D9%81%D8%B9%D8%A7%D9%84_%DA%A9%D8%B1%D8%AF%D9%86_%D8%B7%D8%A8%D9%82%D9%87%E2%80%8C%D8%A8%D9%86%D8%AF%DB%8C_%D8%A7%DB%8C%D9%85%D9%86%DB%8C_%D9%85%D8%AA%D9%86_%D8%AF%D8%B1_%DA%A9%D8%B1%D9%88%D9%85\" >\u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0637\u0628\u0642\u0647\u200c\u0628\u0646\u062f\u06cc \u0627\u06cc\u0645\u0646\u06cc \u0645\u062a\u0646 \u062f\u0631 \u06a9\u0631\u0648\u0645<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D8%AF%D8%A7%D8%B1%D8%A8%D8%B3%D8%AA_%DB%8C%DA%A9_%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87_%D8%B2%D8%A7%D9%88%DB%8C%D9%87_%D8%A7%DB%8C\" >\u062f\u0627\u0631\u0628\u0633\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0632\u0627\u0648\u06cc\u0647 \u0627\u06cc<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D9%88%D8%A7%D8%A8%D8%B3%D8%AA%DA%AF%DB%8C_%D9%87%D8%A7_%D8%B1%D8%A7_%D9%86%D8%B5%D8%A8_%DA%A9%D9%86%DB%8C%D8%AF\" >\u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D9%85%D8%AF%D9%84_%D8%B2%D8%A8%D8%A7%D9%86_%D8%B1%D8%A7_%D8%A8%D9%88%D8%AA_%D8%A7%D8%B3%D8%AA%D8%B1%D9%BE_%DA%A9%D9%86%DB%8C%D8%AF\" >\u0645\u062f\u0644 \u0632\u0628\u0627\u0646 \u0631\u0627 \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D9%86%D8%B3%D8%AE%D9%87_%D9%85%D8%B1%D9%88%D8%B1%DA%AF%D8%B1_%D9%88_%D8%AF%D8%B1_%D8%AF%D8%B3%D8%AA%D8%B1%D8%B3_%D8%A8%D9%88%D8%AF%D9%86_API_%D8%B1%D8%A7_%D8%AA%D8%A3%DB%8C%DB%8C%D8%AF_%DA%A9%D9%86%DB%8C%D8%AF\" >\u0646\u0633\u062e\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u0648 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0628\u0648\u062f\u0646 API \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D9%86%D9%85%D8%A7%DB%8C%D8%B4_%D8%A7%D8%AC%D8%B2%D8%A7%DB%8C_%D9%87%D9%88%D8%B4_%D9%85%D8%B5%D9%86%D9%88%D8%B9%DB%8C\" >\u0646\u0645\u0627\u06cc\u0634 \u0627\u062c\u0632\u0627\u06cc \u0647\u0648\u0634 \u0645\u0635\u0646\u0648\u0639\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#N_Shots_Prompt_Component\" >N Shots Prompt Component<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#N-shots_prompting\" >N-shots prompting<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D8%AC%D8%B2%D8%A1_%D9%BE%D8%A7%DB%8C%D9%87\" >\u062c\u0632\u0621 \u067e\u0627\u06cc\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%DB%8C%DA%A9_%D9%84%D8%A7%DB%8C%D9%87_%D8%B3%D8%B1%D9%88%DB%8C%D8%B3_%D8%B1%D9%88%DB%8C_Prompt_Detection_API_%D8%AA%D8%B9%D8%B1%DB%8C%D9%81_%DA%A9%D9%86%DB%8C%D8%AF\" >\u06cc\u06a9 \u0644\u0627\u06cc\u0647 \u0633\u0631\u0648\u06cc\u0633 \u0631\u0648\u06cc Prompt Detection API \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/nabfollower.com\/blog\/build-a-sentiment-classifier-with-chromes-prompt-api-in-angular-43ek\/#%D9%85%D9%86%D8%A7%D8%A8%D8%B9\" >\u0645\u0646\u0627\u0628\u0639:<\/a><\/li><\/ul><\/nav><\/div>\n<h2><span class=\"ez-toc-section\" id=\"Gemini_Nano_%D8%B1%D8%A7_%D8%B1%D9%88%DB%8C_%DA%A9%D8%B1%D9%88%D9%85_%D9%86%D8%B5%D8%A8_%DA%A9%D9%86%DB%8C%D8%AF\"><\/span>\n<p>  Gemini Nano \u0631\u0627 \u0631\u0648\u06cc \u06a9\u0631\u0648\u0645 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Chrome Dev\/Canary \u0631\u0627 \u0628\u0647 \u0622\u062e\u0631\u06cc\u0646 \u0646\u0633\u062e\u0647 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u062f. \u062a\u0627 \u0644\u062d\u0638\u0647 \u0646\u06af\u0627\u0631\u0634 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u062c\u062f\u06cc\u062f\u062a\u0631\u06cc\u0646 \u0646\u0633\u062e\u0647 Chrome Canary 133 \u0627\u0633\u062a. <\/p>\n<p>\u0644\u0637\u0641\u0627\u064b \u0628\u0631\u0627\u06cc \u062b\u0628\u062a \u0646\u0627\u0645 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u067e\u06cc\u0634 \u0646\u0645\u0627\u06cc\u0634 \u0627\u0648\u0644\u06cc\u0647 Chrome Built-in AI \u0628\u0647 \u0627\u06cc\u0646 \u0628\u062e\u0634 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f.<br \/>https:\/\/developer.chrome.com\/docs\/ai\/built-in#get_an_early_preview<\/p>\n<p>\u0644\u0637\u0641\u0627\u064b \u0628\u0631\u0627\u06cc \u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 Gemini Nano \u062f\u0631 \u06a9\u0631\u0648\u0645 \u0648 \u062f\u0627\u0646\u0644\u0648\u062f \u0645\u062f\u0644 \u0628\u0647 \u0627\u06cc\u0646 \u0628\u062e\u0634 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f. https:\/\/developer.chrome.com\/docs\/ai\/get-started#use_apis_on_localhost<\/p>\n<h2><span class=\"ez-toc-section\" id=\"%D8%BA%DB%8C%D8%B1%D9%81%D8%B9%D8%A7%D9%84_%DA%A9%D8%B1%D8%AF%D9%86_%D8%B7%D8%A8%D9%82%D9%87%E2%80%8C%D8%A8%D9%86%D8%AF%DB%8C_%D8%A7%DB%8C%D9%85%D9%86%DB%8C_%D9%85%D8%AA%D9%86_%D8%AF%D8%B1_%DA%A9%D8%B1%D9%88%D9%85\"><\/span>\n<p>  \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0637\u0628\u0642\u0647\u200c\u0628\u0646\u062f\u06cc \u0627\u06cc\u0645\u0646\u06cc \u0645\u062a\u0646 \u062f\u0631 \u06a9\u0631\u0648\u0645<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ul>\n<li>(\u062a\u0648\u0633\u0639\u0647 \u0645\u062d\u0644\u06cc) \u0628\u0647 chrome:\/\/flags\/#text-safety-classifier \u0628\u0631\u0648\u06cc\u062f.<\/li>\n<li>(\u062a\u0648\u0633\u0639\u0647 \u0645\u062d\u0644\u06cc) Disabled \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f<\/li>\n<li>\u0631\u0648\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062c\u062f\u062f \u06cc\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062c\u062f\u062f \u06a9\u0631\u0648\u0645 \u06a9\u0644\u06cc\u06a9 \u06a9\u0646\u06cc\u062f.<\/li>\n<\/ul>\n<h2><span class=\"ez-toc-section\" id=\"%D8%AF%D8%A7%D8%B1%D8%A8%D8%B3%D8%AA_%DB%8C%DA%A9_%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87_%D8%B2%D8%A7%D9%88%DB%8C%D9%87_%D8%A7%DB%8C\"><\/span>\n<p>  \u062f\u0627\u0631\u0628\u0633\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0632\u0627\u0648\u06cc\u0647 \u0627\u06cc<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight shell\"><code>ng new prompt-api-demo\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<h3><span class=\"ez-toc-section\" id=\"%D9%88%D8%A7%D8%A8%D8%B3%D8%AA%DA%AF%DB%8C_%D9%87%D8%A7_%D8%B1%D8%A7_%D9%86%D8%B5%D8%A8_%DA%A9%D9%86%DB%8C%D8%AF\"><\/span>\n<p>  \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight shell\"><code>npm i <span class=\"nt\">-save-exact<\/span> <span class=\"nt\">-save-dev<\/span> @types\/dom-chromium-ai\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0627\u06cc\u0646 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u062a\u0627\u06cc\u067e TypeScript \u0647\u0645\u0647 API\u0647\u0627\u06cc \u062f\u0627\u062e\u0644\u06cc Chrome \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f. \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u06a9\u062f\u0647\u0627\u06cc \u0638\u0631\u06cc\u0641\u06cc \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0647\u0648\u0634 \u0645\u0635\u0646\u0648\u0639\u06cc \u062f\u0631 TypeScript \u0628\u0646\u0648\u06cc\u0633\u0646\u062f.<\/p>\n<p>\u062f\u0631 main.ts\u060c \u06cc\u06a9 \u062a\u06af \u0645\u0631\u062c\u0639 \u0628\u0631\u0627\u06cc \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 \u0641\u0627\u06cc\u0644 \u062a\u0639\u0631\u06cc\u0641 \u062a\u0627\u06cc\u067e \u0628\u0633\u062a\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"c1\">\/\/ main.ts<\/span>\n\n<span class=\"c1\">\/\/\/ <reference path=\"..\/..\/..\/node_modules\/@types\/dom-chromium-ai\/index.d.ts\"\/>   <\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<h3><span class=\"ez-toc-section\" id=\"%D9%85%D8%AF%D9%84_%D8%B2%D8%A8%D8%A7%D9%86_%D8%B1%D8%A7_%D8%A8%D9%88%D8%AA_%D8%A7%D8%B3%D8%AA%D8%B1%D9%BE_%DA%A9%D9%86%DB%8C%D8%AF\"><\/span>\n<p>  \u0645\u062f\u0644 \u0632\u0628\u0627\u0646 \u0631\u0627 \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e \u06a9\u0646\u06cc\u062f<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">InjectionToken<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">@angular\/core<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\n\n<span class=\"k\">export<\/span> <span class=\"kd\">const<\/span> <span class=\"nx\">AI_PROMPT_API_TOKEN<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nx\">InjectionToken<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">AILanguageModelFactory<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">AI_PROMPT_API_TOKEN<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">export<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">provideLanguageModel<\/span><span class=\"p\">():<\/span> <span class=\"nx\">EnvironmentProviders<\/span> <span class=\"p\">{<\/span>\n   <span class=\"k\">return<\/span> <span class=\"nf\">makeEnvironmentProviders<\/span><span class=\"p\">([<\/span>\n       <span class=\"p\">{<\/span>\n           <span class=\"na\">provide<\/span><span class=\"p\">:<\/span> <span class=\"nx\">AI_PROMPT_API_TOKEN<\/span><span class=\"p\">,<\/span>\n           <span class=\"na\">useFactory<\/span><span class=\"p\">:<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n               <span class=\"kd\">const<\/span> <span class=\"nx\">platformId<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">PLATFORM_ID<\/span><span class=\"p\">);<\/span>\n               <span class=\"kd\">const<\/span> <span class=\"nx\">objWindow<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">isPlatformBrowser<\/span><span class=\"p\">(<\/span><span class=\"nx\">platformId<\/span><span class=\"p\">)<\/span> <span class=\"p\">?<\/span> <span class=\"nb\">window<\/span> <span class=\"p\">:<\/span> <span class=\"kc\">undefined<\/span><span class=\"p\">;<\/span>\n               <span class=\"k\">return<\/span>  <span class=\"nx\">objWindow<\/span><span class=\"p\">?.<\/span><span class=\"nx\">ai<\/span><span class=\"p\">?.<\/span><span class=\"nx\">languageModel<\/span><span class=\"p\">;<\/span>\n           <span class=\"p\">},<\/span>\n       <span class=\"p\">}<\/span>\n   <span class=\"p\">]);<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0645\u0646 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0645\u062d\u06cc\u0637 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06af\u0634\u062a \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645 <code>languageModel<\/code> \u062f\u0631 <code>window.ai<\/code> \u0641\u0636\u0627\u06cc \u0646\u0627\u0645 \u0648\u0642\u062a\u06cc \u06a9\u062f\u0647\u0627 \u0631\u0627 \u062a\u0632\u0631\u06cc\u0642 \u0645\u06cc \u06a9\u0646\u0646\u062f <code>AI_LANGUAGE_PROMPT_API_TOKEN<\/code> \u0622\u0646\u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 Prompt API \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f \u062a\u0627 \u0645\u062a\u062f\u0647\u0627\u06cc \u0622\u0646 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u0628\u0647 Gemini Nano \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"c1\">\/\/ app.config.ts<\/span>\n\n<span class=\"k\">export<\/span> <span class=\"kd\">const<\/span> <span class=\"nx\">appConfig<\/span><span class=\"p\">:<\/span> <span class=\"nx\">ApplicationConfig<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\n  <span class=\"na\">providers<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\n    <span class=\"nf\">provideLanguageModel<\/span><span class=\"p\">()<\/span>\n  <span class=\"p\">]<\/span>\n<span class=\"p\">};<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u062f\u0631 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0628\u0631\u0646\u0627\u0645\u0647\u060c <code>provideLanguageModel<\/code> \u0628\u0647 \u0622\u0631\u0627\u06cc\u0647 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0648\u0627\u0631\u062f \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<h3><span class=\"ez-toc-section\" id=\"%D9%86%D8%B3%D8%AE%D9%87_%D9%85%D8%B1%D9%88%D8%B1%DA%AF%D8%B1_%D9%88_%D8%AF%D8%B1_%D8%AF%D8%B3%D8%AA%D8%B1%D8%B3_%D8%A8%D9%88%D8%AF%D9%86_API_%D8%B1%D8%A7_%D8%AA%D8%A3%DB%8C%DB%8C%D8%AF_%DA%A9%D9%86%DB%8C%D8%AF\"><\/span>\n<p>  \u0646\u0633\u062e\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u0648 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0628\u0648\u062f\u0646 API \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u06cc\u062f<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0647\u0648\u0634 \u0645\u0635\u0646\u0648\u0639\u06cc \u062f\u0627\u062e\u0644\u06cc \u06a9\u0631\u0648\u0645 \u062f\u0631 \u0648\u0636\u0639\u06cc\u062a \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0627\u0633\u062a \u0648 Prompt API \u062f\u0631 \u0646\u0633\u062e\u0647 131 \u06a9\u0631\u0648\u0645 \u0648 \u062c\u062f\u06cc\u062f\u062a\u0631 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0645\u06cc\u200c\u0634\u0648\u062f. \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0645\u0646 \u0645\u0646\u0637\u0642 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0628\u0648\u062f\u0646 API \u0642\u0628\u0644 \u0627\u0632 \u0646\u0645\u0627\u06cc\u0634 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0627\u062c\u0631\u0627 \u06a9\u0631\u062f\u0645 \u062a\u0627 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u062a\u0648\u0627\u0646\u0646\u062f \u0645\u062a\u0648\u0646 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0642\u0648\u0627\u0646\u06cc\u0646 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632:<\/p>\n<ul>\n<li>\u0645\u0631\u0648\u0631\u06af\u0631 \u06a9\u0631\u0648\u0645 \u0627\u0633\u062a<\/li>\n<li>\u0646\u0633\u062e\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u062d\u062f\u0627\u0642\u0644 131 \u0627\u0633\u062a<\/li>\n<li>ai Object \u062f\u0631 \u0641\u0636\u0627\u06cc \u0646\u0627\u0645 \u067e\u0646\u062c\u0631\u0647 \u0627\u0633\u062a<\/li>\n<li>\u0648\u0636\u0639\u06cc\u062a Prompt API \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0627\u0633\u062a\n<\/li>\n<\/ul>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">export<\/span> <span class=\"k\">async<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">checkChromeBuiltInAI<\/span><span class=\"p\">():<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">string<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nf\">isChromeBrowser<\/span><span class=\"p\">())<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">NOT_CHROME_BROWSER<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nf\">getChromVersion<\/span><span class=\"p\">()<\/span> <span class=\"o\">&lt;<\/span> <span class=\"nx\">CHROME_VERSION<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">OLD_BROWSER<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">ai<\/span><span class=\"dl\">'<\/span> <span class=\"k\">in<\/span> <span class=\"nx\">globalThis<\/span><span class=\"p\">))<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">NO_PROMPT_API<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"kd\">const<\/span> <span class=\"nx\">assistant<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">AI_PROMPT_API_TOKEN<\/span><span class=\"p\">);<\/span>\n  <span class=\"kd\">const<\/span> <span class=\"nx\">status<\/span> <span class=\"o\">=<\/span> <span class=\"p\">(<\/span><span class=\"k\">await<\/span> <span class=\"nx\">assistant<\/span><span class=\"p\">?.<\/span><span class=\"nf\">capabilities<\/span><span class=\"p\">())?.<\/span><span class=\"nx\">available<\/span><span class=\"p\">;<\/span>\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">status<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">API_NOT_READY<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span> <span class=\"k\">else<\/span> <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">status<\/span> <span class=\"o\">===<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">after-download<\/span><span class=\"dl\">'<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">AFTER_DOWNLOAD<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span> <span class=\"k\">else<\/span> <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">status<\/span> <span class=\"o\">===<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">no<\/span><span class=\"dl\">'<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">NO_LARGE_LANGUAGE_MODEL<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"k\">return<\/span> <span class=\"dl\">''<\/span><span class=\"p\">;<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>checkChromeBuiltInAI<\/code> \u062a\u0627\u0628\u0639 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 Prompt API \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0648 \u0622\u0645\u0627\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0633\u062a. \u0627\u06af\u0631 \u0628\u0631\u0631\u0633\u06cc \u0646\u0627\u0645\u0648\u0641\u0642 \u0628\u0627\u0634\u062f\u060c \u062a\u0627\u0628\u0639 \u062e\u0637\u0627 \u0645\u06cc \u062f\u0647\u062f. \u062f\u0631 \u063a\u06cc\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u062e\u0627\u0644\u06cc \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">export<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">isPromptAPISupported<\/span><span class=\"p\">():<\/span> <span class=\"nx\">Observable<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">string<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\n  <span class=\"k\">return<\/span> <span class=\"k\">from<\/span><span class=\"p\">(<\/span><span class=\"nf\">checkChromeBuiltInAI<\/span><span class=\"p\">()).<\/span><span class=\"nf\">pipe<\/span><span class=\"p\">(<\/span>\n     <span class=\"nf\">catchError<\/span><span class=\"p\">(<\/span>\n        <span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n           <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">error<\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">);<\/span>\n           <span class=\"k\">return<\/span> <span class=\"k\">of<\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span> <span class=\"k\">instanceof<\/span> <span class=\"nb\">Error<\/span> <span class=\"p\">?<\/span> <span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"nx\">message<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">unknown<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n        <span class=\"p\">}<\/span>\n     <span class=\"p\">)<\/span>\n  <span class=\"p\">);<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>isPromptApiSupported<\/code> \u062a\u0627\u0628\u0639 \u062e\u0637\u0627 \u0631\u0627 \u0645\u06cc \u06af\u06cc\u0631\u062f \u0648 \u067e\u06cc\u063a\u0627\u0645 \u062e\u0637\u0627\u06cc Observable of \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f. <\/p>\n<h3><span class=\"ez-toc-section\" id=\"%D9%86%D9%85%D8%A7%DB%8C%D8%B4_%D8%A7%D8%AC%D8%B2%D8%A7%DB%8C_%D9%87%D9%88%D8%B4_%D9%85%D8%B5%D9%86%D9%88%D8%B9%DB%8C\"><\/span>\n<p>  \u0646\u0645\u0627\u06cc\u0634 \u0627\u062c\u0632\u0627\u06cc \u0647\u0648\u0634 \u0645\u0635\u0646\u0648\u0639\u06cc<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"p\">@<\/span><span class=\"nd\">Component<\/span><span class=\"p\">({<\/span>\n    <span class=\"na\">selector<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">app-detect-ai<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n    <span class=\"na\">imports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">PromptShowcaseComponent<\/span><span class=\"p\">],<\/span>\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\n    <div>\n      @let error = hasCapability();\n      @if (!error) {\n        <app-promt-showcase\/>\n      } @else if (error !== 'unknown') {\n        {{ error }}\n      }\n    <\/div>\n  `<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">DetectAIComponent<\/span> <span class=\"p\">{<\/span>\n  <span class=\"nx\">hasCapability<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">toSignal<\/span><span class=\"p\">(<\/span><span class=\"nf\">isPromptAPISupported<\/span><span class=\"p\">(),<\/span> <span class=\"p\">{<\/span> <span class=\"na\">initialValue<\/span><span class=\"p\">:<\/span> <span class=\"dl\">''<\/span> <span class=\"p\">});<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>DetectAIComponent<\/code> \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f <code>PromptShowcaseComponent<\/code> \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0647\u06cc\u0686 \u062e\u0637\u0627\u06cc\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f \u062f\u0631 \u063a\u06cc\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u067e\u06cc\u063a\u0627\u0645 \u062e\u0637\u0627 \u0631\u0627 \u062f\u0631 \u0633\u06cc\u06af\u0646\u0627\u0644 \u062e\u0637\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"c1\">\/\/ prompt-showcase.component.ts <\/span>\n\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span><span class=\"p\">({<\/span>\n   <span class=\"na\">selector<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">app-prompt-showcase<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n   <span class=\"na\">imports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">NgComponentOutlet<\/span><span class=\"p\">],<\/span>\n   <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\n   @let outlet = componentOutlet();\n   <ng-container\/>\n `<\/span><span class=\"p\">,<\/span>\n   <span class=\"na\">changeDetection<\/span><span class=\"p\">:<\/span> <span class=\"nx\">ChangeDetectionStrategy<\/span><span class=\"p\">.<\/span><span class=\"nx\">OnPush<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">PromptShowcaseComponent<\/span> <span class=\"p\">{<\/span>\n   <span class=\"nx\">promptService<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">ZeroPromptService<\/span><span class=\"p\">);<\/span>\n   <span class=\"nx\">componentOutlet<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">computed<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>  \n      <span class=\"k\">return<\/span> <span class=\"p\">{<\/span>\n        <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">NShotsPromptComponent<\/span><span class=\"p\">,<\/span>\n        <span class=\"na\">inputs<\/span><span class=\"p\">:<\/span> <span class=\"p\">{}<\/span>\n      <span class=\"p\">}<\/span>\n   <span class=\"p\">});<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>PromptShowcaserComponent<\/code> \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f <code>NShotsPromptComponent<\/code> \u0628\u0647 \u0635\u0648\u0631\u062a \u067e\u0648\u06cc\u0627<\/p>\n<h3><span class=\"ez-toc-section\" id=\"N_Shots_Prompt_Component\"><\/span>\n<p>  N Shots Prompt Component<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"c1\">\/\/ n-shots-prompt.component.ts<\/span>\n\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span><span class=\"p\">({<\/span>\n   <span class=\"na\">selector<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">app-n-shot-prompt<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n   <span class=\"na\">imports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">FormsModule<\/span><span class=\"p\">],<\/span>\n   <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\n   <div>\n     <h3><span class=\"ez-toc-section\" id=\"N-shots_prompting\"><\/span>N-shots prompting<span class=\"ez-toc-section-end\"><\/span><\/h3>\n     @let myState = state();\n     <p>\n       <span class=\"label\" for=\"input\">Prompt: <\/span>\n       <textarea id=\"input\" name=\"input\" rows=\"3\"\/>\n     <\/p>\n     <button>{{ myState.text }}<\/button>\n     \n     @if (error()) {\n       \n     }\n   <\/div>`<\/span><span class=\"p\">,<\/span>\n   <span class=\"na\">styleUrl<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/prompt.component.css<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n   <span class=\"na\">providers<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\n       <span class=\"p\">{<\/span>\n           <span class=\"na\">provide<\/span><span class=\"p\">:<\/span> <span class=\"nx\">AbstractPromptService<\/span><span class=\"p\">,<\/span>\n           <span class=\"na\">useClass<\/span><span class=\"p\">:<\/span> <span class=\"nx\">NShotsPromptService<\/span><span class=\"p\">,<\/span>\n       <span class=\"p\">}<\/span>\n   <span class=\"p\">],<\/span>\n   <span class=\"na\">changeDetection<\/span><span class=\"p\">:<\/span> <span class=\"nx\">ChangeDetectionStrategy<\/span><span class=\"p\">.<\/span><span class=\"nx\">OnPush<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">NShotsPromptComponent<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">BasePromptComponent<\/span> <span class=\"p\">{<\/span>\n <span class=\"nx\">initialPrompts<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">LanguageInitialPrompt<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">([<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">system<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`You are an expert in determine the sentiment of a text.\n   If it is positive, say 'positive'. If it is negative, say 'negative'. If you are not sure, then say 'not sure'`<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">user<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">The food is affordable and delicious, and the venue is close to the train station.<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">assistant<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">positive<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">user<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">The waiters are very rude, the food is salty, and the drinks are sour.<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">assistant<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">negative<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">user<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">Google is a company<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">assistant<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">not sure<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">user<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">The weather is hot and sunny today.<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">},<\/span>\n   <span class=\"p\">{<\/span> <span class=\"na\">role<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">assistant<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">content<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">postive<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">}<\/span>\n <span class=\"p\">]);<\/span>\n\n <span class=\"nf\">constructor<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n   <span class=\"k\">super<\/span><span class=\"p\">();<\/span>\n   <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">query<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">The toilet has no toilet papers again.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n   <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">promptService<\/span><span class=\"p\">.<\/span><span class=\"nf\">setPromptOptions<\/span><span class=\"p\">({<\/span> <span class=\"na\">initialPrompts<\/span><span class=\"p\">:<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">initialPrompts<\/span><span class=\"p\">()<\/span> <span class=\"p\">});<\/span>\n <span class=\"p\">}<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>NShotsPromptComponent<\/code> \u06cc\u06a9 \u0646\u0627\u062d\u06cc\u0647 \u0645\u062a\u0646\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u062f \u0648 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u0627\u0631\u0633\u0627\u0644 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0622\u0646 \u0628\u0647 LLM \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u062d\u0633\u0627\u0633 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f. \u0631\u0627 <code>initialPrompts<\/code> \u0633\u06cc\u06af\u0646\u0627\u0644 \u0646\u0645\u0648\u0646\u0647 \u0647\u0627\u06cc\u06cc \u0627\u0632 \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0645\u062b\u0628\u062a \u0648 \u0645\u0646\u0641\u06cc \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u062f. \u0627\u0648\u0644\u06cc\u0646 \u0648\u0631\u0648\u062f\u06cc \u0633\u06cc\u06af\u0646\u0627\u0644 \u06cc\u06a9 \u0627\u0639\u0644\u0627\u0646 \u0633\u06cc\u0633\u062a\u0645\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0632\u0645\u06cc\u0646\u0647 \u0645\u0634\u06a9\u0644 \u0631\u0627 \u062a\u0648\u0635\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u062f. \u062f\u0631 \u0627\u06cc\u0646 \u062f\u0645\u0648\u060c \u0627\u0632 Gemini Nano \u062e\u0648\u0627\u0633\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f \u062a\u0627 \u0627\u062d\u0633\u0627\u0633 \u06cc\u06a9 \u062c\u0645\u0644\u0647 \u0631\u0627 \u062a\u0639\u06cc\u06cc\u0646 \u06a9\u0646\u062f. \u0627\u06af\u0631 \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0645\u062b\u0628\u062a \u0628\u0627\u0634\u062f\u060c \u0646\u062a\u06cc\u062c\u0647 &#8220;\u0645\u062b\u0628\u062a&#8221; \u0627\u0633\u062a. \u0627\u06af\u0631 \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0645\u0646\u0641\u06cc \u0628\u0627\u0634\u062f\u060c \u0646\u062a\u06cc\u062c\u0647 &#8220;\u0645\u0646\u0641\u06cc&#8221; \u0627\u0633\u062a. \u062f\u0631 \u063a\u06cc\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a\u060c \u0646\u062a\u06cc\u062c\u0647 &#8220;\u0645\u0637\u0645\u0626\u0646 \u0646\u06cc\u0633\u062a&#8221;.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"nf\">constructor<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n   <span class=\"k\">super<\/span><span class=\"p\">();<\/span>\n   <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">query<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">The toilet has no toilet papers again.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n   <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">promptService<\/span><span class=\"p\">.<\/span><span class=\"nf\">setPromptOptions<\/span><span class=\"p\">({<\/span> <span class=\"na\">initialPrompts<\/span><span class=\"p\">:<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">initialPrompts<\/span><span class=\"p\">()<\/span> <span class=\"p\">});<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0633\u0627\u0632\u0646\u062f\u0647 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0645\u0642\u062f\u0627\u0631 \u0627\u0648\u0644\u06cc\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f\u0647 \u0648 \u0622\u0646 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f <code>NShotsPromptService<\/code> \u0628\u0631\u0627\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 Prompt API.<\/p>\n<h3><span class=\"ez-toc-section\" id=\"%D8%AC%D8%B2%D8%A1_%D9%BE%D8%A7%DB%8C%D9%87\"><\/span>\n<p>  \u062c\u0632\u0621 \u067e\u0627\u06cc\u0647<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"p\">@<\/span><span class=\"nd\">Directive<\/span><span class=\"p\">({<\/span>\n   <span class=\"na\">standalone<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">abstract<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">BasePromptComponent<\/span> <span class=\"p\">{<\/span>\n   <span class=\"nx\">promptService<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">AbstractPromptService<\/span><span class=\"p\">);<\/span>\n    <span class=\"nx\">session<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">promptService<\/span><span class=\"p\">.<\/span><span class=\"nx\">session<\/span><span class=\"p\">;<\/span>\n\n   <span class=\"nx\">isLoading<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">signal<\/span><span class=\"p\">(<\/span><span class=\"kc\">false<\/span><span class=\"p\">);<\/span>\n   <span class=\"nx\">error<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">signal<\/span><span class=\"p\">(<\/span><span class=\"dl\">''<\/span><span class=\"p\">);<\/span>\n   <span class=\"nx\">query<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">signal<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">Tell me about the job responsibility of an A.I. engineer, maximum 500 words.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n   <span class=\"nx\">response<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">signal<\/span><span class=\"p\">(<\/span><span class=\"dl\">''<\/span><span class=\"p\">);<\/span>\n\n   <span class=\"nx\">state<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">computed<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">isLoading<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">isLoading<\/span><span class=\"p\">();<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">isUnavailableForCall<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">isLoading<\/span> <span class=\"o\">||<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">query<\/span><span class=\"p\">().<\/span><span class=\"nf\">trim<\/span><span class=\"p\">()<\/span> <span class=\"o\">===<\/span> <span class=\"dl\">''<\/span><span class=\"p\">;<\/span>\n       <span class=\"k\">return<\/span> <span class=\"p\">{<\/span>\n           <span class=\"na\">status<\/span><span class=\"p\">:<\/span> <span class=\"nx\">isLoading<\/span> <span class=\"p\">?<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">Processing...<\/span><span class=\"dl\">'<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">Idle<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n           <span class=\"na\">text<\/span><span class=\"p\">:<\/span> <span class=\"nx\">isLoading<\/span> <span class=\"p\">?<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">Progressing...<\/span><span class=\"dl\">'<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">Submit<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n           <span class=\"na\">disabled<\/span><span class=\"p\">:<\/span> <span class=\"nx\">isLoading<\/span><span class=\"p\">,<\/span>\n           <span class=\"na\">submitDisabled<\/span><span class=\"p\">:<\/span> <span class=\"nx\">isUnavailableForCall<\/span>\n       <span class=\"p\">}<\/span>\n   <span class=\"p\">});<\/span>\n\n    <span class=\"k\">async<\/span> <span class=\"nf\">submitPrompt<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">try<\/span> <span class=\"p\">{<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isLoading<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"kc\">true<\/span><span class=\"p\">);<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">error<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"dl\">''<\/span><span class=\"p\">);<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">response<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"dl\">''<\/span><span class=\"p\">);<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">answer<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">promptService<\/span><span class=\"p\">.<\/span><span class=\"nf\">prompt<\/span><span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">query<\/span><span class=\"p\">());<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">response<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">answer<\/span><span class=\"p\">);<\/span>\n     <span class=\"p\">}<\/span> <span class=\"k\">catch<\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">errMsg<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">e<\/span> <span class=\"k\">instanceof<\/span> <span class=\"nb\">Error<\/span> <span class=\"p\">?<\/span> <span class=\"p\">(<\/span><span class=\"nx\">e<\/span> <span class=\"k\">as<\/span> <span class=\"nb\">Error<\/span><span class=\"p\">).<\/span><span class=\"nx\">message<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">Error in submitPrompt<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">error<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">errMsg<\/span><span class=\"p\">);<\/span>\n     <span class=\"p\">}<\/span> <span class=\"k\">finally<\/span> <span class=\"p\">{<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isLoading<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"kc\">false<\/span><span class=\"p\">);<\/span>\n     <span class=\"p\">}<\/span>\n   <span class=\"p\">}<\/span>\n <span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>BasePromptComponent<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0631\u0633\u0627\u0644 \u0648 \u0633\u06cc\u06af\u0646\u0627\u0644 \u0647\u0627 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u0648\u0636\u0639\u06cc\u062a \u0647\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648\u060c \u067e\u0627\u0633\u062e \u0648 \u0645\u0634\u0627\u0647\u062f\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0645\u062a\u062f submitPrompt \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u0628\u0647 Gemini Nano \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0645\u062a\u0646 \u0647\u0627 \u0631\u0627 \u062a\u0648\u0644\u06cc\u062f \u06a9\u0646\u062f \u0648 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0633\u06cc\u06af\u0646\u0627\u0644 \u067e\u0627\u0633\u062e \u0627\u062e\u062a\u0635\u0627\u0635 \u062f\u0647\u062f. \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 LLM \u0627\u0634\u063a\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f\u060c \u0633\u06cc\u06af\u0646\u0627\u0644 isLoading \u0631\u0648\u06cc true \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0639\u0646\u0627\u0635\u0631 UI (\u0645\u0646\u0637\u0642\u0647 \u0645\u062a\u0646 \u0648 \u062f\u06a9\u0645\u0647) \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f. \u0648\u0642\u062a\u06cc \u0633\u06cc\u06af\u0646\u0627\u0644 \u0631\u0648\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u062a\u0646\u0638\u06cc\u0645 \u0634\u0648\u062f\u060c \u0639\u0646\u0627\u0635\u0631 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0641\u0639\u0627\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<h3><span class=\"ez-toc-section\" id=\"%DB%8C%DA%A9_%D9%84%D8%A7%DB%8C%D9%87_%D8%B3%D8%B1%D9%88%DB%8C%D8%B3_%D8%B1%D9%88%DB%8C_Prompt_Detection_API_%D8%AA%D8%B9%D8%B1%DB%8C%D9%81_%DA%A9%D9%86%DB%8C%D8%AF\"><\/span>\n<p>  \u06cc\u06a9 \u0644\u0627\u06cc\u0647 \u0633\u0631\u0648\u06cc\u0633 \u0631\u0648\u06cc Prompt Detection API \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0631\u0627 <code>NShotsPromptService<\/code> \u0633\u0631\u0648\u06cc\u0633 \u0645\u0646\u0637\u0642 Prompt API \u0631\u0627 \u06a9\u067e\u0633\u0648\u0644\u0647 \u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u0631\u0627 <code>createPromptSession<\/code> \u06cc\u06a9 \u062c\u0644\u0633\u0647 \u0628\u0627 \u062f\u0633\u062a\u0648\u0631\u0627\u062a \u0627\u0648\u0644\u06cc\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f. \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0633\u0631\u0648\u06cc\u0633 \u0627\u0632 \u0628\u06cc\u0646 \u0645\u06cc \u0631\u0648\u062f\u060c <code>ngOnDestroy<\/code> \u0631\u0648\u0634 \u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u0646\u0634\u062a \u062d\u0627\u0641\u0638\u0647\u060c \u062c\u0644\u0633\u0647 \u0631\u0627 \u0627\u0632 \u0628\u06cc\u0646 \u0645\u06cc \u0628\u0631\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"p\">@<\/span><span class=\"nd\">Injectable<\/span><span class=\"p\">({<\/span>\n <span class=\"na\">providedIn<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">root<\/span><span class=\"dl\">'<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">NShotsPromptService<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">AbstractPromptService<\/span> <span class=\"k\">implements<\/span> <span class=\"nx\">OnDestroy<\/span>  <span class=\"p\">{<\/span>\n <span class=\"err\">#<\/span><span class=\"nx\">controller<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">AbortController<\/span><span class=\"p\">();<\/span>\n\n <span class=\"nx\">override<\/span> <span class=\"k\">async<\/span> <span class=\"nf\">createPromptSession<\/span><span class=\"p\">(<\/span><span class=\"nx\">options<\/span><span class=\"p\">?:<\/span> <span class=\"nx\">PromptOptions<\/span><span class=\"p\">):<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">AILanguageModel<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\n   <span class=\"kd\">const<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">initialPrompts<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">undefined<\/span> <span class=\"p\">}<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">options<\/span> <span class=\"o\">||<\/span> <span class=\"p\">{};<\/span>\n   <span class=\"k\">return<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">promptApi<\/span><span class=\"p\">?.<\/span><span class=\"nf\">create<\/span><span class=\"p\">({<\/span> <span class=\"nx\">initialPrompts<\/span><span class=\"p\">,<\/span> <span class=\"na\">signal<\/span><span class=\"p\">:<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">controller<\/span><span class=\"p\">.<\/span><span class=\"nx\">signal<\/span> <span class=\"p\">});<\/span>\n <span class=\"p\">}<\/span>\n\n <span class=\"nf\">ngOnDestroy<\/span><span class=\"p\">():<\/span> <span class=\"k\">void<\/span> <span class=\"p\">{<\/span>\n   <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">destroySession<\/span><span class=\"p\">();<\/span>\n <span class=\"p\">}<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>AbtractPromptService<\/code> \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f\u06cc \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0633\u0627\u06cc\u0631 \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc \u0633\u0631\u06cc\u0639 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0631\u062b \u0628\u0628\u0631\u0646\u062f.<\/p>\n<p>\u0631\u0627 <code>createSessionIfNotExists<\/code> \u0645\u062a\u062f \u06cc\u06a9 \u062c\u0644\u0633\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0622\u0646 \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u062f <code>#session<\/code> \u0633\u06cc\u06af\u0646\u0627\u0644 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u06cc\u06a9 \u062c\u0644\u0633\u0647 \u0632\u0645\u0627\u0646\u06cc \u062f\u0648\u0628\u0627\u0631\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u0642\u0628\u0644\u06cc \u06a9\u0645\u062a\u0631 \u0627\u0632 500 \u062a\u0648\u06a9\u0646 \u0628\u0627\u0642\u06cc \u0645\u0627\u0646\u062f\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">export<\/span> <span class=\"kd\">abstract<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">AbstractPromptService<\/span> <span class=\"p\">{<\/span>\n   <span class=\"nx\">promptApi<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">AI_PROMPT_API_TOKEN<\/span><span class=\"p\">);<\/span>\n   <span class=\"err\">#<\/span><span class=\"nx\">session<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">AILanguageModel<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"kc\">undefined<\/span><span class=\"p\">);<\/span>\n   <span class=\"err\">#<\/span><span class=\"nx\">tokenContext<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">Tokenization<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">null<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"kc\">null<\/span><span class=\"p\">);<\/span>\n   <span class=\"err\">#<\/span><span class=\"nx\">options<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">PromptOptions<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"kc\">undefined<\/span><span class=\"p\">);<\/span>\n\n   <span class=\"nf\">resetSession<\/span><span class=\"p\">(<\/span><span class=\"nx\">newSession<\/span><span class=\"p\">:<\/span> <span class=\"nx\">AILanguageModel<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">session<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">newSession<\/span><span class=\"p\">);<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">tokenContext<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"kc\">null<\/span><span class=\"p\">);<\/span>\n   <span class=\"p\">}<\/span>\n\n   <span class=\"nf\">shouldCreateSession<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">session<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nf\">session<\/span><span class=\"p\">();<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">context<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nf\">tokenContext<\/span><span class=\"p\">();<\/span>\n       <span class=\"k\">return<\/span> <span class=\"o\">!<\/span><span class=\"nx\">session<\/span> <span class=\"o\">||<\/span> <span class=\"p\">(<\/span><span class=\"nx\">context<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"nx\">context<\/span><span class=\"p\">.<\/span><span class=\"nx\">tokensLeft<\/span> <span class=\"o\">&lt;<\/span> <span class=\"mi\">500<\/span><span class=\"p\">);<\/span>\n   <span class=\"p\">}<\/span>\n\n   <span class=\"nf\">setPromptOptions<\/span><span class=\"p\">(<\/span><span class=\"nx\">options<\/span><span class=\"p\">?:<\/span> <span class=\"nx\">PromptOptions<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n       <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">options<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">options<\/span><span class=\"p\">);<\/span>\n   <span class=\"p\">}<\/span>\n\n   <span class=\"k\">async<\/span> <span class=\"nf\">createSessionIfNotExists<\/span><span class=\"p\">():<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"k\">void<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\n     <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">shouldCreateSession<\/span><span class=\"p\">())<\/span> <span class=\"p\">{<\/span>\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">destroySession<\/span><span class=\"p\">();<\/span>\n        <span class=\"kd\">const<\/span> <span class=\"nx\">newSession<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">createPromptSession<\/span><span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nf\">options<\/span><span class=\"p\">());<\/span>\n        <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">newSession<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n           <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">Prompt API failed to create a session.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>      \n        <span class=\"p\">}<\/span>\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">resetSession<\/span><span class=\"p\">(<\/span><span class=\"nx\">newSession<\/span><span class=\"p\">);<\/span>\n     <span class=\"p\">}<\/span>\n   <span class=\"p\">}<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0645\u062a\u062f \u0627\u0646\u062a\u0632\u0627\u0639\u06cc createPromptSession \u0628\u0647 \u062e\u062f\u0645\u0627\u062a \u0628\u062a\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641 \u062c\u0644\u0633\u0627\u062a \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u0646\u062f. \u06cc\u06a9 \u062c\u0644\u0633\u0647 \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0639\u0644\u0627\u0646\u060c \u0627\u0639\u0644\u0627\u0646 \u0633\u06cc\u0633\u062a\u0645 \u06cc\u0627 \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0639\u0644\u0627\u0646 \u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"kd\">abstract<\/span> <span class=\"nf\">createPromptSession<\/span><span class=\"p\">(<\/span><span class=\"nx\">options<\/span><span class=\"p\">?:<\/span> <span class=\"nx\">PromptOptions<\/span><span class=\"p\">):<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">AILanguageModel<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">;<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0645\u062a\u062f prompt \u0632\u0645\u0627\u0646\u06cc \u06cc\u06a9 \u062c\u0644\u0633\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f. \u0633\u067e\u0633\u060c \u062c\u0644\u0633\u0647 \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0648 \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u0645\u062a\u0648\u0646 \u0645\u06cc \u067e\u0630\u06cc\u0631\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">async<\/span> <span class=\"nf\">prompt<\/span><span class=\"p\">(<\/span><span class=\"nx\">query<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">):<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">string<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\n       <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">promptApi<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n           <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"nx\">ERROR_CODES<\/span><span class=\"p\">.<\/span><span class=\"nx\">NO_PROMPT_API<\/span><span class=\"p\">);<\/span>\n       <span class=\"p\">}<\/span>\n\n       <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">createSessionIfNotExists<\/span><span class=\"p\">();<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">session<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nf\">session<\/span><span class=\"p\">();<\/span>\n       <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">session<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n           <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Error<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">Session does not exist.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>      \n       <span class=\"p\">}<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">answer<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nx\">session<\/span><span class=\"p\">.<\/span><span class=\"nf\">prompt<\/span><span class=\"p\">(<\/span><span class=\"nx\">query<\/span><span class=\"p\">);<\/span>\n       <span class=\"k\">return<\/span> <span class=\"nx\">answer<\/span><span class=\"p\">;<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0631\u0627 <code>destroySession<\/code> \u0645\u062a\u062f \u062c\u0644\u0633\u0647 \u0631\u0627 \u0627\u0632 \u0628\u06cc\u0646 \u0645\u06cc \u0628\u0631\u062f \u0648 \u0633\u06cc\u06af\u0646\u0627\u0644 \u0647\u0627\u06cc \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u0633\u0631\u0648\u06cc\u0633 \u0631\u0627 \u0628\u0627\u0632\u0646\u0634\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"nf\">destroySession<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n    <span class=\"kd\">const<\/span> <span class=\"nx\">session<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">session<\/span><span class=\"p\">();<\/span>\n\n    <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">session<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n        <span class=\"nx\">session<\/span><span class=\"p\">.<\/span><span class=\"nf\">destroy<\/span><span class=\"p\">();<\/span>\n        <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">log<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">Destroy the prompt session.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">resetSession<\/span><span class=\"p\">(<\/span><span class=\"kc\">undefined<\/span><span class=\"p\">);<\/span>\n    <span class=\"p\">}<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u062f\u0631 \u0646\u062a\u06cc\u062c\u0647\u060c \u0645\u0647\u0646\u062f\u0633\u0627\u0646 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0628\u062f\u0648\u0646 \u0631\u0627\u0647\u200c\u0627\u0646\u062f\u0627\u0632\u06cc \u0633\u0631\u0648\u0631 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646 \u06cc\u0627 \u062c\u0645\u0639\u200c\u0622\u0648\u0631\u06cc \u0647\u0632\u06cc\u0646\u0647\u200c\u0647\u0627\u06cc LLM \u062f\u0631 \u0641\u0636\u0627\u06cc \u0627\u0628\u0631\u06cc\u060c \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u0647\u0648\u0634 \u0645\u0635\u0646\u0648\u0639\u06cc \u0648\u0628 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u0646\u062f. <\/p>\n<h2><span class=\"ez-toc-section\" id=\"%D9%85%D9%86%D8%A7%D8%A8%D8%B9\"><\/span>\n<p>  \u0645\u0646\u0627\u0628\u0639:<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0648\u0628\u0644\u0627\u06af\u060c \u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0637\u0628\u0642\u0647 \u0628\u0646\u062f\u06cc \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Chrome&#39;s Built-In Prompt API \u0648 Angular \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u0645\u06cc \u062f\u0647\u0645. \u0628\u0631\u0646\u0627\u0645\u0647 Angular \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644 \u0632\u0628\u0627\u0646\u060c Prompt API \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 Gemini Nano \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0627\u062d\u0633\u0627\u0633\u0627\u062a \u0645\u062b\u0628\u062a \u06cc\u0627 &hellip;<\/p>\n","protected":false},"author":2,"featured_media":91415,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-91414","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/91414","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=91414"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/91414\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/91415"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=91414"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=91414"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=91414"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}