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 { ...@@ -34,7 +34,7 @@ export default {
return converter.makeHtml(this.contenu) return converter.makeHtml(this.contenu)
}, },
actionContenu: function (action) { actionContenu: function (action) {
this.$emit("actionContenu", {action: action, contenu: this.contenuClique}) this.$emit("actionContenu", {action: action, contenu: this.contenuClique, texte: this.contenu})
}, },
revenirArriere: function () { revenirArriere: function () {
this.$emit("retour_arriere", {panierChoisi: this.contenuCliqueProvenance !== 'banque'}) this.$emit("retour_arriere", {panierChoisi: this.contenuCliqueProvenance !== 'banque'})
......
...@@ -7,8 +7,8 @@ ...@@ -7,8 +7,8 @@
</div> </div>
<div class="markdown"> <div class="markdown">
<br> <br>
<button id="validerModif" v-on:click="validerUneModif">modifier </button> <button id="validerModif" v-on:click="action('valider')">modifier </button>
<button> revenir en arrière</button> <button v-on:click="action('arriere')"> revenir en arrière</button>
</div> </div>
...@@ -16,32 +16,31 @@ ...@@ -16,32 +16,31 @@
</template> </template>
<script> <script>
import Service from "@/service/Service";
export default { export default {
name: "Modifier_Contenu", name: "Modifier_Contenu",
props: ['contenuClique', 'auteur', 'contenuCliqueProvenance'], props: ['texteDuContenu', 'auteur', 'contenuCliqueProvenance'],
data: function () { data: function () {
return { return {
contenu: '' contenu: ''
} }
}, },
methods: { 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) // Modification du contenu en cours (au niveau de l'intérieur du fichier)
} }
}, },
watch: { watch: {
contenuClique: function () { texteDuContenu: function () {
let that = this this.contenu = this.texteDuContenu
Service.recupererTexteContenu(JSON.stringify(this.contenuClique._id)).then(
function (response) {
that.contenu = response.data
// alert(response.data)
}
)
} }
}, },
......
...@@ -54,11 +54,11 @@ ...@@ -54,11 +54,11 @@
<h1>I am</h1> popover <b>component</b> content! <h1>I am</h1> popover <b>component</b> content!
</b-popover>--> </b-popover>-->
<td :id="JSON.stringify(item._id)" v-on:click="chargerContenu(item, item.provenance)">{{item._id}}</td> <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"> <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="whatYouGonnaDoNow(item.versionEnCours.commit)"></p> <p id="beautiful" v-html="texteDuContenu"></p>
</b-popover> </b-popover>
<td>{{item.auteur}}</td> <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 v-else>{{ item.versionEnCours.numero }}</td>
<td>The table body</td> <td>The table body</td>
<td class="prout">with two columns</td> <td class="prout">with two columns</td>
...@@ -97,7 +97,7 @@ ...@@ -97,7 +97,7 @@
</div> </div>
</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"/> <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 v-show="panierChoisi && !modeConsultation" class="circle" v-on:click="ajouterContenu" v-bind:style="{'margin-left': '95%'}">
</div> </div>
...@@ -143,6 +143,7 @@ export default { ...@@ -143,6 +143,7 @@ export default {
oui: 0, oui: 0,
checkes: [], checkes: [],
nouveauContenu: false, nouveauContenu: false,
texteDuContenu: '',
chocolat: '<h1 id="hellomarkdown">hello, markdown!</h1>', 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", 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: "" imgPoubelle: ""
...@@ -168,12 +169,6 @@ export default { ...@@ -168,12 +169,6 @@ export default {
$('#ensemble').draggable() $('#ensemble').draggable()
}, },
methods: { methods: {
whatYouGonnaDoNow: function (contenu) {
let showdown = require('showdown'),
converter = new showdown.Converter();
return converter.makeHtml(contenu)
/* console.log($(this).children().text())*/
},
contenusDuPanier: function(){ contenusDuPanier: function(){
let that = this let that = this
// Dès que l'auteur est connu, on charge tous ses contenus // Dès que l'auteur est connu, on charge tous ses contenus
...@@ -283,21 +278,7 @@ export default { ...@@ -283,21 +278,7 @@ export default {
break break
case "modifier": case "modifier":
this.modeModification = true this.modeModification = true
if (this.contenuCliqueProvenance !== 'en-cours'){ this.texteDuContenu = event.texte
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
break break
case "supprimer": case "supprimer":
this.panierChoisi = true this.panierChoisi = true
...@@ -363,6 +344,54 @@ export default { ...@@ -363,6 +344,54 @@ export default {
else { else {
this.checkes.push([idContenu, provenance]) 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 { ...@@ -96,10 +96,13 @@ export default {
gererMajTiers(data) { gererMajTiers(data) {
return axios.patch(urlBase + "gererMajTiers", data) return axios.patch(urlBase + "gererMajTiers", data)
}, },
modifierContenuBasique(data) { changerTexte(data, id) {
return axios.patch(urlBase + "modifierContenuBasique", data) return axios.patch(urlBase + "changerTexte/" + id, data)
}, },
recupererTexteContenu(idContenu){ recupererTexteContenu(idContenu){
return axios.get(urlBase + "getTexteContenu/" + 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