concernements.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540
  1. import { defineStore } from 'pinia'
  2. // import REST from '@api/rest-axios'
  3. // import JSONAPI from '@api/json-axios'
  4. import { print } from 'graphql/language/printer'
  5. import gql from 'graphql-tag'
  6. // import REST from '@api/rest-axios'
  7. import GQL from '@api/graphql-axios'
  8. // import JSONAPI from '@api/json-axios'
  9. import ConcernementFields from '@api/gql/concernement.fragment.gql'
  10. // import EntityFields from '@api/gql/entitydef.fragment.gql'
  11. export const ConcernementsStore = defineStore({
  12. id: 'concernements',
  13. state: () => ({
  14. map_mode: null,
  15. concernements_loading_nb: 0,
  16. concernements: [],
  17. concernementsByID: {},
  18. allEntitesById: {},
  19. allBesoinsById: {},
  20. allSuperpositions: [],
  21. allSuperpositions_bycids: {},
  22. allSuperpositions_clustered: [],
  23. allMapItems_byid: {},
  24. allProximites: [],
  25. opened_concernement: false,
  26. opened_entite_id: null,
  27. opened_recit: false,
  28. recit_plyr_player: null,
  29. ct_concernement: {},
  30. ct_entite: {},
  31. ct_cercle_politique: {},
  32. p_groupes_interets: {},
  33. p_reception_et_traitement: {},
  34. p_mise_en_oeuvre_decision: {},
  35. p_reception_application_decision: {},
  36. concernements_loaded: false,
  37. concernements_are_loading: false,
  38. concernement_active_revision: null,
  39. detailsZoomValue: 1,
  40. }),
  41. getters: {
  42. },
  43. actions: {
  44. setMapMode(mode) {
  45. console.log(`set map_mode ${mode}`);
  46. // mode can be : terraindevie, proximite, superposition, puissancedagir, action, doleancer
  47. this.map_mode = mode;
  48. },
  49. loadConcernements () {
  50. console.log('concernements store loadConcernements');
  51. this.concernements_are_loading = true;
  52. return new Promise((resolve, reject) => {
  53. const ast = gql`{
  54. allconcernements {
  55. ...ConcernementFields
  56. }
  57. }
  58. ${ConcernementFields}
  59. `
  60. // console.log('ast', ast);
  61. GQL.post('', { query: print(ast) })
  62. .then(({ data : { data : { allconcernements } } }) => {
  63. console.log('loadconcernements loaded', allconcernements)
  64. this.concernements = [];
  65. this.parseConcernements(allconcernements, true)
  66. this.concernements_loaded = true;
  67. this.concernements_loading_nb ++;
  68. this.concernements_are_loading = false;
  69. resolve();
  70. })
  71. .catch(error => {
  72. console.warn('Issue with loadConcernements', error)
  73. this.concernements_are_loading = false;
  74. Promise.reject(error)
  75. })
  76. })
  77. },
  78. parseConcernements(allconcernements, init) {
  79. console.log('parse concernements');
  80. let temp_allSuperpositions = [];
  81. allconcernements.forEach((concernement) => {
  82. // console.log(`parsing concernement ${concernement.id}`);
  83. concernement.visible = true;
  84. concernement.entites_byid = {};
  85. concernement.entitesagissantes_byid = {};
  86. concernement.has_proximites = false;
  87. concernement.has_superpositions = false;
  88. concernement.has_agissantes = false;
  89. // var entites_temp = concernement.entites; // record a temp entites liste
  90. // concernement.entites = []; // erase the concernement.entite array as we want to keep only visible entites
  91. concernement.entites.forEach(entite => {
  92. // console.log(`parsing entite ${entite.id}`);
  93. if (entite.entite) { // entite.entite may be null because of workflow confidentiality
  94. if (!concernement.entites_byid[entite.entite.id]) {
  95. concernement.entites_byid[entite.entite.id] = entite;
  96. }
  97. // record entite agissante
  98. if (entite.entite.agissante) {
  99. if (!concernement.entitesagissantes_byid[entite.entite.id]) {
  100. concernement.entitesagissantes_byid[entite.entite.id] = entite;
  101. }
  102. concernement.has_agissantes = true;
  103. }
  104. // record a flat list of all entités of all concernement for map-popup
  105. if (!this.allEntitesById[entite.entite.id]) {
  106. this.allEntitesById[entite.entite.id] = entite;
  107. this.allEntitesById[entite.entite.id].cid = concernement.id;
  108. }
  109. // concernement.entites.push(entite); // fill the entites array with visible entite only
  110. // PROXIMITES
  111. if (entite.entite.proximite.length) {
  112. // console.log("proximite", entite.entite.proximite);
  113. concernement.has_proximites = true;
  114. }
  115. // SUPERPOSITIONS
  116. if (entite.entite.superposition.length) {
  117. // create properties for later
  118. if (init) {
  119. concernement.superpositions = {};
  120. concernement.superposition_constraints_id = {};
  121. concernement.all_superposed_concernements_id = [];
  122. concernement.superposed_mapitem_id_by_mapitem_id = {};
  123. }
  124. entite.entite.superposition.forEach(entite_superpose => {
  125. // console.log(`superposition eid:${entite.entite.id}, teid:${entite_superpose.id}`);
  126. let already_recorded = false;
  127. // loop through all already recorded superposition to complete the array instead of create duplicates
  128. // TODO check if target cid and eid are accessible before recording the superposition
  129. // check if half of the superpositions is already recorded, if yes complete it (add the missing concernement id)
  130. for(let superposition of temp_allSuperpositions) {
  131. for(let superposition_item of superposition) {
  132. if (superposition_item.eid === entite.entite.id && !superposition_item.cid) {
  133. // console.log(`already_recorded, eid:${entite.entite.id}, teid:${entite_superpose.id}`, entite.entite.title);
  134. already_recorded = true;
  135. superposition_item.cid = concernement.id;
  136. break;
  137. }
  138. }
  139. if (already_recorded) {
  140. break;
  141. }
  142. }
  143. // if not already recorded, add it to the array. It is incomplete has it's missing one concernement id wich will be filled in next loops
  144. if (!already_recorded) {
  145. // console.log(`NOT already_recorded, eid:${entite.entite.id}, teid:${entite_superpose.id}`, entite.entite.title);
  146. let s = [
  147. {
  148. cid: concernement.id,
  149. eid: entite.entite.id
  150. },
  151. {
  152. cid: null,
  153. eid: entite_superpose.id
  154. }
  155. ];
  156. // concernement.superpositions.push(s);
  157. temp_allSuperpositions.push(s);
  158. }
  159. })
  160. }
  161. }
  162. }); // end of concernement.entites loop
  163. // revisions
  164. concernement.active_revision = concernement.revision_id;
  165. concernement.revisions_byid = {};
  166. concernement.revisions.forEach(rev => {
  167. concernement.revisions_byid[rev.revision_id] = rev;
  168. });
  169. // puissance d'agir
  170. concernement.has_puissancedagir = concernement.besoins.length ? true : false;
  171. concernement.besoins.forEach(besoin => {
  172. this.allBesoinsById[besoin.id] = besoin;
  173. });
  174. // doleance
  175. concernement.has_doleance = concernement.doleances.length ? true : false;
  176. if (concernement.has_doleance) {
  177. // console.log('concernement has doleance', concernement.doleances);
  178. concernement.opened_doleance = {
  179. id: concernement.doleances[0].id
  180. };
  181. }
  182. // recit
  183. concernement.has_recit = concernement.recit !== null;
  184. // common
  185. // if (!concernement_is_reloaded) {
  186. this.concernements.push(concernement);
  187. this.concernementsByID[concernement.id] = concernement;
  188. // }else{
  189. // // this.concernements[concernement_index] = concernement;
  190. // this.concernementsByID[concernement.id] = concernement;
  191. // // TODO check that this.concernements and this.concernementsByID contains the same item
  192. // }
  193. }); // end of concernements loop
  194. // console.log('this.concernements', this.concernements);
  195. // console.log('this.concernementsByID', this.concernementsByID);
  196. // console.log('temp_allSuperpositions', temp_allSuperpositions);
  197. // cleaning superpositions, removing all incomplète onces
  198. this.allSuperpositions = [];
  199. temp_allSuperpositions.forEach(s => {
  200. if (s[0] && s[0].cid && s[0].eid && s[1] && s[1].cid && s[1].eid) {
  201. this.allSuperpositions.push(s);
  202. this.concernementsByID[s[0].cid].has_superpositions = true;
  203. this.concernementsByID[s[1].cid].has_superpositions = true;
  204. }
  205. });
  206. // console.log('this.allSuperpositions', this.allSuperpositions);
  207. // 1 check if cluster already exists and if yes complete with the next item of cluster
  208. // 2 if cluster deos not exists, create the cluster and fill it with first item of cluster
  209. // 1 check if cluster already exists and if yes complete with the next item of cluster
  210. // get superpositions by cluster
  211. for(let superpos_to_record of this.allSuperpositions){
  212. let recorded = false;
  213. // console.log('-- -- --');
  214. // console.log(`superpos_to_record : ${superpos_to_record[0].cid}-${superpos_to_record[0].eid}, ${superpos_to_record[1].cid}-${superpos_to_record[1].eid}`);
  215. // loop through alredy recorded clusters
  216. for(let [cluster_index, superpo_cluster] of this.allSuperpositions_clustered.entries()){
  217. // console.log('cluster_index', cluster_index);
  218. // for each cluster loop throug each superposition
  219. in_cluster_loop:{
  220. for(let s of superpo_cluster){
  221. // console.log(`s : ${s.cid}-${s.eid}`);
  222. // loop through each cid_eid couple of superpo to be recorded
  223. for(let i = 0; i <= 1; i++){
  224. // if one couple already recorded in the cluster, add the other one to the same cluster
  225. if (superpos_to_record[i].cid === s.cid && superpos_to_record[i].eid === s.eid){
  226. // console.log('-- recorded');
  227. let j = i === 0 ? 1 : 0;
  228. // check if item is not already recorded in the cluster (in case of reparsing concernements)
  229. let already_clustered = false;
  230. for (let s2 of superpo_cluster) {
  231. if (superpos_to_record[j].cid === s2.cid && superpos_to_record[j].eid === s2.eid){
  232. already_clustered = true;
  233. break;
  234. }
  235. }
  236. // if not already recorded
  237. if (!already_clustered) {
  238. // add the right item to the cluster
  239. this.allSuperpositions_clustered[cluster_index].push(superpos_to_record[j]);
  240. }
  241. // record the superposition on the concernement BY cluster index
  242. // create array if not already exists
  243. if(typeof this.concernementsByID[superpos_to_record[j].cid].superpositions[cluster_index] === 'undefined'){
  244. this.concernementsByID[superpos_to_record[j].cid].superpositions[cluster_index] = [superpos_to_record];
  245. }else if(!already_clustered){
  246. this.concernementsByID[superpos_to_record[j].cid].superpositions[cluster_index].push(superpos_to_record);
  247. }
  248. recorded = true;
  249. break in_cluster_loop;
  250. }
  251. }
  252. }
  253. }
  254. }
  255. // 2 if cluster deos not exists, create the cluster and fill it with first item of cluster
  256. if(!recorded){
  257. // console.log('-- not recorded');
  258. // create cluster and fill it with first item of couple
  259. this.allSuperpositions_clustered.push(superpos_to_record);
  260. // record superposition on each concernement of each couple member BY cluster index
  261. for( let i=0; i <= 1; i++){
  262. this.concernementsByID[superpos_to_record[i].cid].superpositions[this.allSuperpositions_clustered.length-1] = [superpos_to_record];
  263. // console.log(`concernement ${superpos_to_record[i].cid} superposition by cluster index`,this.concernementsByID[superpos_to_record[i].cid].superpositions);
  264. }
  265. }
  266. }
  267. // console.log('this.allSuperpositions_clustered', this.allSuperpositions_clustered);
  268. // console.log(`end of parsing concernements`);
  269. },
  270. reloadConcernements () {
  271. console.log('reloadConcernements');
  272. return new Promise((resolve, reject) => {
  273. // reset the arrays
  274. this.concernements = [];
  275. this.concernementsByID = {};
  276. // this.concernements_loaded = false;
  277. this.loadConcernements()
  278. .then(()=>{
  279. resolve();
  280. });
  281. })
  282. },
  283. reloadConcernementEntites(nid){
  284. // console.log('reloadConcernementEntites nid', nid);
  285. // const ast = gql`{
  286. // concernement(id:${nid}) {
  287. // entites {
  288. // id
  289. // revision_id
  290. // menacemaintien
  291. // actuelfuture
  292. // entite {
  293. // title
  294. // id
  295. // agissante
  296. // proximite {
  297. // id
  298. // title
  299. // }
  300. // superposition {
  301. // id
  302. // title
  303. // }
  304. // }
  305. // }
  306. // }
  307. // }
  308. // `
  309. // // console.log('ast', ast);
  310. // GQL.post('', { query: print(ast) })
  311. // .then(({ data : { data : { concernement } } }) => {
  312. // console.log('reloadConcernementEntites loaded', concernement)
  313. // // this.concernementsByID[concernement.id].entites = concernement.entites;
  314. // })
  315. // .catch(error => {
  316. // console.warn('Issue with reloadConcernementEntites', error)
  317. // Promise.reject(error)
  318. // })
  319. },
  320. loadContentTypeDefinition () {
  321. const body = {
  322. query: `
  323. query EntityDef($type: String!, $bundle: String!){
  324. entitydef(type: $type, bundle: $bundle) {
  325. fields {
  326. type
  327. field_name
  328. label
  329. description
  330. }
  331. }
  332. }`,
  333. variables: {}
  334. }
  335. // concernement
  336. body.variables = { type: 'node', bundle: 'concernement' }
  337. GQL.post('', body)
  338. .then(({ data: { data: { entitydef }}}) => {
  339. // console.log('loadContentTypeDefinition entitydef', entitydef);
  340. entitydef.fields.forEach(field => {
  341. this.ct_concernement[field.field_name] = field;
  342. });
  343. console.log('loadContentTypeDefinition entitydef concernement', this.ct_concernement);
  344. })
  345. // entite
  346. body.variables = { type: 'node', bundle: 'entite' }
  347. GQL.post('', body)
  348. .then(({ data: { data: { entitydef }}}) => {
  349. // console.log('loadContentTypeDefinition entitydef', entitydef);
  350. entitydef.fields.forEach(field => {
  351. this.ct_entite[field.field_name] = field;
  352. });
  353. console.log('loadContentTypeDefinition entitydef entite', this.ct_entite);
  354. })
  355. // cercle_politique
  356. body.variables = { type: 'node', bundle: 'cercle_politique' }
  357. GQL.post('', body)
  358. .then(({ data: { data: { entitydef }}}) => {
  359. // console.log('loadContentTypeDefinition entitydef', entitydef);
  360. entitydef.fields.forEach(field => {
  361. this.ct_cercle_politique[field.field_name] = field;
  362. });
  363. console.log('loadContentTypeDefinition entitydef cercle_politique', this.ct_cercle_politique);
  364. })
  365. // paragraphe groupes_interets
  366. body.variables = { type: 'paragraph', bundle: 'groupes_interets' }
  367. GQL.post('', body)
  368. .then(({ data: { data: { entitydef }}}) => {
  369. // console.log('loadContentTypeDefinition entitydef', entitydef);
  370. entitydef.fields.forEach(field => {
  371. this.p_groupes_interets[field.field_name] = field;
  372. });
  373. console.log('loadContentTypeDefinition entitydef p_groupes_interets', this.p_groupes_interets);
  374. })
  375. // paragraphe reception_et_traitement
  376. body.variables = { type: 'paragraph', bundle: 'reception_et_traitement' }
  377. GQL.post('', body)
  378. .then(({ data: { data: { entitydef }}}) => {
  379. // console.log('loadContentTypeDefinition entitydef', entitydef);
  380. entitydef.fields.forEach(field => {
  381. this.p_reception_et_traitement[field.field_name] = field;
  382. });
  383. console.log('loadContentTypeDefinition entitydef p_reception_et_traitement', this.p_reception_et_traitement);
  384. })
  385. // paragraphe mise_en_oeuvre_decision
  386. body.variables = { type: 'paragraph', bundle: 'mise_en_oeuvre_decision' }
  387. GQL.post('', body)
  388. .then(({ data: { data: { entitydef }}}) => {
  389. // console.log('loadContentTypeDefinition entitydef', entitydef);
  390. entitydef.fields.forEach(field => {
  391. this.p_mise_en_oeuvre_decision[field.field_name] = field;
  392. });
  393. console.log('loadContentTypeDefinition entitydef p_mise_en_oeuvre_decision', this.p_mise_en_oeuvre_decision);
  394. })
  395. // paragraphe reception_application_decision
  396. body.variables = { type: 'paragraph', bundle: 'reception_application_decision' }
  397. GQL.post('', body)
  398. .then(({ data: { data: { entitydef }}}) => {
  399. // console.log('loadContentTypeDefinition entitydef', entitydef);
  400. entitydef.fields.forEach(field => {
  401. this.p_reception_application_decision[field.field_name] = field;
  402. });
  403. console.log('loadContentTypeDefinition entitydef p_reception_application_decision', this.p_reception_application_decision);
  404. })
  405. },
  406. hideShowConcernement (id, state) {
  407. // console.log(`disableConcernement id: ${id}`);
  408. this.concernements.forEach((c, i) => {
  409. if (c.id === id) {
  410. this.concernements[i].visible = this.concernementsByID[id].visible = state;
  411. }
  412. })
  413. },
  414. openCloseConcernements (cid, id) {
  415. console.log(`openCloseConcernements cid: ${cid}, id: ${id}`);
  416. var state;
  417. let mapitem_id = id ? id : cid;
  418. this.opened_concernement = null;
  419. this.opened_recit = null;
  420. this.concernements.forEach((c, i) => {
  421. // console.log(`openCloseConcernements foreach id: ${id}, c.id: ${c.id}, state: ${state}`, id, c.id);
  422. c.opened = this.concernements[i].opened = this.concernementsByID[c.id].opened = cid === c.id;
  423. if (c.opened) {
  424. this.opened_concernement = c;
  425. this.opened_concernement.opened_mapitem_id = mapitem_id;
  426. if (c.has_recit && this.map_mode === "terraindevie") {
  427. this.opened_recit = c.recit;
  428. }
  429. this.concernement_active_revision = {cid: cid, rid: c.active_revision}
  430. // console.log('openCloseConcernements', this.opened_concernement.opened);
  431. }
  432. });
  433. },
  434. resetConcernementOpened () {
  435. this.opened_concernement = null;
  436. this.openCloseConcernements();
  437. },
  438. // setConcernementScale(cid, scale){
  439. // console.log(`setConcernementScale ${cid} ${scale}`);
  440. // this.concernementsByID[cid].scale = scale;
  441. // },
  442. setOpenedEntiteId(id){
  443. this.opened_entite_id = id;
  444. },
  445. setBesoinPaperId(paper_id, cid, bid, rid){
  446. // this.concernements.forEach((c, i) => {
  447. // if(c.id === cid){
  448. this.concernementsByID[cid].besoins.forEach((b,j) => {
  449. if(b.id === bid) {
  450. if (!rid) {
  451. // this.concernements[i].besoins[j].paper_id = this.concernementsByID[cid].besoins[j].paper_id = paper_id;
  452. this.concernementsByID[cid].besoins[j].paper_id = paper_id;
  453. } else {
  454. this.concernementsByID[cid].besoins[j].reponses.forEach((r,k) => {
  455. if (r.id === rid) {
  456. // this.concernements[i].besoins[j].reponses[k].paper_id = this.concernementsByID[cid].besoins[j].reponses[k].paper_id = paper_id;
  457. this.concernementsByID[cid].besoins[j].reponses[k].paper_id = paper_id;
  458. }
  459. })
  460. }
  461. }
  462. })
  463. // }
  464. // })
  465. },
  466. setOpenedDoleance(cid, did){
  467. console.log(`setOpenedDoleance(${cid}, ${did})`, cid, did);
  468. this.concernementsByID[cid].opened_doleance = {id: did};
  469. // console.log('this.opened_concernement.opened_doleance', this.opened_concernement.opened_doleance);
  470. },
  471. setOpenedDoleanceField(cid, did, field, index){
  472. console.log(`setOpenedDoleanceField cid, did, field, index`, cid, did, field, index);
  473. this.concernementsByID[cid].opened_doleance = {
  474. cid: cid,
  475. id: did,
  476. field: field,
  477. field_index: index
  478. };
  479. },
  480. setOpenedRecit (recit) {
  481. this.opened_recit = recit;
  482. },
  483. setRecitPlayer (player) {
  484. console.log('concernement store setRecitPlayer', player);
  485. this.recit_plyr_player = player;
  486. },
  487. setActiveRevision (cid, rid) {
  488. console.log(`setActiveRevision, cid:${cid}, rid:${rid}`);
  489. // this.concernementsByID[cid].active_revision = rid;
  490. this.concernement_active_revision = {cid: cid, rid: rid};
  491. },
  492. setDetailsZoomValue (z) {
  493. console.log(`concernement store setDetailsZoomValue ${z}`);
  494. this.detailsZoomValue = z;
  495. }
  496. }
  497. })