đź“• Node [[mediawiki]]
↳ 📓 Resource @communecter/mediawiki
đź“„ mediawiki.md by @communecter

Mediawiki & Communecter

Introduction

Cette partie du module interop, cherche en cas de mediawiki existant Ă  le connecter avec communecter et de permettre via un bouton a crĂ©er des Ă©lĂ©ments du type de la page du wiki, ou en cas d’Ă©lĂ©ment prĂ©sent de fournir le lien, enfin mais nĂ©cessitant un rĂ©glage sur le wiki existant de marquer le wiki avec le liens de la page co.

Initialisation du mediawiki

Dans le sub-menu-left d’un Ă©lĂ©ment on clic sur @Mediawiki .

dans MediaWikiController.php beforeAction() instancie APIMediawiki (model de relations avec le wiki) qui est enfant de DB (model de relations avec la bdd)

interop/MediaWiki/index

beforeAction() du controller instancie APIMediawiki (model de relations avec le wiki) qui est enfant de DB (model de relations avec la bdd)

le controlleur rend une vue partiel sauf pour edit qui renvoi une string.

L’action par default du controller actionIndex()

un formulaire s’ouvre lors de la premiĂ©re connection ou l’url du wiki et son nom dans communecter son rentrĂ© par l’utilisateur. $this->renderPartial("interop.views.create.index"); a la validation du form direction actionChooseCat()

Si wiki deja connectĂ© renvoi vers l’index via: $this->renderPartial("interop.views.default.indexMediaWiki");

L’action actionChooseCategory()

Insére les données du formulaire (url et name) puis ouvre $this->renderPartial("interop.views.create.chooseCat");

un formulaire prĂ©remplie par les donnĂ©es de l’api du wiki sur les catĂ©gories filtrer par regex afin de coler aux catĂ©gorie du futur menu soit (acteurs, ressource, projet) (les regex son en dur dans le code faire un tableau de comparaison afin d’ajouter ou enlever des mots de trie peu Ă©tre une bonne contribution en cas de contributeur volontaire ;o) a la validation du form direction actionInsertCat()

L’action actionInsertCat()

Insére les données du formulaire le wiki en db vaut désormais:

 "_id" : ObjectId("idmongo"),
    "name" : "name du wiki entré par l'user",
    "parent" : {
        "mongo id du parent" : {
            "type" : "type parent",
            "name" : "name parent"
        }
    },
    "url" : "url entré par l'utilisateur + '/api.php",
    "params" : {
        "actors" : [ 
            "categorie choisit par l'user",
            ...
        ],
        "classifieds" : [ 
            "categorie choisit par l'user",
            ...
        ],
        "projects" : [ 
            "categorie choisit par l'user",
            ...
        ]
    },
    "logo" : ""
}

renvoi vers la vue index return $this->renderPartial("interop.views.default.indexMediaWiki");

L’action actionMenuLeft()

Vas chercher les données pour le menuleft des pages du wiki en fonction du button-catégorie(acteurs,ressources,projet) clicker ou du texte de la search bar. puis les rend dans la vue return $this->renderPartial("interop.views.menus.pages");

L’action actionPage()

Vas chercher les données pour la page du wiki en fonction du nom de la page. puis les rend dans la vue return $this->renderPartial("interop.views.page.index");

L’action actionEdit()

Ici via le modĂ©le ApiMediawiki.php on marque la page du wiki avec un lien communecter (!! une propriĂ©tĂ©es est a crĂ©er sur le wiki distant |pageCo= voir avec l’administrateur du wiki.) renvoie une string message sur le status de l’edition.

L’action actionDoc()

renvoi vers cette page

Relations wiki et Intégration dans communecter

Dans A propos il ya trois boutons qui font les liens: Un bouton Page du Wiki qui redirige vers la page source du wiki. Un bouton Site web qui redirige vers le site de l’Ă©lement du wiki.

Le dernier bouton peu avoir deux valeurs : CrĂ©er dans communecter qui ouvre un formulaire prĂ©remplie et Ă©ditable afin de crĂ©er un Ă©lĂ©ment communecter. Page Communecter qui redirige vers la page communecter en relation avec l’Ă©lĂ©ment du wiki.

