{"id":123,"date":"2024-01-16T00:00:00","date_gmt":"2024-01-15T23:00:00","guid":{"rendered":"https:\/\/helloblog.io\/hr\/acorn-prettify-nasljednik-soil-plugina\/"},"modified":"2026-01-20T06:33:04","modified_gmt":"2026-01-20T05:33:04","slug":"acorn-prettify-nasljednik-soil-plugina","status":"publish","type":"post","link":"https:\/\/helloblog.io\/hr\/acorn-prettify-nasljednik-soil-plugina\/","title":{"rendered":"Acorn Prettify: nasljednik Soil plugina i \u201cclean markup\u201d paket za Acorn projekte"},"content":{"rendered":"\n<p>Roots ekipa je predstavila <strong>Acorn Prettify<\/strong>, novi paket koji preuzima ulogu koju je godinama imao <strong>Soil<\/strong>. Ako radi\u0161 na projektima sa <strong>Sage<\/strong> temom ili op\u0107enito koristi\u0161 <strong>Acorn<\/strong> (Rootsov Laravel-like sloj za WordPress), ovo je prili\u010dno logi\u010dan korak: umjesto da \u201cmust-have\u201d sitnice \u017eive u zasebnom pluginu, sele se u Acorn paketni ekosustav i odr\u017eavaju se tamo gdje ih ve\u0107ina modernih Roots projekata i o\u010dekuje.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Kratki kontekst: gdje u pri\u010di zavr\u0161ava Soil, a po\u010dinje Prettify<\/h2>\n\n\n\n<p>Soil je bio dio Roots starter teme jo\u0161 od ranih dana (2011\u20132014), a kasnije je izdvojen kao samostalan plugin kad je iza\u0161ao Roots v7. U praksi, Soil je mnogima bio prvi \u201cinstaliraj i zaboravi\u201d dodatak koji sredi neke WordPress rubove bez da svaki put pi\u0161e\u0161 vlastiti set filtera.<\/p>\n\n\n\n<p>Roots sada jasno signalizira fokus: <strong>\u201call-in on Acorn\u201d<\/strong>. Drugim rije\u010dima, \u017eele da se ovakve funkcionalnosti isporu\u010duju i odr\u017eavaju kao Acorn paketi, a ne kao klasi\u010dni pluginovi. Acorn Prettify je zato pozicioniran kao <strong>nasljednik Soil-a<\/strong>.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u0160to Acorn Prettify zapravo radi<\/h2>\n\n\n\n<p>Acorn Prettify uklju\u010duje glavne Soil mogu\u0107nosti koje Roots planira nastaviti odr\u017eavati. Trenutno su u fokusu tri stvari:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n\n<li><strong>\u010ci\u0161\u0107i WordPress markup<\/strong> \u2013 cilj je smanjiti \u201c\u0161um\u201d u generiranom HTML-u i ispeglati defaultni output gdje ima smisla.<\/li>\n\n\n<li><strong>\u201cNice search\u201d<\/strong> \u2013 prakti\u010dnija obrada pretrage (tipi\u010dno da rezultati rade o\u010dekivanije i bez \u010dudnih rubnih slu\u010dajeva u query stringu).<\/li>\n\n\n<li><strong>Relative URLs<\/strong> \u2013 podr\u0161ka za relativne URL-ove, ali uz va\u017enu napomenu: <strong>po defaultu su sada isklju\u010deni<\/strong>.<\/li>\n\n<\/ul>\n\n\n\n<div class=\"wp-block-group callout callout-info is-style-info is-layout-flow wp-block-group-is-layout-flow\" style=\"border-width:1px;border-radius:8px;padding-top:1rem;padding-right:1.5rem;padding-bottom:1rem;padding-left:1.5rem\">\n\n<h4 class=\"wp-block-heading callout-title\">Za\u0161to je bitno da su Relative URLs disabled by default?<\/h4>\n\n\n<p>Relative URL-ovi znaju biti korisni u odre\u0111enim setupovima, ali \u010desto stvaraju probleme u edge-caseovima (CDN, multisite, headless dijelovi, canonical URL-ovi). Roots ih sada eksplicitno tretira kao opciju koju uklju\u010duje\u0161 namjerno, a ne kao ne\u0161to \u0161to \u201csamo radi svima\u201d.<\/p>\n\n<\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Migracija sa Soil-a na Acorn Prettify (Composer)<\/h2>\n\n\n\n<p>Migracija je zami\u0161ljena jednostavno jer oba paketa \u017eive u Composer svijetu. Osnovna ideja: makne\u0161 Soil i doda\u0161 Prettify.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">1) Ukloni Soil kao Composer dependency<\/h3>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#24292e\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#e1e4e8;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>composer remove roots\/soil\n\n<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">composer<\/span><span style=\"color:#9ECBFF\"> remove<\/span><span style=\"color:#9ECBFF\"> roots\/soil<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">2) Dodaj Acorn Prettify<\/h3>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#24292e\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#e1e4e8;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>composer require roots\/acorn-prettify\n\n<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">composer<\/span><span style=\"color:#9ECBFF\"> require<\/span><span style=\"color:#9ECBFF\"> roots\/acorn-prettify<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">3) Ako koristi\u0161 Sage: o\u010disti add_theme_support postavke za Soil<\/h3>\n\n\n\n<p>U Sage projektima se Soil \u010desto aktivirao preko <code>add_theme_support<\/code> opcija u <code>app\/setup.php<\/code>. Nakon migracije to vi\u0161e nema smisla dr\u017eati pa se te stavke mogu ukloniti. Roots u objavi linka i konkretan primjer promjene u Sage repozitoriju.<\/p>\n\n\n\n<p>Primjer referenciran u slu\u017ebenom materijalu: <a href=\"https:\/\/github.com\/roots\/sage\/pull\/3172\/files\">https:\/\/github.com\/roots\/sage\/pull\/3172\/files<\/a><\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Konfiguracija: sve ide kroz config\/prettify.php<\/h2>\n\n\n\n<p>Za razliku od klasi\u010dnog pristupa \u201cupalim plugin i klikam po Settings\u201d, Acorn Prettify se pona\u0161a kao tipi\u010dan paket u modernom stacku: featurei se pale i pode\u0161avaju kroz config datoteku. Slu\u017ebena konfiguracija je u <code>config\/prettify.php<\/code>.<\/p>\n\n\n\n<p>Ako \u017eeli\u0161 promijeniti defaultne vrijednosti, prvo objavi (publish) config u svoj projekt, pa onda ure\u0111uj lokalnu kopiju:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#24292e\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#e1e4e8;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>wp acorn vendor:publish --tag=prettify-config\n\n<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">wp<\/span><span style=\"color:#9ECBFF\"> acorn<\/span><span style=\"color:#9ECBFF\"> vendor:publish<\/span><span style=\"color:#79B8FF\"> --tag=prettify-config<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre><\/div>\n\n\n\n<div class=\"wp-block-group callout callout-warning is-style-warning is-layout-flow wp-block-group-is-layout-flow\" style=\"border-width:1px;border-radius:8px;padding-top:1rem;padding-right:1.5rem;padding-bottom:1rem;padding-left:1.5rem\">\n\n<h4 class=\"wp-block-heading callout-title\">Prakti\u010dna napomena<\/h4>\n\n\n<p>Nemoj pretpostaviti da se pona\u0161anje 1:1 poklapa sa Soil-om. Posebno provjeri stvari poput Relative URLs, jer su u Prettifyju po defaultu druga\u010dije postavljene (disabled) i to mo\u017ee utjecati na routing, interne linkove i asset URL-ove.<\/p>\n\n<\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u0160to ovo zna\u010di za Roots\/Acorn ekosustav<\/h2>\n\n\n\n<p>Ova objava je zanimljiva i izvan samog paketa: Roots time potvr\u0111uje strategiju gdje se \u201copinionated\u201d WordPress pobolj\u0161anja isporu\u010duju kroz <strong>Acorn package ecosystem<\/strong>. Ako ti je to radni model, Acorn Prettify je upravo tip paketa koji \u017eeli\u0161 imati kao standardnu stavku u startu projekta: mali, fokusiran, Composer-first i konfigurabilan kroz kod.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Sa\u017eetak<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n\n<li>Acorn Prettify je slu\u017ebeni nasljednik Soil plugina unutar Roots svijeta.<\/li>\n\n\n<li>Donosi odr\u017eavane klju\u010dne Soil zna\u010dajke: \u010di\u0161\u0107i markup, \u201cnice search\u201d i relativne URL-ove (sada defaultno isklju\u010dene).<\/li>\n\n\n<li>Migracija je Composer-based: <code>composer remove roots\/soil<\/code> pa <code>composer require roots\/acorn-prettify<\/code>.<\/li>\n\n\n<li>Konfiguracija ide kroz <code>config\/prettify.php<\/code>, a publish radi\u0161 s <code>wp acorn vendor:publish --tag=prettify-config<\/code>.<\/li>\n\n<\/ul>\n\n\n<div class=\"references-section\">\n                <h2>Reference \/ Izvori<\/h2>\n                <ul class=\"references-list\"><li><a href=\"https:\/\/roots.io\/announcing-acorn-prettify\/\" target=\"_blank\" rel=\"noopener noreferrer\">Announcing Acorn Prettify<\/a><\/li><li><a href=\"https:\/\/github.com\/roots\/acorn-prettify\" target=\"_blank\" rel=\"noopener noreferrer\">roots\/acorn-prettify<\/a><\/li><li><a href=\"https:\/\/github.com\/roots\/soil\" target=\"_blank\" rel=\"noopener noreferrer\">Soil<\/a><\/li><li><a href=\"https:\/\/roots.io\/creating-an-acorn-package\/\" target=\"_blank\" rel=\"noopener noreferrer\">Creating an Acorn Package<\/a><\/li><li><a href=\"https:\/\/github.com\/roots\/sage\/pull\/3172\/files\" target=\"_blank\" rel=\"noopener noreferrer\">Sage PR example (Remove Soil \/ related changes)<\/a><\/li><\/ul>\n            <\/div>","protected":false},"excerpt":{"rendered":"<p>Ako si koristio Soil za \u010di\u0161\u0107i WordPress markup i prakti\u010dnije URL-ove, Roots je sada tu pri\u010du preselio u Acorn ekosustav. Acorn Prettify donosi klju\u010dne Soil zna\u010dajke, ali kao moderni Composer paket.<\/p>\n","protected":false},"author":44,"featured_media":122,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[31],"tags":[4,7,3,69,10],"class_list":["post-123","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-wordpress-ekosustav","tag-acorn","tag-composer","tag-roots","tag-sage","tag-wordpress"],"_links":{"self":[{"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/posts\/123","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/users\/44"}],"replies":[{"embeddable":true,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/comments?post=123"}],"version-history":[{"count":1,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/posts\/123\/revisions"}],"predecessor-version":[{"id":144,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/posts\/123\/revisions\/144"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/media\/122"}],"wp:attachment":[{"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/media?parent=123"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/categories?post=123"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/helloblog.io\/hr\/wp-json\/wp\/v2\/tags?post=123"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}