{"id":90609,"date":"2024-12-31T05:06:47","date_gmt":"2024-12-31T01:36:47","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/"},"modified":"2024-12-31T05:06:47","modified_gmt":"2024-12-31T01:36:47","slug":"%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/","title":{"rendered":"\u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0628\u0627 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 Chrome \u062f\u0631 Angular \u0628\u0633\u0627\u0632\u06cc\u062f"},"content":{"rendered":"<div data-article-id=\"2182511\" 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\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0633\u0627\u062f\u0647 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 API \u0648 Angular \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u062f\u0627\u062e\u0644\u06cc \u06a9\u0631\u0648\u0645 \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u0645\u06cc \u062f\u0647\u0645. \u0627\u0628\u062a\u062f\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 Angular API \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u06cc\u06a9 \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \u0632\u0628\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f \u0648 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u062a\u0634\u062e\u06cc\u0635 \u06a9\u062f \u0632\u0628\u0627\u0646 \u0645\u062a\u0646 \u0648\u0631\u0648\u062f\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f. \u0633\u067e\u0633\u060c \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u06a9\u0645\u06a9\u06cc \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u06a9\u062f \u0632\u0628\u0627\u0646 \u0631\u0627 \u062f\u0631 \u0646\u0627\u0645 \u0632\u0628\u0627\u0646 \u0646\u06af\u0627\u0634\u062a \u06a9\u0646\u062f.  <\/p>\n<p>\u0647\u0632\u06cc\u0646\u0647 \u0622\u0646 \u0635\u0641\u0631 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0647 LLM \u0647\u06cc\u0686 \u0641\u0631\u0648\u0634\u0646\u062f\u0647 \u0627\u06cc \u0646\u06cc\u0627\u0632 \u0646\u062f\u0627\u0631\u062f.  <\/p>\n<p>\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 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0645\u062c\u062f\u062f \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc Gemma \u06cc\u0627 Gemini \u062f\u0631 Vertex AI \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u0646\u0627\u0645 \u0632\u0628\u0627\u0646 \u0645\u062a\u0646.  <\/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\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#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\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#API_%D8%AA%D8%B4%D8%AE%DB%8C%D8%B5_%D8%B2%D8%A8%D8%A7%D9%86_%D8%B1%D8%A7_%D8%AF%D8%B1_%DA%A9%D8%B1%D9%88%D9%85_%D9%86%D8%B5%D8%A8_%DA%A9%D9%86%DB%8C%D8%AF\" >API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0631\u0627 \u062f\u0631 \u06a9\u0631\u0648\u0645 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/nabfollower.com\/blog\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%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><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/nabfollower.com\/blog\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%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\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%D8%B1%D8%AF%DB%8C%D8%A7%D8%A8_%D8%B2%D8%A8%D8%A7%D9%86_%D8%A8%D9%88%D8%AA_%D8%A7%D8%B3%D8%AA%D8%B1%D9%BE\" >\u0631\u062f\u06cc\u0627\u0628 \u0632\u0628\u0627\u0646 \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e<\/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\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%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\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%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\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%DB%8C%DA%A9_%D8%B3%D8%B1%D9%88%DB%8C%D8%B3_%D8%A8%D8%B1%D8%A7%DB%8C_%D8%A8%D8%B3%D8%AA%D9%87_%D8%A8%D9%86%D8%AF%DB%8C_API_%D8%AA%D8%B4%D8%AE%DB%8C%D8%B5_%D8%B2%D8%A8%D8%A7%D9%86_%D8%A7%D8%B6%D8%A7%D9%81%D9%87_%DA%A9%D9%86%DB%8C%D8%AF\" >\u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u0628\u0631\u0627\u06cc \u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0627\u0636\u0627\u0641\u0647 \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-9\" href=\"https:\/\/nabfollower.com\/blog\/%db%8c%da%a9-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-%d8%a8%d8%a7-api-%d8%aa%d8%b4%d8%ae%db%8c%d8%b5-%d8%b2%d8%a8%d8%a7%d9%86-chrome-%d8%af%d8%b1-a\/#%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=\"API_%D8%AA%D8%B4%D8%AE%DB%8C%D8%B5_%D8%B2%D8%A8%D8%A7%D9%86_%D8%B1%D8%A7_%D8%AF%D8%B1_%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>  API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0631\u0627 \u062f\u0631 \u06a9\u0631\u0648\u0645 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ol>\n<li>\u0628\u0647 chrome:\/\/flags\/#language-detection-api \u0628\u0631\u0648\u06cc\u062f.<\/li>\n<li>Enabled \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<\/ol>\n<h3><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><\/h3>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight shell\"><code>ng new language-detector-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=\"%D8%B1%D8%AF%DB%8C%D8%A7%D8%A8_%D8%B2%D8%A8%D8%A7%D9%86_%D8%A8%D9%88%D8%AA_%D8%A7%D8%B3%D8%AA%D8%B1%D9%BE\"><\/span>\n<p>  \u0631\u062f\u06cc\u0627\u0628 \u0632\u0628\u0627\u0646 \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e<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_LANGUAGE_DETECTION_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\">AILanguageDetectorFactory<\/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_LANGUAGE_DETECTION_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\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">AI_LANGUAGE_DETECTION_API_TOKEN<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">..\/constants\/core.constant<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\n\n<span class=\"k\">export<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">provideAILanguageDetectionAPI<\/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_LANGUAGE_DETECTION_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\">languageDetector<\/span> <span class=\"p\">?<\/span> <span class=\"nx\">objWindow<\/span><span class=\"p\">?.<\/span><span class=\"nx\">ai<\/span><span class=\"p\">?.<\/span><span class=\"nx\">languageDetector<\/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    <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 \u06cc\u06a9 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u0646\u062f\u0647 \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>languageDetector<\/code> \u0646\u0645\u0648\u0646\u0647 \u062f\u0631 <code>window.ai<\/code> \u0641\u0636\u0627\u06cc \u0646\u0627\u0645 \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u062f\u0647\u0627 \u0631\u0627 \u062a\u0632\u0631\u06cc\u0642 \u0645\u06cc \u06a9\u0646\u0646\u062f <code>AI_LANGUAGE_DETECTION_API_TOKEN<\/code> \u0622\u0646\u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \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 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u06a9\u062f \u0632\u0628\u0627\u0646 \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\">provideAILanguageDetectionAPI<\/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>provideAILanguageDetectorAPI<\/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 Chrome \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0627\u0633\u062a\u060c \u0627\u0645\u0627 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u062f\u0631 \u06a9\u0631\u0648\u0645 \u0646\u0633\u062e\u0647 129 \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<ol>\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 129 \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 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0627\u0633\u062a\n<\/li>\n<\/ol>\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\">UNSUPPORTED_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_BROSWER<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"kd\">const<\/span> <span class=\"nx\">apiName<\/span> <span class=\"o\">=<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">Language Detection API<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\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_API<\/span><span class=\"p\">);<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"kd\">const<\/span> <span class=\"nx\">languageDetector<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">AI_LANGUAGE_DETECTION_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\">languageDetector<\/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\">NO_API<\/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_GEMINI_NANO<\/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 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \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\">isLanguageDetectionAPISupported<\/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>isLanguageDetectionAPISupported<\/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\">LanguageDetectionComponent<\/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-language-detection\/>\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\">isLanguageDetectionAPISupported<\/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>LanguageDetectionComponent<\/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=\"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-language-detection<\/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> <span class=\"nx\">LanguageDetectionResultComponent<\/span><span class=\"p\">],<\/span>\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\n    <div>\n      <p>\n        <span class=\"label\" for=\"input\">Input text: <\/span>\n        <textarea id=\"input\" name=\"input\" rows=\"3\"\/>\n      <\/p>\n      <button>Create capabilities and detector<\/button>\n      <button>Destroy capabilities and detector<\/button>\n      <button>Detect Language<\/button>\n      <app-language-detection-result\/>\n    <\/div>`<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">LanguageDetectionComponent<\/span> <span class=\"p\">{<\/span>\n  <span class=\"nx\">service<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">LanguageDetectionService<\/span><span class=\"p\">);<\/span>\n  <span class=\"nx\">inputText<\/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\">detectedLanguages<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">LanguageDetectionWithNameResult<\/span><span class=\"p\">[]<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">([]);<\/span>\n\n  <span class=\"nx\">capabilities<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">service<\/span><span class=\"p\">.<\/span><span class=\"nx\">capabilities<\/span><span class=\"p\">;<\/span>\n  <span class=\"nx\">detector<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">service<\/span><span class=\"p\">.<\/span><span class=\"nx\">detector<\/span><span class=\"p\">;<\/span>\n\n  <span class=\"nx\">isDisableDetectLanguage<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">computed<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> \n<span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">capabilities<\/span><span class=\"p\">()?.<\/span><span class=\"nx\">available<\/span> <span class=\"o\">!==<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">readily<\/span><span class=\"dl\">'<\/span> \n<span class=\"o\">||<\/span> <span class=\"o\">!<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">detector<\/span><span class=\"p\">()<\/span> <span class=\"o\">||<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">inputText<\/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\n  <span class=\"k\">async<\/span> <span class=\"nf\">setup<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n    <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">service<\/span><span class=\"p\">.<\/span><span class=\"nf\">createDetector<\/span><span class=\"p\">();<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"nf\">teardown<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">service<\/span><span class=\"p\">.<\/span><span class=\"nf\">destroyDetector<\/span><span class=\"p\">();<\/span>\n  <span class=\"p\">}<\/span>\n\n  <span class=\"k\">async<\/span> <span class=\"nf\">detectLanguage<\/span><span class=\"p\">(<\/span><span class=\"nx\">topNLanguages<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">3<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n    <span class=\"kd\">const<\/span> <span class=\"nx\">results<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">service<\/span><span class=\"p\">.<\/span><span class=\"nf\">detect<\/span><span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">inputText<\/span><span class=\"p\">(),<\/span> <span class=\"nx\">topNLanguages<\/span><span class=\"p\">);<\/span>\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">detectedLanguages<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">results<\/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>LanguageDetectionComponent<\/code> \u062f\u0627\u0631\u0627\u06cc \u0633\u0647 \u062f\u06a9\u0645\u0647 \u062f\u06a9\u0645\u0647 \u0627\u06cc\u062c\u0627\u062f\u060c \u0633\u0631\u0648\u06cc\u0633 \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \u0632\u0628\u0627\u0646 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f. \u062f\u06a9\u0645\u0647 \u0646\u0627\u0628\u0648\u062f \u06a9\u0631\u062f\u0646\u060c \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \u0632\u0628\u0627\u0646 \u0631\u0627 \u0627\u0632 \u0628\u06cc\u0646 \u0645\u06cc \u0628\u0631\u062f \u062a\u0627 \u0645\u0646\u0627\u0628\u0639 \u0631\u0627 \u0622\u0632\u0627\u062f \u06a9\u0646\u062f. \u062f\u06a9\u0645\u0647 \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0633\u0647 \u06a9\u062f \u0632\u0628\u0627\u0646 \u0628\u0631\u062a\u0631 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">export<\/span> <span class=\"kd\">type<\/span> <span class=\"nx\">LanguageDetectionWithNameResult<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">LanguageDetectionResult<\/span> <span class=\"o\">&amp;<\/span> <span class=\"p\">{<\/span>\n   <span class=\"na\">name<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/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<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-language-detection-result<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\n <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\n   <div>\n       <span class=\"label\">Response: <\/span>\n       @for (language of detectedLanguages(); track language.detectedLanguage) {\n         <p>\n           <span>Confidence: {{ language.confidence.toFixed(3) }}, <\/span>\n           <span>Detected Language: {{ language.detectedLanguage }}, <\/span>\n           <span>Detected Language Name: {{ language.name }}<\/span>\n         <\/p>\n       }\n   <\/div>\n `<\/span><span class=\"p\">,<\/span>\n<span class=\"p\">})<\/span>\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">LanguageDetectionResultComponent<\/span> <span class=\"p\">{<\/span>\n   <span class=\"nx\">detectedLanguages<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">input<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">LanguageDetectionWithNameResult<\/span><span class=\"p\">[]<\/span><span class=\"o\">&gt;<\/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>LanguageDetectionResultComponent<\/code> \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 \u0627\u0631\u0627\u0626\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0637\u0645\u06cc\u0646\u0627\u0646\u060c \u06a9\u062f\u0647\u0627\u06cc \u0632\u0628\u0627\u0646 \u0648 \u0646\u0627\u0645 \u0632\u0628\u0627\u0646 \u0647\u0627 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<h3><span class=\"ez-toc-section\" id=\"%DB%8C%DA%A9_%D8%B3%D8%B1%D9%88%DB%8C%D8%B3_%D8%A8%D8%B1%D8%A7%DB%8C_%D8%A8%D8%B3%D8%AA%D9%87_%D8%A8%D9%86%D8%AF%DB%8C_API_%D8%AA%D8%B4%D8%AE%DB%8C%D8%B5_%D8%B2%D8%A8%D8%A7%D9%86_%D8%A7%D8%B6%D8%A7%D9%81%D9%87_%DA%A9%D9%86%DB%8C%D8%AF\"><\/span>\n<p>  \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u0628\u0631\u0627\u06cc \u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0627\u0636\u0627\u0641\u0647 \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=\"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\">LanguageDetectionService<\/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=\"err\">#<\/span><span class=\"nx\">languageDetectionAPI<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">inject<\/span><span class=\"p\">(<\/span><span class=\"nx\">AI_LANGUAGE_DETECTION_API_TOKEN<\/span><span class=\"p\">);<\/span>\n   <span class=\"err\">#<\/span><span class=\"nx\">detector<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">AILanguageDetector<\/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=\"nx\">detector<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">detector<\/span><span class=\"p\">.<\/span><span class=\"nf\">asReadonly<\/span><span class=\"p\">();<\/span>\n   <span class=\"err\">#<\/span><span class=\"nx\">capabilities<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">signal<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">AILanguageDetectorCapabilities<\/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=\"nx\">capabilities<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">capabilities<\/span><span class=\"p\">.<\/span><span class=\"nf\">asReadonly<\/span><span class=\"p\">();<\/span>\n\n   <span class=\"k\">async<\/span> <span class=\"nf\">detect<\/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=\"nx\">topNResults<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">3<\/span><span class=\"p\">):<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">LanguageDetectionWithNameResult<\/span><span class=\"p\">[]<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\n      <span class=\"err\">\u2026<\/span>\n   <span class=\"p\">}<\/span>\n\n   <span class=\"nf\">destroyDetector<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n      <span class=\"err\">\u2026<\/span>\n   <span class=\"p\">}<\/span>\n\n   <span class=\"k\">private<\/span> <span class=\"nf\">resetDetector<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">detector<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">detector<\/span><span class=\"p\">();<\/span>\n\n       <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">detector<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n           <span class=\"nx\">detector<\/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 language detector.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n           <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">detector<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/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\n   <span class=\"k\">async<\/span> <span class=\"nf\">createDetector<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n       <span class=\"err\">\u2026<\/span>\n   <span class=\"p\">}<\/span>\n\n   <span class=\"nf\">ngOnDestroy<\/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>LanguageDetectionService<\/code> \u0633\u0631\u0648\u06cc\u0633 \u0645\u0646\u0637\u0642 API \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0631\u0627 \u062f\u0631 \u0628\u0631 \u0645\u06cc \u06af\u06cc\u0631\u062f. \u0631\u0627 <code>createDetector<\/code> \u0645\u062a\u062f \u0648\u0636\u0639\u06cc\u062a \u0642\u0627\u0628\u0644\u06cc\u062a \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u06cc\u06a9 \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"k\">async<\/span> <span class=\"nf\">createDetector<\/span><span class=\"p\">()<\/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=\"err\">#<\/span><span class=\"nx\">languageDetectionAPI<\/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_API<\/span><span class=\"p\">);<\/span>\n    <span class=\"p\">}<\/span>\n\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">resetDetector<\/span><span class=\"p\">();<\/span>\n    <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">capabilities<\/span><span class=\"p\">,<\/span> <span class=\"nx\">newDetector<\/span><span class=\"p\">]<\/span>  <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">.<\/span><span class=\"nf\">all<\/span><span class=\"p\">([<\/span>\n           <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">languageDetectionAPI<\/span><span class=\"p\">.<\/span><span class=\"nf\">capabilities<\/span><span class=\"p\">(),<\/span>\n           <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">languageDetectionAPI<\/span><span class=\"p\">.<\/span><span class=\"nf\">create<\/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     <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">capabilities<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">capabilities<\/span><span class=\"p\">);<\/span>\n     <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"err\">#<\/span><span class=\"nx\">detector<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">newDetector<\/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>destroyDetector<\/code> \u0631\u0648\u0634 \u0648\u0636\u0639\u06cc\u062a \u0642\u0627\u0628\u0644\u06cc\u062a \u0631\u0627 \u067e\u0627\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \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=\"nf\">destroyDetector<\/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\">capabilities<\/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=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">resetDetector<\/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>detect<\/code> \u0645\u062a\u062f \u0645\u062a\u0646 \u0631\u0627 \u0645\u06cc\u200c\u067e\u0630\u06cc\u0631\u062f \u0648 API \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f \u062a\u0627 \u0646\u062a\u0627\u06cc\u062c\u06cc \u06a9\u0647 \u0628\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0628\u0647 \u062a\u0631\u062a\u06cc\u0628 \u0646\u0632\u0648\u0644\u06cc \u0645\u0631\u062a\u0628 \u0634\u062f\u0647\u200c\u0627\u0646\u062f \u0631\u0627 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f. \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0633\u0647 \u0646\u062a\u06cc\u062c\u0647 \u0628\u0631\u062a\u0631 \u0648 \u0646\u0627\u0645 \u0632\u0628\u0627\u0646 \u0622\u0646\u0647\u0627 \u0631\u0627 \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\">async<\/span> <span class=\"nf\">detect<\/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=\"nx\">topNResults<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">3<\/span><span class=\"p\">)<\/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=\"err\">#<\/span><span class=\"nx\">languageDetectionAPI<\/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_API<\/span><span class=\"p\">);<\/span>\n       <span class=\"p\">}<\/span>\n\n       <span class=\"kd\">const<\/span> <span class=\"nx\">detector<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">detector<\/span><span class=\"p\">();<\/span>\n       <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">detector<\/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\">Failed to create the LanguageDetector.<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\n       <span class=\"p\">}<\/span>\n\n       <span class=\"kd\">const<\/span> <span class=\"nx\">minTopNReesults<\/span> <span class=\"o\">=<\/span> <span class=\"nb\">Math<\/span><span class=\"p\">.<\/span><span class=\"nf\">min<\/span><span class=\"p\">(<\/span><span class=\"nx\">topNResults<\/span><span class=\"p\">,<\/span> <span class=\"nx\">MAX_LANGUAGE_RESULTS<\/span><span class=\"p\">);<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">results<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nx\">detector<\/span><span class=\"p\">.<\/span><span class=\"nf\">detect<\/span><span class=\"p\">(<\/span><span class=\"nx\">query<\/span><span class=\"p\">);<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">probablyLanguages<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">results<\/span><span class=\"p\">.<\/span><span class=\"nf\">slice<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"nx\">minTopNReesults<\/span><span class=\"p\">);<\/span>\n       <span class=\"k\">return<\/span> <span class=\"nx\">probablyLanguages<\/span><span class=\"p\">.<\/span><span class=\"nf\">map<\/span><span class=\"p\">((<\/span><span class=\"nx\">item<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">({<\/span> <span class=\"p\">...<\/span><span class=\"nx\">item<\/span><span class=\"p\">,<\/span> <span class=\"na\">name<\/span><span class=\"p\">:<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">languageTagToHumanReadable<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">detectedLanguage<\/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>\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 \u0686\u0631\u062e\u0647 \u062d\u06cc\u0627\u062a \u0628\u0631\u0627\u06cc \u0627\u0632 \u0628\u06cc\u0646 \u0628\u0631\u062f\u0646 \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \u0632\u0628\u0627\u0646 \u0628\u0631\u0627\u06cc \u0622\u0632\u0627\u062f \u06a9\u0631\u062f\u0646 \u062d\u0627\u0641\u0638\u0647 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code><span class=\"nf\">ngOnDestroy<\/span><span class=\"p\">():<\/span> <span class=\"k\">void<\/span> <span class=\"p\">{<\/span>\n   <span class=\"kd\">const<\/span> <span class=\"nx\">detector<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nf\">detector<\/span><span class=\"p\">();<\/span>\n   <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">detector<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n       <span class=\"nx\">detector<\/span><span class=\"p\">.<\/span><span class=\"nf\">destroy<\/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\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u0633\u0627\u062f\u0647 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 API \u0648 Angular \u062a\u0634\u062e\u06cc\u0635 \u0632\u0628\u0627\u0646 \u062f\u0627\u062e\u0644\u06cc \u06a9\u0631\u0648\u0645 \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u0645\u06cc \u062f\u0647\u0645. \u0627\u0628\u062a\u062f\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 Angular API \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u06cc\u06a9 \u0622\u0634\u06a9\u0627\u0631\u0633\u0627\u0632 \u0632\u0628\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f \u0648 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u062a\u0634\u062e\u06cc\u0635 \u06a9\u062f \u0632\u0628\u0627\u0646 \u0645\u062a\u0646 \u0648\u0631\u0648\u062f\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f. \u0633\u067e\u0633\u060c \u06cc\u06a9 &hellip;<\/p>\n","protected":false},"author":2,"featured_media":90610,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"https:\/\/media2.dev.to\/dynamic\/image\/width=1000,height=500,fit=cover,gravity=auto,format=auto\/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fo3ey7xb0x5m12dc8hzzo.png","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-90609","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\/90609","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=90609"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/90609\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/90610"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=90609"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=90609"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=90609"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}