đź“„ mediawiki.md by @communecter

Mediawiki & Communecter

Introduction

Cette partie du module interop, cherche en cas de mediawiki existant Ă  le connecter avec communecter et de permettre via un bouton a crĂ©er des Ă©lĂ©ments du type de la page du wiki, ou en cas d’Ă©lĂ©ment prĂ©sent de fournir le lien.

Initialisation du mediawiki

Dans le menu d’un Ă©lĂ©ment on clic sur @Mediawiki en dessous de "Points d’intĂ©rĂŞt".

Arrivé dans interop/MediaWiki/ beforeAction() instancie APIMediawiki (model de relations avec le wiki) qui est enfant de DB (model de relations avec la bdd) cherche en base de données l’existence ou non de ce wiki, si non cela crée dans collection "mediawiki" un wiki vide de la forme:

public function newIn($id, $name, $type)
{
$baseDataDB = [
"name" => $name,
"parent" => [
"id" => $id,
"type" => $type
],
"url" => "",
"params" => "none",
"logo" => ""
];
PHDB::insert("mediawiki", $baseDataDB);
}

L’action par default du controller ActionIndex() elle rĂ©cupère les infos en base de donnĂ©es via le model et envoie les bonnes donnĂ©es dans la vue

{
    "_id" : ObjectId(""),
    "name" : nomduwiki,
    "parent" : {
        "id" : ,
        "type" : 
    },
    "url" : "<urlEnregistré>/api.php",
    "params" : {
        "ressources" : {
            "get" : [ 
                "[[Cat%C3%A9gorie:<catTrouvé>]]", 
...
            ]
        },
        "acteurs" : {
            "get" : [ 
                 "[[Cat%C3%A9gorie:<catTrouvé>]]", 
...
            ]
        },
        "projets" : {
            "get" : [ 
               "[[Cat%C3%A9gorie:<catTrouvé>]]", 
...
        }
    },
    "logo" : ""
}

Utilisation navigation

Sur interop.views.default.indexMediaWiki les boutons Acteurs, Projets, Emplois s’affiche en cas d’existence. Clic direction interop/mediawiki/menuleft qui appel la mĂ©thode **menu(**catĂ©gorieChoisie) de l’instance APIMediaWiki. Qui va chercher la listes des pages liĂ©es crĂ©er la data pour la vue appelĂ© par le controller qui affiche les rĂ©sultats dans un menu dĂ©roulant triĂ© par ordre alphabĂ©tique en accordĂ©on si rĂ©sultat est supĂ©rieur Ă  30 unitĂ©s: interop.views.menus.pages.

Au clic sur le nom du page direction interop/mediawiki/page qui appel la mĂ©thode page(nomPage) de l’instance APIMediaWiki qui scan les propriĂ©tĂ©s disponibles de la page puis rĂ©cupère les donnĂ©es. Ces donnĂ©es sont triĂ© et converties afin de standardiser pour la vue et les inputs prĂ©remplies de formulaires de crĂ©ation d’Ă©lĂ©ment via convertWikiMediaToPh(['data' => $dataRĂ©cupĂ©rer, $nomCatĂ©gorie, $nomDuWiki) dans le module citizenToolKit/model/Convert.php

Ces données sont envoyées dans la vue interop.views.page.index qui affiche par défault un A propos de la page du wiki et le menu left contient en fonction des données des boutons proposant de lister Communautées(sous divisé en communauté et utilisateur), Défis, Ressources en rapport avec la page du wiki.

Tout clic sur une entités réprésentant une autre page du wiki fait le méme chemin a partir de interop/mediawiki/page du controlleur interop/MediaWiki.

Relations wiki et Intégration dans communecter

Dans A propos il ya trois boutons qui font les liens: Un bouton Page du Wiki qui redirige vers la page source du wiki. Un bouton Site web qui redirige vers le site de l’Ă©lement du wiki.

Le dernier bouton peu avoir deux valeurs : CrĂ©er dans communecter qui ouvre un formulaire prĂ©remplie et Ă©ditable afin de crĂ©er un Ă©lĂ©ment communecter. Page Communecter qui redirige vers la page communecter en relation avec l’Ă©lĂ©ment du wiki.

Loading pushes...

Rendering context...