Skip to content

Commit

Permalink
add version extension
Browse files Browse the repository at this point in the history
  • Loading branch information
RobinDev committed Jan 18, 2021
1 parent 1f8d42c commit 99066b9
Show file tree
Hide file tree
Showing 35 changed files with 732 additions and 33 deletions.
13 changes: 7 additions & 6 deletions .github/workflows/split-monorepo.yaml
Expand Up @@ -51,6 +51,7 @@ jobs:
- installer
- facebook
- js-helper
- version
#package: ${{fromJson(needs.provide_packages_json.outputs.matrix)}}

steps:
Expand All @@ -60,17 +61,17 @@ jobs:

- # get git previous tag
id: previous_tag
uses: 'WyriHaximus/github-action-get-previous-tag@master'
uses: "WyriHaximus/github-action-get-previous-tag@master"

- # Uses an action in the root directory
name: Monorepo Split of ${{ matrix.package }}
uses: symplify/github-action-monorepo-split@master
env:
GITHUB_TOKEN: ${{ secrets.ACCESS_TOKEN }}
with:
package-directory: 'packages/${{ matrix.package }}'
split-repository-organization: 'pushword'
split-repository-name: '${{ matrix.package }}'
package-directory: "packages/${{ matrix.package }}"
split-repository-organization: "pushword"
split-repository-name: "${{ matrix.package }}"
tag: ${{ steps.previous_tag.outputs.tag }}
user-name: 'RobinDev'
user-email: 'contact@piedweb.com'
user-name: "RobinDev"
user-email: "contact@piedweb.com"
3 changes: 3 additions & 0 deletions composer.json
Expand Up @@ -53,6 +53,7 @@
"symfony/security-bundle": "^5.2",
"symfony/security-csrf": "^5.2",
"symfony/security-guard": "^5.2",
"symfony/serializer": "^5.2",
"symfony/translation": "^5.2",
"symfony/twig-bundle": "^5.2",
"symfony/validator": "^5.2",
Expand Down Expand Up @@ -102,6 +103,7 @@
"Pushword\\StaticGenerator\\": "packages/static-generator/src",
"Pushword\\Svg\\": "packages/svg/src",
"Pushword\\Facebook\\": "packages/facebook/src",
"Pushword\\Version\\": "packages/version/src",
"Pushword\\TemplateEditor\\": "packages/template-editor/src"
}
},
Expand All @@ -117,6 +119,7 @@
"Pushword\\StaticGenerator\\Tests\\": "packages/static-generator/tests",
"Pushword\\Svg\\Tests\\": "packages/svg/tests",
"Pushword\\Facebook\\Tests\\": "packages/facebook/tests",
"Pushword\\Version\\Tests\\": "packages/Version/tests",
"Pushword\\TemplateEditor\\Tests\\": "packages/template-editor/tests"
}
},
Expand Down
6 changes: 6 additions & 0 deletions docs/extension/version.html
@@ -0,0 +1,6 @@
<!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> Page Versionning for Pushword CMS </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 &raquo; Flux" type=application/rss+xml><link href=https://pushword.piedweb.com/extension/version rel=canonical><link href=https://pushword.piedweb.com/extension/version hreflang=en rel=alternate><meta content="Page Versionning for Pushword CMS" name=og:title><meta content=https://pushword.piedweb.com/extension/version 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=/extensions>Find your missing feature with a Pushword Extension</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>Version</h1> <p>Versionning pages with Pushword CMS.</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=#install>Install</a> <li class=last><a href=#usage>Usage</a> <ul class=menu_level_1><li class="first last"><span></span> <ul class=menu_level_2><li class="first last"><a href=#does-it-work-with-flat> Does it work with Flat ?</a> </ul> </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=install>Install</h2> <pre><code class="shell">composer require pushword/version
</code></pre> <p>Add Routes <pre><code class="yaml">admin:
resource: "@PushwordVersionBundle/VersionRoutes.yaml"
# or do it in 1 command line
# $ sed -i '1s/^/version:\n resource: "@PushwordVersionBundle\/VersionRoutes.yaml"\n/' config/routes.yaml
</code></pre> <h2 id=usage>Usage</h2> <p>This extension automatically (<em>event sucriber</em> on page update and persist) store a serialized version of the current page. <p>It adds a new <a href=/extension/admin>admin</a> (reachable for each page under <em>created at</em> field) wich list all versions for a page. <p>Then you can switch from one or an other version (identified by it <em>h1</em> and the *_updated date_). <h4 id=does-it-work-with-flat>&nbsp;Does it work with <a href=/extension/flat>Flat</a>&nbsp;?</h4> <p>Yes, but you need to install admin extension to able to restore a previous version from a page. Else you can use a versionning tool like git.</div> </div></div> <div class="flex max-w-3xl mt-5 mx-3"></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/rkgrafvba/irefvba.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 px-1 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="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=/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="bg-blue-500 duration-200 font-bold hidden hover:bg-opacity-75 md:inline-block px-3 py-4 rounded text-white transition-colors" href=/installation>Get Started</a> <li><a class="duration-200 font-bold hover:bg-opacity-75 hover:bg-primary hover:text-white inline-block px-3 py-4 rounded 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 text-primary transition-colors" href=/extension>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 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 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>

0 comments on commit 99066b9

Please sign in to comment.