Commit 8c990e28 authored by Jérémie Passerat's avatar Jérémie Passerat

Création et maj en cours ok

parent 134126a8
......@@ -34,7 +34,7 @@ export default {
return converter.makeHtml(this.contenu)
},
actionContenu: function (action) {
this.$emit("actionContenu", {action: action, contenu: this.contenuClique})
this.$emit("actionContenu", {action: action, contenu: this.contenuClique, texte: this.contenu})
},
revenirArriere: function () {
this.$emit("retour_arriere", {panierChoisi: this.contenuCliqueProvenance !== 'banque'})
......
......@@ -7,8 +7,8 @@
</div>
<div class="markdown">
<br>
<button id="validerModif" v-on:click="validerUneModif">modifier </button>
<button> revenir en arrière</button>
<button id="validerModif" v-on:click="action('valider')">modifier </button>
<button v-on:click="action('arriere')"> revenir en arrière</button>
</div>
......@@ -16,32 +16,31 @@
</template>
<script>
import Service from "@/service/Service";
export default {
name: "Modifier_Contenu",
props: ['contenuClique', 'auteur', 'contenuCliqueProvenance'],
props: ['texteDuContenu', 'auteur', 'contenuCliqueProvenance'],
data: function () {
return {
contenu: ''
}
},
methods: {
validerUneModif: function (message) {
action: function (actionChoisie) {
if (actionChoisie === 'valider'){
this.$emit("choixModif", {action: actionChoisie, nouveauTexte: this.contenu})
} else {
this.$emit("choixModif", {action: actionChoisie})
}
// Modification du contenu en cours (au niveau de l'intérieur du fichier)
}
},
watch: {
contenuClique: function () {
let that = this
Service.recupererTexteContenu(JSON.stringify(this.contenuClique._id)).then(
function (response) {
that.contenu = response.data
// alert(response.data)
}
)
texteDuContenu: function () {
this.contenu = this.texteDuContenu
}
},
......
......@@ -54,11 +54,11 @@
<h1>I am</h1> popover <b>component</b> content!
</b-popover>-->
<td :id="JSON.stringify(item._id)" v-on:click="chargerContenu(item, item.provenance)">{{item._id}}</td>
<b-popover class="non" v-on:show="chocolat === item._id" :target="JSON.stringify(item._id)" triggers="hover" placement="bottom">
<p id="beautiful" v-html="whatYouGonnaDoNow(item.versionEnCours.commit)"></p>
<b-popover class="non" v-on:show="rechercherTexte(item._id, item.provenance)" :target="JSON.stringify(item._id)" triggers="hover" placement="bottom">
<p id="beautiful" v-html="texteDuContenu"></p>
</b-popover>
<td>{{item.auteur}}</td>
<td v-if="item.provenance === 'tiers'">{{ item.version }}</td>
<td v-if="item.provenance === 'en-cours'">{{ item.version }}</td>
<td v-else>{{ item.versionEnCours.numero }}</td>
<td>The table body</td>
<td class="prout">with two columns</td>
......@@ -97,7 +97,7 @@
</div>
</div>
<Consulter_Contenu v-bind:auteur="auteur" @actionContenu="actionContenu" @retour_arriere="retourArriere" v-bind:contenuClique = "contenuClique" v-bind:contenuCliqueProvenance = "contenuCliqueProvenance" v-show="modeConsultation && !modeModification"/>
<Modifier_Contenu v-bind:auteur="auteur" v-bind:contenuClique = "contenuClique" v-bind:contenuCliqueProvenance = "contenuCliqueProvenance" v-show="!modeConsultation && modeModification"/>
<Modifier_Contenu v-bind:auteur="auteur" v-bind:texteDuContenu = "texteDuContenu" v-bind:contenuCliqueProvenance = "contenuCliqueProvenance" v-show="!modeConsultation && modeModification" @choixModif="choixModif"/>
<div v-show="panierChoisi && !modeConsultation" class="circle" v-on:click="ajouterContenu" v-bind:style="{'margin-left': '95%'}">
</div>
......@@ -143,6 +143,7 @@ export default {
oui: 0,
checkes: [],
nouveauContenu: false,
texteDuContenu: '',
chocolat: '<h1 id="hellomarkdown">hello, markdown!</h1>',
imgEtoile: "https://previews.123rf.com/images/ylivdesign/ylivdesign1612/ylivdesign161208906/67933171-ic%C3%B4ne-%C3%A9toile-%C3%A0-cinq-branches-jaunes-illustration-de-dessin-anim%C3%A9-d-ic%C3%B4ne-de-vecteur-%C3%A9toile-jaune-%C3%A0-cinq-branches-.jpg",
imgPoubelle: ""
......@@ -168,12 +169,6 @@ export default {
$('#ensemble').draggable()
},
methods: {
whatYouGonnaDoNow: function (contenu) {
let showdown = require('showdown'),
converter = new showdown.Converter();
return converter.makeHtml(contenu)
/* console.log($(this).children().text())*/
},
contenusDuPanier: function(){
let that = this
// Dès que l'auteur est connu, on charge tous ses contenus
......@@ -283,21 +278,7 @@ export default {
break
case "modifier":
this.modeModification = true
if (this.contenuCliqueProvenance !== 'en-cours'){
let data = {auteur: this.auteur, id_contenu: JSON.stringify(event.contenu._id), version: event.contenu.versionEnCours["numero"]}
// let that = this
Service.creerEnCours(data).then(
function (response) {
alert("Je suis l'id du contenu en cours :" + response.data)
}
)
}
else {
alert("Je suis l'id du contenu en cours :" + event.contenu._id)
}
// Il faudrait que j'arrive à récupérer l'id du contenu en cours (soit qui vient juste d'être créé, soit déja existant
this.texteDuContenu = event.texte
break
case "supprimer":
this.panierChoisi = true
......@@ -363,6 +344,54 @@ export default {
else {
this.checkes.push([idContenu, provenance])
}
},
rechercherTexte: function (id, provenance) {
let that = this
if(provenance === 'en-cours'){
Service.recupererTexteContenuEnCours(JSON.stringify(id)).then(
function (response) {
let showdown = require('showdown'),
converter = new showdown.Converter()
that.texteDuContenu = converter.makeHtml(response.data)
}
)
}
else {
Service.recupererTexteContenu(JSON.stringify(id)).then(
function (response) {
let showdown = require('showdown'),
converter = new showdown.Converter()
that.texteDuContenu = converter.makeHtml(response.data)
}
)
}
},
choixModif: function (event) {
this.modeModification = false
this.panierChoisi = true
let data = {nouveau_texte: event.nouveauTexte}
if(event.action === "valider"){
alert(event.nouveauTexte)
if (this.contenuCliqueProvenance !== 'en-cours'){
let dataDeux = {auteur: this.auteur, id_contenu: JSON.stringify(this.contenuClique._id), version: this.contenuClique.versionEnCours["numero"]}
let that = this
Service.creerEnCours(dataDeux).then(function (reponse) {
that.contenusDuPanier()
alert ("reponse " + reponse.data)
Service.changerTexte(data, reponse.data)
})
}
else {
Service.changerTexte(data, JSON.stringify(this.contenuClique._id))
}
}
}
}
}
......
......@@ -96,10 +96,13 @@ export default {
gererMajTiers(data) {
return axios.patch(urlBase + "gererMajTiers", data)
},
modifierContenuBasique(data) {
return axios.patch(urlBase + "modifierContenuBasique", data)
changerTexte(data, id) {
return axios.patch(urlBase + "changerTexte/" + id, data)
},
recupererTexteContenu(idContenu){
return axios.get(urlBase + "getTexteContenu/" + idContenu)
},
recupererTexteContenuEnCours(idContenu){
return axios.get(urlBase + "getTexteContenuEnCours/" + idContenu)
}
}
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment