{"id":7313,"date":"2025-11-19T12:34:00","date_gmt":"2025-11-19T10:34:00","guid":{"rendered":"https:\/\/sofia.wordcamp.org\/2025\/?p=7313"},"modified":"2025-11-17T16:11:15","modified_gmt":"2025-11-17T14:11:15","slug":"wordcamp-sofia-speakers-8-9","status":"publish","type":"post","link":"https:\/\/sofia.wordcamp.org\/2025\/wordcamp-sofia-speakers-8-9\/","title":{"rendered":"WordCamp Sofia Speakers 8\/9"},"content":{"rendered":"\n<h2 class=\"wp-block-heading has-text-align-center\">From Static to Dynamic: Mastering the Interactivity API<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\ud83c\udde7\ud83c\uddec \u0414\u043d\u0435\u0441 \u043f\u0440\u043e\u0434\u044a\u043b\u0436\u0430\u0432\u0430\u043c\u0435 \u0441 \u043e\u0449\u0435 \u0435\u0434\u043d\u0430 \u0442\u0435\u043c\u0430 \u043e\u0442 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u044f \u0442\u0440\u0430\u043a \u043d\u0430 WordCamp Sofia 2025!<br>\u0424\u043e\u043a\u0443\u0441\u044a\u0442 \u0442\u043e\u0437\u0438 \u043f\u044a\u0442 \u0435 \u0432\u044a\u0440\u0445\u0443 \u0435\u0434\u043d\u0430 \u043e\u0442 \u043d\u0430\u0439-\u0437\u043d\u0430\u0447\u0438\u043c\u0438\u0442\u0435 \u043f\u0440\u043e\u043c\u0435\u043d\u0438 \u0432 WordPress \u0435\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u0430\u0442\u0430 \u043f\u0440\u0435\u0437 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0442\u0435 \u0433\u043e\u0434\u0438\u043d\u0438 &#8211; Interactivity API.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u0421 \u043f\u0440\u0435\u043c\u0438\u043d\u0430\u0432\u0430\u043d\u0435\u0442\u043e \u043e\u0442 \u0441\u0442\u0430\u0442\u0438\u0447\u043d\u043e \u043a\u044a\u043c \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u043d\u043e \u0441\u044a\u0434\u044a\u0440\u0436\u0430\u043d\u0438\u0435, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u0446\u0438\u0442\u0435 \u0432\u0435\u0447\u0435 \u0438\u043c\u0430\u0442 \u043d\u0430\u0442\u0438\u0432\u0435\u043d \u043d\u0430\u0447\u0438\u043d \u0434\u0430 \u0441\u044a\u0437\u0434\u0430\u0432\u0430\u0442 \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u0438 \u043f\u0440\u0435\u0436\u0438\u0432\u044f\u0432\u0430\u043d\u0438\u044f \u0434\u0438\u0440\u0435\u043a\u0442\u043d\u043e \u0432 WordPress, \u0431\u0435\u0437 \u043d\u0443\u0436\u0434\u0430 \u043e\u0442 \u0432\u044a\u043d\u0448\u043d\u0438 JavaScript \u0444\u0440\u0435\u0439\u043c\u0443\u044a\u0440\u0446\u0438.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\ud83d\udcac From Static to Dynamic: Mastering the Interactivity API (\ud83c\udde7\ud83c\uddec )<strong><br><\/strong>\u041e\u0442 \u0432\u044a\u0432\u0435\u0436\u0434\u0430\u043d\u0435\u0442\u043e \u043d\u0430 <code>block.json<\/code> \u0432 WordPress 5.8, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u0446\u0438\u0442\u0435 \u0438\u043c\u0430\u0445\u0430 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0438\u0437\u0438\u0440\u0430\u043d \u043c\u0435\u0442\u043e\u0434 \u0437\u0430 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0438\u0440\u0430\u043d\u0435 \u043d\u0430 \u0431\u043b\u043e\u043a\u043e\u0432\u0435 &#8211; \u043d\u043e \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u0442\u0430 \u043d\u0430 \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0430 \u043e\u0441\u0442\u0430\u0432\u0430\u0448\u0435 \u043f\u0440\u0435\u0434\u0438\u0437\u0432\u0438\u043a\u0430\u0442\u0435\u043b\u0441\u0442\u0432\u043e.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u041f\u0440\u0435\u0434\u0438 WordPress 6.5 \u0442\u0440\u044f\u0431\u0432\u0430\u0448\u0435 \u0434\u0430 \u043f\u0438\u0448\u0435\u043c custom JavaScript \u0438\u043b\u0438 \u0434\u0430 \u0440\u0430\u0437\u0447\u0438\u0442\u0430\u043c\u0435 \u043d\u0430 \u0432\u044a\u043d\u0448\u043d\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f, \u043a\u043e\u0435\u0442\u043e \u0432\u043e\u0434\u0435\u0448\u0435 \u0434\u043e \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442 \u0438 \u0434\u0443\u0431\u043b\u0438\u0440\u0430\u043d\u0435. \u0421 \u043d\u043e\u0432\u0438\u044f Interactivity API, WordPress \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430 \u0434\u0435\u043a\u043b\u0430\u0440\u0430\u0442\u0438\u0432\u0435\u043d, \u043d\u0430\u0442\u0438\u0432\u0435\u043d \u043f\u043e\u0434\u0445\u043e\u0434 \u0437\u0430 \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u043d\u0430 \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u043e \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0447\u0440\u0435\u0437 \u0434\u0438\u0440\u0435\u043a\u0442\u0438\u0432\u0438 \u043a\u0430\u0442\u043e:<br><code>\u2013 data-wp-on-click<br>\u2013 data-wp-bind<br>\u2013 data-wp-context<\/code><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u0412 \u0442\u0430\u0437\u0438 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0430 \u0441\u0435\u0441\u0438\u044f \u0449\u0435 \u0440\u0430\u0437\u0433\u043b\u0435\u0434\u0430\u043c\u0435:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0430\u0442\u0430 \u0438 \u0446\u0435\u043b\u0438\u0442\u0435 \u043d\u0430 Interactivity API<\/li>\n\n\n\n<li>\u041a\u0430\u043a \u0434\u0430 \u043c\u0430\u0440\u043a\u0438\u0440\u0430\u043c\u0435 \u0431\u043b\u043e\u043a\u043e\u0432\u0435 \u043a\u0430\u0442\u043e \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u0438 \u0447\u0440\u0435\u0437 <code>supports.interactivity<\/code><\/li>\n\n\n\n<li>\u041a\u0430\u043a \u0434\u0430 \u0438\u0437\u043f\u043e\u043b\u0437\u0432\u0430\u043c\u0435 \u0434\u0438\u0440\u0435\u043a\u0442\u0438\u0432\u0438 \u0437\u0430 \u043a\u043b\u0438\u043a\u043e\u0432\u0435, \u043a\u043b\u0430\u0441\u043e\u0432\u0435, data binding, loops \u0438 \u0434\u0440.<\/li>\n\n\n\n<li>\u041a\u0430\u043a \u0434\u0430 \u0438\u0437\u0433\u0440\u0430\u0434\u0438\u043c store \u0437\u0430 state management, actions \u0438 side effects<\/li>\n\n\n\n<li>\u0420\u0435\u0430\u043b\u043d\u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u0438 \u043a\u0430\u0442\u043e: button toggles, \u0441\u043b\u0430\u0439\u0434\u0435\u0440 \u0433\u0430\u043b\u0435\u0440\u0438\u0438 \u0438\u0437\u0433\u0440\u0430\u0434\u0435\u043d\u0438 \u0447\u0440\u0435\u0437 Core Image \u0431\u043b\u043e\u043a\u043e\u0432\u0435, query loop \u0444\u0438\u043b\u0442\u0440\u0438\u0440\u0430\u043d\u0435 \u0438 SPA-like \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u044f \u0431\u0435\u0437 reload<\/li>\n<\/ul>\n\n\n\n<div class=\"wp-block-group has-background has-global-padding is-layout-constrained wp-block-group-is-layout-constrained\" style=\"border-top-left-radius:20px;border-top-right-radius:20px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#f0f0f061;padding-top:var(--wp--preset--spacing--20);padding-bottom:var(--wp--preset--spacing--20)\"><ul class=\"wordcamp-block wordcamp-post-list has-layout-list wordcamp-speakers\"><li class=\"wordcamp-post-list__post wordcamp-clearfix\">\n<div class=\"wordcamp-speaker wordcamp-speakers__post slug-ryan-welcher\">\n\t<h3 class=\"wordcamp-block__item-title wordcamp-speakers__title\"><a href=\"https:\/\/sofia.wordcamp.org\/2025\/speaker\/ryan-welcher\/\">Ryan Welcher<\/a><\/h3>\n\t\t\t<div class=\"wordcamp-image__avatar-container align-left\">\n\t\t\t<a href=\"https:\/\/sofia.wordcamp.org\/2025\/speaker\/ryan-welcher\/\" class=\"wordcamp-image__avatar-link\">\n\t\t\t\t<img decoding=\"async\" src=\"https:\/\/secure.gravatar.com\/avatar\/865d90ad698b325440361a71943d729f8ad5c44c66a6d65c5a046a8323ac7ced?s=150&amp;d=mm&amp;r=g\" alt=\"\u0410\u0432\u0430\u0442\u0430\u0440 \u043d\u0430 Ryan Welcher\" \/>\t\t\t<\/a>\n\t\t<\/div>\n\t\n\t\t\t<div class=\"wordcamp-block__item-content wordcamp-speakers__content is-excerpt\"><p>Ryan is a Developer Advocate at Automattic. He focuses on removing barriers to adoption for developers working with Gutenberg and WordPress. He is a seasoned WordPress developer and regular contributor to WordPress and the Gutenberg project. He also streams on Twitch as RyanWelcherCodes were he focuses on custom block development. \u0421\u0435\u0441\u0438\u0438<\/p>\n<\/div>\t\n\t\t\t<div class=\"wordcamp-speakers__sessions\">\n\t\t\t<h4 class=\"wordcamp-speakers__sessions-heading\">\n\t\t\t\t\u0421\u0435\u0441\u0438\u044f\t\t\t<\/h4>\n\n\t\t\t<ul class=\"wordcamp-speakers__sessions-list\">\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<li class=\"wordcamp-speakers__sessions-list-item\">\n\t\t\t\t\t\t<a class=\"wordcamp-speakers__session-link\" href=\"https:\/\/sofia.wordcamp.org\/2025\/session\/ai-beyond-wordpress\/\">\n\t\t\t\t\t\t\tPanel Discussion: WordPress in the Age of AI \ud83c\uddec\ud83c\udde7\t\t\t\t\t\t<\/a>\n\n\t\t\t\t\t\t<span class=\"wordcamp-speakers__session-info\">\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\u043d\u043e\u0435\u043c\u0432\u0440\u0438 29, 2025 \u0432 2:00 pm EET \u0432 Track 1 (Hall 6)\n\t\t\t\t\t\t\t\t\t\t\t\t\t<\/span>\n\t\t\t\t\t<\/li>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<li class=\"wordcamp-speakers__sessions-list-item\">\n\t\t\t\t\t\t<a class=\"wordcamp-speakers__session-link\" href=\"https:\/\/sofia.wordcamp.org\/2025\/session\/modern-front-end-interactivity-the-wordpress-way-inside-the-interactivity-api\/\">\n\t\t\t\t\t\t\tFrom Static to Dynamic: Mastering the Interactivity API \ud83c\uddec\ud83c\udde7\t\t\t\t\t\t<\/a>\n\n\t\t\t\t\t\t<span class=\"wordcamp-speakers__session-info\">\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\u043d\u043e\u0435\u043c\u0432\u0440\u0438 29, 2025 \u0432 3:00 pm EET \u0432 Track 1 (Hall 6)\n\t\t\t\t\t\t\t\t\t\t\t\t\t<\/span>\n\t\t\t\t\t<\/li>\n\t\t\t\t\t\t\t<\/ul>\n\t\t<\/div>\n\t<\/div>\n\n<\/li><\/ul><\/div>\n\n\n\n<div class=\"wp-block-group is-style-section-2 has-border-color has-accent-6-border-color is-content-justification-space-between is-nowrap is-layout-flex wp-container-core-group-is-layout-6a5c19ad wp-block-group-is-layout-flex is-style-section-2--1\" style=\"border-width:5px;margin-top:var(--wp--preset--spacing--50);margin-bottom:var(--wp--preset--spacing--50);padding-right:0;padding-left:var(--wp--preset--spacing--30);box-shadow:var(--wp--preset--shadow--sharp)\">\n<h2 class=\"wp-block-heading has-text-align-left\" style=\"font-size:4vw\"><a href=\"https:\/\/sofia.wordcamp.org\/2025\/tickets\/\">\u041a\u0443\u043f\u0438 \u0431\u0438\u043b\u0435\u0442 \u0441\u0435\u0433\u0430! <\/a><\/h2>\n\n\n\n<figure class=\"wp-block-image size-thumbnail\"><a href=\"https:\/\/sofia.wordcamp.org\/2025\/tickets\/\"><img data-recalc-dims=\"1\" loading=\"lazy\" decoding=\"async\" width=\"150\" height=\"150\" src=\"https:\/\/i0.wp.com\/sofia.wordcamp.org\/2025\/files\/2025\/09\/wp-tickets.jpg?resize=150%2C150&#038;ssl=1\" alt=\"\" class=\"wp-image-1676\" style=\"object-fit:cover\" srcset=\"https:\/\/i0.wp.com\/sofia.wordcamp.org\/2025\/files\/2025\/09\/wp-tickets.jpg?resize=150%2C150&amp;ssl=1 150w, https:\/\/i0.wp.com\/sofia.wordcamp.org\/2025\/files\/2025\/09\/wp-tickets.jpg?zoom=2&amp;resize=150%2C150&amp;ssl=1 300w\" sizes=\"auto, (max-width: 150px) 100vw, 150px\" \/><\/a><\/figure>\n<\/div>\n\n\n\n<p class=\"wp-block-paragraph\">\ud83c\uddec\ud83c\udde7 Today we highlight another powerful session in the Tech track at WordCamp Sofia 2025 &#8211; a deep dive into the new Interactivity API and the future of dynamic WordPress experiences.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\ud83d\udcac From Static to Dynamic: Mastering the Interactivity API<strong><br><\/strong>Since <code>block.json<\/code> standardized how developers define blocks in WordPress 5.8, the editor has grown more robust. But front-end interactivity remained a manual process, until now.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">With the release of WordPress 6.5 and the Interactivity API, developers finally have a unified, declarative way to build reactive, dynamic interfaces within WordPress itself.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">This developer-focused talk will cover:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The architecture and core goals of the Interactivity API<\/li>\n\n\n\n<li>How to enable interactivity using <code>supports.interactivity<\/code><\/li>\n\n\n\n<li>Using directives for click handlers, class toggles, binding data, looping arrays, and more<\/li>\n\n\n\n<li>How to define a store for shared state, actions, and side effects<\/li>\n\n\n\n<li>Real-world examples like: button toggles, gallery sliders built on Core Image blocks, query Loop filtering &amp; SPA-style navigation without full reloads<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>From Static to Dynamic: Mastering the Interactivity API \ud83c\udde7\ud83c\uddec \u0414\u043d\u0435\u0441 \u043f\u0440\u043e\u0434\u044a\u043b\u0436\u0430\u0432\u0430\u043c\u0435 \u0441 \u043e\u0449\u0435 \u0435\u0434\u043d\u0430 \u0442\u0435\u043c\u0430 \u043e\u0442 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u044f \u0442\u0440\u0430\u043a \u043d\u0430 WordCamp Sofia 2025!\u0424\u043e\u043a\u0443\u0441\u044a\u0442 \u0442\u043e\u0437\u0438 \u043f\u044a\u0442 \u0435 \u0432\u044a\u0440\u0445\u0443 \u0435\u0434\u043d\u0430 \u043e\u0442 \u043d\u0430\u0439-\u0437\u043d\u0430\u0447\u0438\u043c\u0438\u0442\u0435 \u043f\u0440\u043e\u043c\u0435\u043d\u0438 \u0432 WordPress \u0435\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u0430\u0442\u0430 \u043f\u0440\u0435\u0437 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0442\u0435 \u0433\u043e\u0434\u0438\u043d\u0438 &#8211; Interactivity API. \u0421 \u043f\u0440\u0435\u043c\u0438\u043d\u0430\u0432\u0430\u043d\u0435\u0442\u043e \u043e\u0442 \u0441\u0442\u0430\u0442\u0438\u0447\u043d\u043e \u043a\u044a\u043c \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u043d\u043e \u0441\u044a\u0434\u044a\u0440\u0436\u0430\u043d\u0438\u0435, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u0446\u0438\u0442\u0435 \u0432\u0435\u0447\u0435 \u0438\u043c\u0430\u0442 \u043d\u0430\u0442\u0438\u0432\u0435\u043d \u043d\u0430\u0447\u0438\u043d \u0434\u0430 \u0441\u044a\u0437\u0434\u0430\u0432\u0430\u0442 \u0438\u043d\u0442\u0435\u0440\u0430\u043a\u0442\u0438\u0432\u043d\u0438 \u043f\u0440\u0435\u0436\u0438\u0432\u044f\u0432\u0430\u043d\u0438\u044f [&hellip;]<\/p>\n","protected":false},"author":5747069,"featured_media":7314,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_crdt_document":"","advanced_seo_description":"","jetpack_seo_html_title":"","jetpack_seo_noindex":false,"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[1],"tags":[52,51,44],"class_list":["post-7313","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-uncategorized","tag-interactivity-api","tag-ryan-welcher","tag-wordcamp-sofia"],"jetpack_featured_media_url":"https:\/\/i0.wp.com\/sofia.wordcamp.org\/2025\/files\/2025\/11\/7th-batch-of-speakers-desktop-2.png?fit=1440%2C810&ssl=1","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/posts\/7313","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/users\/5747069"}],"replies":[{"embeddable":true,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/comments?post=7313"}],"version-history":[{"count":2,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/posts\/7313\/revisions"}],"predecessor-version":[{"id":7316,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/posts\/7313\/revisions\/7316"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/media\/7314"}],"wp:attachment":[{"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/media?parent=7313"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/categories?post=7313"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/sofia.wordcamp.org\/2025\/wp-json\/wp\/v2\/tags?post=7313"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}