/
roadmap.html
1 lines (1 loc) · 15.8 KB
/
roadmap.html
1
<!DOCTYPE html><html class="bg-white dark:bg-gray-900 dark:text-gray-100 leading-tight text-gray-900" lang=en><head><meta charset=UTF-8><meta content="width=device-width, initial-scale=1, shrink-to-fit=no" name=viewport><link href=/assets/favicons/apple-touch-icon.png rel=apple-touch-icon sizes=180x180><link href=/assets/favicons/favicon-32x32.png rel=icon sizes=32x32 type=image/png><link href=/assets/favicons/favicon-16x16.png rel=icon sizes=16x16 type=image/png><link href=/assets/favicons/site.webmanifest rel=manifest><link color=#000000 href=/assets/favicons/safari-pinned-tab.svg rel=mask-icon><link href=/assets/favicons/favicon.ico rel="shortcut icon"><meta content=Pushword name=apple-mobile-web-app-title><meta content=Pushword name=application-name><meta content=#fff name=msapplication-TileColor><meta content=/assets/favicons/browserconfig.xml name=msapplication-config><meta content=#fff name=theme-color><title> Where Pushword is going ? Roadmap, TODO and Ideas </title><link href=/assets/tw.css rel=stylesheet><style>:root{--primary:#f59e0b;--secondary:#d97706;--font-family:Inter var,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol}</style><style>.nojs{display:block}</style><script>document.head.insertAdjacentHTML('beforeend','<style>.nojs{display:none !important}<\/style>')</script><link href=https://pushword.piedweb.com/feed.xml rel=alternate title="Pushword » Flux" type=application/rss+xml><link href=https://pushword.piedweb.com/roadmap rel=canonical><link href=https://pushword.piedweb.com/roadmap hreflang=en rel=alternate><meta content="Where Pushword is going ? Roadmap, TODO and Ideas" name=og:title><meta content=https://pushword.piedweb.com/roadmap name=og:url> <body><div class="flex flex-wrap items-stretch max-w-screen-xl mx-auto"><div class="lg:ml-0 lg:mr-0 lg:w-3/4 mx-auto order-2 w-full"><div class=pt-6></div> <nav aria-label=breadcrumb class="dark:text-gray-300 font-light p-3 text-gray-700 text-sm"><ul><li class=inline-block><a class=hover:underline href=https://pushword.piedweb.com/>Pushword</a> <span class="inline-block px-1">›</span> <li class=inline-block><a class=hover:underline href=/contribute>Contribute</a> </ul> </nav> <div class="flex flex-wrap max-w-5xl"><div class="lg:order-1 lg:w-4/5 order-2 overflow-hidden w-full"><div class="dark:prose-light max-w-none p-3 prose"><h1><s>ROADMAP</s> Just TODO and IDEA</h1> </div> </div> <div class="lg:order-2 lg:w-1/5 order-3 overflow-hidden w-full"><div class="bg-gray-50 dark:border-gray-700 lg:absolute lg:max-w-xs m-2 max-w-screen-sm p-3 pt-4 rounded shadow-inner"><h3 class="block dark:text-gray-100 font-semibold lg:mb-3 lg:text-xs mb-3 px-1 text-gray-900 text-sm tracking-wide uppercase">Contents</h3> <div class="-ml-6 dark:prose-light max-w-none prose-sm px-1"><ul><li class=first><a href=#todo-before-v1>TODO before v1</a> <li class=last><a href=#todo-extension>TODO Extension</a> <ul class=menu_level_1><li class="first last"><a href=#to-plan>To plan</a> </ul></ul> </div></div> </div> <div class="lg:w-4/5 order-4 overflow-hidden w-full"><div class="dark:prose-light max-w-3xl p-3 prose"><h2 id=todo-before-v1>TODO before v1</h2> <ul><li>release de sonata 4 <li>Issue : User Password Edit don't work from admin <li>installer via composer-create (command pushword:new creating a new app config array)</ul> <h2 id=todo-extension>TODO Extension</h2> <ul><li>Intégrer Schema.org dans le backend d'une page <li>Static: copy only used media in public <li>FacebookManager (post from facebook and ~~show last facebook status~~ ) <li>Flat: Transform markdown link to page link (useful for navigate in docs from editor) <li>Flat: Throw error when the content is more up to date in database... add export (and maintain ID) <li>Wordpress To Pushword/Core (and vice versa) <li>Intégrer LinksImprover (+ UX), après précédent <li>name suggester : parse content, find words or multiple words used only in this doc, suggest it as potential name <li>export/import FLAT FILES (spatie/yaml-front-matter, vérif à chaque requête pour une sync constante admin -> flat files) <li>Create a page from a Media (media edit) => button to create a new page with title = name and mainImage = Media (useful for photographer website)... or create a dynamic page /media/[slug]/ showing data from Media <li>Settings Manager (simple textarea permitting to edit pushword config and parameters ? and rebooting cache) <li>smart image optimizer (using all otpimizer avalaible and choosing the smallest file) <li>interventionImageBundle (sortir mediaManager du bundle principal)</ul> <h3 id=to-plan>To plan</h3> <ul><li>Media Management v2 : utiliser IPTC&exif pour stocker toutes les infos stockées en bdd (static power) <li>CI : Test Installer <li>Author for page (will permit to manage page view right later) <li>Archive edit (page) (extension or core ?) <li>Multi-user editor Multi-site but not everybody can edit everything (see draft.md) (extension or core ?) <li>Look for a better writer experience (https://github.com/front/g-editor or https://editorjs.io) (1/2) <li>Gérer un système d'extension viable pour l'admin : à l'install, créer les fichiers Admin qui étendent l'admin de base L'ajout d'un plugin modifie automatiquement ce nouveau fichier en ajoutant le code nécessaire (ajout d'une trait + édition d'une fonction) Retro-compatibilité : créer le fichier admin + le services (autowire) si il n'existe pas <li>Scan : scanner une page en direct + scanner plus de choses (liens externes, texte alternative manquant, etc.) <li>Multi upload <li>Test the code, search for all "todo" in the code, <li>Installation without composer (download composer if not installed) <li>Pagination children/list (molto idea : PageController capture les pages /slug/[0-0]*/ et renvoie si existe) <li>Page with dynamic slug ?! <li>Add https://github.com/nan-guo/Sonata-Menu-Bundle <li>Move route to annotation (less extendable but more pratical with priority) <li>Move media to var (and create a link ?!)</ul></div> </div></div> <div class="flex max-w-3xl mt-5 mx-3"><a class="dark:hover:text-gray-100 flex hover:text-gray-900 mr-8 text-gray-500" href=/architecture><span aria-hidden=true class=mr-2>←</span> The Architecture </a> </div> <div class="font-light mt-10 mx-3 text-center text-gray-500 text-sm"><span class="dark:hover:text-gray-100 hover:text-gray-900" data-rot=_tvguho.pbz/Chfujbeq/Chfujbeq/rqvg/znva/cnpxntrf/qbpf/pbagrag/ebnqznc.zq><svg xmlns=http://www.w3.org/2000/svg class="-mt-1 fill-current inline-block w-3" viewbox="0 0 576 512"><path d="M402.6 83.2l90.2 90.2c3.8 3.8 3.8 10 0 13.8L274.4 405.6l-92.8 10.3c-12.4 1.4-22.9-9.1-21.5-21.5l10.3-92.8L388.8 83.2c3.8-3.8 10-3.8 13.8 0zm162-22.9l-48.8-48.8c-15.2-15.2-39.9-15.2-55.2 0l-35.4 35.4c-3.8 3.8-3.8 10 0 13.8l90.2 90.2c3.8 3.8 10 3.8 13.8 0l35.4-35.4c15.2-15.3 15.2-40 0-55.2zM384 346.2V448H64V128h229.8c3.2 0 6.2-1.3 8.5-3.5l40-40c7.6-7.6 2.2-20.5-8.5-20.5H48C21.5 64 0 85.5 0 112v352c0 26.5 21.5 48 48 48h352c26.5 0 48-21.5 48-48V306.2c0-10.7-12.9-16-20.5-8.5l-40 40c-2.2 2.3-3.5 5.3-3.5 8.5z"></path></svg><span class="hidden lg:inline-block ml-2">Edit via github</span></span> </div> <div class=pb-10></div></div> <div class="lg:w-auto order-1 w-0"><div class=h-full><input class=hidden id=right-column type=checkbox> <label class="bg-primary block bottom-0 cursor-pointer fixed h-12 hover:bg-opacity-75 left-0 m-2 p-3 w-12 z-50" for=right-column id=right-column-toggler><div class="content-center flex flex-wrap h-6 relative w-6"><span class="block border-b-2 border-gray-100 h-1 w-full"></span> <span class="block border-b-2 border-gray-100 h-1 my-1 w-full"></span> <span class="block border-b-2 border-gray-100 h-1 w-full"></span></div> </label> <div class="bg-white border-gray-200 border-r dark:bg-gray-900 dark:border-gray-700 h-full lg:block lg:mr-3 lg:top-18 mr-24 overflow-hidden pl-1 pr-3 py-6 sticky text-sm w-60 z-40" id=right-column-nav><a class="block dark:text-gray-100 font-semibold lg:mb-3 lg:text-xs mb-3 mt-3 px-3 text-gray-900 text-sm tracking-wide uppercase" href=/installation> Get Started</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/> Introduction</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/installation> Installation</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/configuration> Configuration</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/upgrade> Upgrade Guide</a> <a class="block dark:text-gray-100 font-semibold lg:mb-3 lg:text-xs mb-3 mt-3 px-3 text-gray-900 text-sm tracking-wide uppercase" href=/command> Usage</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/command> Command</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/editor> Editor</a> <a class="block dark:text-gray-100 font-semibold lg:mb-3 lg:text-xs mb-3 mt-3 px-3 text-gray-900 text-sm tracking-wide uppercase" href=/themes> Theme</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/themes> Find a Theme</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/manage-assets> Customize the assets (css/js)</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/override-theme> Override the template files</a> <a class="block dark:text-gray-100 font-semibold lg:mb-3 lg:text-xs mb-3 mt-3 px-3 text-gray-900 text-sm tracking-wide uppercase" href=/extensions> Extensions</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/extensions> Find an extension</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/create-extension> Create an extension</a> <a class="block dark:text-gray-100 font-semibold lg:mb-3 lg:text-xs mb-3 mt-3 px-3 text-gray-900 text-sm tracking-wide uppercase" href=/contribute> Contribute</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/contribute> Issues and Pull Request</a> <a class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/architecture> The Architecture</a> <a class="bg-gray-200 block dark:bg-gray-700 dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" href=/roadmap> Roadmap</a> <span class="block dark:text-gray-100 duration-200 hover:bg-opacity-75 hover:bg-primary hover:text-white px-3 py-2 relative rounded text-gray-900 transition-colors" data-rot=_tvguho.pbz/Chfujbeq/Chfujbeq><div style=display:inline-block;margin-bottom:-2px><svg xmlns=http://www.w3.org/2000/svg class="bi bi-github" fill=currentColor height=16 viewbox="0 0 16 16" width=16><path d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.012 8.012 0 0 0 16 8c0-4.42-3.58-8-8-8z"></path></svg></div> Source Code</span></div></div> <script>document.addEventListener('DOMContentLoaded',function(){if(window.screen.width>=1025){document.querySelector('#right-column').checked=!0;document.querySelector('#right-column-toggler').classList.add('lg:hidden')}})</script> <style>#right-column:checked~label span:nth-child(1){transform:rotate(45deg) translateY(.2rem) translateX(.1rem)}#right-column:checked~label span:nth-child(2){border-color:transparent;margin:0 !important}#right-column:checked~label span:nth-child(3){transform:rotate(-45deg) translateY(-.3rem) translateX(.1rem)}#right-column:not(:checked)~#right-column-nav{height:0 !important;width:0}#right-column:checked~label{left:15rem}</style></div></div> <footer class="bg-gray-50 border-t border-yellow-50 dark:bg-gray-900 dark:border-gray-700 shadow-inner shadow-sm text-sm"><div class="max-w-screen-md mx-auto p-3 py-10 text-right"><a class="block hover:opacity-75 mb-3 text-2xl text-primary" href=/>Pushword</a> Crafted by Robin from <a class="hover:opacity-75 text-primary" href=https://piedweb.com>Pied Web</a>. </div> </footer> <header class="fixed flex flex-col left-0 right-0 top-0 z-50"><div class="bg-gray-50 border-b border-gray-50 dark:bg-gray-900 dark:border-gray-700 flex flex-row items-center justify-between p-4 shadow-sm"><span class="block font-mono mr-1 text-4xl"><a class="flex font-bold hover:text-primary logo text-primary" href=https://pushword.piedweb.com/><span class="bg-center bg-contain fill-current h-12 inline-block text-primary w-12" style="background-image:url('/assets/logo.svg')"></span> <span class="hidden lg:inline-block ml-2 mt-2 text-small">Pushword</span></a> </span> <div class="flex flex-1 flex-row md:mx-6 mx-3"><input class="bg-white border-2 border-white dark:bg-gray-700 focus:border-primary focus:w-60 md:focus:w-full md:rounded-l-lg md:w-full outline-none px-2 py-1 rounded rounded-r-none text-xl w-20" id=search placeholder=Search type=text> <button class="bg-primary font-bold hover:opacity-75 md:block px-4 py-4 rounded-r-lg text-white" onclick="document.querySelector('#search').focus()"><svg xmlns=http://www.w3.org/2000/svg fill=currentColor height=16 viewbox="0 0 16 16" width=16><path d="M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z"></path> </svg> </button></div> <nav class=nav><ul class="flex space-x-1"><li><a class="duration-200 font-bold hover:bg-opacity-75 hover:bg-primary hover:text-white inline-block px-3 py-4 rounded-lg text-primary transition-colors" href=/installation>Docs</a> <li><a class="duration-200 font-bold hidden hover:bg-opacity-75 hover:bg-primary hover:text-white md:inline-block px-3 py-4 rounded-lg text-primary transition-colors" href=/extensions>Extensions</a> <li><a class="duration-200 font-bold hidden hover:bg-opacity-75 hover:bg-primary hover:text-white md:inline-block px-3 py-4 rounded-lg text-primary transition-colors" href=/contribute>Contribute</a> <li><a class="duration-200 font-bold hidden hover:bg-opacity-75 hover:bg-primary hover:text-white md:inline-block px-3 py-4 rounded-lg text-primary transition-colors" href=/roadmap>Roadmap</a></ul> </nav></div> <div class="bg-gray-100 flex flex-col md:px-20 px-5 rounded-b-200" id=search-results></div></header> <style>body{margin-top:85px}a.logo:hover{filter:sepia(20%)}:root{--tw-ring-color:transparent}</style> <script src=/assets/app.js></script>