[PATCH sherpa V2] [pkg] move to new "cube as package" layout

Sylvain Thénault sylvain.thenault at logilab.fr
Fri Feb 24 07:54:27 CET 2017


applied


Le 23/02/2017 à 13:27, Philippe Pepiot a écrit :
> # HG changeset patch
> # User Philippe Pepiot <philippe.pepiot at logilab.fr>
> # Date 1487846436 -3600
> #      Thu Feb 23 11:40:36 2017 +0100
> # Node ID 1d793e3baff947bc176016d3d1808f4cc61137e1
> # Parent  def05818d79ae2e07320a856e4553e0ce9350e98
> # Available At https://hg.logilab.org/review/cubes/sherpa
> #              hg pull https://hg.logilab.org/review/cubes/sherpa -r 1d793e3baff9
> # Tested add https://jenkins.logilab.org/job/cubicweb-sherpa/19
> [pkg] move to new "cube as package" layout
>
> diff --git a/MANIFEST.in b/MANIFEST.in
> --- a/MANIFEST.in
> +++ b/MANIFEST.in
> @@ -1,9 +1,9 @@
> -include *.py
> -include */*.py
> +recursive-include cubicweb_sherpa *.py
> +recursive-include cubicweb_sherpa/data *.gif *.png *.ico *.css *.js *.otf *.ttf *.txt
> +recursive-include cubicweb_sherpa/i18n *.po
> +include cubicweb_sherpa/views/templates/*.jinja2
>  include tox.ini
>  include doc/Makefile doc/conf.py doc/*.rst
> -include views/templates/*.jinja2
> -recursive-include data *.gif *.png *.ico *.css *.js *.otf *.ttf *.txt
> -recursive-include i18n *.po
>  
> +prune __pkginfo__.py
>  prune docker
> diff --git a/__init__.py b/__init__.py
> deleted file mode 100644
> --- a/__init__.py
> +++ /dev/null
> @@ -1,4 +0,0 @@
> -"""cubicweb-agape2 application package
> -
> -SEDA v2 profile generator
> -"""
> diff --git a/__pkginfo__.py b/__pkginfo__.py
> old mode 100644
> new mode 120000
> --- a/__pkginfo__.py
> +++ b/__pkginfo__.py
> @@ -1,60 +1,1 @@
> -# pylint: disable=W0622
> -"""cubicweb-agape2 application packaging information"""
> -
> -from os import listdir as _listdir
> -from os.path import join, isdir
> -from glob import glob
> -
> -
> -modname = 'sherpa'
> -distname = 'cubicweb-sherpa'
> -
> -numversion = (0, 1, 1)
> -version = '.'.join(str(num) for num in numversion)
> -
> -license = 'GPL'
> -author = 'LOGILAB S.A. (Paris, FRANCE)'
> -author_email = 'contact at logilab.fr'
> -description = 'SEDA v2 profile generator'
> -web = 'http://www.cubicweb.org/project/%s' % distname
> -
> -__depends__ = {
> -    'cubicweb': '>= 3.24.0', 'six': '>= 1.4.0',
> -    'cubicweb-seda': None,
> -    'cubicweb-registration': None,
> -    'cubicweb-rememberme': None,
> -    'cubicweb-relationwidget': None,
> -    'jinja2': None,
> -}
> -
> -__recommends__ = {}
> -
> -classifiers = [
> -    'Environment :: Web Environment',
> -    'Framework :: CubicWeb',
> -    'Programming Language :: Python',
> -    'Programming Language :: JavaScript',
> -]
> -
> -THIS_CUBE_DIR = join('share', 'cubicweb', 'cubes', modname)
> -
> -
> -def listdir(dirpath):
> -    return [join(dirpath, fname) for fname in _listdir(dirpath)
> -            if fname[0] != '.' and not fname.endswith('.pyc')
> -            and not fname.endswith('~')
> -            and not isdir(join(dirpath, fname))]
> -
> -
> -data_files = [
> -    # common files
> -    [THIS_CUBE_DIR, [fname for fname in glob('*.py') if fname != 'setup.py']],
> -]
> -# check for possible extended cube layout
> -for dname in ('entities', 'views', 'sobjects', 'hooks', 'schema', 'data',
> -              'wdoc', 'i18n', 'migration',
> -              'views/templates', 'data/fonts/lovelo', 'data/fonts/Open_Sans', 'data/images'):
> -    if isdir(dname):
> -        data_files.append([join(THIS_CUBE_DIR, dname), listdir(dname)])
> -# Note: here, you'll need to add subdirectories if you want
> -# them to be included in the debian package
> +cubicweb_sherpa/__pkginfo__.py
> \ No newline at end of file
> diff --git a/cubicweb_sherpa/__init__.py b/cubicweb_sherpa/__init__.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/__init__.py
> @@ -0,0 +1,4 @@
> +"""cubicweb-agape2 application package
> +
> +SEDA v2 profile generator
> +"""
> diff --git a/cubicweb_sherpa/__pkginfo__.py b/cubicweb_sherpa/__pkginfo__.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/__pkginfo__.py
> @@ -0,0 +1,33 @@
> +# pylint: disable=W0622
> +"""cubicweb-sherpa application packaging information"""
> +
> +modname = 'sherpa'
> +distname = 'cubicweb-sherpa'
> +
> +numversion = (0, 1, 1)
> +version = '.'.join(str(num) for num in numversion)
> +
> +license = 'GPL'
> +author = 'LOGILAB S.A. (Paris, FRANCE)'
> +author_email = 'contact at logilab.fr'
> +description = 'SEDA v2 profile generator'
> +web = 'http://www.cubicweb.org/project/%s' % distname
> +
> +__depends__ = {
> +    'cubicweb': '>= 3.24.0',
> +    'six': '>= 1.4.0',
> +    'cubicweb-seda': None,
> +    'cubicweb-registration': None,
> +    'cubicweb-rememberme': None,
> +    'cubicweb-relationwidget': None,
> +    'jinja2': None,
> +}
> +
> +__recommends__ = {}
> +
> +classifiers = [
> +    'Environment :: Web Environment',
> +    'Framework :: CubicWeb',
> +    'Programming Language :: Python',
> +    'Programming Language :: JavaScript',
> +]
> diff --git a/data/cubes.sherpa.css b/cubicweb_sherpa/data/cubes.sherpa.css
> rename from data/cubes.sherpa.css
> rename to cubicweb_sherpa/data/cubes.sherpa.css
> diff --git a/data/fonts/Open_Sans/LICENSE.txt b/cubicweb_sherpa/data/fonts/Open_Sans/LICENSE.txt
> rename from data/fonts/Open_Sans/LICENSE.txt
> rename to cubicweb_sherpa/data/fonts/Open_Sans/LICENSE.txt
> diff --git a/data/fonts/Open_Sans/OpenSans-Bold.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Bold.ttf
> rename from data/fonts/Open_Sans/OpenSans-Bold.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Bold.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-BoldItalic.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-BoldItalic.ttf
> rename from data/fonts/Open_Sans/OpenSans-BoldItalic.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-BoldItalic.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-CondBold.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-CondBold.ttf
> rename from data/fonts/Open_Sans/OpenSans-CondBold.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-CondBold.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-CondLight.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-CondLight.ttf
> rename from data/fonts/Open_Sans/OpenSans-CondLight.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-CondLight.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-CondLightItalic.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-CondLightItalic.ttf
> rename from data/fonts/Open_Sans/OpenSans-CondLightItalic.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-CondLightItalic.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-ExtraBold.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-ExtraBold.ttf
> rename from data/fonts/Open_Sans/OpenSans-ExtraBold.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-ExtraBold.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-ExtraBoldItalic.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-ExtraBoldItalic.ttf
> rename from data/fonts/Open_Sans/OpenSans-ExtraBoldItalic.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-ExtraBoldItalic.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-Italic.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Italic.ttf
> rename from data/fonts/Open_Sans/OpenSans-Italic.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Italic.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-Light.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Light.ttf
> rename from data/fonts/Open_Sans/OpenSans-Light.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Light.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-LightItalic.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-LightItalic.ttf
> rename from data/fonts/Open_Sans/OpenSans-LightItalic.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-LightItalic.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-Regular.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Regular.ttf
> rename from data/fonts/Open_Sans/OpenSans-Regular.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Regular.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-Semibold.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Semibold.ttf
> rename from data/fonts/Open_Sans/OpenSans-Semibold.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-Semibold.ttf
> diff --git a/data/fonts/Open_Sans/OpenSans-SemiboldItalic.ttf b/cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-SemiboldItalic.ttf
> rename from data/fonts/Open_Sans/OpenSans-SemiboldItalic.ttf
> rename to cubicweb_sherpa/data/fonts/Open_Sans/OpenSans-SemiboldItalic.ttf
> diff --git a/data/fonts/Open_Sans/readme.txt b/cubicweb_sherpa/data/fonts/Open_Sans/readme.txt
> rename from data/fonts/Open_Sans/readme.txt
> rename to cubicweb_sherpa/data/fonts/Open_Sans/readme.txt
> diff --git a/data/fonts/lovelo/Lovelo-Black.otf b/cubicweb_sherpa/data/fonts/lovelo/Lovelo-Black.otf
> rename from data/fonts/lovelo/Lovelo-Black.otf
> rename to cubicweb_sherpa/data/fonts/lovelo/Lovelo-Black.otf
> diff --git a/data/fonts/lovelo/licence.txt b/cubicweb_sherpa/data/fonts/lovelo/licence.txt
> rename from data/fonts/lovelo/licence.txt
> rename to cubicweb_sherpa/data/fonts/lovelo/licence.txt
> diff --git a/data/images/exemple_bordereau.png b/cubicweb_sherpa/data/images/exemple_bordereau.png
> rename from data/images/exemple_bordereau.png
> rename to cubicweb_sherpa/data/images/exemple_bordereau.png
> diff --git a/data/images/exemple_invalide.png b/cubicweb_sherpa/data/images/exemple_invalide.png
> rename from data/images/exemple_invalide.png
> rename to cubicweb_sherpa/data/images/exemple_invalide.png
> diff --git a/data/images/exemple_profil.png b/cubicweb_sherpa/data/images/exemple_profil.png
> rename from data/images/exemple_profil.png
> rename to cubicweb_sherpa/data/images/exemple_profil.png
> diff --git a/data/images/exemple_valide.png b/cubicweb_sherpa/data/images/exemple_valide.png
> rename from data/images/exemple_valide.png
> rename to cubicweb_sherpa/data/images/exemple_valide.png
> diff --git a/data/images/logo_SHERPA.png b/cubicweb_sherpa/data/images/logo_SHERPA.png
> rename from data/images/logo_SHERPA.png
> rename to cubicweb_sherpa/data/images/logo_SHERPA.png
> diff --git a/data/images/logo_SHERPA_2.png b/cubicweb_sherpa/data/images/logo_SHERPA_2.png
> rename from data/images/logo_SHERPA_2.png
> rename to cubicweb_sherpa/data/images/logo_SHERPA_2.png
> diff --git a/data/images/logo_SIAF.png b/cubicweb_sherpa/data/images/logo_SIAF.png
> rename from data/images/logo_SIAF.png
> rename to cubicweb_sherpa/data/images/logo_SIAF.png
> diff --git a/data/images/seda.png b/cubicweb_sherpa/data/images/seda.png
> rename from data/images/seda.png
> rename to cubicweb_sherpa/data/images/seda.png
> diff --git a/data/images/sherpa_bordereau.png b/cubicweb_sherpa/data/images/sherpa_bordereau.png
> rename from data/images/sherpa_bordereau.png
> rename to cubicweb_sherpa/data/images/sherpa_bordereau.png
> diff --git a/data/images/sherpa_general.png b/cubicweb_sherpa/data/images/sherpa_general.png
> rename from data/images/sherpa_general.png
> rename to cubicweb_sherpa/data/images/sherpa_general.png
> diff --git a/data/images/sherpa_profil.png b/cubicweb_sherpa/data/images/sherpa_profil.png
> rename from data/images/sherpa_profil.png
> rename to cubicweb_sherpa/data/images/sherpa_profil.png
> diff --git a/cubicweb_sherpa/i18n/en.po b/cubicweb_sherpa/i18n/en.po
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/i18n/en.po
> @@ -0,0 +1,8 @@
> +msgid ""
> +msgstr ""
> +"PO-Revision-Date: YEAR-MO-DA HO:MI +ZONE\n"
> +"MIME-Version: 1.0\n"
> +"Content-Type: text/plain; charset=UTF-8\n"
> +"Content-Transfer-Encoding: 8bit\n"
> +"Generated-By: pygettext.py 1.5\n"
> +"Plural-Forms: nplurals=2; plural=(n > 1);\n"
> diff --git a/cubicweb_sherpa/i18n/fr.po b/cubicweb_sherpa/i18n/fr.po
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/i18n/fr.po
> @@ -0,0 +1,8 @@
> +msgid ""
> +msgstr ""
> +"PO-Revision-Date: YEAR-MO-DA HO:MI +ZONE\n"
> +"MIME-Version: 1.0\n"
> +"Content-Type: text/plain; charset=UTF-8\n"
> +"Content-Transfer-Encoding: 8bit\n"
> +"Generated-By: pygettext.py 1.5\n"
> +"Plural-Forms: nplurals=2; plural=(n > 1);\n"
> diff --git a/cubicweb_sherpa/migration/postcreate.py b/cubicweb_sherpa/migration/postcreate.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/migration/postcreate.py
> @@ -0,0 +1,26 @@
> +# copyright 2016 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> +# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> +#
> +# This program is free software: you can redistribute it and/or modify it under
> +# the terms of the GNU General Public License as published by the Free
> +# Software Foundation, either version 2.1 of the License, or (at your option)
> +# any later version.
> +#
> +# This program is distributed in the hope that it will be useful, but WITHOUT
> +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> +# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
> +# details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program. If not, see <http://www.gnu.org/licenses/>.
> +"""cubicweb-agape2 postcreate script, executed at instance creation time or when
> +the cube is added to an existing instance.
> +
> +You could setup site properties or a workflow here for example.
> +"""
> +
> +# Example of site property change
> +set_property('ui.site-title', u'Agape 2')
> +set_property('ui.language', u'fr')
> +set_property('ui.date-format', u'%d/%m/%Y')
> +set_property('ui.datetime-format', u'%d/%m/%Y %H:%M')
> diff --git a/cubicweb_sherpa/site_cubicweb.py b/cubicweb_sherpa/site_cubicweb.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/site_cubicweb.py
> @@ -0,0 +1,24 @@
> +# copyright 2016 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> +# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> +#
> +# This program is free software: you can redistribute it and/or modify it under
> +# the terms of the GNU General Public License as published by the Free
> +# Software Foundation, either version 2.1 of the License, or (at your option)
> +# any later version.
> +#
> +# This program is distributed in the hope that it will be useful, but WITHOUT
> +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> +# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
> +# details.
> +#
> +# You should have received a copy of the GNU General Public License along
> +# with this program. If not, see <http://www.gnu.org/licenses/>.
> +
> +from logilab.common.decorators import monkeypatch
> +
> +from cubicweb.web import request
> +
> +
> + at monkeypatch(request._CubicWebRequestBase)
> +def negotiated_language(self):
> +    return 'fr'
> diff --git a/cubicweb_sherpa/uiprops.py b/cubicweb_sherpa/uiprops.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/uiprops.py
> @@ -0,0 +1,4 @@
> +# flake8: noqa
> +STYLESHEETS.extend([
> +    data('cubes.sherpa.css')
> +])
> diff --git a/cubicweb_sherpa/views/__init__.py b/cubicweb_sherpa/views/__init__.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/__init__.py
> @@ -0,0 +1,80 @@
> +# -*- coding: utf-8
> +# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> +# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> +#
> +# This program is free software: you can redistribute it and/or modify it under
> +# the terms of the GNU Lesser General Public License as published by the Free
> +# Software Foundation, either version 2.1 of the License, or (at your option)
> +# any later version.
> +#
> +# This program is distributed in the hope that it will be useful, but WITHOUT
> +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> +# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> +# details.
> +#
> +# You should have received a copy of the GNU Lesser General Public License along
> +# with this program. If not, see <http://www.gnu.org/licenses/>.
> +
> +from jinja2 import Environment, PackageLoader
> +
> +from cubicweb.view import View
> +from cubicweb.web.views import urlrewrite, startup
> +
> +_JINJA_ENV = Environment(loader=PackageLoader('cubicweb_sherpa.views'))
> +
> +
> +def jinja_render(template_name, **ctx):
> +    """Return a string containing result of rendering of Jinja2's `template_name` with
> +    `ctx` as context.
> +    """
> +    template = _JINJA_ENV.get_template(template_name + '.jinja2')
> +    return template.render(**ctx)
> +
> +
> +class JinjaStaticView(View):
> +    """Abstract base class to render static pages from a jinja template."""
> +    __abstract__ = True
> +    template_name = None
> +    title = None
> +
> +    def call(self, **kw):
> +        self.w(jinja_render(self.template_name,
> +                            title=self._cw._(self.title),
> +                            data_url=self._cw.datadir_url))
> +
> +
> +def jinja_static_view(template_name, title=None, regid=None):
> +    """Generate a sub-class of JinjaStaticView parametrized with its `template_name` and `title`.
> +
> +    `__regid__` is built by prepending 'sherpa.' to template_name.
> +    """
> +    class_name = template_name.capitalize() + 'View'
> +    if regid is None:
> +        regid = 'sherpa.' + template_name
> +
> +    return type(class_name, (JinjaStaticView,), {'__regid__': regid,
> +                                                 'template_name': template_name,
> +                                                 'title': title})
> +
> +
> +ProjectView = jinja_static_view('project', u'Sherpa un générateur de profils')
> +UtilisationView = jinja_static_view('utilisation', u'Pour commencer')
> +SedaView = jinja_static_view('seda', u'Le SEDA')
> +IndexView = jinja_static_view('index', regid='index')
> +
> +
> +class SherpaReqRewriter(urlrewrite.SimpleReqRewriter):
> +    rules = [
> +        ('/', dict(vid='sherpa.index')),
> +        ('/project', dict(vid='sherpa.project')),
> +        ('/utilisation', dict(vid='sherpa.utilisation')),
> +        ('/seda', dict(vid='sherpa.seda')),
> +    ]
> +
> +
> +def registration_callback(vreg):
> +    from cubicweb.web.views import bookmark
> +
> +    vreg.register_and_replace(IndexView, startup.IndexView)
> +    vreg.register_all(globals().values(), __name__, (IndexView,))
> +    vreg.unregister(bookmark.BookmarksBox)
> diff --git a/cubicweb_sherpa/views/components.py b/cubicweb_sherpa/views/components.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/components.py
> @@ -0,0 +1,96 @@
> +# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> +# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> +#
> +# This program is free software: you can redistribute it and/or modify it under
> +# the terms of the GNU Lesser General Public License as published by the Free
> +# Software Foundation, either version 2.1 of the License, or (at your option)
> +# any later version.
> +#
> +# This program is distributed in the hope that it will be useful, but WITHOUT
> +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> +# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> +# details.
> +#
> +# You should have received a copy of the GNU Lesser General Public License along
> +# with this program. If not, see <http://www.gnu.org/licenses/>.
> +"""cubicweb-sherpa components, originaly copied from the saem_ref cube."""
> +
> +from cubicweb import _, tags
> +from cubicweb.predicates import multi_lines_rset, has_permission, is_instance
> +from cubicweb.web import component
> +
> +
> +def add_etype_link(req, etype, text=u'', klass='icon-plus-circled pull-right',
> +                   **urlparams):
> +    """Return an HTML link to add an entity of type 'etype'."""
> +    vreg = req.vreg
> +    eschema = vreg.schema.eschema(etype)
> +    if eschema.has_perm(req, 'add'):
> +        url = vreg['etypes'].etype_class(etype).cw_create_url(req, **urlparams)
> +        return tags.a(text, href=url, klass=klass,
> +                      title=req.__('New %s' % etype))
> +    return u''
> +
> +
> +def import_etype_link(req, etype, url):
> +    """Return an HTML link to the view that may be used to import an entity of type `etype`.
> +    """
> +    eschema = req.vreg.schema.eschema(etype)
> +    if eschema.has_perm(req, 'add'):
> +        return tags.a(u'', href=url, klass='icon-upload pull-right',
> +                      title=req.__('Import %s' % etype))
> +    return u''
> +
> +
> +class AddEntityComponent(component.CtxComponent):
> +    """Component with 'add' link to be displayed in 'same etype' views usually 'SameETypeListView'.
> +    """
> +    __regid__ = 'sherpa.add_entity'
> +    __select__ = (component.CtxComponent.__select__ & multi_lines_rset() & has_permission('add') &
> +                  is_instance('AuthorityRecord', 'ConceptScheme',
> +                              'SEDAArchiveTransfer', 'SEDAArchiveUnit'))
> +    context = 'navtop'
> +    extra_kwargs = {'SEDAArchiveUnit': {'unit_type': 'unit_content'}}
> +
> +    def render_body(self, w):
> +        etype = self.cw_rset.description[0][0]
> +        w(add_etype_link(self._cw, etype, **self.extra_kwargs.get(etype, {})))
> +
> +
> +class ImportEntityComponent(component.CtxComponent):
> +    """Component with 'import' link to be displayed in 'same etype' views usually
> +    'SameETypeListView'.
> +
> +    Concret class should fill the `import_vid` class attribute and add a proper `is_instance`
> +    selector.
> +    """
> +    __abstract__ = True
> +    __regid__ = 'sherpa.import_entity'
> +    __select__ = component.CtxComponent.__select__ & multi_lines_rset() & has_permission('add')
> +    import_url = None  # URL of the view that may be used to import data
> +    context = 'navtop'
> +
> +    def render_body(self, w):
> +        etype = self.cw_rset.description[0][0]
> +        w(import_etype_link(self._cw, etype, self.import_url))
> +
> +
> +class EACImportComponent(ImportEntityComponent):
> +    """Component with a link to import an authority record from an EAC-CPF file."""
> +    __select__ = (ImportEntityComponent.__select__
> +                  & is_instance('AuthorityRecord'))
> +    _('Import AuthorityRecord')  # generate message used by the import component
> +
> +    @property
> +    def import_url(self):
> +        return self._cw.build_url('view', vid='eac.import')
> +
> +
> +class SKOSImportComponent(ImportEntityComponent):
> +    """Component with a link to import a concept scheme from a SKOS file."""
> +    __select__ = ImportEntityComponent.__select__ & is_instance('ConceptScheme')
> +    _('Import ConceptScheme')  # generate message used by the import component
> +
> +    @property
> +    def import_url(self):
> +        return self._cw.build_url('add/skossource')
> diff --git a/cubicweb_sherpa/views/management.py b/cubicweb_sherpa/views/management.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/management.py
> @@ -0,0 +1,64 @@
> +# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> +# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> +#
> +# This program is free software: you can redistribute it and/or modify it under
> +# the terms of the GNU Lesser General Public License as published by the Free
> +# Software Foundation, either version 2.1 of the License, or (at your option)
> +# any later version.
> +#
> +# This program is distributed in the hope that it will be useful, but WITHOUT
> +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> +# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> +# details.
> +#
> +# You should have received a copy of the GNU Lesser General Public License
> +# along with this program. If not, see <http://www.gnu.org/licenses/>.
> +
> +from logilab.mtconverter import xml_escape
> +
> +from cubicweb.predicates import relation_possible, one_line_rset, non_final_entity
> +from cubicweb.web import action, formwidgets
> +from cubicweb.web.formfields import guess_field
> +from cubicweb.web.views import actions, management
> +
> +from cubes.relationwidget.views import RelationFacetWidget
> +
> +
> +class SherpaSecurityManagementView(management.SecurityManagementView):
> +    """Security view overriden to hide permissions definitions and using a
> +    RelationFacetWidget to edit owner"""
> +    __select__ = (management.SecurityManagementView.__select__ &
> +                  relation_possible('owned_by', action='add'))
> +
> +    def entity_call(self, entity):
> +        w = self.w
> +        w(u'<h1><span class="etype">%s</span> <a href="%s">%s</a></h1>'
> +          % (entity.dc_type().capitalize(),
> +             xml_escape(entity.absolute_url()),
> +             xml_escape(entity.dc_title())))
> +        w('<h2>%s</h2>' % self._cw.__('Manage security'))
> +        msg = self._cw.__('ownerships have been changed')
> +        form = self._cw.vreg['forms'].select(
> +            'base', self._cw, entity=entity,
> +            form_renderer_id='base', submitmsg=msg,
> +            form_buttons=[formwidgets.SubmitButton()],
> +            domid='ownership%s' % entity.eid,
> +            __redirectvid='security',
> +            __redirectpath=entity.rest_path())
> +        field = guess_field(entity.e_schema,
> +                            self._cw.vreg.schema['owned_by'],
> +                            req=self._cw,
> +                            widget=RelationFacetWidget())
> +        field.help = None
> +        form.append_field(field)
> +        form.render(w=w, display_progress_div=False)
> +
> +
> +actions.ManagePermissionsAction.__select__ = (
> +    action.Action.__select__ & one_line_rset() & non_final_entity()
> +    & relation_possible('owned_by', action='add'))
> +
> +
> +def registration_callback(vreg):
> +    vreg.register_all(globals().values(), __name__)
> +    vreg.unregister(management.SecurityManagementView)
> diff --git a/cubicweb_sherpa/views/templates.py b/cubicweb_sherpa/views/templates.py
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/templates.py
> @@ -0,0 +1,147 @@
> +# -*- coding: utf-8
> +# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> +# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> +#
> +# This program is free software: you can redistribute it and/or modify it under
> +# the terms of the GNU Lesser General Public License as published by the Free
> +# Software Foundation, either version 2.1 of the License, or (at your option)
> +# any later version.
> +#
> +# This program is distributed in the hope that it will be useful, but WITHOUT
> +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> +# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> +# details.
> +#
> +# You should have received a copy of the GNU Lesser General Public License
> +# along with this program. If not, see <http://www.gnu.org/licenses/>.
> +"""sherpa views/templates"""
> +
> +from logilab.common.decorators import monkeypatch
> +
> +from cubicweb.utils import HTMLHead, UStringIO
> +from cubicweb.web.views import basetemplates
> +
> +from . import jinja_render
> +
> +
> +# Bootstrap configuration.
> +basetemplates.TheMainTemplate.twbs_container_cls = 'container-fluid'
> +
> +
> + at monkeypatch(HTMLHead)
> +def add_onload(self, jscode):
> +    """original `add_onload` implementation use `$(cw)`
> +    but `cw` variable is not available
> +    in francearchive, use `$` instead"""
> +    self.add_post_inline_script(u"""$(function() {
> +  %s
> +});""" % jscode)
> +
> +
> +class SherpaMainTemplate(basetemplates.TheMainTemplate):
> +
> +    def call(self, view):
> +        self.set_request_content_type()
> +        self.write_doctype()
> +        self.template_header(self.content_type, view=view)
> +        context = self.template_context(view)
> +        self.w(jinja_render('maintemplate', **context))
> +
> +    def template_context(self, view):
> +        """Return the main-template's context."""
> +        # left boxes
> +        left_boxes = list(self._cw.vreg['ctxcomponents'].poss_visible_objects(
> +            self._cw, rset=self.cw_rset, view=view, context='left'))
> +        stream = UStringIO()
> +        for box in left_boxes:
> +            box.render(w=stream.write, view=view)
> +        left_boxes_html = stream.getvalue()
> +        # header
> +        stream = UStringIO()
> +        w = stream.write
> +        components = self.get_components(view, context='header-right')
> +        if components:
> +            w(u'<ul class="nav navbar-nav navbar-right">')
> +            for component in components:
> +                w(u'<li>')
> +                component.render(w=w)
> +                w(u'</li>')
> +            w(u'</ul>')
> +        right_header_component = stream.getvalue()
> +        # application message
> +        msgcomp = self._cw.vreg['components'].select_or_none(
> +            'applmessages', self._cw, rset=self.cw_rset)
> +        application_message = msgcomp.render() if msgcomp else u''
> +        # breadcrumbs
> +        stream = UStringIO()
> +        w = stream.write
> +        components = self.get_components(view, context='header-center')
> +        if components:
> +            for component in components:
> +                component.render(w=w)
> +        breadcrumbs = stream.getvalue()
> +        # contextual components
> +        contextual_components = self._cw.view('contentheader', rset=self.cw_rset, view=view)
> +
> +        ctx = self.base_context()
> +        url = self._cw.build_url
> +        ctx.update({
> +            'title': view.page_title(),
> +            'page_content': view.render(),
> +            'breadcrumbs': breadcrumbs,
> +            'application_message': application_message,
> +            'contextual_components': contextual_components,
> +            'right_header_component': right_header_component,
> +            'left_boxes': left_boxes_html,
> +            'side_box': {
> +                'goTo_links': [
> +                    {'url': url('SEDAArchiveTransfer'),
> +                     'label': 'profils SEDA'},
> +                    {'url': url('sedalib'),
> +                     'label': u"unités d'archive"},
> +                    {'url': url('AuthorityRecord'),
> +                     'label': u"notices d'autorité"},
> +                    {'url': url('ConceptScheme'),
> +                     'label': u"vocabulaires"},
> +                ],
> +            },
> +            'footer': {
> +                'resources': [
> +                    {'url': url('shema_seda'),
> +                     'label': u'Schéma du SEDA 2.0'},
> +                    {'url': url('dictionnaire'),
> +                     'label': 'Dictionnaire des balises'},
> +                    {'url': url('documentation_fonctionnelle'),
> +                     'label': 'Documentation fonctionnelle'},
> +                    {'url': url('documentation_technique'),
> +                     'label': 'Documentation technique'},
> +                ],
> +                'navigation_Link': [
> +                    {'url': url('project'),
> +                     'label': u'SHERPA, un générateur de profils'},
> +                    {'url': url('utilisation'),
> +                     'label': "Pour commencer"},
> +                    {'url': url('seda'),
> +                     'label': "Le SEDA"},
> +                ]
> +            },
> +        })
> +        ctx.update(getattr(view, 'template_context', lambda: {})())
> +
> +        return ctx
> +
> +    def base_context(self):
> +        """Return a basic context using standard cubicweb information."""
> +        req = self._cw
> +        return {
> +            'page_id': 'contentmain',
> +            '_': req._,
> +            'user': req.user.login,
> +            'base_url': req.build_url(''),
> +            'data_url': req.datadir_url,
> +            'current_url': req.relative_path(),
> +        }
> +
> +
> +def registration_callback(vreg):
> +    vreg.register_and_replace(SherpaMainTemplate, basetemplates.TheMainTemplate)
> diff --git a/cubicweb_sherpa/views/templates/index.jinja2 b/cubicweb_sherpa/views/templates/index.jinja2
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/templates/index.jinja2
> @@ -0,0 +1,47 @@
> +<div class="col-md-12" id="accueil">
> +
> +  <section id="presentation">
> +      <h2>Créer un profil</h2>
> +      <div class="titleUnderline">
> +        <span class="underline mr"></span>
> +        <span class="losange"></span>
> +        <span class="underline ml"></span>
> +      </div>
> +
> +
> +      <div class="col-md-10 col-md-offset-1">
> +      <div id="buttons-wrapper">
> +        <a href="/SEDAArchiveTransfer" class="btn btn-default">Profils Seda</a>
> +      </div>
> +
> +        <p>
> +SHERPA est un outil qui permet de créer des profils d'archivage conformes au standard d'échange en mode collaboratif.
> +        </p>
> +      </div>
> +  </section>
> +
> +
> +  <section id="seda">
> +    <h2> Pour commencer </h2>
> +    <div class="titleUnderline">
> +      <span class="underline mr"></span>
> +      <span class="losange"></span>
> +      <span class="underline ml"></span>
> +    </div>
> +
> +    <div id="buttons-wrapper">
> +      <a href="/project" class="btn btn-default">SHERPA un générateur de profils</a>
> +      <a href="/utilisation" class="btn btn-default">Comment utiliser SHERPA ?</a>
> +      <a href="/seda" class="btn btn-default">Le SEDA</a>
> +    </div>
> +
> +    <div class="col-md-12">
> +      <p>
> +      Le projet <span class="emphasis">SHERPA</span> a été conduit par le Service interministériel des Archives de France en 2016 afin de doter le <span class="emphasis">réseau des services publics d’archives</span> d’un outil disponible en ligne et permettant de <span class="emphasis">rédiger des profils d’archivage</span> conformes au <span class="emphasis">Standard</span> d’échange des données pour l’archivage, version 2.0.
> +     <br>
> +     Le projet SHERPA a été réalisé en collaboration avec le projet <a href="http://saem.e-bordeaux.org/">SAEM</a> auquel participent le Conseil départemental de la Gironde, Bordeaux Métropole et la Ville de Bordeaux, dans une optique de mutualisation des moyens. SHERPA a été réalisé par la société LOGILAB. Son code source est librement réutilisable.<br>
> +     Licence : ### LICENCE ###
> +      </p>
> +    </div>
> +  </section>
> +</div>
> diff --git a/cubicweb_sherpa/views/templates/maintemplate.jinja2 b/cubicweb_sherpa/views/templates/maintemplate.jinja2
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/templates/maintemplate.jinja2
> @@ -0,0 +1,73 @@
> +<body>
> +  <nav class="navbar navbar-default navbar-sherpa" role="banner">
> +    <div class="container-fluid">
> +      <div class="col-md-2 hidden-xs hidden-sm">
> +        <a href="{{ base_url }}"><img src="{{ data_url }}images/logo_SIAF.png" class="logoSIAF" /></a>
> +      </div>
> +      <div class="col-md-7 col-xs-8">
> +        <a href="/">
> +          <div class="logoSHERPA">
> +            <img src="{{ data_url }}images/logo_SHERPA_2.png" class="img-responsive"/>
> +          </div>
> +          <div class="textSHERPA">
> +            <h1>Service Hébergé pour la Rédaction de Profils d'Archivage</h1>
> +          </div>
> +        </a>
> +      </div>
> +      <div class="col-md-3 col-xs-4">
> +        {{ right_header_component }}
> +      </div>
> +    </div>
> +  </nav>
> +  {% if breadcrumbs %}
> +  <nav role="navigation" class="breadcrumbs_wrapper">
> +    <div class="col-md-offset-2">
> +      {{ breadcrumbs }}
> +    </div>
> +  </nav>
> +  {% endif %}
> +  <div id="{{page_id}}" class="container-fluid" role="main">
> +    <aside id="aside-main-left" class="col-md-2 cwjs-aside">
> +      {{ left_boxes }}
> +      <div class="panel panel-default contextFreeBox facet_filterbox" id="facet_filterbox">
> +        <div class="panel-heading">
> +          <div class="panel-title">navigation</div>
> +        </div>
> +        <div class="panel-body">
> +          <ul class="list-unstyled">
> +            {% for page in side_box.goTo_links %}
> +            <li class="facetvalue"><a href='{{ page.url }}'> {{ page.label }}</a></li>
> +            {% endfor %}
> +          </ul>
> +        </div>
> +      </div>
> +    </aside>
> +    <div class="col-md-10 page-content" id="pageContent">
> +      {{ application_message }}
> +      {{ contextual_components }}
> +      {{ page_content }}
> +    </div>
> +  </div>
> +  <div class="container-fluid">
> +    <footer role="contentinfo" id="pagefooter">
> +      <section class="links">
> +        <div id="sherpa-resources">
> +        <h3>Ressources</h3>
> +        {% for resource in footer.resources %}
> +          <a href='{{ resource.url }}'> {{ resource.label }}</a>
> +        {% endfor %}
> +        </div>
> +        <div id="sherpa-navigation">
> +        <h3>Navigation</h3>
> +        {% for page in footer.navigation_Link %}
> +          <a href='{{ page.url }}'> {{ page.label }}</a>
> +        {% endfor %}
> +        </div>
> +      </section>
> +      <div id="copyright">
> +        <span>copyright</span> |
> +        <span><a href="">contact</a></span>
> +      </div>
> +    </footer>
> +  </div>
> +</body>
> diff --git a/cubicweb_sherpa/views/templates/project.jinja2 b/cubicweb_sherpa/views/templates/project.jinja2
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/templates/project.jinja2
> @@ -0,0 +1,99 @@
> +<h1>{{ title }}</h1>
> +
> +<section id="sherpa-project-page">
> +  <div class="column-wrap">
> +    <div class="col-md-2 vcenter">
> +      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_bordereau.png"/>
> +    </div>
> +    <div class="col-md-9">
> +      <h2>Du bordereau de versement ...</h2>
> +      <p>
> +        Le bordereau de versement est le document qui accompagne toute entrée d’archives publiques dans un service d’archives. Le bordereau contient des informations sur le service producteur et/ou versant, le service d’archives et une description sommaire des archives qui constituent le versement. Le bordereau matérialise le transfert de responsabilité entre le service versant et le service d’archives. C’est donc un document indispensable.
> +      </p>
> +      <p>
> +        Dans le monde numérique, le bordereau de versement peut être dématérialisé, mais il continue d’avoir la même utilité et doit comporter les mêmes informations qu’un bordereau papier. C’est pourquoi le Standard d’échange de données pour l’archivage propose une modélisation des informations qui constituent le bordereau de versement.
> +      </p>
> +    </div>
> +  </div>
> +  <div class="column-wrap">
> +    <div class="col-md-2 vcenter">
> +      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_profil.png"/>
> +    </div>
> +    <div class="col-md-9">
> +      <h2>… au profil d’archivage</h2>
> +      <p>
> +        Toute entrée de documents dans un service d’archives fait l’objet d’une série de contrôles destinés à vérifier la conformité de cette entrée aux attentes du service en matière sanitaire, de conditionnement, etc. Le contrôle du bordereau de versement en fait partie.
> +      </p>
> +      <p>
> +        Dans le monde numérique, le Système d’archivage électronique (SAE) va lui aussi effectuer une série de contrôles, pour la plupart automatisés et pré-paramétrés (format, taille des fichiers, etc.). Il va également réaliser un contrôle du bordereau de versement. Pour évaluer la conformité du bordereau, le SAE doit savoir précisément ce qui est attendu dans ce bordereau et donc disposer d’une matrice de bordereau appelée profil d’archivage. Le profil est, pour un flux donné, la matrice de référence à partir de laquelle le SAE va pouvoir contrôler la conformité des bordereaux de versement de ce flux.
> +      </p>
> +    </div>
> +
> +  </div>
> +  <div class="img-bottom">
> +    <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_general.png"/>
> +  </div>
> +  
> +  <div class="col-md-12">
> +    <h2>Exemple</h2>
> +
> +    <table class="table">
> +        <tbody>
> +            <thead>
> +            <tr>
> +              <th>Profil</th>
> +              <th>Bordereau</th>
> +              <th>Vérification</th>
> +            </tr>
> +          </thead>
> +          <tr>
> +            <td>
> +                <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
> +                <p>J’attends un nom de service versant de façon obligatoire</p>
> +            </td>
> +            <td>
> +              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
> +              <p>Le service versant de mon versement est « Direction XXX »</p>
> +            </td>
> +            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
> +          </tr>
> +          <tr>
> +            <td>
> +              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
> +              <p>J’attends 35 fichiers dans le versement</p>
> +            </td>
> +            <td>
> +              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
> +              <p>Mon versement contient 40 fichiers</p>
> +            </td>
> +            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_invalide.png"/></td>
> +          </tr>
> +          <tr>
> +            <td>
> +              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
> +              <p>J’attends au niveau Dossier le terme d’indexation YYY</p>
> +            </td>
> +            <td>
> +              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
> +              <p>Mon versement contient au niveau Dossier le terme d’indexation YYY</p>
> +            </td>
> +            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
> +          </tr>
> +        </tbody>
> +      </table>
> +
> +  </div>
> +
> +  <div class="col-md-12">
> +    <h2>Un générateur de profils</h2>
> +    <p>
> +    Les bordereaux de versement conformes au standard d’échange de données pour l’archivage sont des fichiers de format XML. Les profils d’archivage utilisent pour leur part des langages comme XSD ou RelaxNG qui permettent de définir la structure et le type de contenu d’un document XML.
> +    </p>
> +    <p>
> +      SHERPA propose une interface simple et ergonomique pour rédiger des profils d’archivage et les exporter en RelaxNG. SHERPA permet également d’exporter une documentation associée au profil, lisible par un humain.
> +    </p>
> +  </div>
> +
> +
> +
> +</section>
> diff --git a/cubicweb_sherpa/views/templates/seda.jinja2 b/cubicweb_sherpa/views/templates/seda.jinja2
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/templates/seda.jinja2
> @@ -0,0 +1,39 @@
> +<h1>{{ title }}</h1>
> +
> +<section id="sherpa-seda-page">
> +
> +    <div class="col-md-3">
> +      <img class="img-responsive seda-img" src="{{ data_url }}images/seda.png"/>
> +    </div>
> +
> +    <div class="col-md-9">
> +      <p>
> +        Si les processus d’archivage et les documents qui leur sont associés (bordereaux) demeurent entièrement valables dans le monde numérique, celui-ci exige cependant une formalisation et une standardisation beaucoup plus fortes de ces processus et documents associés afin de pouvoir aller vers davantage d’automatisation.
> +        Le standard d’échange de données pour l’archivage permet de modéliser les transactions d’un processus d’archivage (transfert, communication, élimination, modification et restitution) entre différents acteurs (service producteur, service versant, service d’archives et demandeur d’archives) . Il précise les types, l’ordre et la forme des messages échangés. Il définit d’autre part les métadonnées à utiliser pour décrire, gérer et pérenniser l’information.
> +
> +        Plusieurs versions du standard ont été successivement publiées en mars 2006 (version 0.1), janvier 2010 (version 0.2), septembre 2012 (version 1.0) et décembre 2015 (version 2.0 conforme à la norme MEDONA).
> +      </p>
> +
> +      <p>
> +        Le standard est une déclinaison technique des pratiques archivistiques utilisées dans le monde papier. Les principes du SEDA reprennent donc largement les concepts métier tels que l’usage des bordereaux (versement, élimination), l’application du contrôle scientifique et technique (transaction de demande d’autorisation), la définition des acteurs ou l’apposition de règles de gestion (sorts finaux et communicabilité).
> +      </p>
> +    </div>
> +    <div class="col-md-12">
> +      <h2>Les agents</h2>
> +
> +      <p>
> +        Le SEDA permet d’associer aux transactions des Agents, qui sont des personnes ou des collectivités (concepts inspirés de la norme ISAAR-CPF) afin de décrire les archives échangées ou de spécifier des informations de gestion les concernant. Le modèle de métadonnées utilisé pour décrire ces agents est identique qu’il s’agisse d’identifier les acteurs de l’échange ou d’indiquer la provenance d’un document.
> +        Un agent peut être utilisé plusieurs fois dans différentes transactions et peut également avoir plusieurs rôles attribués dans les messages du SEDA.
> +
> +        C’est pourquoi SHERPA propose de gérer un seul référentiel « Agents » dont les notices peuvent être utilisées dans tous les profils d’archivage rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir une seule liste de référence pour l’ensemble de son corpus de profils.
> +    </p>
> +
> +    <h2>Les vocabulaires </h2>
> +    <p>
> +      Le SEDA permet d’ajouter des termes d’indexation à tous les niveaux de description du plan de classement. Il s’inspire en la matière des pratiques d’indexation telles qu’elles sont recommandées par l’ EAD. Il est donc nécessaire de gérer des listes de vocabulaires d’indexation.
> +      D’autres listes de valeurs contrôlées sont également utilisées dans le SEDA, notamment pour échanger les métadonnées techniques (telles que les référentiels de format, d’encodage…), les métadonnées descriptives (telles que les niveaux de description, les langues…) et les métadonnées de gestion (telles que les sorts finaux, les délais de communicabilité…).
> +
> +      C’est pourquoi SHERPA propose de gérer un seul référentiel « Vocabulaires » dont les références et les valeurs peuvent être utilisées dans l’ensemble des profils rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir un ensemble de listes de références unique pour l’ensemble du corpus de profils.
> +    </p>
> +    </div>
> +</section>
> diff --git a/cubicweb_sherpa/views/templates/utilisation.jinja2 b/cubicweb_sherpa/views/templates/utilisation.jinja2
> new file mode 100644
> --- /dev/null
> +++ b/cubicweb_sherpa/views/templates/utilisation.jinja2
> @@ -0,0 +1,60 @@
> +<h1>{{ title }}</h1>
> +<section id="utilisation">
> +  <div id="utilisationWrapper">
> +    <div class="utilisation col-xs-12">
> +      <div>
> +        <h2>Formulaire complet <span class="font-openSans">&</span> formulaire simplifié</h2>
> +        <p>
> +          SHERPA est basé sur la version 2.0 du Standard d’échange de données pour l’archivage.
> +        </p>
> +          <div class="form">
> +            <h4><span class="icon-right-dir"></span>Formulaire complet</h4>
> +            <p>
> +              Le formulaire complet propose l’exhaustivité des métadonnées du SEDA 2.0 mais ne permet pas d’exporter le profil créé dans les anciennes versions du SEDA, moins riches en métadonnées.
> +            </p>
> +          </div>
> +
> +          <div class="form">
> +            <h4><span class="icon-right-dir"></span>Formulaire simplifié</h4>
> +            <p>
> +              Une version simplifiée de l’outil a également été développée afin d’une part de faciliter sa prise en main  et d’autre part d’exporter des profils simples dans toutes les versions du Standard (0.2, 1.0 et 2.0). Ces profils simples sont nécessairement moins riches en métadonnées que les profils complets conformes au SEDA 2.0.
> +            </p>
> +          </div>
> +      </div>
> +    </div>
> +
> +    <div class="utilisation col-xs-12">
> +
> +      <div>
> +        <h2>Travail modulaire</h2>
> +        <p>
> +          Sherpa repose sur une approche modulaire. Il est donc possible de décrire des unités d'archives à n'importe quel niveau et de les agencer ensuite pour créer un ou plusieurs profils.
> +        </p>
> +      </div>
> +  </div>
> +
> +    <div class="utilisation col-xs-12">
> +
> +      <div>
> +        <h2>Travail en référentiel</h2>
> +        <p>
> +          Comme indiqué ci-dessus, le SEDA 2.0 fonctionne, pour un certain nombre de valeurs, avec des référentiels externes qu’il convient donc de définir à l’extérieur du profil. SHERPA met en œuvre ce principe en proposant des zones permettant d’alimenter et de mettre à jour les agents et les vocabulaires utilisés dans les échanges.
> +          Le rédacteur peut gérer des listes de valeurs contrôlées référencées dans les bordereaux de transfert ainsi que des notices d’agents employées pour identifier les acteurs. Ces deux types de ressources centralisées peuvent être utilisés dans l’ensemble du corpus de profils.
> +        </p>
> +      </div>
> +  </div>
> +
> +  <div class="utilisation col-xs-12">
> +
> +    <div>
> +      <h2>Travail collaboratif</h2>
> +      <p>
> +        SHERPA est une application web et est proposé en tant que service hébergé par le Service interministériel des Archives de France. Les modules référentiels d’Agents et de Vocabulaires sont communs à toute la communauté d’utilisateurs, de même que le corpus de profils et d'unités d'archives.
> +
> +        Un système d’habilitation simplifié permet à tous les utilisateurs connectés de consulter le travail des autres utilisateurs. Le rédacteur d’un profil peut le modifier à tout moment et peut étendre les droits de modifications à d’autres utilisateurs s’il le souhaite.
> +
> +        L’ensemble des contenus est accessible en lecture à la communauté d’utilisateurs de SHERPA. Un utilisateur peut via la page gestion des permissions, donner des droits d’écriture sur les profils et les notices d’autorité qu’il a créés à un autre utilisateur. Sans avoir les droits d’écriture, il est néanmoins possible de copier un profil existant afin de le modifier.
> +      </p>
> +    </div>
> +  </div>
> +</section>
> diff --git a/i18n/en.po b/i18n/en.po
> deleted file mode 100644
> --- a/i18n/en.po
> +++ /dev/null
> @@ -1,8 +0,0 @@
> -msgid ""
> -msgstr ""
> -"PO-Revision-Date: YEAR-MO-DA HO:MI +ZONE\n"
> -"MIME-Version: 1.0\n"
> -"Content-Type: text/plain; charset=UTF-8\n"
> -"Content-Transfer-Encoding: 8bit\n"
> -"Generated-By: pygettext.py 1.5\n"
> -"Plural-Forms: nplurals=2; plural=(n > 1);\n"
> diff --git a/i18n/fr.po b/i18n/fr.po
> deleted file mode 100644
> --- a/i18n/fr.po
> +++ /dev/null
> @@ -1,8 +0,0 @@
> -msgid ""
> -msgstr ""
> -"PO-Revision-Date: YEAR-MO-DA HO:MI +ZONE\n"
> -"MIME-Version: 1.0\n"
> -"Content-Type: text/plain; charset=UTF-8\n"
> -"Content-Transfer-Encoding: 8bit\n"
> -"Generated-By: pygettext.py 1.5\n"
> -"Plural-Forms: nplurals=2; plural=(n > 1);\n"
> diff --git a/migration/postcreate.py b/migration/postcreate.py
> deleted file mode 100644
> --- a/migration/postcreate.py
> +++ /dev/null
> @@ -1,26 +0,0 @@
> -# copyright 2016 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> -# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> -#
> -# This program is free software: you can redistribute it and/or modify it under
> -# the terms of the GNU General Public License as published by the Free
> -# Software Foundation, either version 2.1 of the License, or (at your option)
> -# any later version.
> -#
> -# This program is distributed in the hope that it will be useful, but WITHOUT
> -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> -# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
> -# details.
> -#
> -# You should have received a copy of the GNU General Public License
> -# along with this program. If not, see <http://www.gnu.org/licenses/>.
> -"""cubicweb-agape2 postcreate script, executed at instance creation time or when
> -the cube is added to an existing instance.
> -
> -You could setup site properties or a workflow here for example.
> -"""
> -
> -# Example of site property change
> -set_property('ui.site-title', u'Agape 2')
> -set_property('ui.language', u'fr')
> -set_property('ui.date-format', u'%d/%m/%Y')
> -set_property('ui.datetime-format', u'%d/%m/%Y %H:%M')
> diff --git a/setup.py b/setup.py
> --- a/setup.py
> +++ b/setup.py
> @@ -22,185 +22,61 @@
>  """
>  __docformat__ = "restructuredtext en"
>  
> -import os
> -import sys
> -import shutil
> -from os.path import exists, join, walk
> -
> -try:
> -    if os.environ.get('NO_SETUPTOOLS'):
> -        raise ImportError()  # do as there is no setuptools
> -    from setuptools import setup
> -    from setuptools.command import install_lib
> -    USE_SETUPTOOLS = True
> -except ImportError:
> -    from distutils.core import setup
> -    from distutils.command import install_lib
> -    USE_SETUPTOOLS = False
> -from distutils.command import install_data
> -
> -# import required features
> -from __pkginfo__ import modname, version, license, description, web, \
> -    author, author_email, classifiers
> -
> -if exists('README'):
> -    long_description = open('README').read()
> -else:
> -    long_description = ''
> +from os.path import join, dirname
>  
> -# import optional features
> -import __pkginfo__
> -if USE_SETUPTOOLS:
> -    requires = {}
> -    for entry in ("__depends__",):  # "__recommends__"):
> -        requires.update(getattr(__pkginfo__, entry, {}))
> -    install_requires = [("%s %s" % (d, v and v or "")).strip()
> -                        for d, v in requires.items()]
> -else:
> -    install_requires = []
> -
> -distname = getattr(__pkginfo__, 'distname', modname)
> -scripts = getattr(__pkginfo__, 'scripts', ())
> -include_dirs = getattr(__pkginfo__, 'include_dirs', ())
> -data_files = getattr(__pkginfo__, 'data_files', None)
> -ext_modules = getattr(__pkginfo__, 'ext_modules', None)
> -dependency_links = getattr(__pkginfo__, 'dependency_links', ())
> -
> -BASE_BLACKLIST = ('CVS', '.svn', '.hg', 'debian', 'dist', 'build')
> -IGNORED_EXTENSIONS = ('.pyc', '.pyo', '.elc', '~')
> -
> -
> -def ensure_scripts(linux_scripts):
> -    """
> -    Creates the proper script names required for each platform
> -    (taken from 4Suite)
> -    """
> -    from distutils import util
> -    if util.get_platform()[:3] == 'win':
> -        scripts_ = [script + '.bat' for script in linux_scripts]
> -    else:
> -        scripts_ = linux_scripts
> -    return scripts_
> +from setuptools import find_packages, setup
>  
>  
> -def export(from_dir, to_dir,
> -           blacklist=BASE_BLACKLIST,
> -           ignore_ext=IGNORED_EXTENSIONS,
> -           verbose=True):
> -    """make a mirror of from_dir in to_dir, omitting directories and files
> -    listed in the black list
> -    """
> -    def make_mirror(arg, directory, fnames):
> -        """walk handler"""
> -        for norecurs in blacklist:
> -            try:
> -                fnames.remove(norecurs)
> -            except ValueError:
> -                pass
> -        for filename in fnames:
> -            # don't include binary files
> -            if filename[-4:] in ignore_ext:
> -                continue
> -            if filename[-1] == '~':
> -                continue
> -            src = join(directory, filename)
> -            dest = to_dir + src[len(from_dir):]
> -            if verbose:
> -                sys.stderr.write('%s -> %s\n' % (src, dest))
> -            if os.path.isdir(src):
> -                if not exists(dest):
> -                    os.mkdir(dest)
> -            else:
> -                if exists(dest):
> -                    os.remove(dest)
> -                shutil.copy2(src, dest)
> -    try:
> -        os.mkdir(to_dir)
> -    except OSError as ex:
> -        # file exists ?
> -        import errno
> -        if ex.errno != errno.EEXIST:
> -            raise
> -    walk(from_dir, make_mirror, None)
> +here = dirname(__file__)
> +
> +# load metadata from the __pkginfo__.py file so there is no risk of conflict
> +# see https://packaging.python.org/en/latest/single_source_version.html
> +pkginfo = join(here, 'cubicweb_sherpa', '__pkginfo__.py')
> +__pkginfo__ = {}
> +with open(pkginfo) as f:
> +    exec(f.read(), __pkginfo__)
> +
> +# get required metadatas
> +distname = __pkginfo__['distname']
> +version = __pkginfo__['version']
> +license = __pkginfo__['license']
> +description = __pkginfo__['description']
> +web = __pkginfo__['web']
> +author = __pkginfo__['author']
> +author_email = __pkginfo__['author_email']
> +classifiers = __pkginfo__['classifiers']
> +
> +with open(join(here, 'README')) as f:
> +    long_description = f.read()
> +
> +# get optional metadatas
> +data_files = __pkginfo__.get('data_files', None)
> +dependency_links = __pkginfo__.get('dependency_links', ())
> +
> +requires = {}
> +for entry in ("__depends__",):  # "__recommends__"):
> +    requires.update(__pkginfo__.get(entry, {}))
> +install_requires = ["{0} {1}".format(d, v and v or "").strip()
> +                    for d, v in requires.items()]
>  
>  
> -class MyInstallLib(install_lib.install_lib):
> -    """extend install_lib command to handle  package __init__.py and
> -    include_dirs variable if necessary
> -    """
> -    def run(self):
> -        """overridden from install_lib class"""
> -        install_lib.install_lib.run(self)
> -        # manually install included directories if any
> -        if include_dirs:
> -            base = modname
> -            for directory in include_dirs:
> -                dest = join(self.install_dir, base, directory)
> -                export(directory, dest, verbose=False)
> -
> -# re-enable copying data files in sys.prefix
> -old_install_data = install_data.install_data
> -if USE_SETUPTOOLS:
> -    # overwrite InstallData to use sys.prefix instead of the egg directory
> -    class MyInstallData(old_install_data):
> -        """A class that manages data files installation"""
> -        def run(self):
> -            _old_install_dir = self.install_dir
> -            if self.install_dir.endswith('egg'):
> -                self.install_dir = sys.prefix
> -            old_install_data.run(self)
> -            self.install_dir = _old_install_dir
> -    try:
> -        # only if easy_install available
> -        import setuptools.command.easy_install  # noqa
> -        # monkey patch: Crack SandboxViolation verification
> -        from setuptools.sandbox import DirectorySandbox as DS
> -        old_ok = DS._ok
> -
> -        def _ok(self, path):
> -            """Return True if ``path`` can be written during installation."""
> -            out = old_ok(self, path)  # here for side effect from setuptools
> -            realpath = os.path.normcase(os.path.realpath(path))
> -            allowed_path = os.path.normcase(sys.prefix)
> -            if realpath.startswith(allowed_path):
> -                out = True
> -            return out
> -        DS._ok = _ok
> -    except ImportError:
> -        pass
> -
> -
> -def install(**kwargs):
> -    """setup entry point"""
> -    if USE_SETUPTOOLS:
> -        if '--force-manifest' in sys.argv:
> -            sys.argv.remove('--force-manifest')
> -    # install-layout option was introduced in 2.5.3-1~exp1
> -    elif sys.version_info < (2, 5, 4) and '--install-layout=deb' in sys.argv:
> -        sys.argv.remove('--install-layout=deb')
> -    cmdclass = {'install_lib': MyInstallLib}
> -    if USE_SETUPTOOLS:
> -        kwargs['install_requires'] = install_requires
> -        kwargs['dependency_links'] = dependency_links
> -        kwargs['zip_safe'] = False
> -        cmdclass['install_data'] = MyInstallData
> -
> -    return setup(name=distname,
> -                 version=version,
> -                 license=license,
> -                 description=description,
> -                 long_description=long_description,
> -                 author=author,
> -                 author_email=author_email,
> -                 url=web,
> -                 scripts=ensure_scripts(scripts),
> -                 data_files=data_files,
> -                 ext_modules=ext_modules,
> -                 cmdclass=cmdclass,
> -                 classifiers=classifiers,
> -                 **kwargs
> -                 )
> -
> -
> -if __name__ == '__main__':
> -    install()
> +setup(
> +    name=distname,
> +    version=version,
> +    license=license,
> +    description=description,
> +    long_description=long_description,
> +    author=author,
> +    author_email=author_email,
> +    url=web,
> +    classifiers=classifiers,
> +    packages=find_packages(exclude=['test']),
> +    install_requires=install_requires,
> +    include_package_data=True,
> +    entry_points={
> +        'cubicweb.cubes': [
> +            'sherpa=cubicweb_sherpa',
> +        ],
> +    },
> +    zip_safe=False,
> +)
> diff --git a/site_cubicweb.py b/site_cubicweb.py
> deleted file mode 100644
> --- a/site_cubicweb.py
> +++ /dev/null
> @@ -1,24 +0,0 @@
> -# copyright 2016 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> -# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> -#
> -# This program is free software: you can redistribute it and/or modify it under
> -# the terms of the GNU General Public License as published by the Free
> -# Software Foundation, either version 2.1 of the License, or (at your option)
> -# any later version.
> -#
> -# This program is distributed in the hope that it will be useful, but WITHOUT
> -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> -# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
> -# details.
> -#
> -# You should have received a copy of the GNU General Public License along
> -# with this program. If not, see <http://www.gnu.org/licenses/>.
> -
> -from logilab.common.decorators import monkeypatch
> -
> -from cubicweb.web import request
> -
> -
> - at monkeypatch(request._CubicWebRequestBase)
> -def negotiated_language(self):
> -    return 'fr'
> diff --git a/tox.ini b/tox.ini
> --- a/tox.ini
> +++ b/tox.ini
> @@ -30,4 +30,4 @@ format = pylint
>  ignore = W503
>  max-line-length = 100
>  max-complexity = 12
> -exclude = setup.py,doc/conf.py,migration/*,.tox/*
> +exclude = setup.py,doc/conf.py,cubicweb_sherpa/migration/*,.tox/*
> diff --git a/uiprops.py b/uiprops.py
> deleted file mode 100644
> --- a/uiprops.py
> +++ /dev/null
> @@ -1,4 +0,0 @@
> -# flake8: noqa
> -STYLESHEETS.extend([
> -    data('cubes.sherpa.css')
> -])
> diff --git a/views/__init__.py b/views/__init__.py
> deleted file mode 100644
> --- a/views/__init__.py
> +++ /dev/null
> @@ -1,80 +0,0 @@
> -# -*- coding: utf-8
> -# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> -# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> -#
> -# This program is free software: you can redistribute it and/or modify it under
> -# the terms of the GNU Lesser General Public License as published by the Free
> -# Software Foundation, either version 2.1 of the License, or (at your option)
> -# any later version.
> -#
> -# This program is distributed in the hope that it will be useful, but WITHOUT
> -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> -# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> -# details.
> -#
> -# You should have received a copy of the GNU Lesser General Public License along
> -# with this program. If not, see <http://www.gnu.org/licenses/>.
> -
> -from jinja2 import Environment, PackageLoader
> -
> -from cubicweb.view import View
> -from cubicweb.web.views import urlrewrite, startup
> -
> -_JINJA_ENV = Environment(loader=PackageLoader('cubes.sherpa.views'))
> -
> -
> -def jinja_render(template_name, **ctx):
> -    """Return a string containing result of rendering of Jinja2's `template_name` with
> -    `ctx` as context.
> -    """
> -    template = _JINJA_ENV.get_template(template_name + '.jinja2')
> -    return template.render(**ctx)
> -
> -
> -class JinjaStaticView(View):
> -    """Abstract base class to render static pages from a jinja template."""
> -    __abstract__ = True
> -    template_name = None
> -    title = None
> -
> -    def call(self, **kw):
> -        self.w(jinja_render(self.template_name,
> -                            title=self._cw._(self.title),
> -                            data_url=self._cw.datadir_url))
> -
> -
> -def jinja_static_view(template_name, title=None, regid=None):
> -    """Generate a sub-class of JinjaStaticView parametrized with its `template_name` and `title`.
> -
> -    `__regid__` is built by prepending 'sherpa.' to template_name.
> -    """
> -    class_name = template_name.capitalize() + 'View'
> -    if regid is None:
> -        regid = 'sherpa.' + template_name
> -
> -    return type(class_name, (JinjaStaticView,), {'__regid__': regid,
> -                                                 'template_name': template_name,
> -                                                 'title': title})
> -
> -
> -ProjectView = jinja_static_view('project', u'Sherpa un générateur de profils')
> -UtilisationView = jinja_static_view('utilisation', u'Pour commencer')
> -SedaView = jinja_static_view('seda', u'Le SEDA')
> -IndexView = jinja_static_view('index', regid='index')
> -
> -
> -class SherpaReqRewriter(urlrewrite.SimpleReqRewriter):
> -    rules = [
> -        ('/', dict(vid='sherpa.index')),
> -        ('/project', dict(vid='sherpa.project')),
> -        ('/utilisation', dict(vid='sherpa.utilisation')),
> -        ('/seda', dict(vid='sherpa.seda')),
> -    ]
> -
> -
> -def registration_callback(vreg):
> -    from cubicweb.web.views import bookmark
> -
> -    vreg.register_and_replace(IndexView, startup.IndexView)
> -    vreg.register_all(globals().values(), __name__, (IndexView,))
> -    vreg.unregister(bookmark.BookmarksBox)
> diff --git a/views/components.py b/views/components.py
> deleted file mode 100644
> --- a/views/components.py
> +++ /dev/null
> @@ -1,96 +0,0 @@
> -# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> -# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> -#
> -# This program is free software: you can redistribute it and/or modify it under
> -# the terms of the GNU Lesser General Public License as published by the Free
> -# Software Foundation, either version 2.1 of the License, or (at your option)
> -# any later version.
> -#
> -# This program is distributed in the hope that it will be useful, but WITHOUT
> -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> -# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> -# details.
> -#
> -# You should have received a copy of the GNU Lesser General Public License along
> -# with this program. If not, see <http://www.gnu.org/licenses/>.
> -"""cubicweb-sherpa components, originaly copied from the saem_ref cube."""
> -
> -from cubicweb import _, tags
> -from cubicweb.predicates import multi_lines_rset, has_permission, is_instance
> -from cubicweb.web import component
> -
> -
> -def add_etype_link(req, etype, text=u'', klass='icon-plus-circled pull-right',
> -                   **urlparams):
> -    """Return an HTML link to add an entity of type 'etype'."""
> -    vreg = req.vreg
> -    eschema = vreg.schema.eschema(etype)
> -    if eschema.has_perm(req, 'add'):
> -        url = vreg['etypes'].etype_class(etype).cw_create_url(req, **urlparams)
> -        return tags.a(text, href=url, klass=klass,
> -                      title=req.__('New %s' % etype))
> -    return u''
> -
> -
> -def import_etype_link(req, etype, url):
> -    """Return an HTML link to the view that may be used to import an entity of type `etype`.
> -    """
> -    eschema = req.vreg.schema.eschema(etype)
> -    if eschema.has_perm(req, 'add'):
> -        return tags.a(u'', href=url, klass='icon-upload pull-right',
> -                      title=req.__('Import %s' % etype))
> -    return u''
> -
> -
> -class AddEntityComponent(component.CtxComponent):
> -    """Component with 'add' link to be displayed in 'same etype' views usually 'SameETypeListView'.
> -    """
> -    __regid__ = 'sherpa.add_entity'
> -    __select__ = (component.CtxComponent.__select__ & multi_lines_rset() & has_permission('add') &
> -                  is_instance('AuthorityRecord', 'ConceptScheme',
> -                              'SEDAArchiveTransfer', 'SEDAArchiveUnit'))
> -    context = 'navtop'
> -    extra_kwargs = {'SEDAArchiveUnit': {'unit_type': 'unit_content'}}
> -
> -    def render_body(self, w):
> -        etype = self.cw_rset.description[0][0]
> -        w(add_etype_link(self._cw, etype, **self.extra_kwargs.get(etype, {})))
> -
> -
> -class ImportEntityComponent(component.CtxComponent):
> -    """Component with 'import' link to be displayed in 'same etype' views usually
> -    'SameETypeListView'.
> -
> -    Concret class should fill the `import_vid` class attribute and add a proper `is_instance`
> -    selector.
> -    """
> -    __abstract__ = True
> -    __regid__ = 'sherpa.import_entity'
> -    __select__ = component.CtxComponent.__select__ & multi_lines_rset() & has_permission('add')
> -    import_url = None  # URL of the view that may be used to import data
> -    context = 'navtop'
> -
> -    def render_body(self, w):
> -        etype = self.cw_rset.description[0][0]
> -        w(import_etype_link(self._cw, etype, self.import_url))
> -
> -
> -class EACImportComponent(ImportEntityComponent):
> -    """Component with a link to import an authority record from an EAC-CPF file."""
> -    __select__ = (ImportEntityComponent.__select__
> -                  & is_instance('AuthorityRecord'))
> -    _('Import AuthorityRecord')  # generate message used by the import component
> -
> -    @property
> -    def import_url(self):
> -        return self._cw.build_url('view', vid='eac.import')
> -
> -
> -class SKOSImportComponent(ImportEntityComponent):
> -    """Component with a link to import a concept scheme from a SKOS file."""
> -    __select__ = ImportEntityComponent.__select__ & is_instance('ConceptScheme')
> -    _('Import ConceptScheme')  # generate message used by the import component
> -
> -    @property
> -    def import_url(self):
> -        return self._cw.build_url('add/skossource')
> diff --git a/views/management.py b/views/management.py
> deleted file mode 100644
> --- a/views/management.py
> +++ /dev/null
> @@ -1,64 +0,0 @@
> -# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> -# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> -#
> -# This program is free software: you can redistribute it and/or modify it under
> -# the terms of the GNU Lesser General Public License as published by the Free
> -# Software Foundation, either version 2.1 of the License, or (at your option)
> -# any later version.
> -#
> -# This program is distributed in the hope that it will be useful, but WITHOUT
> -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> -# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> -# details.
> -#
> -# You should have received a copy of the GNU Lesser General Public License
> -# along with this program. If not, see <http://www.gnu.org/licenses/>.
> -
> -from logilab.mtconverter import xml_escape
> -
> -from cubicweb.predicates import relation_possible, one_line_rset, non_final_entity
> -from cubicweb.web import action, formwidgets
> -from cubicweb.web.formfields import guess_field
> -from cubicweb.web.views import actions, management
> -
> -from cubes.relationwidget.views import RelationFacetWidget
> -
> -
> -class SherpaSecurityManagementView(management.SecurityManagementView):
> -    """Security view overriden to hide permissions definitions and using a
> -    RelationFacetWidget to edit owner"""
> -    __select__ = (management.SecurityManagementView.__select__ &
> -                  relation_possible('owned_by', action='add'))
> -
> -    def entity_call(self, entity):
> -        w = self.w
> -        w(u'<h1><span class="etype">%s</span> <a href="%s">%s</a></h1>'
> -          % (entity.dc_type().capitalize(),
> -             xml_escape(entity.absolute_url()),
> -             xml_escape(entity.dc_title())))
> -        w('<h2>%s</h2>' % self._cw.__('Manage security'))
> -        msg = self._cw.__('ownerships have been changed')
> -        form = self._cw.vreg['forms'].select(
> -            'base', self._cw, entity=entity,
> -            form_renderer_id='base', submitmsg=msg,
> -            form_buttons=[formwidgets.SubmitButton()],
> -            domid='ownership%s' % entity.eid,
> -            __redirectvid='security',
> -            __redirectpath=entity.rest_path())
> -        field = guess_field(entity.e_schema,
> -                            self._cw.vreg.schema['owned_by'],
> -                            req=self._cw,
> -                            widget=RelationFacetWidget())
> -        field.help = None
> -        form.append_field(field)
> -        form.render(w=w, display_progress_div=False)
> -
> -
> -actions.ManagePermissionsAction.__select__ = (
> -    action.Action.__select__ & one_line_rset() & non_final_entity()
> -    & relation_possible('owned_by', action='add'))
> -
> -
> -def registration_callback(vreg):
> -    vreg.register_all(globals().values(), __name__)
> -    vreg.unregister(management.SecurityManagementView)
> diff --git a/views/templates.py b/views/templates.py
> deleted file mode 100644
> --- a/views/templates.py
> +++ /dev/null
> @@ -1,147 +0,0 @@
> -# -*- coding: utf-8
> -# copyright 2017 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
> -# contact http://www.logilab.fr -- mailto:contact at logilab.fr
> -#
> -# This program is free software: you can redistribute it and/or modify it under
> -# the terms of the GNU Lesser General Public License as published by the Free
> -# Software Foundation, either version 2.1 of the License, or (at your option)
> -# any later version.
> -#
> -# This program is distributed in the hope that it will be useful, but WITHOUT
> -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
> -# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
> -# details.
> -#
> -# You should have received a copy of the GNU Lesser General Public License
> -# along with this program. If not, see <http://www.gnu.org/licenses/>.
> -"""sherpa views/templates"""
> -
> -from logilab.common.decorators import monkeypatch
> -
> -from cubicweb.utils import HTMLHead, UStringIO
> -from cubicweb.web.views import basetemplates
> -
> -from . import jinja_render
> -
> -
> -# Bootstrap configuration.
> -basetemplates.TheMainTemplate.twbs_container_cls = 'container-fluid'
> -
> -
> - at monkeypatch(HTMLHead)
> -def add_onload(self, jscode):
> -    """original `add_onload` implementation use `$(cw)`
> -    but `cw` variable is not available
> -    in francearchive, use `$` instead"""
> -    self.add_post_inline_script(u"""$(function() {
> -  %s
> -});""" % jscode)
> -
> -
> -class SherpaMainTemplate(basetemplates.TheMainTemplate):
> -
> -    def call(self, view):
> -        self.set_request_content_type()
> -        self.write_doctype()
> -        self.template_header(self.content_type, view=view)
> -        context = self.template_context(view)
> -        self.w(jinja_render('maintemplate', **context))
> -
> -    def template_context(self, view):
> -        """Return the main-template's context."""
> -        # left boxes
> -        left_boxes = list(self._cw.vreg['ctxcomponents'].poss_visible_objects(
> -            self._cw, rset=self.cw_rset, view=view, context='left'))
> -        stream = UStringIO()
> -        for box in left_boxes:
> -            box.render(w=stream.write, view=view)
> -        left_boxes_html = stream.getvalue()
> -        # header
> -        stream = UStringIO()
> -        w = stream.write
> -        components = self.get_components(view, context='header-right')
> -        if components:
> -            w(u'<ul class="nav navbar-nav navbar-right">')
> -            for component in components:
> -                w(u'<li>')
> -                component.render(w=w)
> -                w(u'</li>')
> -            w(u'</ul>')
> -        right_header_component = stream.getvalue()
> -        # application message
> -        msgcomp = self._cw.vreg['components'].select_or_none(
> -            'applmessages', self._cw, rset=self.cw_rset)
> -        application_message = msgcomp.render() if msgcomp else u''
> -        # breadcrumbs
> -        stream = UStringIO()
> -        w = stream.write
> -        components = self.get_components(view, context='header-center')
> -        if components:
> -            for component in components:
> -                component.render(w=w)
> -        breadcrumbs = stream.getvalue()
> -        # contextual components
> -        contextual_components = self._cw.view('contentheader', rset=self.cw_rset, view=view)
> -
> -        ctx = self.base_context()
> -        url = self._cw.build_url
> -        ctx.update({
> -            'title': view.page_title(),
> -            'page_content': view.render(),
> -            'breadcrumbs': breadcrumbs,
> -            'application_message': application_message,
> -            'contextual_components': contextual_components,
> -            'right_header_component': right_header_component,
> -            'left_boxes': left_boxes_html,
> -            'side_box': {
> -                'goTo_links': [
> -                    {'url': url('SEDAArchiveTransfer'),
> -                     'label': 'profils SEDA'},
> -                    {'url': url('sedalib'),
> -                     'label': u"unités d'archive"},
> -                    {'url': url('AuthorityRecord'),
> -                     'label': u"notices d'autorité"},
> -                    {'url': url('ConceptScheme'),
> -                     'label': u"vocabulaires"},
> -                ],
> -            },
> -            'footer': {
> -                'resources': [
> -                    {'url': url('shema_seda'),
> -                     'label': u'Schéma du SEDA 2.0'},
> -                    {'url': url('dictionnaire'),
> -                     'label': 'Dictionnaire des balises'},
> -                    {'url': url('documentation_fonctionnelle'),
> -                     'label': 'Documentation fonctionnelle'},
> -                    {'url': url('documentation_technique'),
> -                     'label': 'Documentation technique'},
> -                ],
> -                'navigation_Link': [
> -                    {'url': url('project'),
> -                     'label': u'SHERPA, un générateur de profils'},
> -                    {'url': url('utilisation'),
> -                     'label': "Pour commencer"},
> -                    {'url': url('seda'),
> -                     'label': "Le SEDA"},
> -                ]
> -            },
> -        })
> -        ctx.update(getattr(view, 'template_context', lambda: {})())
> -
> -        return ctx
> -
> -    def base_context(self):
> -        """Return a basic context using standard cubicweb information."""
> -        req = self._cw
> -        return {
> -            'page_id': 'contentmain',
> -            '_': req._,
> -            'user': req.user.login,
> -            'base_url': req.build_url(''),
> -            'data_url': req.datadir_url,
> -            'current_url': req.relative_path(),
> -        }
> -
> -
> -def registration_callback(vreg):
> -    vreg.register_and_replace(SherpaMainTemplate, basetemplates.TheMainTemplate)
> diff --git a/views/templates/index.jinja2 b/views/templates/index.jinja2
> deleted file mode 100644
> --- a/views/templates/index.jinja2
> +++ /dev/null
> @@ -1,47 +0,0 @@
> -<div class="col-md-12" id="accueil">
> -
> -  <section id="presentation">
> -      <h2>Créer un profil</h2>
> -      <div class="titleUnderline">
> -        <span class="underline mr"></span>
> -        <span class="losange"></span>
> -        <span class="underline ml"></span>
> -      </div>
> -
> -
> -      <div class="col-md-10 col-md-offset-1">
> -      <div id="buttons-wrapper">
> -        <a href="/SEDAArchiveTransfer" class="btn btn-default">Profils Seda</a>
> -      </div>
> -
> -        <p>
> -SHERPA est un outil qui permet de créer des profils d'archivage conformes au standard d'échange en mode collaboratif.
> -        </p>
> -      </div>
> -  </section>
> -
> -
> -  <section id="seda">
> -    <h2> Pour commencer </h2>
> -    <div class="titleUnderline">
> -      <span class="underline mr"></span>
> -      <span class="losange"></span>
> -      <span class="underline ml"></span>
> -    </div>
> -
> -    <div id="buttons-wrapper">
> -      <a href="/project" class="btn btn-default">SHERPA un générateur de profils</a>
> -      <a href="/utilisation" class="btn btn-default">Comment utiliser SHERPA ?</a>
> -      <a href="/seda" class="btn btn-default">Le SEDA</a>
> -    </div>
> -
> -    <div class="col-md-12">
> -      <p>
> -      Le projet <span class="emphasis">SHERPA</span> a été conduit par le Service interministériel des Archives de France en 2016 afin de doter le <span class="emphasis">réseau des services publics d’archives</span> d’un outil disponible en ligne et permettant de <span class="emphasis">rédiger des profils d’archivage</span> conformes au <span class="emphasis">Standard</span> d’échange des données pour l’archivage, version 2.0.
> -     <br>
> -     Le projet SHERPA a été réalisé en collaboration avec le projet <a href="http://saem.e-bordeaux.org/">SAEM</a> auquel participent le Conseil départemental de la Gironde, Bordeaux Métropole et la Ville de Bordeaux, dans une optique de mutualisation des moyens. SHERPA a été réalisé par la société LOGILAB. Son code source est librement réutilisable.<br>
> -     Licence : ### LICENCE ###
> -      </p>
> -    </div>
> -  </section>
> -</div>
> diff --git a/views/templates/maintemplate.jinja2 b/views/templates/maintemplate.jinja2
> deleted file mode 100644
> --- a/views/templates/maintemplate.jinja2
> +++ /dev/null
> @@ -1,73 +0,0 @@
> -<body>
> -  <nav class="navbar navbar-default navbar-sherpa" role="banner">
> -    <div class="container-fluid">
> -      <div class="col-md-2 hidden-xs hidden-sm">
> -        <a href="{{ base_url }}"><img src="{{ data_url }}images/logo_SIAF.png" class="logoSIAF" /></a>
> -      </div>
> -      <div class="col-md-7 col-xs-8">
> -        <a href="/">
> -          <div class="logoSHERPA">
> -            <img src="{{ data_url }}images/logo_SHERPA_2.png" class="img-responsive"/>
> -          </div>
> -          <div class="textSHERPA">
> -            <h1>Service Hébergé pour la Rédaction de Profils d'Archivage</h1>
> -          </div>
> -        </a>
> -      </div>
> -      <div class="col-md-3 col-xs-4">
> -        {{ right_header_component }}
> -      </div>
> -    </div>
> -  </nav>
> -  {% if breadcrumbs %}
> -  <nav role="navigation" class="breadcrumbs_wrapper">
> -    <div class="col-md-offset-2">
> -      {{ breadcrumbs }}
> -    </div>
> -  </nav>
> -  {% endif %}
> -  <div id="{{page_id}}" class="container-fluid" role="main">
> -    <aside id="aside-main-left" class="col-md-2 cwjs-aside">
> -      {{ left_boxes }}
> -      <div class="panel panel-default contextFreeBox facet_filterbox" id="facet_filterbox">
> -        <div class="panel-heading">
> -          <div class="panel-title">navigation</div>
> -        </div>
> -        <div class="panel-body">
> -          <ul class="list-unstyled">
> -            {% for page in side_box.goTo_links %}
> -            <li class="facetvalue"><a href='{{ page.url }}'> {{ page.label }}</a></li>
> -            {% endfor %}
> -          </ul>
> -        </div>
> -      </div>
> -    </aside>
> -    <div class="col-md-10 page-content" id="pageContent">
> -      {{ application_message }}
> -      {{ contextual_components }}
> -      {{ page_content }}
> -    </div>
> -  </div>
> -  <div class="container-fluid">
> -    <footer role="contentinfo" id="pagefooter">
> -      <section class="links">
> -        <div id="sherpa-resources">
> -        <h3>Ressources</h3>
> -        {% for resource in footer.resources %}
> -          <a href='{{ resource.url }}'> {{ resource.label }}</a>
> -        {% endfor %}
> -        </div>
> -        <div id="sherpa-navigation">
> -        <h3>Navigation</h3>
> -        {% for page in footer.navigation_Link %}
> -          <a href='{{ page.url }}'> {{ page.label }}</a>
> -        {% endfor %}
> -        </div>
> -      </section>
> -      <div id="copyright">
> -        <span>copyright</span> |
> -        <span><a href="">contact</a></span>
> -      </div>
> -    </footer>
> -  </div>
> -</body>
> diff --git a/views/templates/project.jinja2 b/views/templates/project.jinja2
> deleted file mode 100644
> --- a/views/templates/project.jinja2
> +++ /dev/null
> @@ -1,99 +0,0 @@
> -<h1>{{ title }}</h1>
> -
> -<section id="sherpa-project-page">
> -  <div class="column-wrap">
> -    <div class="col-md-2 vcenter">
> -      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_bordereau.png"/>
> -    </div>
> -    <div class="col-md-9">
> -      <h2>Du bordereau de versement ...</h2>
> -      <p>
> -        Le bordereau de versement est le document qui accompagne toute entrée d’archives publiques dans un service d’archives. Le bordereau contient des informations sur le service producteur et/ou versant, le service d’archives et une description sommaire des archives qui constituent le versement. Le bordereau matérialise le transfert de responsabilité entre le service versant et le service d’archives. C’est donc un document indispensable.
> -      </p>
> -      <p>
> -        Dans le monde numérique, le bordereau de versement peut être dématérialisé, mais il continue d’avoir la même utilité et doit comporter les mêmes informations qu’un bordereau papier. C’est pourquoi le Standard d’échange de données pour l’archivage propose une modélisation des informations qui constituent le bordereau de versement.
> -      </p>
> -    </div>
> -  </div>
> -  <div class="column-wrap">
> -    <div class="col-md-2 vcenter">
> -      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_profil.png"/>
> -    </div>
> -    <div class="col-md-9">
> -      <h2>… au profil d’archivage</h2>
> -      <p>
> -        Toute entrée de documents dans un service d’archives fait l’objet d’une série de contrôles destinés à vérifier la conformité de cette entrée aux attentes du service en matière sanitaire, de conditionnement, etc. Le contrôle du bordereau de versement en fait partie.
> -      </p>
> -      <p>
> -        Dans le monde numérique, le Système d’archivage électronique (SAE) va lui aussi effectuer une série de contrôles, pour la plupart automatisés et pré-paramétrés (format, taille des fichiers, etc.). Il va également réaliser un contrôle du bordereau de versement. Pour évaluer la conformité du bordereau, le SAE doit savoir précisément ce qui est attendu dans ce bordereau et donc disposer d’une matrice de bordereau appelée profil d’archivage. Le profil est, pour un flux donné, la matrice de référence à partir de laquelle le SAE va pouvoir contrôler la conformité des bordereaux de versement de ce flux.
> -      </p>
> -    </div>
> -
> -  </div>
> -  <div class="img-bottom">
> -    <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_general.png"/>
> -  </div>
> -  
> -  <div class="col-md-12">
> -    <h2>Exemple</h2>
> -
> -    <table class="table">
> -        <tbody>
> -            <thead>
> -            <tr>
> -              <th>Profil</th>
> -              <th>Bordereau</th>
> -              <th>Vérification</th>
> -            </tr>
> -          </thead>
> -          <tr>
> -            <td>
> -                <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
> -                <p>J’attends un nom de service versant de façon obligatoire</p>
> -            </td>
> -            <td>
> -              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
> -              <p>Le service versant de mon versement est « Direction XXX »</p>
> -            </td>
> -            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
> -          </tr>
> -          <tr>
> -            <td>
> -              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
> -              <p>J’attends 35 fichiers dans le versement</p>
> -            </td>
> -            <td>
> -              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
> -              <p>Mon versement contient 40 fichiers</p>
> -            </td>
> -            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_invalide.png"/></td>
> -          </tr>
> -          <tr>
> -            <td>
> -              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
> -              <p>J’attends au niveau Dossier le terme d’indexation YYY</p>
> -            </td>
> -            <td>
> -              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
> -              <p>Mon versement contient au niveau Dossier le terme d’indexation YYY</p>
> -            </td>
> -            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
> -          </tr>
> -        </tbody>
> -      </table>
> -
> -  </div>
> -
> -  <div class="col-md-12">
> -    <h2>Un générateur de profils</h2>
> -    <p>
> -    Les bordereaux de versement conformes au standard d’échange de données pour l’archivage sont des fichiers de format XML. Les profils d’archivage utilisent pour leur part des langages comme XSD ou RelaxNG qui permettent de définir la structure et le type de contenu d’un document XML.
> -    </p>
> -    <p>
> -      SHERPA propose une interface simple et ergonomique pour rédiger des profils d’archivage et les exporter en RelaxNG. SHERPA permet également d’exporter une documentation associée au profil, lisible par un humain.
> -    </p>
> -  </div>
> -
> -
> -
> -</section>
> diff --git a/views/templates/seda.jinja2 b/views/templates/seda.jinja2
> deleted file mode 100644
> --- a/views/templates/seda.jinja2
> +++ /dev/null
> @@ -1,39 +0,0 @@
> -<h1>{{ title }}</h1>
> -
> -<section id="sherpa-seda-page">
> -
> -    <div class="col-md-3">
> -      <img class="img-responsive seda-img" src="{{ data_url }}images/seda.png"/>
> -    </div>
> -
> -    <div class="col-md-9">
> -      <p>
> -        Si les processus d’archivage et les documents qui leur sont associés (bordereaux) demeurent entièrement valables dans le monde numérique, celui-ci exige cependant une formalisation et une standardisation beaucoup plus fortes de ces processus et documents associés afin de pouvoir aller vers davantage d’automatisation.
> -        Le standard d’échange de données pour l’archivage permet de modéliser les transactions d’un processus d’archivage (transfert, communication, élimination, modification et restitution) entre différents acteurs (service producteur, service versant, service d’archives et demandeur d’archives) . Il précise les types, l’ordre et la forme des messages échangés. Il définit d’autre part les métadonnées à utiliser pour décrire, gérer et pérenniser l’information.
> -
> -        Plusieurs versions du standard ont été successivement publiées en mars 2006 (version 0.1), janvier 2010 (version 0.2), septembre 2012 (version 1.0) et décembre 2015 (version 2.0 conforme à la norme MEDONA).
> -      </p>
> -
> -      <p>
> -        Le standard est une déclinaison technique des pratiques archivistiques utilisées dans le monde papier. Les principes du SEDA reprennent donc largement les concepts métier tels que l’usage des bordereaux (versement, élimination), l’application du contrôle scientifique et technique (transaction de demande d’autorisation), la définition des acteurs ou l’apposition de règles de gestion (sorts finaux et communicabilité).
> -      </p>
> -    </div>
> -    <div class="col-md-12">
> -      <h2>Les agents</h2>
> -
> -      <p>
> -        Le SEDA permet d’associer aux transactions des Agents, qui sont des personnes ou des collectivités (concepts inspirés de la norme ISAAR-CPF) afin de décrire les archives échangées ou de spécifier des informations de gestion les concernant. Le modèle de métadonnées utilisé pour décrire ces agents est identique qu’il s’agisse d’identifier les acteurs de l’échange ou d’indiquer la provenance d’un document.
> -        Un agent peut être utilisé plusieurs fois dans différentes transactions et peut également avoir plusieurs rôles attribués dans les messages du SEDA.
> -
> -        C’est pourquoi SHERPA propose de gérer un seul référentiel « Agents » dont les notices peuvent être utilisées dans tous les profils d’archivage rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir une seule liste de référence pour l’ensemble de son corpus de profils.
> -    </p>
> -
> -    <h2>Les vocabulaires </h2>
> -    <p>
> -      Le SEDA permet d’ajouter des termes d’indexation à tous les niveaux de description du plan de classement. Il s’inspire en la matière des pratiques d’indexation telles qu’elles sont recommandées par l’ EAD. Il est donc nécessaire de gérer des listes de vocabulaires d’indexation.
> -      D’autres listes de valeurs contrôlées sont également utilisées dans le SEDA, notamment pour échanger les métadonnées techniques (telles que les référentiels de format, d’encodage…), les métadonnées descriptives (telles que les niveaux de description, les langues…) et les métadonnées de gestion (telles que les sorts finaux, les délais de communicabilité…).
> -
> -      C’est pourquoi SHERPA propose de gérer un seul référentiel « Vocabulaires » dont les références et les valeurs peuvent être utilisées dans l’ensemble des profils rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir un ensemble de listes de références unique pour l’ensemble du corpus de profils.
> -    </p>
> -    </div>
> -</section>
> diff --git a/views/templates/utilisation.jinja2 b/views/templates/utilisation.jinja2
> deleted file mode 100644
> --- a/views/templates/utilisation.jinja2
> +++ /dev/null
> @@ -1,60 +0,0 @@
> -<h1>{{ title }}</h1>
> -<section id="utilisation">
> -  <div id="utilisationWrapper">
> -    <div class="utilisation col-xs-12">
> -      <div>
> -        <h2>Formulaire complet <span class="font-openSans">&</span> formulaire simplifié</h2>
> -        <p>
> -          SHERPA est basé sur la version 2.0 du Standard d’échange de données pour l’archivage.
> -        </p>
> -          <div class="form">
> -            <h4><span class="icon-right-dir"></span>Formulaire complet</h4>
> -            <p>
> -              Le formulaire complet propose l’exhaustivité des métadonnées du SEDA 2.0 mais ne permet pas d’exporter le profil créé dans les anciennes versions du SEDA, moins riches en métadonnées.
> -            </p>
> -          </div>
> -
> -          <div class="form">
> -            <h4><span class="icon-right-dir"></span>Formulaire simplifié</h4>
> -            <p>
> -              Une version simplifiée de l’outil a également été développée afin d’une part de faciliter sa prise en main  et d’autre part d’exporter des profils simples dans toutes les versions du Standard (0.2, 1.0 et 2.0). Ces profils simples sont nécessairement moins riches en métadonnées que les profils complets conformes au SEDA 2.0.
> -            </p>
> -          </div>
> -      </div>
> -    </div>
> -
> -    <div class="utilisation col-xs-12">
> -
> -      <div>
> -        <h2>Travail modulaire</h2>
> -        <p>
> -          Sherpa repose sur une approche modulaire. Il est donc possible de décrire des unités d'archives à n'importe quel niveau et de les agencer ensuite pour créer un ou plusieurs profils.
> -        </p>
> -      </div>
> -  </div>
> -
> -    <div class="utilisation col-xs-12">
> -
> -      <div>
> -        <h2>Travail en référentiel</h2>
> -        <p>
> -          Comme indiqué ci-dessus, le SEDA 2.0 fonctionne, pour un certain nombre de valeurs, avec des référentiels externes qu’il convient donc de définir à l’extérieur du profil. SHERPA met en œuvre ce principe en proposant des zones permettant d’alimenter et de mettre à jour les agents et les vocabulaires utilisés dans les échanges.
> -          Le rédacteur peut gérer des listes de valeurs contrôlées référencées dans les bordereaux de transfert ainsi que des notices d’agents employées pour identifier les acteurs. Ces deux types de ressources centralisées peuvent être utilisés dans l’ensemble du corpus de profils.
> -        </p>
> -      </div>
> -  </div>
> -
> -  <div class="utilisation col-xs-12">
> -
> -    <div>
> -      <h2>Travail collaboratif</h2>
> -      <p>
> -        SHERPA est une application web et est proposé en tant que service hébergé par le Service interministériel des Archives de France. Les modules référentiels d’Agents et de Vocabulaires sont communs à toute la communauté d’utilisateurs, de même que le corpus de profils et d'unités d'archives.
> -
> -        Un système d’habilitation simplifié permet à tous les utilisateurs connectés de consulter le travail des autres utilisateurs. Le rédacteur d’un profil peut le modifier à tout moment et peut étendre les droits de modifications à d’autres utilisateurs s’il le souhaite.
> -
> -        L’ensemble des contenus est accessible en lecture à la communauté d’utilisateurs de SHERPA. Un utilisateur peut via la page gestion des permissions, donner des droits d’écriture sur les profils et les notices d’autorité qu’il a créés à un autre utilisateur. Sans avoir les droits d’écriture, il est néanmoins possible de copier un profil existant afin de le modifier.
> -      </p>
> -    </div>
> -  </div>
> -</section>
>

-- 
Sylvain Thénault, LOGILAB, Paris (01.45.32.03.12) - Toulouse (05.62.17.16.42)
Formations Python, Debian, Méth. Agiles: http://www.logilab.fr/formations
Développement logiciel sur mesure:       http://www.logilab.fr/services
CubicWeb, the semantic web framework:    http://www.cubicweb.org



More information about the saem-devel mailing list