@beam3_dev/api_module 0.0.44 → 0.0.46

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
- (function(u,b){typeof exports=="object"&&typeof module<"u"?b(exports,require("uuid"),require("luxon"),require("@widget-lab/3ddashboard-utils")):typeof define=="function"&&define.amd?define(["exports","uuid","luxon","@widget-lab/3ddashboard-utils"],b):(u=typeof globalThis<"u"?globalThis:u||self,b(u["@beam3_dev/api_module"]={},u.uuid,u.luxon,u["@widget-lab/3ddashboard-utils"]))})(this,function(u,b,U,C){"use strict";function A(){return b.v4()}const v={b3M3Yellow:"#FFB300",b3AboutageBlue:"#42A5F5",b3UsinageGreen:"#689F38",b3PanneauOrange:"#ff8000",b3M350percent:"#fafa6e",b3M380percent:"#aae479",b3M390percent:"#64c987",b3M3100percent:"#23aa8f",b3M3105percent:"#00898a",b3M3110percent:"#176877",b3M3120percent:"#2a4858",b3Aboutage50percent:"#fafa6e",b3Aboutage80percent:"#aae479",b3Aboutage90percent:"#64c987",b3Aboutage100percent:"#23aa8f",b3Aboutage105percent:"#00898a",b3Aboutage110percent:"#176877",b3Aboutage120percent:"#2a4858",b3Warning:"#FF0000",b3Edit1:"#AD1457",b3Edit2:"#F4511E",b3Edit3:"#009688",b3Edit4:"#D50000",b3Edit5:"#039BE5",b3Edit6:"#9E69AF",b3Edit7:"#A79B8E",b3Edit8:"#616161",b3Edit9:"#795548"};async function H(e,t=void 0,n=void 0){const s=parseInt(e);await fetch("https://apicarto.ign.fr/api/codes-postaux/communes/"+s,{method:"GET",headers:{Accept:"application/json"}}).then(i=>i.json()).then(i=>{t&&t(i)}).catch(i=>{n&&n(i),console.error("Erreur : "+i)})}async function z(e,t=void 0,n=void 0){e=encodeURIComponent(e),await fetch("https://api-adresse.data.gouv.fr/search/?q="+e+"&limit=15",{method:"GET",headers:{Accept:"application/json"}}).then(s=>s.json()).then(s=>{t&&t(s)}).catch(s=>{n&&n(s),console.error("Erreur : "+s)})}async function Q(e,t=v){let n=U.DateTime.now().year;const s=e,i=[],c=a=>{for(let r in a)i.push({date:r,comment:a[r]})};for(let a=n;a<=n+1;a++)await fetch("https://calendrier.api.gouv.fr/jours-feries/metropole/"+a+".json",{method:"GET",headers:{Accept:"application/json"}}).then(r=>r.json()).then(r=>{c(r)}).catch(r=>console.error("Erreur : "+r));return(()=>{const a=s.length===0?{events:[]}:s;for(let r of i)a.events.findIndex(l=>l.start===U.DateTime.fromISO(r.date).toISODate()&&l.name==="Férié : "+r.comment)===-1&&a.events.push({name:"Férié : "+r.comment,start:U.DateTime.fromISO(r.date).toISODate(),end:U.DateTime.fromISO(r.date).toISODate(),color:t.b3BusinnessDays,timed:!1});return a})()}async function Z(e,t,n=!0){const s=e.events.findIndex(i=>i.uuid===t.uuid);return s===-1?e.events.push(t):n?e.events[s]=t:e.events.splice(s,1),e.length>0&&e.sort((i,c)=>i.start-c.start),e}function m(e,t){C.requirejs(["DS/WAFData/WAFData"],n=>{n.authenticatedRequest(e,t)})}function ee(e,t,n){C.requirejs(["DS/DataDragAndDrop/DataDragAndDrop"],s=>{s.draggable(e,{data:t,start:n})})}function te(e,t=void 0){C.requirejs(["DS/TagNavigatorProxy/TagNavigatorProxy"],n=>{let s;s===void 0&&(s=n.createProxy({widgetId:C.widget.id,filteringMode:"WithFilteringServices"}),t!==void 0&&s.addEvent("onFilterSubjectsChange",t)),s.setSubjectsTags(e)})}function ne(e,t){C.requirejs(["DS/DataDragAndDrop/DataDragAndDrop"],n=>{n.droppable(e,{drop:t})})}async function se(e,t=void 0,n=void 0){C.requirejs(["DS/i3DXCompassServices/i3DXCompassServices"],s=>{(!e||e==="")&&(e=C.widget.getValue("PlatFormInstanceId")),(!e||e==="")&&(e=void 0),t&&t(s.getPlatformServices({platformId:e,onComplete:t,onFailure:n}))})}function ae(){let e={};return C.requirejs(["DS/PlatformAPI/PlatformAPI"],t=>{const n=t.getTenant(),s=t.getUser(),i=t.getAllApplicationConfigurations(),c=t.getApplicationConfiguration("com.3ds.wp.passport.cors");e={tenant:n,user:s,appsConfiguration:i,appConf:c}}),console.log("%cRETOUR API :","color:blue",e),e}function ie(e,t,n){const s={base:`${e.space}`,uri:"/resources/AppsMngt/api/custom/applications",option:`?filter=${e.tenant}`},i=`${s.base}${s.uri}${s.option}`;m(i,{method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json"},onComplete(c,o,a){const r=JSON.parse(c),d=r.data.map(l=>{const p=l.attributes.name,f=l.id;return{name:p,id:f}});t&&t(d,r)},onFailure(c,o){const a=c;a.msg=o.errormsg,a.errCode=o.errorcode,n&&n(a)}})}function oe(e,t=void 0,n=void 0){let s=`${e.space}/resources/AppsMngt/user?platform=${e.tenant}&limit=-1`;m(s,{onComplete(i,c,o){const a=JSON.parse(i);console.log("_AppMngt_get_users => ",a),t&&t(a)},onFailure(i,c){const o=i;o.msg=c.errormsg,o.errCode=c.errorcode,n&&n(o)}})}function re(e,t,n=void 0,s=void 0){let i=`${e.space}/resources/AppsMngt/user?platform=${e.tenant}&id=${t}`;m(i,{onComplete(c,o,a){const r=JSON.parse(c);n&&n(r)},onFailure(c,o){const a=c;a.msg=o.errormsg,a.errCode=o.errorcode,s&&s(a)}})}const I={"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"};function ce(e,t,n=void 0,s=void 0){const{space:i,currentUser:c}=e,a=`${i}${{URIUGr:"/3drdfpersist/resources/v1/usersgroup"}.URIUGr}`,r={groups:[{title:t.title,description:t.description,members:t.members||[c.email,"samuel.mureau@beam3.fr"],pending_members:[],sharing:t.sharing,visibility:t.visibility}]};m(a,{method:"POST",headers:I,data:JSON.stringify(r),onComplete(d){n&&n(JSON.parse(d))},onFailure(d,l){console.log(d);const p=d;p.msg=l.errormsg,p.errCode=l.errorcode,console.log("❌ sendDirectMessage => ",p),s&&s(p)}})}function de(e,t,n=void 0,s=void 0){const{space:i,tenant:c}=e,o=i,a=`/3drdfpersist/v1/resources/${t}`,r=`?$mask=dsaccess:Mask.GroupUI.Properties&tenant=dstenant:${c}`,d=`${o}${a}${r}`;m(d,{opts:{method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"}},onComplete(f){n&&n(JSON.parse(f))},onFailure(f,g){const _=f;_.msg=g.errormsg,_.errCode=g.errorcode,s&&s(_)}})}function M(e,t=void 0,n=void 0){const{space:s,tenant:i}=e,c=s,o="/3drdfpersist/resources/v1/option-sets/dsusergroup:ListOfGroupResponsibilities/options",a=`?tenant=dstenant:${i}`,r={method:"GET",Accept:"application/json,*/*,test/javascript"},d=`${c}${o}${a}`;m(d,{OPTsH:r,onComplete(l){t&&t(JSON.parse(l))},onFailure(l,p){const f=l;f.msg=p.errormsg,f.errCode=p.errorcode,n&&n(f)}})}function le(e,t=void 0,n=void 0){const{space:s,currentUser:i}=e,a=`${s}/3drdfpersist/resources/v1/usersgroup?select=uri,title,description,owner,members,pending_members,creation_date,modification_date,visibility`,d={method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"}};try{m(a,{opts:d,onComplete(l){const p=JSON.parse(l),f={},g=p.groups.filter(_=>_.uri.startsWith("uuid:"));if(i&&Object.keys(i).length>0){const _=g.filter(y=>y.owner===i.email),S=g.filter(y=>y.members.includes(i.email)),h=_.concat(S);f.iam=h,f.UG=g,f.iamMember=S,M(e,y=>{f.rules=y,t&&t(f)},y=>{n&&n(y)})}},onFailure(l){n&&n(l)}})}catch(l){console.log(l)}}function ue(e,t){const{space:n}=e,i=`${n}/3drdfpersist/resources/v1/usersgroup/${t}`;m(i,{method:"DELETE"})}function pe(e,t,n,s=void 0,i=void 0){const{space:c,tenant:o}=e,a={URITI:"/3drdfpersist/resources/v1/template-instances",URIUGr:"/3drdfpersist/resources/v1/usersgroup",nextURICh:"/characteristics",nextURIGr:"/group",nexURImem:"/members",OPTsTI:"?$mask=dsaccess:Mask.GroupUI.Properties",OPTsTenant:`tenant=dstenant:${o}`},r=n,d=`${c}${a.URIUGr}/${t}`,l=JSON.stringify(r);m(d,{headers:I,method:"PATCH",data:l,type:"json",onComplete(p){s&&s(p)},onFailure(p){i&&i(p)}})}function fe(e,t,n,s=void 0,i=void 0){const{space:c}=e,a=`${c}/3drdfpersist/resources/v1/usersgroup/${t}/sharing`;m(a,{method:"PATCH",headers:I,data:JSON.stringify(n),type:"json",onComplete(d){s&&s(d)},onFailure(d){i&&i(d)}})}function me(e,t,n=void 0,s=void 0){const{space:i}=e,o=`${i}/3drdfpersist/resources/v1/usersgroup/${t}/sharing`;m(o,{opts:{method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"}},onComplete(d){n&&n(JSON.parse(d))},onFailure(d){s&&s(d)}})}async function P(e,t=void 0,n=void 0,s=void 0){const i=e.space;if(t===void 0){console.log("Le paramètre docid est obligatoire");return}const c=i+`/resources/v1/modeler/documents/${t}`;m(c,{onComplete(o,a,r){const d=JSON.parse(o);n&&n(d)},onFailure(o){s&&s(o)}})}function F(e,t=void 0,n=void 0){if(e.objID&&e.objID!==""){let s=`${e.space}/resources/v1/modeler/documents/${e.objID}`;m(s,{onComplete(i,c,o){const a=JSON.parse(i);e.token=a?.csrf?.value,e.datas=a?.data[0],t&&(console.log("info => ",a),t(e))},onFailure(i){n&&n(i)}})}else D(e)}function D(e,t=void 0,n=void 0){if(e.space){const s=e.space+"/resources/v1/application/CSRF";m(s,{onComplete(i,c,o){const a=JSON.parse(i);t&&t(a.csrf.value)},onFailure(i,c,o){n&&n({response:i,headers:c,xhr:o})}})}else n&&n("ERROR : url du 3DSpace non défini.")}function k(e,t,n=void 0,s=void 0){let i=e.space+`/resources/v1/modeler/documents/${t}/files/DownloadTicket`;F(e,c=>{m(i,{method:"PUT",headers:{ENO_CSRF_TOKEN:e.token},onComplete(o){let a=JSON.parse(o);if(a.success===!0)try{const r=a.data[0].dataelements.ticketURL;n&&n(r)}catch(r){s&&s(r)}},onFailure(o,a){console.log("☠️ error => ",o,a),s&&s(o,a)}})},s)}function ge(e,t,n,s=void 0,i=void 0){const c=`${e.space}/resources/v1/modeler/documents/${t}/files/DownloadTicket`;m(c,{method:"PUT",headers:{ENO_CSRF_TOKEN:n},onComplete(o){let a=JSON.parse(o);if(a.success===!0)try{const r=a.data[0].dataelements.ticketURL;s&&s(r)}catch(r){i&&i(r)}},onFailure(o){i&&i(o)}})}function L(e,t,n,s,i,c=void 0,o=void 0){F(e,t,a=>{J(e,t,n,s,i,a.csrf.value,c,o)})}function J(e,t,n,s,i,c,o=void 0,a=void 0){const r=e.space+`/resources/v1/modeler/documents/${t}/files/CheckinTicket`;m(r,{method:"PUT",headers:{ENO_CSRF_TOKEN:c},onComplete(d,l,p){const f=JSON.parse(d).data[0].dataelements,g=new FormData;g.append("__fcs__jobTicket",f.ticket),g.append("file_0",s,i);const _={};_.method="POST",_.data=g,_.onComplete=function(S){let h="temp_"+Date.now(),y={method:"PUT",headers:{ENO_CSRF_TOKEN:c},data:JSON.stringify({data:[{id:t,relateddata:{files:[{id:n,dataelements:{title:i,receipt:S},updateAction:"REVISE"}]},tempId:h}]}),type:"json",onComplete(T){o&&o(T)},onFailure(T){a&&a(T)}};m(e.space+"/resources/v1/modeler/documents",y)},_.onFailure=function(S){a&&a(S)},_.timeout=0,m(f.ticketURL,_)}})}async function _e(e,t,n,s,i=void 0,c=void 0){const o=e.space,a=e.token,r=e.ctx,d=new FormData,l=new Blob([JSON.stringify(t)],{type:"text/plain"}),p={url_Ticket:`${o}/resources/v1/modeler/documents/files/CheckinTicket`,url_Post:`${o}/resources/v1/modeler/documents/?SecurityContext=ctx::${r}`};if(!o&&o!==""){console.log("le store._3DSpace est vide");return}m(p.url_Ticket,{method:"PUT",headers:{ENO_CSRF_TOKEN:a.value},onComplete(f,g,_){const S=JSON.parse(f).data[0].dataelements;d.append("__fcs__jobTicket",S.ticket),d.append("filename",l,n);const h={method:"POST",data:d,onComplete(O){if(r!==""&&a!==""){const $={method:"POST",headers:{ENO_CSRF_TOKEN:a,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{type:"Document",dataelements:{title:`Title_${n.toLowerCase().split(" ").join("_")}`,policy:"Document Release",description:s},relateddata:{files:[{dataelements:{title:`${n}.json`,receipt:O}}]},tempId:A()}]}),type:"json",timeout:0,onComplete:y,onFailure:T};r!==""&&m(p.url_Post,$)}else console.warn("le store est vide")},onFailure:T};function y(O){console.log("Success -- response ",O.data[0]),i&&i(O)}function T(O,$){console.log("Erreur -- response ",O,`
2
- headers `,$),c&&c(O)}m(S.ticketURL,h)}})}function N(e,t=void 0,n=void 0,s=void 0,i=void 0,c=void 0){const o=`${e.space}/resources/modeler/pno/person?current=true&select=preferredcredentials&select=collabspaces`;m(o,{method:"GET",onComplete(a){const r=JSON.parse(a);let d="",l,p,f;if(t){let g=r.collabspaces.find(_=>_.title===t);if(g){l=t;let _=g.couples;_=_.filter((S,h,y)=>h===y.findIndex(T=>T.organization.pid===S.organization.pid&&T.role.pid===S.role.pid)),n&&(Array.isArray(n)?n.forEach(S=>{f||_.forEach(h=>{if(S===h.role.name&&s===h.organization.title)f=S,p=s;else if(S===h.role.name){let y=_.filter(T=>T.role.name===S);y.length===1?(f=y[0].role.name,p=y[0].organization.title):c(y)}})}):_.forEach(S=>{if(n===S.role.name&&s===S.organization.title)f=n,p=s;else if(n===S.role.name){let h=_.filter(y=>y.role.name===n);h.length===1?(f=h[0].role.name,p=h[0].organization.title):c(h)}}))}}l&&p&&f?(d=f+"."+p+"."+l,i(d)):r.preferredcredentials?(d=r.preferredcredentials.role.name+"."+r.preferredcredentials.organization.title+"."+r.preferredcredentials.collabspace.title,i(d)):c&&(d=f+"."+p+"."+l,c(d))},onFailure(a){console.log("Erreur de récupération du contexte de sécurité. => ",a)}})}async function j(e,t=void 0,n=void 0,s=void 0){const i=e.objID;(i===void 0||i==="")&&console.warn("_3DSpace_download_doc() / Le paramètre objectId est obligatoire"),(e.space===""||!e.space)&&console.warn("_3DSpace_download_doc() / Le paramètre space est obligatoire");try{k(e,i,c=>{console.log("_3dspace_download_doc / _3DSpace_file_url / response ",c),m(c,{headers:{ENO_CSRF_TOKEN:e.token},onComplete(o){const a=JSON.parse(o);t&&t(a)},onFailure(o,a,r){n&&(console.log("error http",o),n({error:o,headers:a,xhr:r}))}})},c=>{n&&n(c),console.log("*_3dspace_download_doc / error file URL *",c)})}catch(c){console.log("*_3dspace_download_doc / error file URL *",c)}}async function E(e,t,n=void 0,s=void 0){let i=[];for(let a=0;a<t.length;a+=80){const r=t.slice(a,a+80);i.push(r)}const o=a=>{G(e,i[a],()=>{a++,a<i.length&&o(a)},r=>{n&&n(r)})};o(0)}function G(e,t,n=void 0,s=void 0,i=void 0){const c=[];t.forEach(r=>{c.push({id:r})});let o=JSON.stringify({csrf:{name:"ENO_CSRF_TOKEN",value:e.token},data:c});const a=`${e.space}/resources/v1/modeler/documents/DownloadTicket?tenant=${e.tenant}&e6w-lang=fr&e6w-timezone=-120`;m(a,{method:"PUT",data:o,type:"json",onComplete(r){const d=r.data;r.success===!0&&(n&&n(),d.forEach(l=>{try{const p=l.dataelements.fileName,f=l.dataelements.ticketURL;m(f,{onComplete:g=>{s&&s({objectId:l.id,fileName:p,data:JSON.parse(g)})},onFailure:g=>{console.log("error http",g)}})}catch(p){console.log(p),i&&i(p)}}))},onFailure(r){console.log(r),i&&i(r)}})}function Se(e,t,n=void 0,s=void 0){return new Promise(i=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const c=`${e.space}/resources/v1/modeler/dslc/maturity/getNextStates`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,a=>e.ctx=a,a=>{console.log("onError =>",a)});let o={method:"POST",headers:{SecurityContext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{id:t}]}),type:"json",onComplete(a){n&&n(a)},onFailure(a){s&&s(a)}};m(c,o)}})}function he(e,t,n,s=void 0,i=void 0){return new Promise(c=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const o=`${e.space}/resources/v1/modeler/dslc/maturity/changeState`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,r=>e.ctx=r,r=>{console.log("onError =>",r)});let a={method:"POST",headers:{SecurityContext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{id:t,nextState:n}]}),type:"json",onComplete(r){s&&s(r)},onFailure(r){i&&i(r)}};m(o,a)}})}function ye(e,t,n=void 0,s=void 0){return new Promise(i=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const c=`${e.space}/resources/v1/dslc/versiongraph?withThumbnail=0&withIsLastVersion=0&withAttributes=0&withCopyFrom=0&tenant=${e.tenant}`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,a=>e.ctx=a,a=>{console.log("onError =>",a)});let o={method:"POST",headers:{securitycontext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({graphRequests:[{id:t}]}),type:"json",onComplete(a){n&&n(a)},onFailure(a){s&&s(a)}};m(c,o)}})}function we(e,t,n=void 0,s=void 0){return new Promise(i=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const c=`${e.space}/resources/lifecycle/revise/prepare_revise_maskattributes?tenant=${e.tenant}`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,a=>e.ctx=a,a=>{console.log("onError =>",a)});let o={method:"POST",headers:{SecurityContext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{"attribute[PLMReference.V_versionComment]":null,physicalid:t,type:"Document",tenant:e.tenant,objectId:t,policy:"Document Release",availableSemantic:["E","LAST","NEW","DUP"]}]}),type:"json",onComplete(a){n&&n(a)},onFailure(a){s&&s(a)}};m(c,o)}})}function Te(e,t,n,s=void 0,i=void 0){return new Promise(c=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const o=`${e.space}/resources/lifecycle/revise/major?tenant=${e.tenant}`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,r=>e.ctx=r,r=>{console.log("onError =>",r)});let a={method:"POST",headers:{securitycontext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{physicalid:t,proposedRevision:n,modifiedAttributes:{revision:n}}],folderid:null,notificationTimeout:600}),type:"json",onComplete(r){s&&s(r)},onFailure(r){i&&i(r)}};m(o,a)}})}//!SECTION
1
+ (function(u,b){typeof exports=="object"&&typeof module<"u"?b(exports,require("uuid"),require("luxon"),require("@widget-lab/3ddashboard-utils")):typeof define=="function"&&define.amd?define(["exports","uuid","luxon","@widget-lab/3ddashboard-utils"],b):(u=typeof globalThis<"u"?globalThis:u||self,b(u["@beam3_dev/api_module"]={},u.uuid,u.luxon,u["@widget-lab/3ddashboard-utils"]))})(this,function(u,b,U,C){"use strict";function A(){return b.v4()}const v={b3M3Yellow:"#FFB300",b3AboutageBlue:"#42A5F5",b3UsinageGreen:"#689F38",b3PanneauOrange:"#ff8000",b3M350percent:"#fafa6e",b3M380percent:"#aae479",b3M390percent:"#64c987",b3M3100percent:"#23aa8f",b3M3105percent:"#00898a",b3M3110percent:"#176877",b3M3120percent:"#2a4858",b3Aboutage50percent:"#fafa6e",b3Aboutage80percent:"#aae479",b3Aboutage90percent:"#64c987",b3Aboutage100percent:"#23aa8f",b3Aboutage105percent:"#00898a",b3Aboutage110percent:"#176877",b3Aboutage120percent:"#2a4858",b3Warning:"#FF0000",b3Edit1:"#AD1457",b3Edit2:"#F4511E",b3Edit3:"#009688",b3Edit4:"#D50000",b3Edit5:"#039BE5",b3Edit6:"#9E69AF",b3Edit7:"#A79B8E",b3Edit8:"#616161",b3Edit9:"#795548"};async function H(e,t=void 0,n=void 0){const s=parseInt(e);await fetch("https://apicarto.ign.fr/api/codes-postaux/communes/"+s,{method:"GET",headers:{Accept:"application/json"}}).then(i=>i.json()).then(i=>{t&&t(i)}).catch(i=>{n&&n(i),console.error("Erreur : "+i)})}async function z(e,t=void 0,n=void 0){e=encodeURIComponent(e),await fetch("https://api-adresse.data.gouv.fr/search/?q="+e+"&limit=15",{method:"GET",headers:{Accept:"application/json"}}).then(s=>s.json()).then(s=>{t&&t(s)}).catch(s=>{n&&n(s),console.error("Erreur : "+s)})}async function Q(e,t=v){let n=U.DateTime.now().year;const s=e,i=[],c=a=>{for(let r in a)i.push({date:r,comment:a[r]})};for(let a=n;a<=n+1;a++)await fetch("https://calendrier.api.gouv.fr/jours-feries/metropole/"+a+".json",{method:"GET",headers:{Accept:"application/json"}}).then(r=>r.json()).then(r=>{c(r)}).catch(r=>console.error("Erreur : "+r));return(()=>{const a=s.length===0?{events:[]}:s;for(let r of i)a.events.findIndex(l=>l.start===U.DateTime.fromISO(r.date).toISODate()&&l.name==="Férié : "+r.comment)===-1&&a.events.push({name:"Férié : "+r.comment,start:U.DateTime.fromISO(r.date).toISODate(),end:U.DateTime.fromISO(r.date).toISODate(),color:t.b3BusinnessDays,timed:!1});return a})()}async function Z(e,t,n=!0){const s=e.events.findIndex(i=>i.uuid===t.uuid);return s===-1?e.events.push(t):n?e.events[s]=t:e.events.splice(s,1),e.length>0&&e.sort((i,c)=>i.start-c.start),e}function m(e,t){C.requirejs(["DS/WAFData/WAFData"],n=>{n.authenticatedRequest(e,t)})}function ee(e,t,n){C.requirejs(["DS/DataDragAndDrop/DataDragAndDrop"],s=>{s.draggable(e,{data:t,start:n})})}function te(e,t=void 0){C.requirejs(["DS/TagNavigatorProxy/TagNavigatorProxy"],n=>{let s;s===void 0&&(s=n.createProxy({widgetId:C.widget.id,filteringMode:"WithFilteringServices"}),t!==void 0&&s.addEvent("onFilterSubjectsChange",t)),s.setSubjectsTags(e)})}function ne(e,t){C.requirejs(["DS/DataDragAndDrop/DataDragAndDrop"],n=>{n.droppable(e,{drop:t})})}async function se(e,t=void 0,n=void 0){C.requirejs(["DS/i3DXCompassServices/i3DXCompassServices"],s=>{(!e||e==="")&&(e=C.widget.getValue("PlatFormInstanceId")),(!e||e==="")&&(e=void 0),t&&t(s.getPlatformServices({platformId:e,onComplete:t,onFailure:n}))})}function ae(){let e={};return C.requirejs(["DS/PlatformAPI/PlatformAPI"],t=>{const n=t.getTenant(),s=t.getUser(),i=t.getAllApplicationConfigurations(),c=t.getApplicationConfiguration("com.3ds.wp.passport.cors");e={tenant:n,user:s,appsConfiguration:i,appConf:c}}),console.log("%cRETOUR API :","color:blue",e),e}function ie(e,t,n){const s={base:`${e.space}`,uri:"/resources/AppsMngt/api/custom/applications",option:`?filter=${e.tenant}`},i=`${s.base}${s.uri}${s.option}`;m(i,{method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json"},onComplete(c,o,a){const r=JSON.parse(c),d=r.data.map(l=>{const p=l.attributes.name,f=l.id;return{name:p,id:f}});t&&t(d,r)},onFailure(c,o){const a=c;a.msg=o.errormsg,a.errCode=o.errorcode,n&&n(a)}})}function oe(e,t=void 0,n=void 0){let s=`${e.space}/resources/AppsMngt/user?platform=${e.tenant}&limit=-1`;m(s,{onComplete(i,c,o){const a=JSON.parse(i);console.log("_AppMngt_get_users => ",a),t&&t(a)},onFailure(i,c){const o=i;o.msg=c.errormsg,o.errCode=c.errorcode,n&&n(o)}})}function re(e,t,n=void 0,s=void 0){let i=`${e.space}/resources/AppsMngt/user?platform=${e.tenant}&id=${t}`;m(i,{onComplete(c,o,a){const r=JSON.parse(c);n&&n(r)},onFailure(c,o){const a=c;a.msg=o.errormsg,a.errCode=o.errorcode,s&&s(a)}})}const I={"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"};function ce(e,t,n=void 0,s=void 0){const{space:i,currentUser:c}=e,a=`${i}${{URIUGr:"/3drdfpersist/resources/v1/usersgroup"}.URIUGr}`,r={groups:[{title:t.title,description:t.description,members:t.members||[c.email,"samuel.mureau@beam3.fr"],pending_members:[],sharing:t.sharing,visibility:t.visibility}]};m(a,{method:"POST",headers:I,data:JSON.stringify(r),onComplete(d){n&&n(JSON.parse(d))},onFailure(d,l){console.log(d);const p=d;p.msg=l.errormsg,p.errCode=l.errorcode,console.log("❌ sendDirectMessage => ",p),s&&s(p)}})}function de(e,t,n=void 0,s=void 0){const{space:i,tenant:c}=e,o=i,a=`/3drdfpersist/v1/resources/${t}`,r=`?$mask=dsaccess:Mask.GroupUI.Properties&tenant=dstenant:${c}`,d=`${o}${a}${r}`;m(d,{opts:{method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"}},onComplete(f){n&&n(JSON.parse(f))},onFailure(f,g){const _=f;_.msg=g.errormsg,_.errCode=g.errorcode,s&&s(_)}})}function M(e,t=void 0,n=void 0){const{space:s,tenant:i}=e,c=s,o="/3drdfpersist/resources/v1/option-sets/dsusergroup:ListOfGroupResponsibilities/options",a=`?tenant=dstenant:${i}`,r={method:"GET",Accept:"application/json,*/*,test/javascript"},d=`${c}${o}${a}`;m(d,{OPTsH:r,onComplete(l){t&&t(JSON.parse(l))},onFailure(l,p){const f=l;f.msg=p.errormsg,f.errCode=p.errorcode,n&&n(f)}})}function le(e,t=void 0,n=void 0){const{space:s,currentUser:i}=e,a=`${s}/3drdfpersist/resources/v1/usersgroup?select=uri,title,description,owner,members,pending_members,creation_date,modification_date,visibility`,d={method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"}};try{m(a,{opts:d,onComplete(l){const p=JSON.parse(l),f={},g=p.groups.filter(_=>_.uri.startsWith("uuid:"));if(i&&Object.keys(i).length>0){const _=g.filter(y=>y.owner===i.email),S=g.filter(y=>y.members.includes(i.email)),h=_.concat(S);f.iam=h,f.UG=g,f.iamMember=S,M(e,y=>{f.rules=y,t&&t(f)},y=>{n&&n(y)})}},onFailure(l){n&&n(l)}})}catch(l){console.log(l)}}function ue(e,t){const{space:n}=e,i=`${n}/3drdfpersist/resources/v1/usersgroup/${t}`;m(i,{method:"DELETE"})}function pe(e,t,n,s=void 0,i=void 0){const{space:c,tenant:o}=e,a={URITI:"/3drdfpersist/resources/v1/template-instances",URIUGr:"/3drdfpersist/resources/v1/usersgroup",nextURICh:"/characteristics",nextURIGr:"/group",nexURImem:"/members",OPTsTI:"?$mask=dsaccess:Mask.GroupUI.Properties",OPTsTenant:`tenant=dstenant:${o}`},r=n,d=`${c}${a.URIUGr}/${t}`,l=JSON.stringify(r);m(d,{headers:I,method:"PATCH",data:l,type:"json",onComplete(p){s&&s(p)},onFailure(p){i&&i(p)}})}function fe(e,t,n,s=void 0,i=void 0){const{space:c}=e,a=`${c}/3drdfpersist/resources/v1/usersgroup/${t}/sharing`;m(a,{method:"PATCH",headers:I,data:JSON.stringify(n),type:"json",onComplete(d){s&&s(d)},onFailure(d){i&&i(d)}})}function me(e,t,n=void 0,s=void 0){const{space:i}=e,o=`${i}/3drdfpersist/resources/v1/usersgroup/${t}/sharing`;m(o,{opts:{method:"GET",headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"}},onComplete(d){n&&n(JSON.parse(d))},onFailure(d){s&&s(d)}})}async function P(e,t=void 0,n=void 0,s=void 0){const i=e.space;if(t===void 0){console.log("Le paramètre docid est obligatoire");return}const c=i+`/resources/v1/modeler/documents/${t}`;m(c,{onComplete(o,a,r){const d=JSON.parse(o);n&&n(d)},onFailure(o){s&&s(o)}})}function F(e,t=void 0,n=void 0){if(e.objID&&e.objID!==""){let s=`${e.space}/resources/v1/modeler/documents/${e.objID}`;m(s,{onComplete(i,c,o){const a=JSON.parse(i);e.token=a?.csrf?.value,e.datas=a?.data[0],t&&t(e)},onFailure(i){n&&n(i)}})}else D(e)}function D(e,t=void 0,n=void 0){if(e.space){const s=e.space+"/resources/v1/application/CSRF";m(s,{onComplete(i,c,o){const a=JSON.parse(i);t&&t(a.csrf.value)},onFailure(i,c,o){n&&n({response:i,headers:c,xhr:o})}})}else n&&n("ERROR : url du 3DSpace non défini.")}function k(e,t,n=void 0,s=void 0){let i=e.space+`/resources/v1/modeler/documents/${t}/files/DownloadTicket`;F(e,c=>{m(i,{method:"PUT",headers:{ENO_CSRF_TOKEN:e.token},onComplete(o){let a=JSON.parse(o);if(a.success===!0)try{const r=a.data[0].dataelements.ticketURL;n&&n(r)}catch(r){s&&s(r)}},onFailure(o,a){console.log("☠️ error => ",o,a),s&&s(o,a)}})},s)}function ge(e,t,n,s=void 0,i=void 0){const c=`${e.space}/resources/v1/modeler/documents/${t}/files/DownloadTicket`;n||(n=e.token),m(c,{method:"PUT",headers:{ENO_CSRF_TOKEN:n},onComplete(o){let a=JSON.parse(o);if(a.success===!0)try{const r=a.data[0].dataelements.ticketURL;s&&s(r)}catch(r){i&&i(r)}},onFailure(o){i&&i(o)}})}function L(e,t,n,s,i,c=void 0,o=void 0){F(e,t,a=>{J(e,t,n,s,i,a.csrf.value,c,o)})}function J(e,t,n,s,i,c,o=void 0,a=void 0){const r=e.space+`/resources/v1/modeler/documents/${t}/files/CheckinTicket`;m(r,{method:"PUT",headers:{ENO_CSRF_TOKEN:c},onComplete(d,l,p){const f=JSON.parse(d).data[0].dataelements,g=new FormData;g.append("__fcs__jobTicket",f.ticket),g.append("file_0",s,i);const _={};_.method="POST",_.data=g,_.onComplete=function(S){let h="temp_"+Date.now(),y={method:"PUT",headers:{ENO_CSRF_TOKEN:c},data:JSON.stringify({data:[{id:t,relateddata:{files:[{id:n,dataelements:{title:i,receipt:S},updateAction:"REVISE"}]},tempId:h}]}),type:"json",onComplete(T){o&&o(T)},onFailure(T){a&&a(T)}};m(e.space+"/resources/v1/modeler/documents",y)},_.onFailure=function(S){a&&a(S)},_.timeout=0,m(f.ticketURL,_)}})}async function _e(e,t,n,s,i=void 0,c=void 0){const o=e.space,a=e.token,r=e.ctx,d=new FormData,l=new Blob([JSON.stringify(t)],{type:"text/plain"}),p={url_Ticket:`${o}/resources/v1/modeler/documents/files/CheckinTicket`,url_Post:`${o}/resources/v1/modeler/documents/?SecurityContext=ctx::${r}`};if(!o&&o!==""){console.log("le store._3DSpace est vide");return}m(p.url_Ticket,{method:"PUT",headers:{ENO_CSRF_TOKEN:a.value},onComplete(f,g,_){const S=JSON.parse(f).data[0].dataelements;d.append("__fcs__jobTicket",S.ticket),d.append("filename",l,n);const h={method:"POST",data:d,onComplete(O){if(r!==""&&a!==""){const $={method:"POST",headers:{ENO_CSRF_TOKEN:a,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{type:"Document",dataelements:{title:`Title_${n.toLowerCase().split(" ").join("_")}`,policy:"Document Release",description:s},relateddata:{files:[{dataelements:{title:`${n}.json`,receipt:O}}]},tempId:A()}]}),type:"json",timeout:0,onComplete:y,onFailure:T};r!==""&&m(p.url_Post,$)}else console.warn("le store est vide")},onFailure:T};function y(O){console.log("Success -- response ",O.data[0]),i&&i(O)}function T(O,$){console.log("Erreur -- response ",O,`
2
+ headers `,$),c&&c(O)}m(S.ticketURL,h)}})}function N(e,t=void 0,n=void 0,s=void 0,i=void 0,c=void 0){const o=`${e.space}/resources/modeler/pno/person?current=true&select=preferredcredentials&select=collabspaces`;m(o,{method:"GET",onComplete(a){const r=JSON.parse(a);let d="",l,p,f;if(t){let g=r.collabspaces.find(_=>_.title===t);if(g){l=t;let _=g.couples;_=_.filter((S,h,y)=>h===y.findIndex(T=>T.organization.pid===S.organization.pid&&T.role.pid===S.role.pid)),n&&(Array.isArray(n)?n.forEach(S=>{f||_.forEach(h=>{if(S===h.role.name&&s===h.organization.title)f=S,p=s;else if(S===h.role.name){let y=_.filter(T=>T.role.name===S);y.length===1?(f=y[0].role.name,p=y[0].organization.title):c(y)}})}):_.forEach(S=>{if(n===S.role.name&&s===S.organization.title)f=n,p=s;else if(n===S.role.name){let h=_.filter(y=>y.role.name===n);h.length===1?(f=h[0].role.name,p=h[0].organization.title):c(h)}}))}}l&&p&&f?(d=f+"."+p+"."+l,i(d)):r.preferredcredentials?(d=r.preferredcredentials.role.name+"."+r.preferredcredentials.organization.title+"."+r.preferredcredentials.collabspace.title,i(d)):c&&(d=f+"."+p+"."+l,c(d))},onFailure(a){console.log("Erreur de récupération du contexte de sécurité. => ",a)}})}async function j(e,t=void 0,n=void 0,s=void 0){const i=e.objID;(i===void 0||i==="")&&console.warn("_3DSpace_download_doc() / Le paramètre objectId est obligatoire"),(e.space===""||!e.space)&&console.warn("_3DSpace_download_doc() / Le paramètre space est obligatoire");try{console.log("_3DSpace_download_doc / credentials",e),k(e,i,c=>{m(c,{headers:{ENO_CSRF_TOKEN:e.token},onComplete(o){const a=JSON.parse(o);t&&t(a)},onFailure(o,a,r){n&&(console.log("error http",o),n({error:o,headers:a,xhr:r}))}})},c=>{n&&n(c),console.log("*_3dspace_download_doc / error file URL *",c)})}catch(c){console.log("*_3dspace_download_doc / error file URL *",c)}}async function E(e,t,n=void 0,s=void 0){let i=[];for(let a=0;a<t.length;a+=80){const r=t.slice(a,a+80);i.push(r)}const o=a=>{G(e,i[a],()=>{a++,a<i.length&&o(a)},r=>{n&&n(r)})};o(0)}function G(e,t,n=void 0,s=void 0,i=void 0){const c=[];t.forEach(r=>{c.push({id:r})});let o=JSON.stringify({csrf:{name:"ENO_CSRF_TOKEN",value:e.token},data:c});const a=`${e.space}/resources/v1/modeler/documents/DownloadTicket?tenant=${e.tenant}&e6w-lang=fr&e6w-timezone=-120`;m(a,{method:"PUT",data:o,type:"json",onComplete(r){const d=r.data;r.success===!0&&(n&&n(),d.forEach(l=>{try{const p=l.dataelements.fileName,f=l.dataelements.ticketURL;m(f,{onComplete:g=>{s&&s({objectId:l.id,fileName:p,data:JSON.parse(g)})},onFailure:g=>{console.log("error http",g)}})}catch(p){console.log(p),i&&i(p)}}))},onFailure(r){console.log(r),i&&i(r)}})}function Se(e,t,n=void 0,s=void 0){return new Promise(i=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const c=`${e.space}/resources/v1/modeler/dslc/maturity/getNextStates`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,a=>e.ctx=a,a=>{console.log("onError =>",a)});let o={method:"POST",headers:{SecurityContext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{id:t}]}),type:"json",onComplete(a){n&&n(a)},onFailure(a){s&&s(a)}};m(c,o)}})}function he(e,t,n,s=void 0,i=void 0){return new Promise(c=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const o=`${e.space}/resources/v1/modeler/dslc/maturity/changeState`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,r=>e.ctx=r,r=>{console.log("onError =>",r)});let a={method:"POST",headers:{SecurityContext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{id:t,nextState:n}]}),type:"json",onComplete(r){s&&s(r)},onFailure(r){i&&i(r)}};m(o,a)}})}function ye(e,t,n=void 0,s=void 0){return new Promise(i=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const c=`${e.space}/resources/v1/dslc/versiongraph?withThumbnail=0&withIsLastVersion=0&withAttributes=0&withCopyFrom=0&tenant=${e.tenant}`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,a=>e.ctx=a,a=>{console.log("onError =>",a)});let o={method:"POST",headers:{securitycontext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({graphRequests:[{id:t}]}),type:"json",onComplete(a){n&&n(a)},onFailure(a){s&&s(a)}};m(c,o)}})}function we(e,t,n=void 0,s=void 0){return new Promise(i=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const c=`${e.space}/resources/lifecycle/revise/prepare_revise_maskattributes?tenant=${e.tenant}`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,a=>e.ctx=a,a=>{console.log("onError =>",a)});let o={method:"POST",headers:{SecurityContext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{"attribute[PLMReference.V_versionComment]":null,physicalid:t,type:"Document",tenant:e.tenant,objectId:t,policy:"Document Release",availableSemantic:["E","LAST","NEW","DUP"]}]}),type:"json",onComplete(a){n&&n(a)},onFailure(a){s&&s(a)}};m(c,o)}})}function Te(e,t,n,s=void 0,i=void 0){return new Promise(c=>{if(e.token===""&&D(e),t!==void 0&&t!==""&&t!==null){const o=`${e.space}/resources/lifecycle/revise/major?tenant=${e.tenant}`;N(e.space,"ESPACE COMMUN",["VPLMProjectLeader","VPLMCreator"],void 0,r=>e.ctx=r,r=>{console.log("onError =>",r)});let a={method:"POST",headers:{securitycontext:"ctx::"+e.ctx,ENO_CSRF_TOKEN:e.token,Accept:"application/json","Content-Type":"application/json"},data:JSON.stringify({data:[{physicalid:t,proposedRevision:n,modifiedAttributes:{revision:n}}],folderid:null,notificationTimeout:600}),type:"json",onComplete(r){s&&s(r)},onFailure(r){i&&i(r)}};m(o,a)}})}//!SECTION
3
3
  async function Ce(e,t,n){const s=`${e.space}/resources/v1/application/CSRF`;m(s,{onComplete(i){i=JSON.parse(i),t&&t(i.csrf)},onFailure(i,c,o){n&&n({error:i,headers:c,xhr:o})}})}function De(e,t=void 0,n=void 0){const s={base:`${e.space}`,uri:"/resources/bps/cspaces",optTenant:`tenant=${e.tenant}`},i=`${s.base}${s.uri}?${s.optTenant}`;m(i,{method:"GET",headers:{Accept:"application/json,text/javascript,*/*","Content-Type":"application/ds-json"},onComplete(c,o){const a=JSON.parse(c);t&&t(a,o)},onFailure(c,o,a){n&&n({response:c,headers:o,xhr:a})}})}function Oe(e,t,n,s){k(e.space,t,i=>{m(i,{header:{ENO_CSRF_TOKEN:e.token},onComplete:c=>{n&&n(c)},onFailure:c=>{console.log("error http",c),s&&s(c)}})},i=>{console.log("error file URL",i),s&&s(i)})}async function Ne(e,t,n=void 0,s=void 0){return new Promise(i=>{k(e.space,t,c=>{m(c,{onComplete:(o,a,r)=>(i(JSON.parse(o)),n&&n(JSON.parse(o),a,r),i),onFailure:(o,a,r)=>{s&&s(o,a,r),console.log(o,a?.errormsg)}})})})}function be(e,t,n,s=void 0,i=void 0){const c=new Blob([JSON.stringify(t)],{type:"text/plain"});F(e,n,o=>{const a=o.data[0].relateddata.files[0].id,r=o.data[0].dataelements.secondaryTitle!==""?o.data[0].dataelements.secondaryTitle:o.data[0].dataelements.title;L(e,n,a,c,r,d=>{s&&s(d)},d=>{i&&i(d)})})}let x,K;const W=[];async function Fe(e,t=void 0,n=void 0){e.objID&&e.objID!==""?F(e,s=>{t&&t(s)},s=>{n&&n(s)}):e.objID===null&&D(e,s=>{t&&t({rep:s,msg:"Pas d'objID, ou invalide"})},s=>{n&&n({msg:"Pas d'objID et erreur sur le Space",err:s})})}async function Ue(e,t=void 0,n=void 0){console.log("getDatasByTenant",e),await j(e,s=>{const i={};i.obj=s,X(e,c=>{i.datas=c,t&&t(i)},c=>{n&&n(c)})},s=>{n&&n(s)})}function X(e,t=void 0,n=void 0){const s=[];e.objIds.forEach((i,c)=>{j(e,i.objId,o=>{s.push({[i.name]:o}),i.name==="dbProjets"&&(x=o.affaires.map(a=>a.objectID),V(e,K)),c===e.objIds.length-1&&t&&t(s)},o=>{n&&n(o)})})}function V(e,t,n=void 0,s=void 0){E(e,x,i=>{const c=[...t];c.find(o=>o.objectID===i.objectId).data=i.data,K=c,W.push(i.data),n&&n(W)},i=>{s&&(s(i),console.log(i))})}const ke="FA35FB9B177A280065800EA0000F599C",Ae=["swym","3dspace","drive","usersgroup","3dplan","dashboard"],Y={how:"ds6w:how",what:"ds6w:what",when:"ds6w:when",where:"ds6w:where",who:"ds6w:who",why:"ds6w:why"},Ie={objId:ke,pred:"who",order_by:"desc",tag:"testTag"};function je(e,t,n=void 0,s=void 0){const{space:i,tenant:c}=e,{objId:o,pred:a,tag:r}=t,d={uri:"/resources/6w/tags",otpCTX:"SecurityContext=preferred",optTenant:`tenant=${c}`},l=`${i}${d.uri}?${d.otpCTX}&${d.optTenant}`,p={tag:[{subject:[{uri:`pid://${o}`}],predicate:Y[a],object:{literal:r}}]};m(l,{method:"PUT",headers:{"Content-Type":"application/json",Accept:"application/json"},data:JSON.stringify(p),onComplete(f){JSON.parse(f);const g={};setTimeout(()=>{P(e,o,_=>{const S=_.data[0].dataelements.title,h=_.data[0].dataelements.fileExtension!==void 0?_.data[0].dataelements.fileExtension:"",y=_.data[0].relateddata.ownerInfo[0].dataelements.name;g.name=S,g.ext=h,g.createBy=y,t.info={...g},Re(e,t,T=>{n&&n(T)},T=>{s&&s(T)})},(_,S)=>{const h=_;h.msg=S.errormsg,h.errCode=S.errorcode,console.log("❌ sendDirectMessage => ",h),s&&s(h)})},2e3)},onFailure(f,g){const _=f;_.msg=g.errormsg,_.errCode=g.errorcode,console.log("❌ sendDirectMessage => ",_),s&&s(_)}})}function Re(e,t,n=void 0,s=void 0){console.log("obj ",t);const i=t.info.name,c={baseUrl:`https://${e.tenant.toLowerCase()}-eu1-fedsearch.3dexperience.3ds.com`,uri:"/federated/search"},o=`${c.baseUrl}${c.uri}`,a={"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"},r=A(),d={with_indexing_date:!0,with_synthesis:!0,with_nls:!1,label:`3DSearch-${e.currentUser.username}-AjoutDeTagBeam-${r}`,locale:"fr",select_predicate:["ds6w:label","ds6w:type","ds6w:description","ds6w:identifier","ds6w:modified","ds6w:created","ds6wg:revision","ds6w:status","ds6w:responsible","owner","ds6w:responsibleUid","ds6wg:filesize","ds6w:project","ds6w:dataSource","ds6w:community","ds6w:originator","dsgeo:referential","ds6w:lastModifiedBy","ds6w:repository","dcterms:title","dcterms:description","ds6w:containerUid"],with_synthesis_hierarchical:!0,select_file:["icon","thumbnail_2d"],query:i,specific_source_parameter:{"3dspace":{additional_query:' AND NOT (owner:"ENOVIA_CLOUD" OR owner:"Service Creator" OR owner:"Corporate" OR owner:"User Agent" OR owner:"SLMInstallerAdmin" OR owner:"Creator" OR owner:"VPLMAdminUser") AND (ds6w_58_islastrevisionperstate:true OR NOT listoffields:ds6w_58_islastrevisionperstate)'},drive:{additional_query:' AND NOT ([flattenedtaxonomies]:"types/DriveNode" AND ( [current]:"Trashed" OR [policy]:"Drive File Iteration") )'}},select_exclude_synthesis:["ds6w:what/ds6w:topic"],order_by:Ie.order_by,order_field:"relevance",select_snippets:["ds6w:snippet","ds6w:label:snippet","ds6w:responsible:snippet","ds6w:community:snippet","swym:message_text:snippet"],nresults:40,start:"0",source:Ae,tenant:e.tenant,login:{"3dspace":{SecurityContext:e.ctx}}};console.log("dataPattern => ",d),m(o,{method:"POST",headers:a,data:JSON.stringify(d),onComplete(l){const p=JSON.parse(l);n(p)},onFailure(l,p){const f=l;f.msg=p.errormsg,f.errCode=p.errorcode,console.log("❌ sendDirectMessage => ",f),s&&s(f),console.log("Erreur de recuperation d'id du doc et des tags",l)}})}function $e(e,t,n=void 0,s=void 0){const{objId:i,pred:c,tag:o}=t,a={uri:"/resources/6w/tags",otpCTX:"SecurityContext=preferred",optTenant:`tenant=${e.tenant}`},r=`${e.space}${a.uri}?${a.otpCTX}&${a.optTenant}`,d={tag:[{subject:[{uri:`pid://${i}`}],predicate:Y[c],object:{literal:o}}]};m(r,{method:"DELETE",data:JSON.stringify(d),headers:{"Content-Type":"application/json",Accept:"application/json,text/javascript,*/*"},onComplete(l){n&&n(l)},onFailure(l,p){const f=l;f.msg=p.errormsg,f.errCode=p.errorcode,console.log("❌ sendDirectMessage => ",f),s&&s(f)}})}function ve(e,t="",n=void 0,s=void 0){const{space:i}=e;if(t==="")return;const c={uri:"/enovia/resources/v1/modeler/documents"},o={"Content-Type":"application/x-www-form-urlencoded; charset=UTF-8",Accept:"application/json,text/javascript,*/*"},a=`${i}${c.uri}`,r=`$include=none,lockerInfo,ownerInfo,originatorInfo,files,ownerInfo,originatorInfo&$fields=none,title,name,typeNLS,collabSpaceTitle,revision,isLatestRevision,files,lockStatus,lockerInfo.name,lockerInfo.firstname,lockerInfo.lastname,owner,ownerInfo.name,ownerInfo.firstname,ownerInfo.lastname,stateNLS,modified,policy,state,organizationTitle,originator,originatorInfo.name,originatorInfo.firstname,originatorInfo.lastname,hasModifyAccess,fileExtension,files.name,files.title,files.revision,files.locker,ownerInfo,ownerInfo.name,ownerInfo.firstname,ownerInfo.lastname,originatorInfo,originatorInfo.name,originatorInfo.firstname,originatorInfo.lastname&$ids=${t}`;m(a,{method:"POST",headers:o,data:r,onComplete(d){n&&n(JSON.parse(d))},onFailure(d,l){const p=d;p.msg=l.error,s&&s(p)}})}async function w(e,t=void 0,n=void 0){const s=e.space+"/api/index/tk";return m(s,{onComplete(i,c,o){const a=JSON.parse(i);if(t)return t(a),e.token=a?.result?.ServerToken},onFailure(i){n&&n(i)}})}function Me(e,t=void 0,n=void 0){const s=`${e.space}/api/exalead/whatsnew`,i={params:{community_id:null,hash_key:null,legacyFormat:!1,nresults:1,query:"#all",start:0}};w(e,c=>{m(s,{method:"POST",headers:{"X-DS-SWYM-CSRFTOKEN":c.result.ServerToken,"Content-type":"application/json;charset=UTF-8",Accept:"application/json"},data:JSON.stringify(i),type:"json",onComplete(o,a){t&&t(o,a)},onFailure(o,a){n&&n(o,a)}})})}function Pe(e,t=void 0,n=void 0){const s=`${e.space}/api/Recommendation/getpeoplefamiliartocurrentuser`,i={params:{idsToFilterArr:[],mode:"offline",limit:30,itemType:"User",maxNbOfCommonElements:"5"}};w(e,c=>{m(s,{method:"POST",headers:{"X-DS-SWYM-CSRFTOKEN":c.result.ServerToken,"Content-type":"application/json;charset=UTF-8",Accept:"application/json"},data:JSON.stringify(i),type:"json",onComplete(o,a){const r=o.result.hits.map(d=>({login:d.login,fullName:d.name}));t&&t(r,o)},onFailure(o,a){n&&n(o,a)}})})}function Le(e,t=void 0,n=void 0){const s={base:e.space,uri:"/api/community/listmycommunities",limit:`/limit/${e.limit?e.limit:128}`,page:`/page/${e.page?e.page:"1"}`},i=`${s.base}${s.uri}${s.limit}${s.page}`,c=[];w(e,o=>{m(i,{method:"GET",headers:{"X-DS-SWYM-CSRFTOKEN":o.result.ServerToken},onComplete(a,r,d){const p=JSON.parse(a).result;let f=0;p.forEach(g=>{const _={description:g.description,id:g.id,title:g.title,owner:g.owner,role:g.role,access:g.access};B(e,g.id,S=>{f++,_.members=S,c.push(_),f===p.length&&t&&t(c)},S=>n(S))})},onFailure(a,r){const d=a;d.status=r.status,d.response=r.errormsg,n&&n(d)}})})}function B(e,t,n,s){const i=`${e.space}/api/community/listmembers`,c={params:{page:e.page?e.page:1,limit:e.limit?e.limit:50,community_id:t}};w(e,o=>{m(i,{method:"POST",headers:{"Content-type":"application/json;charset=UTF-8",Accept:"application/json","X-DS-SWYM-CSRFTOKEN":o.result.ServerToken},data:JSON.stringify(c),type:"json",onComplete(a,r,d){n&&n(a)},onFailure(a,r){const d=a;d.status=r.status,d.response=r.errormsg,s&&s(d)}})})}function Je(e,t=void 0,n=void 0){const s="YXdA5x4DSUKtlAi2wmnyTA";e.commu_id||(e.commu_id=s);const i=`${e.space}/api/v2/communities/${e.commu_id}/ideas/statuses`;w(e,c=>{m(i,{method:"GET",headers:{"Content-type":"application/json;charset=UTF-8",Accept:"application/json","X-DS-SWYM-CSRFTOKEN":c.result.ServerToken},onComplete(o){const a=JSON.parse(o);t&&t(a)},onFailure(o,a){const r=o;r.status=a.status,r.response=a.errormsg,n&&n(r)}})})}function Ee(e,t,n=void 0,s=void 0){const{listAllContacts:i,currentUser:c}=e;console.log("__listAllContacts",i.hits);const o=`${e.space}/api/directmessages`,a={users:[c.login].concat(t.receipt)},r={id_msg:"",senderId:e.currentUser.login,senderName:`${e.currentUser.first_name} ${e.currentUser.last_name}`,msg:Ge(t.msg)};let d=!1;q(a.users,l=>{l!==void 0&&(r.id_msg=l.id,d=!0,R(e,r))},l=>{d=!1,console.log("_3dSwym_findCommunityToInstantMSG callback",l),s&&s(l),r.id_msg=""}),d===!1&&setTimeout(()=>{d===!1&&w(e,l=>{m(o,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json","X-DS-SWYM-CSRFTOKEN":l.result.ServerToken},data:JSON.stringify(a),type:"json",onComplete(p,f,g){const _=p;_.reponse=JSON.parse(g.response),_.status=g.status,n&&n(_),r.id_msg=_.result.id,R(e,r)},onFailure(p,f,g){const _=p;_.msg=f.errormsg,_.status=f.status,s&&s(_)}})})},500)}function q(e,t,n,s){const i=`${e.space}/api/directmessages/lite?with_favorites=false`;w(e,c=>{m(i,{method:"GET",headers:{Accept:"application/json,text/javascript,*/*","X-DS-SWYM-CSRFTOKEN":c.result.ServerToken},onComplete(o){const a=JSON.parse(o),r=[];a.result.forEach(p=>{p.users=p.users.sort((f,g)=>f.login.localeCompare(g.login)),p.users.length===t.length&&r.push(p)});const d=t.sort(),l=r.find(p=>{const f=[];return p.users.forEach(g=>{f.push(g.login)}),JSON.stringify(f)===JSON.stringify(d)});n&&l!==void 0?n(l):(s||l===void 0)&&s(l)},onFailure(o){const a=o;a.msg=headers.errormsg,a.errCode=headers.errorcode,console.log("❌ sendDirectMessageLite => ",a),s&&s(a)}})})}function R(e,t,n=void 0,s=void 0){const i={base:e.space,uri:"/api/community",id_msg:`${t.id_msg}`,endUri:"/instantmessages"},c=`${i.base}${i.uri}/${i.id_msg}${i.endUri}`,o={author:{login:t.senderId,displayName:t.senderName},accessState:null,commentUri:null,comments:null,endorsements:null,moderationState:null,parentCommentUri:null,richMessage:t.msg};console.log("_3dSwym_sendDirectMessageData url ",c),w(e,a=>{m(c,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json","X-DS-SWYM-CSRFTOKEN":a.result.ServerToken},data:JSON.stringify(o),type:"json",onComplete(r,d,l){const p=r;p.status=l.status,p.response=JSON.parse(l.response),console.log("✅ _3dSwym_sendDirectMessageData => ",p),n&&n(p)},onFailure(r,d){const l=r;l.msg=d.errormsg,l.errCode=d.errorcode,console.log("❌ sendDirectMessage => ",l),s&&s(l)}})})}function Ge(e){const t=new Date().toLocaleDateString(),n=new Date().toLocaleTimeString();return`<p>${e} </p>
4
4
  <br/>
5
5
  <hr/>
@@ -76,4 +76,4 @@ async function Ce(e,t,n){const s=`${e.space}/resources/v1/application/CSRF`;m(s,
76
76
  </tbody></table>
77
77
  <p>
78
78
  </p>`:e}function Be(e,t=void 0,n=void 0){const s=e.space+"/api/user/getcurrent/";w(e,i=>{m(s,{method:"GET",headers:{"X-DS-SWYM-CSRFTOKEN":i.result.ServerToken},onComplete(c,o,a){const r=JSON.parse(c);t&&t(r.result)},onFailure(c,o,a){n&&n({response:c,headers:o,xhr:a})}})},n)}function qe(e,t,n=void 0,s=void 0){const i=e.space+"/api/user/find/login/"+t;w(e,c=>{m(i,{method:"GET",headers:{"X-DS-SWYM-CSRFTOKEN":c.result.ServerToken},onComplete(o,a,r){const d=JSON.parse(o);n&&n(d)},onFailure(o){s&&s(o)}})},s)}function He(e){const t="Hello "+e;return console.log(t),t}u.UUID=A,u._3DSpace_Create_Doc=_e,u._3DSpace_csrf=D,u._3DSpace_download_doc=j,u._3DSpace_download_multidoc=E,u._3DSpace_file_update=L,u._3DSpace_file_update_csr=J,u._3DSpace_file_url=k,u._3DSpace_file_url_csr=ge,u._3DSpace_get_csrf=F,u._3DSpace_get_docInfo=P,u._3DSpace_get_downloadTicket_multidoc=G,u._3DSpace_get_securityContexts=N,u._3DSpace_lifecycle_changeRevision=Te,u._3DSpace_lifecycle_changeState=he,u._3DSpace_lifecycle_getGraph=ye,u._3DSpace_lifecycle_getNextRevision=we,u._3DSpace_lifecycle_getNextStates=Se,u._3DSwim_getAllCommunities=Le,u._3DSwim_getMembersCommunity=B,u._3DSwym_buildDirectMessage=Ee,u._3DSwym_deleteIdea=We,u._3DSwym_findCommunityToInstantMSG=q,u._3DSwym_getAllNews=Me,u._3DSwym_getFamiliarPeople=Pe,u._3DSwym_getIdeaStatusMaturity=Je,u._3DSwym_getSWYMIdea=Xe,u._3DSwym_get_AllSWYMIdeas=Ve,u._3DSwym_get_currentUser=Be,u._3DSwym_get_findUser=qe,u._3DSwym_get_version=w,u._3DSwym_postIdea=Ke,u._3DSwym_sendMessageData=R,u._AppMngt_get_info_user=re,u._AppMngt_get_users=oe,u._getPlateformInfos=ae,u._getPlatformServices=se,u._httpCallAuthenticated=m,u._setDraggable=ee,u._setDroppable=ne,u._setupTagger=te,u.addTagToDoc=je,u.compass_getListAdditionalApps=ie,u.couleurs=v,u.createUserGroups=ce,u.dataMixing=V,u.deleteUserGroups=ue,u.findAdresse=z,u.getAllContextSecurity=De,u.getCSRFToken=Ce,u.getCommunes=H,u.getComplementUG=de,u.getDataFrom3DSpace=Oe,u.getDataFromGouvFr=Q,u.getDatasByTenant=Ue,u.getDatasFrom3DSpace=X,u.getDownloadDocument=Ne,u.getInfoDocTags=ve,u.getUserGroupsList=le,u.getUsersGroupRules=M,u.get_3DSpace_csrf=Fe,u.patchUserGroups=pe,u.patchUserGroupsControl=fe,u.pushDataIn3DSpace=be,u.readUserGroupControl=me,u.removeTagToDoc=$e,u.sayHello=He,u.updateEvent=Z,Object.defineProperty(u,Symbol.toStringTag,{value:"Module"})});
79
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"wb3Api.umd.cjs","sources":["../src/lib/api/index.js","../src/lib/gouv/colors.js","../src/lib/gouv/gouv_api.js","../src/lib/utils/updateEvent.js","../src/lib/plateform/main/3dexperience_api.js","../src/lib/plateform/Compass/index.js","../src/lib/plateform/main/3dcompass_api.js","../src/lib/plateform/Usersgroup/index.js","../src/lib/plateform/main/3dspace_api.js","../src/lib/plateform/main/getCSRFToken.js","../src/lib/plateform/main/getCTX.js","../src/lib/plateform/main/getDataFrom3DSpace.js","../src/lib/plateform/main/getDownloadDocument.js","../src/lib/plateform/main/pushDataIn3DSpace.js","../src/lib/plateform/main/loadDatas.js","../src/lib/plateform/Tag/index.js","../src/lib/plateform/Swym/3dswym_api.js","../src/lib/plateform/Swym/communaute/index.js","../src/lib/plateform/Swym/idea/index.js","../src/lib/plateform/Swym/user/index.js","../src/lib/add/index.js"],"sourcesContent":["import { v4 as uuid } from \"uuid\";\r\n/**\r\n * @description La fonction UUID génère un UUID (Universally Unique Identifier) aléatoire.\r\n * @returns La fonction UUID renvoie un UUID (Universally Unique Identifier) généré aléatoirement à l'aide de la fonction uuid.\r\n *\r\n */\r\nexport function UUID() {\r\n  return uuid();\r\n}\r\n","// pour les charts Piveteau\r\nexport const couleurs = {\r\n  b3M3Yellow: \"#FFB300\",\r\n  b3AboutageBlue: \"#42A5F5\",\r\n  b3UsinageGreen: \"#689F38\",\r\n  b3PanneauOrange: \"#ff8000\",\r\n  b3M350percent: \"#fafa6e\",\r\n  b3M380percent: \"#aae479\",\r\n  b3M390percent: \"#64c987\",\r\n  b3M3100percent: \"#23aa8f\",\r\n  b3M3105percent: \"#00898a\",\r\n  b3M3110percent: \"#176877\",\r\n  b3M3120percent: \"#2a4858\",\r\n  b3Aboutage50percent: \"#fafa6e\",\r\n  b3Aboutage80percent: \"#aae479\",\r\n  b3Aboutage90percent: \"#64c987\",\r\n  b3Aboutage100percent: \"#23aa8f\",\r\n  b3Aboutage105percent: \"#00898a\",\r\n  b3Aboutage110percent: \"#176877\",\r\n  b3Aboutage120percent: \"#2a4858\",\r\n  b3Warning: \"#FF0000\",\r\n  b3Edit1: \"#AD1457\",\r\n  b3Edit2: \"#F4511E\",\r\n  b3Edit3: \"#009688\",\r\n  b3Edit4: \"#D50000\",\r\n  b3Edit5: \"#039BE5\",\r\n  b3Edit6: \"#9E69AF\",\r\n  b3Edit7: \"#A79B8E\",\r\n  b3Edit8: \"#616161\",\r\n  b3Edit9: \"#795548\",\r\n};\r\n","import { DateTime } from \"luxon\";\r\nimport { couleurs } from \"./colors\";\r\n/**\r\n * Cette fonction récupère une liste de communes en fonction d'un code postal donné à l'aide d'une API\r\n * d'IGN France.\r\n * @param {String} cp - Le paramètre `cp` est une chaîne représentant un code postal français. Il est converti\r\n * en entier à l'aide de `parseInt()` avant d'être utilisé dans la requête API.\r\n * @param { Function } - onDone est une fonction de rappel qui sera exécutée lorsque l'appel API réussit et\r\n * renvoie une réponse. Il prend les données de réponse comme argument et peut être utilisé pour gérer\r\n * les données dans la fonction appelante.\r\n * @param { Function } - Le paramètre `onError` est une fonction de rappel qui sera exécutée s'il y a une\r\n * erreur lors de la requête de récupération. Il permet une gestion personnalisée des erreurs et peut\r\n * être utilisé pour afficher des messages d'erreur ou effectuer d'autres actions en réponse à une\r\n * erreur.\r\n */\r\nexport async function getCommunes(cp, onDone = undefined, onError = undefined) {\r\n  const codePostal = parseInt(cp);\r\n  await fetch(\r\n    \"https://apicarto.ign.fr/api/codes-postaux/communes/\" + codePostal,\r\n    {\r\n      method: \"GET\",\r\n      headers: {\r\n        Accept: \"application/json\",\r\n      },\r\n    },\r\n  )\r\n    .then((response) => response.json())\r\n    .then((json) => {\r\n      if (onDone) onDone(json);\r\n    })\r\n    .catch((error) => {\r\n      if (onError) onError(error);\r\n      console.error(\"Erreur : \" + error);\r\n    });\r\n}\r\n\r\n/**\r\n * Il s'agit d'une fonction JavaScript qui utilise l'API-adresse.data.gouv.fr pour rechercher des\r\n * adresses à partir d'une requête et renvoie les résultats au format JSON.\r\n * @param { String } query - L'adresse ou la requête d'emplacement à rechercher dans l'API.\r\n * @param { Function } - onDone est une fonction de rappel qui sera exécutée lorsque l'appel API réussit et\r\n * renvoie une réponse. Il prend la réponse JSON comme paramètre.\r\n * @param { Function } - Le paramètre `onError` est une fonction de rappel qui sera exécutée s'il y a une\r\n * erreur lors de l'appel de l'API. C'est un paramètre optionnel qui peut être passé à la fonction\r\n * `findAdresse`. S'il est fourni, il recevra l'objet d'erreur comme argument.\r\n */\r\nexport async function findAdresse(\r\n  query,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // https://api-adresse.data.gouv.fr/search/?q=\r\n  query = encodeURIComponent(query);\r\n  await fetch(\r\n    \"https://api-adresse.data.gouv.fr/search/?q=\" + query + \"&limit=15\",\r\n    {\r\n      method: \"GET\",\r\n      headers: {\r\n        Accept: \"application/json\",\r\n      },\r\n    },\r\n  )\r\n    .then((response) => response.json())\r\n    .then((json) => {\r\n      if (onDone) onDone(json);\r\n    })\r\n    .catch((error) => {\r\n      if (onError) onError(error);\r\n      console.error(\"Erreur : \" + error);\r\n    });\r\n}\r\n\r\n/**\r\n * @description La fonction `getDataFromGouvFr` récupère les données de l'API du gouvernement français pour les\r\n * jours fériés et les formate dans une structure de données spécifique.\r\n * @param events - Le paramètre `events` est un tableau d'objets représentant des événements. (store.loadedEvents)\r\n * @param colors - Le paramètre `colors` est un objets représentant des couleurs. (Piveteau)\r\n * @returns les données formatées, qui incluent les événements récupérés depuis le point de terminaison\r\n * API \"https://calendrier.api.gouv.fr/jours-feries/metropole/\". Les événements sont formatés dans une\r\n * structure spécifique et renvoyés sous forme d'objet.\r\n */\r\nexport async function getDataFromGouvFr(events, colors = couleurs) {\r\n  let year = DateTime.now().year;\r\n  const loadedEvents = events;\r\n  const sortedData = [];\r\n\r\n  const formatData = (json) => {\r\n    for (let date in json) sortedData.push({ date, comment: json[date] });\r\n  };\r\n\r\n  for (let i = year; i <= year + 1; i++) {\r\n    await fetch(\r\n      \"https://calendrier.api.gouv.fr/jours-feries/metropole/\" + i + \".json\",\r\n      {\r\n        method: \"GET\",\r\n        headers: {\r\n          Accept: \"application/json\",\r\n        },\r\n      },\r\n    )\r\n      .then((response) => response.json())\r\n      .then((json) => {\r\n        formatData(json);\r\n      })\r\n      .catch((error) => console.error(\"Erreur : \" + error));\r\n  }\r\n\r\n  const formatedData = () => {\r\n    const data =\r\n      loadedEvents.length === 0\r\n        ? {\r\n            events: [],\r\n          }\r\n        : loadedEvents;\r\n    for (let each of sortedData) {\r\n      const index = data.events.findIndex(\r\n        (event) =>\r\n          event.start === DateTime.fromISO(each.date).toISODate() &&\r\n          event.name === \"Férié : \" + each.comment,\r\n      );\r\n\r\n      if (index === -1)\r\n        data.events.push({\r\n          name: \"Férié : \" + each.comment,\r\n          start: DateTime.fromISO(each.date).toISODate(),\r\n          end: DateTime.fromISO(each.date).toISODate(),\r\n          color: colors.b3BusinnessDays,\r\n          timed: false,\r\n        });\r\n    }\r\n    return data;\r\n  };\r\n\r\n  return formatedData();\r\n}\r\n","/**\r\n * @description La fonction `updateEvent` met à jour un tableau d'événements en ajoutant ou en supprimant un\r\n * événement en fonction d'une condition donnée.\r\n * @param {Array} events - (store.loadedEvents)Une panoplie d'événements. Chaque événement est un objet avec des propriétés telles que uuid, start, end, etc.\r\n *\r\n * @param {Object} data - Le paramètre `data` est un objet qui représente l'événement à mettre à jour.\r\n * @param {String}[data.uuid] - L'identifiant unique de l'événement.\r\n * @param {Boolean} [add=true] - Le paramètre \"add\" est une valeur booléenne qui détermine s'il faut ajouter ou\r\n * mettre à jour un événement dans le tableau des événements. Si add est vrai, la fonction ajoutera\r\n * l'événement au tableau s'il n'existe pas déjà. Si add est faux, la fonction mettra à jour\r\n * l'événement existant dans le tableau\r\n * @returns le tableau `db` (store.loadedEvents) mis à jour.\r\n */\r\nexport async function updateEvent(events, data, add = true) {\r\n  const index = events.events.findIndex((val) => val.uuid === data.uuid);\r\n\r\n  if (index === -1) {\r\n    events.events.push(data);\r\n  } else {\r\n    if (add) events.events[index] = data;\r\n    else events.events.splice(index, 1);\r\n  }\r\n\r\n  if (events.length > 0) events.sort((a, b) => a.start - b.start);\r\n\r\n  return events;\r\n}\r\n","import { widget, requirejs } from \"@widget-lab/3ddashboard-utils\";\r\n\r\n/**\r\n * @description Cette fonction effectue un appel HTTP authentifié à l'aide de la bibliothèque WAFData en de la plateforme.\r\n * @param {String} url - L'URL du point de terminaison de l'API que la fonction appellera.\r\n * @param {object} options - Le paramètre `options` est un objet qui contient diverses options pour la requête\r\n * HTTP, telles que la méthode de requête (GET, POST, etc.), les en-têtes, le corps, etc. Ces options\r\n * sont généralement transmises à l'API `fetch` ou `XMLHttpRequest` pour effectuer la requête HTTP\r\n * réelle.\r\n */\r\nexport function _httpCallAuthenticated(url, options) {\r\n  requirejs([\"DS/WAFData/WAFData\"], (WAFData) => {\r\n    WAFData.authenticatedRequest(url, options);\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction définit un élément comme étant déplaçable et transmet des données et une fonction de\r\n * rappel à exécuter lorsque le glissement commence (drag and drop).\r\n * @param elem - L'élément HTML qui doit être rendu déplaçable.\r\n * @param strData - strData est une chaîne qui représente les données associées à l'élément déplaçable.\r\n * Ces données sont accessibles lors des opérations de glisser-déposer pour fournir des informations\r\n * supplémentaires sur l'élément déplacé.\r\n * @param onDrag - onDrag est une fonction de rappel qui sera exécutée au début de l'opération de\r\n * glissement. Il peut être utilisé pour effectuer toutes les actions nécessaires avant le début de\r\n * l'opération de glissement, telles que la configuration des données à transférer ou la mise à jour de\r\n * l'apparence de l'élément déplaçable.\r\n */\r\nexport function _setDraggable(elem, strData, onDrag) {\r\n  requirejs([\"DS/DataDragAndDrop/DataDragAndDrop\"], (DataDragAndDrop) => {\r\n    DataDragAndDrop.draggable(elem, { data: strData, start: onDrag });\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction configure un proxy de navigateur de balises avec des balises spécifiées et un événement de filtre facultatif.\r\n *\r\n * @param tags - Le paramètre tags est un tableau de chaînes représentant les balises qui seront\r\n * utilisées pour filtrer les sujets dans le widget TagNavigatorProxy.\r\n * @param [onTaggerFilter] - Le paramètre onTaggerFilter est une fonction de rappel qui sera exécutée\r\n * lorsque l'utilisateur filtrera les sujets dans le tagger. Il recevra les sujets filtrés en argument.\r\n */\r\nexport function _setupTagger(tags, onTaggerFilter = undefined) {\r\n  requirejs([\"DS/TagNavigatorProxy/TagNavigatorProxy\"], (TagNavigatorProxy) => {\r\n    let taggerProxy;\r\n    if (taggerProxy === undefined) {\r\n      taggerProxy = TagNavigatorProxy.createProxy({\r\n        widgetId: widget.id,\r\n        filteringMode: \"WithFilteringServices\",\r\n      });\r\n\r\n      if (onTaggerFilter !== undefined)\r\n        taggerProxy.addEvent(\"onFilterSubjectsChange\", onTaggerFilter);\r\n    }\r\n    taggerProxy.setSubjectsTags(tags);\r\n  });\r\n}\r\n\r\n/**\r\n * Cette fonction définit un élément comme pouvant être déposé à l'aide de la bibliothèque\r\n * DataDragAndDrop.\r\n * @param elem - L'élément HTML qui doit être rendu déposable.\r\n * @param drop - Le paramètre `drop` est une fonction qui sera appelée lorsqu'un élément déplaçable est\r\n * déposé sur l'élément déplaçable. Il prend généralement l'élément supprimé comme argument et exécute\r\n * une action basée sur celui-ci.\r\n */\r\nexport function _setDroppable(elem, drop) {\r\n  requirejs([\"DS/DataDragAndDrop/DataDragAndDrop\"], (DataDragAndDrop) => {\r\n    DataDragAndDrop.droppable(elem, { drop });\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction asynchrone obtient les services de la plateforme à l'aide de la bibliothèque i3DXCompassServices et appelle les fonctions onComplete ou onFailure en fonction du résultat.\r\n *\r\n * @param platformId - ID de la plate-forme pour laquelle les services sont demandés. Si aucun ID de\r\n * plate-forme n'est fourni, la fonction tentera de récupérer l'ID à partir d'une valeur de widget. Si\r\n * aucun ID n'est trouvé, il sera défini sur `undefined`.\r\n * @param onComplete - Une fonction de rappel qui sera exécutée lorsque les services de la plateforme\r\n * seront récupérés avec succès. Il prend les services de plateforme récupérés comme argument.\r\n * @param onFailure - Le paramètre onFailure est une fonction de rappel qui sera exécutée en cas\r\n * d'erreur ou d'échec dans l'exécution de la fonction getPlatformServices. Il permet de gérer les\r\n * erreurs et de fournir un retour d'information approprié à l'utilisateur.\r\n */\r\nexport async function _getPlatformServices(\r\n  platformId,\r\n  onComplete = undefined,\r\n  onFailure = undefined,\r\n) {\r\n  requirejs(\r\n    [\"DS/i3DXCompassServices/i3DXCompassServices\"],\r\n    (i3DXCompassServices) => {\r\n      if (!platformId || platformId === \"\") {\r\n        platformId = widget.getValue(\"PlatFormInstanceId\");\r\n      }\r\n      if (!platformId || platformId === \"\") {\r\n        platformId = undefined;\r\n      }\r\n      if (onComplete) {\r\n        onComplete(\r\n          i3DXCompassServices.getPlatformServices({\r\n            platformId,\r\n            onComplete,\r\n            onFailure,\r\n          }),\r\n        );\r\n      }\r\n    },\r\n  );\r\n}\r\n\r\n/**\r\n * @description\r\n *  La fonction `_getPlateformInfos` récupère les informations sur la plateforme à l'aide du module\r\n * PlatformAPI et renvoie les informations dans un objet.\r\n * @returns un objet appelé \"retourAPI\" qui contient les propriétés suivantes :\r\n * - {String} tenant, Le tenant de la plateforme sur lequel on travaille.\r\n * - {Object} user, L'utilisateur connecté à la plateforme...\r\n * - {ArrayOfObject} appsConfiguration, liste d'app auquel on accès.\r\n * - {String} appConf\r\n *\r\n */\r\nexport function _getPlateformInfos() {\r\n  let retourAPI = {};\r\n\r\n  requirejs([\"DS/PlatformAPI/PlatformAPI\"], (plAPI) => {\r\n    const tenant = plAPI.getTenant();\r\n    const user = plAPI.getUser();\r\n    const appsConfiguration = plAPI.getAllApplicationConfigurations();\r\n    const appConf = plAPI.getApplicationConfiguration(\r\n      \"com.3ds.wp.passport.cors\",\r\n    );\r\n    retourAPI = {\r\n      tenant,\r\n      user,\r\n      appsConfiguration,\r\n      appConf,\r\n    };\r\n  });\r\n  console.log(\"%cRETOUR API :\", \"color:blue\", retourAPI);\r\n  return retourAPI;\r\n}\r\n","import { _httpCallAuthenticated } from \"../main/3dexperience_api\";\r\n/**\r\n * @description La fonction `compass_getListAdditionalApps` effectue une requête HTTP GET authentifiée pour\r\n * récupérer une liste d'applications supplémentaires en fonction des informations d'identification\r\n * fournies.\r\n * @param {Object} credentials Un objet contenant les informations d'identification nécessaires à\r\n * l'authentification. Il doit avoir les propriétés suivantes : space, token\r\n * @property {String} [space] - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace, 3DSwym, 3DCompass...)\r\n * @property {String} [tenant] - le tenant courant (ex: R1132100968447)\r\n * @param onDone - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque l'appel\r\n * d'API réussit et que les données de réponse sont formatées. Il prend deux arguments :\r\n * `formatedInfos` et `info`. `formatedInfos` est un tableau d'objets contenant le nom et l'identifiant\r\n * de chaque application,\r\n * @param onError - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de la requête HTTP. Il prend un paramètre, « info », qui est un objet contenant des\r\n * informations sur l'erreur.\r\n */\r\n\r\nexport function compass_getListAdditionalApps(credentials, onDone, onError) {\r\n  const URL = {\r\n    base: `${credentials.space}`,\r\n    uri: \"/resources/AppsMngt/api/custom/applications\",\r\n    option: `?filter=${credentials.tenant}`, // facultatif\r\n  };\r\n  const url = `${URL.base}${URL.uri}${URL.option}`;\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"GET\",\r\n    headers: {\r\n      \"Content-Type\": \"application/json\",\r\n      Accept: \"application/json\",\r\n    },\r\n    onComplete(response, headers, xhr) {\r\n      const info = JSON.parse(response);\r\n      const formatedInfos = info.data.map((app) => {\r\n        const name = app.attributes.name;\r\n        const id = app.id;\r\n        return { name, id };\r\n      });\r\n\r\n      if (onDone) onDone(formatedInfos, info);\r\n    },\r\n    onFailure(response, headers) {\r\n      const info = response;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n","import { _httpCallAuthenticated } from \"./3dexperience_api.js\";\r\n\r\n/**\r\n * @description La fonction `_AppMngt_get_users` effectue un appel HTTP authentifié pour récupérer une liste\r\n * d'utilisateurs d'une plateforme spécifiée.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex:1132100968447)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque l'appel\r\n * API sera terminé avec succès. Il prend un argument, « info », qui correspond aux données de réponse\r\n * de l'API.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de la requête HTTP. Il est facultatif et peut être indéfini. S'il est fourni, il sera\r\n * appelé avec l'objet de réponse comme argument.\r\n */\r\nexport function _AppMngt_get_users(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  let url = `${credentials.space}/resources/AppsMngt/user?platform=${credentials.tenant}&limit=-1`;\r\n\r\n  _httpCallAuthenticated(url, {\r\n    onComplete(response, headers, xhr) {\r\n      const info = JSON.parse(response);\r\n      console.log(\"_AppMngt_get_users => \", info);\r\n      if (onDone) onDone(info);\r\n    },\r\n    onFailure(response, headers) {\r\n      const info = response;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_AppMngt_get_info_user` effectue un appel HTTP authentifié pour récupérer des\r\n * informations sur un utilisateur à partir d'une plateforme spécifique.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} id - Le paramètre `id` est l'identifiant unique de l'utilisateur pour lequel vous souhaitez\r\n * récupérer des informations.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête sera terminée avec succès. Il prend un argument, «info», qui correspond aux données de réponse du serveur.\r\n *\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de la requête HTTP. Il est facultatif et peut être indéfini. S'il est fourni, il sera\r\n * appelé avec le paramètre `response`, qui contient la réponse d'erreur du serveur.\r\n */\r\nexport function _AppMngt_get_info_user(\r\n  credentials,\r\n  id,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  let url = `${credentials.space}/resources/AppsMngt/user?platform=${credentials.tenant}&id=${id}`;\r\n\r\n  _httpCallAuthenticated(url, {\r\n    onComplete(response, headers, xhr) {\r\n      const info = JSON.parse(response);\r\n      //console.log(\"_AppMngt_get_info_user => \", info);\r\n      if (onDone) onDone(info);\r\n    },\r\n\r\n    onFailure(response, headers) {\r\n      const info = response;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n","import { _httpCallAuthenticated } from \"../main/3dexperience_api\";\r\n\r\n//LINK - https://media.3ds.com/support/documentation/developer/Cloud/en/English/CAAi3DXUGREST/UsersGroup_v1.htm#\r\n//!SECTION, Pour faire des modification de UG il faut être OWNER\r\n\r\n// URI de test sur le tenant PIVETEAU_TEST:\r\nconst _uri = \"uuid:3fcb61f2-6417-476d-8a9c-a16fb888771e\";\r\n\r\nconst topHeader = {\r\n  \"Content-Type\": \"application/json\",\r\n  Accept: \"application/json,text/javascript,*/*\",\r\n};\r\n\r\n/**\r\n * @description La fonction `createUserGroups` crée un nouveau groupe d'utilisateurs avec les détails et les membres\r\n * spécifiés. Attention, l'indexation du UserGroup met du temps.\r\n\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {Object} credentials.currentUser.email - Le paramètre `currentUser` est un qui contient les informations de l'utilisateur qui envoie le message(appeler depuis la fonction `_3DSwym_get_currentuser`).\r\n * \r\n * @param {Object} datas - Les informations du groupe d'utilisateurs.\r\n * @param {String} datas.title - Le titre du groupe d'utilisateurs. Entre 3 et 128 caractères, obligatoire.\r\n * @param {String} datas.description - La description du groupe d'utilisateurs. 512 caractères max.\r\n * @param {Array} datas.members - Un tableau d'emails des membres du groupe d'utilisateurs. 100 max email par groupe.\r\n * @param {String} datas.sharing - Le droit de partage du groupe d'utilisateurs. owner/manager/viewer\r\n * @param {String} datas.visibility - La visibilité du groupe d'utilisateurs. public/private\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque l'appel d'API réussit et que les\r\n * groupes d'utilisateurs sont créés. Il recevra les données de réponse comme argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `createUserGroups`. Il vous permet de gérer et de traiter\r\n * l'erreur de manière personnalisée.\r\n */\r\nexport function createUserGroups(\r\n  credentials,\r\n  datas,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space, currentUser } = credentials;\r\n  const URL = {\r\n    URIUGr: \"/3drdfpersist/resources/v1/usersgroup\",\r\n  };\r\n  const url = `${space}${URL.URIUGr}`;\r\n\r\n  const templateData = {\r\n    groups: [\r\n      {\r\n        title: datas.title,\r\n        description: datas.description,\r\n        members: datas.members || [currentUser.email, \"samuel.mureau@beam3.fr\"],\r\n        pending_members: [],\r\n        sharing: datas.sharing,\r\n        visibility: datas.visibility,\r\n      },\r\n    ],\r\n  };\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"POST\",\r\n    headers: topHeader,\r\n    data: JSON.stringify(templateData),\r\n    onComplete(response) {\r\n      if (onDone) onDone(JSON.parse(response));\r\n    },\r\n    onFailure(err, headers) {\r\n      console.log(err);\r\n      const info = err;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n      console.log(\"❌ sendDirectMessage => \", info);\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `getComplementUG` effectue une requête GET vers un URI spécifié avec les informations\r\n * d'authentification et renvoie la réponse.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n * @param {String} [uri] - Le paramètre `uri` est l'identifiant de la ressource dont vous souhaitez récupérer le\r\n * complément. (ex: uuid:dcad14cc-5bcd-45fd-a54d-246b95047d45)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête HTTP sera terminée avec succès. Il prend un argument, qui correspond aux données de réponse\r\n * de la requête.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `getComplementUG`. Il vous permet de gérer et de traiter\r\n * les informations d'erreur.\r\n */\r\nexport function getComplementUG(\r\n  credentials,\r\n  uri,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space, tenant } = credentials;\r\n  const baseURL = space;\r\n  const URI = `/3drdfpersist/v1/resources/${uri}`;\r\n  const OPTs = `?$mask=dsaccess:Mask.GroupUI.Properties&tenant=dstenant:${tenant}`;\r\n  const URL = `${baseURL}${URI}${OPTs}`;\r\n\r\n  const headers = {\r\n    \"Content-Type\": \"application/json\",\r\n    Accept: \"application/json,text/javascript,*/*\",\r\n  };\r\n  const opts = {\r\n    method: \"GET\",\r\n    headers: headers,\r\n  };\r\n\r\n  _httpCallAuthenticated(URL, {\r\n    opts,\r\n    onComplete(response) {\r\n      if (onDone) onDone(JSON.parse(response));\r\n    },\r\n    onFailure(err, headers) {\r\n      const info = err;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `getUsersGroupRules` effectue une requête HTTP GET pour récupérer une liste de\r\n * responsabilités de groupe pour un groupe d'utilisateurs.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête HTTP sera terminée avec succès. Il faut un argument, qui correspond aux données de réponse\r\n * analysées au format JSON.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `getUsersGroupRules`. C'est un paramètre facultatif, donc\r\n * s'il n'est pas fourni, la fonction ne fera rien en cas d'erreur.\r\n */\r\nexport function getUsersGroupRules(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space, tenant } = credentials;\r\n  const baseURL = space;\r\n  const URI =\r\n    \"/3drdfpersist/resources/v1/option-sets/dsusergroup:ListOfGroupResponsibilities/options\";\r\n  const OPTS = `?tenant=dstenant:${tenant}`;\r\n  const OPTsH = {\r\n    method: \"GET\",\r\n    Accept: \"application/json,*/*,test/javascript\",\r\n  };\r\n  const URL = `${baseURL}${URI}${OPTS}`;\r\n\r\n  _httpCallAuthenticated(URL, {\r\n    OPTsH,\r\n    onComplete(response) {\r\n      if (onDone) onDone(JSON.parse(response));\r\n    },\r\n    onFailure(err, headers) {\r\n      const info = err;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction « getUserGroupsList » récupère une liste de groupes d'utilisateurs d'un serveur en\r\n * utilisant les informations d'identification fournies et appelle la fonction de rappel « onDone »\r\n * avec la réponse.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n * @param {Object} credentials.currentUser.email - Le paramètre `currentUser` est un qui contient les informations de l'utilisateur qui envoie le message(appeler depuis la fonction `_3DSwym_get_currentuser`)\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque l'opération sera terminée avec\r\n * succès. Il recevra la réponse en paramètre.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `getUserGroupsList`. Il vous permet de gérer et de\r\n * répondre à toute erreur qui se produit.\r\n */\r\nexport function getUserGroupsList(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space, currentUser } = credentials;\r\n  const URI = \"/3drdfpersist/resources/v1/usersgroup\";\r\n  const opt =\r\n    \"?select=uri,title,description,owner,members,pending_members,creation_date,modification_date,visibility\";\r\n  const url = `${space}${URI}${opt}`;\r\n  const header = {\r\n    \"Content-Type\": \"application/json\",\r\n    Accept: \"application/json,text/javascript,*/*\",\r\n  };\r\n  const opts = { method: \"GET\", headers: header };\r\n  try {\r\n    _httpCallAuthenticated(url, {\r\n      opts,\r\n      onComplete(response) {\r\n        const repUG = JSON.parse(response);\r\n        const reponse = {};\r\n        const UG = repUG.groups.filter((element) => {\r\n          return element.uri.startsWith(\"uuid:\");\r\n        });\r\n\r\n        if (currentUser && Object.keys(currentUser).length > 0) {\r\n          const iamOwner = UG.filter((element) => {\r\n            return element.owner === currentUser.email;\r\n          });\r\n          const iamMember = UG.filter((element) => {\r\n            return element.members.includes(currentUser.email);\r\n          });\r\n          const iam = iamOwner.concat(iamMember);\r\n          reponse[\"iam\"] = iam;\r\n          reponse[\"UG\"] = UG;\r\n          reponse[\"iamMember\"] = iamMember;\r\n\r\n          getUsersGroupRules(\r\n            credentials,\r\n            (rules) => {\r\n              reponse[\"rules\"] = rules;\r\n              if (onDone) onDone(reponse);\r\n            },\r\n            (err) => {\r\n              if (onError) onError(err);\r\n            },\r\n          );\r\n        }\r\n      },\r\n      onFailure(err) {\r\n        if (onError) onError(err);\r\n      },\r\n    });\r\n  } catch (error) {\r\n    console.log(error);\r\n  }\r\n}\r\n\r\n/**\r\n * @description La fonction deleteUserGroups est utilisée pour supprimer des groupes d'utilisateurs à l'aide des\r\n * informations d'identification et de l'URI fournis.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} [uri] - Le paramètre `uri` est l'identifiant du groupe d'utilisateurs que vous souhaitez\r\n * supprimer. Il est utilisé pour construire l'URL de la requête DELETE.(ex: uuid:dcad14cc-5bcd-45fd-a54d-246b95047d45)\r\n */\r\n\r\nexport function deleteUserGroups(credentials, uri) {\r\n  const { space } = credentials;\r\n  const URI = \"/3drdfpersist/resources/v1/usersgroup\";\r\n  const url = `${space}${URI}/${uri}`;\r\n\r\n  const opts = {\r\n    method: \"DELETE\",\r\n  };\r\n  _httpCallAuthenticated(url, opts);\r\n}\r\n\r\n/**\r\n * @description La fonction `patchUserGroups` est utilisée pour mettre à jour les groupes d'utilisateurs en envoyant\r\n * une requête PATCH à un URI spécifié avec les données fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n * @param uri - Le paramètre `uri` est une chaîne qui représente l'identifiant du groupe d'utilisateurs\r\n * que vous souhaitez corriger. Il est utilisé pour construire l'URL de la requête PATCH.(ex: uuid:dcad14cc-5bcd-45fd-a54d-246b95047d45)\r\n * @param {ArrayOfObjects} datas - Le paramètre `datas` est un tableau d'objets qui spécifient les modifications à\r\n * apporter aux groupes d'utilisateurs.(ex: datas[0].op, datas[0].field, datas[0].value)\r\n * @param {String} datas[0].op - l'opération à réaliser. (ex: \"add\", \"remove\", \"replace\")\r\n * @param {String} datas[0].field - Ce sur quoi agir (ex: members[], title, description, owner, visibility)\r\n * @param {StringOrArray} datas[0].value - La nouvelle valeur impactée. Si ce sont des membres value sera un Tableau de String.\r\n \r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque la requête PATCH sera terminée\r\n * avec succès. Il recevra la réponse en paramètre.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `patchUserGroups`. Il vous permet de gérer toutes les\r\n * erreurs qui se produisent et d’effectuer toute gestion ou journalisation des erreurs nécessaire.\r\n */\r\nexport function patchUserGroups(\r\n  credentials,\r\n  uri,\r\n  datas,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space, tenant } = credentials;\r\n  const URL = {\r\n    URITI: \"/3drdfpersist/resources/v1/template-instances\",\r\n    URIUGr: \"/3drdfpersist/resources/v1/usersgroup\",\r\n    nextURICh: \"/characteristics\",\r\n    nextURIGr: \"/group\",\r\n    nexURImem: \"/members\",\r\n    OPTsTI: `?$mask=dsaccess:Mask.GroupUI.Properties`,\r\n    OPTsTenant: `tenant=dstenant:${tenant}`,\r\n  };\r\n\r\n  // Le format des datas est obligatoire : [{}]\r\n  // op : add, replace, remove\r\n  // field : members[], pending_members[], title, description, owner, visibility\r\n  // value : string ou array\r\n\r\n  const dataMembers = datas;\r\n  //  [\r\n  //   {\r\n  //     op: \"add\",\r\n  //     field: \"members\",\r\n  //     value: [\"samuel.mureau@beam3.fr\"],\r\n  //   },\r\n  //   {\r\n  //     op: \"replace\",\r\n  //     field: \"title\",\r\n  //     value: \"BEAM³ R&D - DEV\",\r\n  //   },\r\n  // ];\r\n\r\n  const baseURL = `${space}${URL.URIUGr}/${uri}`; // route de base pour le PATCH (DOC)\r\n\r\n  const dataMembersSTR = JSON.stringify(dataMembers);\r\n\r\n  _httpCallAuthenticated(baseURL, {\r\n    headers: topHeader,\r\n    method: \"PATCH\",\r\n    data: dataMembersSTR,\r\n    type: \"json\",\r\n    onComplete(response) {\r\n      if (onDone) onDone(response);\r\n    },\r\n    onFailure(err) {\r\n      if (onError) onError(err);\r\n    },\r\n  });\r\n}\r\n\r\n//ANCHOR -  CONTROL (Gestion des propriétaires du groupe)\r\n\r\n/**\r\n * @description La fonction `patchUserGroupsControl` est utilisée pour mettre à jour le contrôle des groupes\r\n * d'utilisateurs en envoyant une requête PATCH à un URI spécifié avec les informations\r\n * d'identification et les données fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} uri - Le paramètre `uri` est une chaîne qui représente l'identifiant du groupe d'utilisateurs\r\n * que vous souhaitez corriger. Il est utilisé pour construire l'URL de la requête PATCH.(ex: uuid:dcad14cc-5bcd-45fd-a54d-246b95047d45)\r\n * @param {ArrayOfObject} _datas - Le paramètre `datas` est un tableau d'objets qui contient les informations\r\n * nécessaires pour patcher le contrôle des groupes d'utilisateurs. (ex : datas[0].op,  datas[0].value)\r\n * @param {String}   op - L'opération de correctif. Il peut être 'add', 'replace', 'remove'.\r\n * @param {Object}   value -\r\n * @param {Array}   value.agents - Un tableau d’utilisateurs. Le 1er index doit être à vide. (ex : [\"\",\"Bob.Dylan@beam3.fr\"]). 100 utilisateurs maximums.\r\n * @param {Array} value.responsibilities - Un tableau de responsibilités. (ex: [\"dsaccess:Responsibility.Group.MainOwner\", \"dsaccess:Responsibility.Group.Owner\", \"dsaccess:Responsibility.Group.Viewer\", \"dsaccess:Responsibility.Group.Author\", \"dsaccess:Responsibility.GroupService.Administrator\"])\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque\r\n * l'opération de patch sera terminée avec succès. Il faut un argument, qui est la réponse du serveur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `patchUserGroupsControl`. Il vous permet de gérer toutes\r\n * les erreurs qui se produisent et d’effectuer toute gestion ou journalisation des erreurs nécessaire.\r\n */\r\nexport function patchUserGroupsControl(\r\n  credentials,\r\n  uri,\r\n  _datas,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space } = credentials;\r\n  const URI = \"/3drdfpersist/resources/v1/usersgroup\";\r\n\r\n  const url = `${space}${URI}/${uri}/sharing`;\r\n  //liste des responsabilités : [\"dsaccess:Responsibility.Group.MainOwner\", \"dsaccess:Responsibility.Group.Owner\", \"dsaccess:Responsibility.Group.Viewer\", \"dsaccess:Responsibility.Group.Author\", \"dsaccess:Responsibility.GroupService.Administrator\"]\r\n  const datas = _datas;\r\n  // [\r\n  //   {\r\n  //     op: \"add\", // add, replace, remove\r\n  //     path: \"/sharing\",\r\n  //     value: {\r\n  //       agents: [\"\", \"samuel.mureau@beam3.fr\", \"yan.coquoz@beam3.fr\"],\r\n  //       responsibilities: [\"dsaccess:Responsibility.Group.Owner\"],\r\n  //     },\r\n  //   },\r\n  // ];\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"PATCH\",\r\n    headers: topHeader,\r\n    data: JSON.stringify(datas),\r\n    type: \"json\",\r\n    onComplete(response) {\r\n      if (onDone) onDone(response);\r\n    },\r\n    onFailure(err) {\r\n      if (onError) onError(err);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction « readUserGroupControl » est utilisée pour récupérer les informations de contrôle de\r\n * groupe d'utilisateurs à partir d'un URI spécifié à l'aide d'une requête HTTP GET.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, usersgroup, 3DCompass...)\r\n * @param {String} uri - Le paramètre `uri` est une chaîne qui représente l'identifiant du groupe d'utilisateurs\r\n * pour lequel vous souhaitez récupérer les informations de contrôle. (ex: uuid:dcad14cc-5bcd-45fd-a54d-246b95047d45)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête HTTP sera terminée avec succès. Il prend un argument, qui correspond aux données de réponse\r\n * de la requête.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `readUserGroupControl`. Il vous permet de gérer et de\r\n * répondre à toute erreur qui se produit.\r\n */\r\nexport function readUserGroupControl(\r\n  credentials,\r\n  uri,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space } = credentials;\r\n  const URI = \"/3drdfpersist/resources/v1/usersgroup\";\r\n\r\n  const url = `${space}${URI}/${uri}/sharing`;\r\n\r\n  const header = {\r\n    \"Content-Type\": \"application/json\",\r\n    Accept: \"application/json,text/javascript,*/*\",\r\n  };\r\n  const opts = {\r\n    method: \"GET\",\r\n    headers: header,\r\n  };\r\n  _httpCallAuthenticated(url, {\r\n    opts,\r\n    onComplete(_rep) {\r\n      if (onDone) onDone(JSON.parse(_rep));\r\n    },\r\n    onFailure(err) {\r\n      if (onError) onError(err);\r\n    },\r\n  });\r\n}\r\n","import {\r\n  _httpCallAuthenticated,\r\n  _getPlatformServices,\r\n} from \"./3dexperience_api\";\r\nimport { UUID } from \"../../api/index\";\r\n\r\n/**\r\n * @description La fonction `_3dSpace_get_docInfo` récupère des informations sur un document dans un espace 3D.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSapce) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n\r\n * @param {String} [docid] - Le paramètre `docid` est l'ID du document pour lequel vous souhaitez récupérer des\r\n * informations. C'est un paramètre obligatoire et doit être fourni.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque les\r\n * informations du document seront récupérées avec succès. Il prend un argument, qui est l'objet\r\n * d'informations du document.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'appel HTTP. Il prend un paramètre, qui est la réponse d'erreur.\r\n * @returns La fonction ne renvoie explicitement rien.\r\n */\r\nexport async function _3DSpace_get_docInfo(\r\n  credentials,\r\n  docid = undefined,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const _3DSpace = credentials.space;\r\n  if (docid === undefined) {\r\n    console.log(\"Le paramètre docid est obligatoire\");\r\n    return;\r\n  }\r\n  const url = _3DSpace + `/resources/v1/modeler/documents/${docid}`;\r\n  _httpCallAuthenticated(url, {\r\n    onComplete(response, headers, xhr) {\r\n      const info = JSON.parse(response);\r\n      if (onDone) onDone(info);\r\n    },\r\n\r\n    onFailure(response) {\r\n      if (onError) onError(response);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction effectue un appel HTTP authentifié pour récupérer le jeton CSRF pour un document de\r\n * modélisation 3D.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.objID - ID du document pour lequel le jeton CSRF est demandé.\r\n * @param {Function} [onDone] - Le paramètre onDone est une fonction de rappel qui sera exécutée lorsque la\r\n * requête HTTP sera terminée avec succès. Il prend un argument, qui correspond aux données de réponse\r\n * renvoyées par le serveur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera exécutée si la requête\r\n * HTTP échoue ou rencontre une erreur. Il prend un argument, qui est la réponse d'erreur.\r\n */\r\nexport function _3DSpace_get_csrf(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  if (credentials.objID && credentials.objID !== \"\") {\r\n    let url = `${credentials.space}/resources/v1/modeler/documents/${credentials.objID}`;\r\n\r\n    _httpCallAuthenticated(url, {\r\n      onComplete(response, headers, xhr) {\r\n        const info = JSON.parse(response);\r\n        credentials[\"token\"] = info?.csrf?.value;\r\n        credentials[\"datas\"] = info?.data[0];\r\n        if (onDone) {\r\n          console.log(\"info => \", info);\r\n          onDone(credentials);\r\n        }\r\n      },\r\n\r\n      onFailure(response) {\r\n        if (onError) onError(response);\r\n      },\r\n    });\r\n  } else {\r\n    _3DSpace_csrf(credentials);\r\n  }\r\n}\r\n\r\n/**\r\n * @description Cette fonction JavaScript récupère le TOKEN CSRF d'une application 3DSpace.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSapce) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {Callback} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le jeton\r\n * CSRF sera récupéré avec succès. Il faut un argument, qui est la valeur du jeton CSRF.\r\n * @param {Callback} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée si une erreur\r\n * survient lors de l'exécution de la fonction `_3DSpace_csrf`. Il est utilisé pour gérer et afficher\r\n * les messages d’erreur ou exécuter toute logique de gestion des erreurs nécessaire.\r\n * @returns la valeur du jeton CSRF, qui est obtenue à partir de la réponse de l'appel HTTP.\r\n */\r\nexport function _3DSpace_csrf(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  if (credentials.space) {\r\n    const url = credentials.space + \"/resources/v1/application/CSRF\";\r\n    _httpCallAuthenticated(url, {\r\n      onComplete(response, headers, xhr) {\r\n        const info = JSON.parse(response);\r\n\r\n        if (onDone) onDone(info.csrf.value);\r\n      },\r\n      onFailure(response, headers, xhr) {\r\n        const infos = { response, headers, xhr };\r\n        if (onError) onError(infos);\r\n      },\r\n    });\r\n  } else {\r\n    if (onError) onError(\"ERROR : url du 3DSpace non défini.\");\r\n  }\r\n}\r\n\r\n/**\r\n * @description Cette fonction génère une URL pour télécharger un fichier à partir d'une plateforme de modélisation\r\n * 3D, en utilisant l'authentification et la gestion des erreurs.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n\r\n * @param {String} docid - ID du document pour lequel l'URL du fichier est demandée.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque l'URL du fichier sera récupérée\r\n * avec succès. Il prend un paramètre, qui est l'URL du fichier.\r\n * @param {Function} [onError] - Le paramètre onError est une fonction qui sera appelée s'il y a une erreur lors\r\n * de l'exécution de la fonction. Il s'agit d'un paramètre facultatif et peut être laissé indéfini s'il\r\n * n'est pas nécessaire.\r\n */\r\nexport function _3DSpace_file_url(\r\n  credentials,\r\n  docid,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  let url =\r\n    credentials.space +\r\n    `/resources/v1/modeler/documents/${docid}/files/DownloadTicket`;\r\n  _3DSpace_get_csrf(\r\n    credentials,\r\n\r\n    (info) => {\r\n      _httpCallAuthenticated(url, {\r\n        method: \"PUT\",\r\n        headers: {\r\n          ENO_CSRF_TOKEN: credentials.token,\r\n        },\r\n\r\n        onComplete(response) {\r\n          let info = JSON.parse(response);\r\n\r\n          if (info.success === true) {\r\n            try {\r\n              const file_url = info.data[0].dataelements.ticketURL;\r\n              if (onDone) onDone(file_url);\r\n            } catch (err) {\r\n              if (onError) onError(err);\r\n            }\r\n          }\r\n        },\r\n\r\n        onFailure(response, head) {\r\n          console.log(\"☠️ error => \", response, head);\r\n          if (onError) onError(response, head);\r\n        },\r\n      });\r\n    },\r\n    onError,\r\n  );\r\n}\r\n\r\n/**\r\n * @description Cette fonction envoie une requête PUT à une URL spécifiée avec des en-têtes d'authentification et\r\n * renvoie une URL de fichier en cas de succès.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} [docid] - L'ID du document pour lequel le ticket de téléchargement de fichier est demandé.\r\n * @param {String} [csr] - Le paramètre \"csr\" est un jeton CSRF utilisé à des fins d'authentification et de\r\n * sécurité. Il est transmis en tant qu'en-tête dans la requête HTTP à l'URL spécifiée.\r\n * @param {Function} [onDone] - Le paramètre onDone est une fonction de rappel qui sera exécutée lorsque la\r\n * requête HTTP aboutira et que l'URL du fichier sera obtenue. Il prend un argument, qui est l'URL du\r\n * fichier.\r\n * @param {Function} [onError] - Le paramètre onError est une fonction de rappel qui sera exécutée s'il y a une\r\n * erreur lors de la requête HTTP. Il est facultatif et peut être laissé indéfini s'il n'est pas\r\n * nécessaire.\r\n */\r\nexport function _3DSpace_file_url_csr(\r\n  credentials,\r\n  docid,\r\n  csr,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url = `${credentials.space}/resources/v1/modeler/documents/${docid}/files/DownloadTicket`;\r\n  _httpCallAuthenticated(url, {\r\n    method: \"PUT\",\r\n    headers: {\r\n      ENO_CSRF_TOKEN: csr,\r\n    },\r\n\r\n    onComplete(response) {\r\n      let info = JSON.parse(response);\r\n      if (info.success === true) {\r\n        try {\r\n          const file_url = info.data[0].dataelements.ticketURL;\r\n          if (onDone) onDone(file_url);\r\n        } catch (err) {\r\n          if (onError) onError(err);\r\n        }\r\n      }\r\n    },\r\n\r\n    onFailure(response) {\r\n      if (onError) onError(response);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction met à jour un fichier dans un espace 3D avec les données et le nom de fichier donnés,\r\n * en utilisant la protection CSRF.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} [docId] - ID de document du fichier d'espace 3D en cours de mise à jour.\r\n * @param {String} [fileId] - Le paramètre fileid est l'identifiant unique du fichier qui doit être mis à jour.\r\n * @param {String} [data] - Ce paramètre représente les données du fichier qui doivent être mises à jour. Il peut\r\n * se présenter sous la forme d'un format binaire ou texte.\r\n * @param {String} [filename] - Nom du fichier mis à jour.\r\n * @param {Function} [onDone] - Le paramètre onDone est une fonction de rappel qui sera exécutée lorsque\r\n * l'opération de mise à jour du fichier sera terminée avec succès.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera exécutée si une erreur\r\n * survient lors de l'exécution de la fonction `_3dspace_file_update`. Il permet de gérer les erreurs\r\n * de manière personnalisée, plutôt que de s'appuyer sur le comportement de gestion des erreurs par\r\n * défaut.\r\n */\r\nexport function _3DSpace_file_update(\r\n  credentials,\r\n  docId,\r\n  fileId,\r\n  data,\r\n  filename,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  _3DSpace_get_csrf(\r\n    credentials,\r\n    docId,\r\n    (info) => {\r\n      _3DSpace_file_update_csr(\r\n        credentials,\r\n        docId,\r\n        fileId,\r\n        data,\r\n        filename,\r\n        info.csrf.value,\r\n        onDone,\r\n        onError,\r\n      );\r\n    },\r\n    onError,\r\n  );\r\n}\r\n\r\n/**\r\n * @description Cette fonction met à jour un fichier dans le document du 3DSpace à l'aide d'un jeton CheckinTicket et CSRF.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} docId - ID du document en cours de mise à jour.\r\n * @param {String} fileId - ID du fichier mis à jour dans le document.\r\n * @param {String} data - Les données binaires du fichier en cours de mise à jour.\r\n * @param {String} filename - Nom du fichier mis à jour.\r\n * @param {String} csr - csr signifie Cross-Site Request Forgery token, qui est une mesure de sécurité utilisée\r\n * pour empêcher l'accès non autorisé aux applications Web. Il s'agit d'un jeton unique généré par le\r\n * serveur et envoyé au client, qui est ensuite inclus dans les requêtes ultérieures pour vérifier\r\n * l'authenticité de la requête. Dans cette fonction, le\r\n * @param {Function} [onDone] - Le paramètre onDone est une fonction de rappel qui sera exécutée lorsque la\r\n * fonction se terminera avec succès. Il prend la réponse comme argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de la requête HTTP. Il est facultatif et s'il n'est pas fourni, l'erreur sera traitée en\r\n * interne.\r\n */\r\nexport function _3DSpace_file_update_csr(\r\n  credentials,\r\n  docId,\r\n  fileId,\r\n  data,\r\n  filename,\r\n  csr,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url =\r\n    credentials.space +\r\n    `/resources/v1/modeler/documents/${docId}/files/CheckinTicket`;\r\n  _httpCallAuthenticated(url, {\r\n    method: \"PUT\",\r\n    headers: {\r\n      ENO_CSRF_TOKEN: csr,\r\n    },\r\n\r\n    onComplete(response, headers, xhr) {\r\n      const info = JSON.parse(response).data[0].dataelements;\r\n\r\n      const formData = new FormData();\r\n\r\n      formData.append(\"__fcs__jobTicket\", info.ticket);\r\n      formData.append(\"file_0\", data, filename);\r\n\r\n      const opts = {};\r\n      opts.method = \"POST\";\r\n      opts.data = formData;\r\n\r\n      opts.onComplete = function (response) {\r\n        //Update the FCS file receipt\r\n        let tempId = \"temp_\" + Date.now();\r\n        let options = {\r\n          method: \"PUT\",\r\n          headers: {\r\n            ENO_CSRF_TOKEN: csr,\r\n          },\r\n          data: JSON.stringify({\r\n            data: [\r\n              {\r\n                id: docId,\r\n                relateddata: {\r\n                  files: [\r\n                    {\r\n                      id: fileId,\r\n                      dataelements: {\r\n                        title: filename,\r\n                        receipt: response,\r\n                      },\r\n                      updateAction: \"REVISE\",\r\n                    },\r\n                  ],\r\n                },\r\n                tempId,\r\n              },\r\n            ],\r\n          }),\r\n\r\n          type: \"json\",\r\n\r\n          onComplete(response) {\r\n            if (onDone) onDone(response);\r\n          },\r\n\r\n          onFailure(response) {\r\n            if (onError) onError(response);\r\n          },\r\n        };\r\n\r\n        _httpCallAuthenticated(\r\n          credentials.space + \"/resources/v1/modeler/documents\",\r\n          options,\r\n        );\r\n      };\r\n\r\n      opts.onFailure = function (err) {\r\n        if (onError) onError(err);\r\n      };\r\n\r\n      opts.timeout = 0;\r\n\r\n      _httpCallAuthenticated(info.ticketURL, opts);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction crée un document dans le 3Dspace à partir des données fournies au format JSON.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token », « space » et « ctx ».(ex: credentials.space, credentials.tenant, credentials.token)\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} credentials.ctx - L'ID du contexte de travail.\r\n * @param {String}[data] - Le paramètre data correspond aux données JSON qui doivent être chargées dans le 3Dspace.\r\n *\r\n * @param {String}[filename] - Le nom du fichier à créer.\r\n * @param {String}[desc] - desc est un paramètre de chaîne qui représente la description du document en cours de création dans le 3Dspace.\r\n *\r\n * @param {Function}[onDone] - Le paramètre onDone est une fonction de rappel qui sera appelée lorsque la requête HTTP sera terminée avec succès. Il prend la réponse comme argument.\r\n *\r\n * @param {Function}[onError] - Le paramètre onError est une fonction de rappel qui sera appelée s'il y a une erreur lors de l'exécution de la fonction _3dSpace_Create_Doc. Il prend l'objet de réponse comme argument.\r\n *\r\n */\r\nexport async function _3DSpace_Create_Doc(\r\n  credentials,\r\n  data, // data\r\n  filename, //ref coclico\r\n  desc, // ref name\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const _space = credentials.space;\r\n  const csr = credentials.token;\r\n  const ctx = credentials.ctx;\r\n\r\n  const formData = new FormData();\r\n  const jsonFile = new Blob([JSON.stringify(data)], {\r\n    type: \"text/plain\",\r\n  });\r\n\r\n  const urls = {\r\n    url_Ticket: `${_space}/resources/v1/modeler/documents/files/CheckinTicket`,\r\n    url_Post: `${_space}/resources/v1/modeler/documents/?SecurityContext=ctx::${ctx}`,\r\n  };\r\n\r\n  if (!_space && _space !== \"\") {\r\n    console.log(\"le store._3DSpace est vide\");\r\n    return;\r\n  }\r\n  // 1\r\n  _httpCallAuthenticated(urls.url_Ticket, {\r\n    method: \"PUT\",\r\n    headers: {\r\n      ENO_CSRF_TOKEN: csr.value,\r\n    },\r\n\r\n    onComplete(response, headers, xhr) {\r\n      const info = JSON.parse(response).data[0].dataelements;\r\n\r\n      formData.append(\"__fcs__jobTicket\", info.ticket);\r\n      formData.append(\"filename\", jsonFile, filename);\r\n\r\n      const opts = {\r\n        method: \"POST\",\r\n        data: formData,\r\n\r\n        onComplete(ticket) {\r\n          if (ctx !== \"\" && csr !== \"\") {\r\n            const options = {\r\n              method: \"POST\",\r\n              headers: {\r\n                ENO_CSRF_TOKEN: csr,\r\n                Accept: \"application/json\",\r\n                \"Content-Type\": \"application/json\",\r\n              },\r\n              data: JSON.stringify({\r\n                data: [\r\n                  {\r\n                    type: \"Document\",\r\n                    dataelements: {\r\n                      title: `Title_${filename\r\n                        .toLowerCase()\r\n                        .split(\" \")\r\n                        .join(\"_\")}`,\r\n                      policy: \"Document Release\",\r\n                      description: desc,\r\n                    },\r\n                    relateddata: {\r\n                      files: [\r\n                        {\r\n                          dataelements: {\r\n                            title: `${filename}.json`,\r\n                            receipt: ticket,\r\n                          },\r\n                        },\r\n                      ],\r\n                    },\r\n                    tempId: UUID(),\r\n                  },\r\n                ],\r\n              }),\r\n              type: \"json\",\r\n              timeout: 0,\r\n\r\n              onComplete: handleSuccess,\r\n              onFailure: handleError,\r\n            };\r\n\r\n            if (ctx !== \"\") {\r\n              // 3\r\n              _httpCallAuthenticated(urls.url_Post, options);\r\n            }\r\n          } else {\r\n            console.warn(\"le store est vide\");\r\n          }\r\n        },\r\n\r\n        onFailure: handleError,\r\n      };\r\n\r\n      function handleSuccess(response) {\r\n        console.log(\"Success -- response \", response.data[0]);\r\n\r\n        if (onDone) {\r\n          onDone(response);\r\n        }\r\n      }\r\n\r\n      function handleError(response, headers) {\r\n        console.log(\"Erreur -- response \", response, \"\\n headers \", headers);\r\n        if (onError) {\r\n          onError(response);\r\n        }\r\n      }\r\n\r\n      _httpCallAuthenticated(info.ticketURL, opts);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction récupère les contextes de sécurité basés sur des paramètres spécifiés à partir d'un\r\n * hôte donné.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n *@param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} [cs] - Le titre d'un espace de collaboration.\r\n * @param {String} [role] - Le paramètre de rôle est un paramètre facultatif qui spécifie le rôle de\r\n * l'utilisateur dans l'espace de collaboration. Si fourni, la fonction filtrera les espaces de\r\n * collaboration pour trouver celui où l'utilisateur a le rôle spécifié. S'il n'est pas fourni, la\r\n * fonction utilisera le premier espace de collaboration trouvé.\r\n * @param {String} [organization] - Nom de l'organisation pour laquelle le contexte de sécurité est récupéré.\r\n * @param {Function} [onDone] - La fonction à appeler lorsque le contexte de sécurité a été récupéré avec succès.\r\n * Il prend le contexte comme paramètre.\r\n * @param {Function} [onError] - Le paramètre onError est une fonction de rappel qui est appelée si une erreur se\r\n * produit lors de l'exécution de la fonction. Il prend un argument, qui est le message d'erreur ou\r\n * l'objet.\r\n */\r\nexport function _3DSpace_get_securityContexts(\r\n  credentials,\r\n  cs = undefined,\r\n  role = undefined,\r\n  organization = undefined,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url =\r\n    `${credentials.space}/resources/modeler/pno/person?` +\r\n    \"current=true\" +\r\n    \"&select=preferredcredentials\" +\r\n    \"&select=collabspaces\";\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"GET\",\r\n    onComplete(response) {\r\n      // role.company.cs\r\n      const contexts = JSON.parse(response);\r\n      let context = \"\";\r\n      let finalCs,\r\n        finalOrg,\r\n        finalRole = undefined;\r\n      if (cs) {\r\n        let oCS = contexts.collabspaces.find((e) => e.title === cs);\r\n        if (oCS) {\r\n          finalCs = cs;\r\n          let couples = oCS.couples;\r\n          couples = couples.filter(\r\n            (value, index, self) =>\r\n              index ===\r\n              self.findIndex(\r\n                (t) =>\r\n                  t.organization.pid === value.organization.pid &&\r\n                  t.role.pid === value.role.pid,\r\n              ),\r\n          );\r\n          if (role) {\r\n            if (Array.isArray(role)) {\r\n              role.forEach((r) => {\r\n                if (!finalRole)\r\n                  couples.forEach((e) => {\r\n                    if (\r\n                      r === e.role.name &&\r\n                      organization === e.organization.title\r\n                    ) {\r\n                      finalRole = r;\r\n                      finalOrg = organization;\r\n                    } else if (r === e.role.name) {\r\n                      let defineSingleItem = couples.filter(\r\n                        (couple) => couple.role.name === r,\r\n                      );\r\n                      if (defineSingleItem.length === 1) {\r\n                        finalRole = defineSingleItem[0].role.name;\r\n                        finalOrg = defineSingleItem[0].organization.title;\r\n                      } else {\r\n                        onError(defineSingleItem);\r\n                      }\r\n                    }\r\n                  });\r\n              });\r\n            } else {\r\n              couples.forEach((e) => {\r\n                if (\r\n                  role === e.role.name &&\r\n                  organization === e.organization.title\r\n                ) {\r\n                  finalRole = role;\r\n                  finalOrg = organization;\r\n                } else if (role === e.role.name) {\r\n                  let defineSingleItem = couples.filter(\r\n                    (couple) => couple.role.name === role,\r\n                  );\r\n                  if (defineSingleItem.length === 1) {\r\n                    finalRole = defineSingleItem[0].role.name;\r\n                    finalOrg = defineSingleItem[0].organization.title;\r\n                  } else {\r\n                    onError(defineSingleItem);\r\n                  }\r\n                }\r\n              });\r\n            }\r\n          }\r\n        }\r\n      }\r\n      if (finalCs && finalOrg && finalRole) {\r\n        context = finalRole + \".\" + finalOrg + \".\" + finalCs;\r\n        onDone(context);\r\n        // onDone(encodeURI(context));\r\n      } else {\r\n        if (contexts.preferredcredentials) {\r\n          context =\r\n            contexts.preferredcredentials.role.name +\r\n            \".\" +\r\n            contexts.preferredcredentials.organization.title +\r\n            \".\" +\r\n            contexts.preferredcredentials.collabspace.title;\r\n          onDone(context);\r\n        } else {\r\n          if (onError) {\r\n            context = finalRole + \".\" + finalOrg + \".\" + finalCs;\r\n            onError(context);\r\n          }\r\n        }\r\n      }\r\n    },\r\n    onFailure(err) {\r\n      console.log(\"Erreur de récupération du contexte de sécurité. => \", err);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_3dspace_download_doc` est une fonction asynchrone qui télécharge un document à partir d'un espace 3D, avec des rappels facultatifs pour le succès et la gestion des erreurs.\r\n * @param {Object} credentials Un objet contenant les informations d'identification nécessaires à\r\n * l'authentification. Il doit avoir les propriétés suivantes: space, token\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n\r\n * @param  {String} [credentials.token] - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} [objectId] - Le paramètre objectId est l'identifiant unique du document que vous souhaitez\r\n * télécharger depuis le 3DSpace.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le\r\n * téléchargement sera terminé avec succès. Il prend un argument, qui est les données de réponse du\r\n * téléchargement.\r\n * @param {Callback} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3dspace_download_doc`. Il vous permet de gérer et de\r\n * répondre à toutes les erreurs qui se produisent.\r\n \r\n * @returns une promesse.\r\n */\r\nexport async function _3DSpace_download_doc(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n  message = undefined,\r\n) {\r\n  const objectId = credentials.objID;\r\n  if (objectId === undefined || objectId === \"\") {\r\n    console.warn(\r\n      \"_3DSpace_download_doc() / Le paramètre objectId est obligatoire\",\r\n    );\r\n  }\r\n\r\n  if (credentials.space === \"\" || !credentials.space) {\r\n    console.warn(\r\n      \"_3DSpace_download_doc() / Le paramètre space est obligatoire\",\r\n    );\r\n  }\r\n  try {\r\n    _3DSpace_file_url(\r\n      credentials,\r\n      objectId,\r\n      (response) => {\r\n        console.log(\r\n          \"_3dspace_download_doc / _3DSpace_file_url / response \",\r\n          response,\r\n        );\r\n        _httpCallAuthenticated(response, {\r\n          headers: {\r\n            ENO_CSRF_TOKEN: credentials.token,\r\n          },\r\n          onComplete(response) {\r\n            const result = JSON.parse(response);\r\n            if (onDone) onDone(result);\r\n          },\r\n          onFailure(error, headers, xhr) {\r\n            if (onError) {\r\n              console.log(\"error http\", error);\r\n              onError({ error, headers, xhr });\r\n            }\r\n          },\r\n        });\r\n      },\r\n      (error) => {\r\n        if (onError) onError(error);\r\n        console.log(\"*_3dspace_download_doc / error file URL *\", error);\r\n      },\r\n    );\r\n  } catch (error) {\r\n    console.log(\"*_3dspace_download_doc / error file URL *\", error);\r\n  }\r\n}\r\n\r\n/**\r\n * @description La fonction `_3dspace_download_multidoc` télécharge plusieurs documents à partir d'un espace 3D en\r\n * utilisant un token et des objectID donnés.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification nécessaires à\r\n * l'authentification dans une fonction interne(_3DSpace_get_downloadTicket_multidoc). Il doit avoir les propriétés suivantes: space, token, tenant\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant \r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} [credentials.token] - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n\r\n * @param {String} [objectIds] - Un tableau d'ID d'objet qui doivent être téléchargés à partir du 3DSpace.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le\r\n * processus de téléchargement sera terminé avec succès. Il faut un argument, qui est le résultat du\r\n * processus de téléchargement.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur pendant le processus de téléchargement. Il vous permet de gérer les erreurs qui surviennent\r\n * lors du téléchargement.\r\n\r\n */\r\nexport async function _3DSpace_download_multidoc(\r\n  credentials,\r\n  objectIds,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  let listDiv = [];\r\n  const chunkSize = 80;\r\n  for (let i = 0; i < objectIds.length; i += chunkSize) {\r\n    const chunk = objectIds.slice(i, i + chunkSize);\r\n    listDiv.push(chunk);\r\n  }\r\n  const loop = (i) => {\r\n    _3DSpace_get_downloadTicket_multidoc(\r\n      credentials,\r\n      listDiv[i],\r\n      () => {\r\n        i++;\r\n        if (i < listDiv.length) {\r\n          loop(i);\r\n        }\r\n      },\r\n      (done) => {\r\n        if (onDone) onDone(done);\r\n      },\r\n    );\r\n  };\r\n\r\n  loop(0);\r\n}\r\n\r\n/**\r\n * @description La fonction `_3dspace_get_downloadTicket_multidoc` permet de récupérer un ticket de téléchargement\r\n * de plusieurs documents dans un espace 3D.\r\n * @param {Object} [credentials] - Un objet contenant les informations d'identification nécessaires à\r\n * l'authentification. Il doit avoir les propriétés suivantes: space, token, tenant\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} [credentials.token] - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} [objectIds] - Tableau d'ID d'objet pour lesquels le ticket de téléchargement doit être généré.\r\n * @param {Function} [onNext] - Une fonction de rappel qui sera appelée après chaque demande de ticket de\r\n * téléchargement réussie pour chaque objectId.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le\r\n * processus de téléchargement de chaque objet sera terminé avec succès. Il lui sera transmis un objet\r\n * contenant « objectId », « fileName » et « data » du fichier téléchargé.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction. Il est facultatif et peut être utilisé pour gérer les\r\n * erreurs qui surviennent.\r\n */\r\nexport function _3DSpace_get_downloadTicket_multidoc(\r\n  credentials,\r\n  objectIds,\r\n  onNext = undefined,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const compilData = [];\r\n  objectIds.forEach((objectId) => {\r\n    compilData.push({\r\n      id: objectId,\r\n    });\r\n  });\r\n  let data = JSON.stringify({\r\n    csrf: {\r\n      name: \"ENO_CSRF_TOKEN\",\r\n      value: credentials.token,\r\n    },\r\n    data: compilData,\r\n  });\r\n\r\n  const url = `${credentials.space}/resources/v1/modeler/documents/DownloadTicket?tenant=${credentials.tenant}&e6w-lang=fr&e6w-timezone=-120`;\r\n  _httpCallAuthenticated(url, {\r\n    method: \"PUT\",\r\n    data,\r\n    type: \"json\",\r\n    onComplete(response) {\r\n      const datas = response.data;\r\n      if (response.success === true) {\r\n        if (onNext) onNext();\r\n        datas.forEach((data) => {\r\n          try {\r\n            const fileName = data.dataelements.fileName;\r\n            const fileUrl = data.dataelements.ticketURL;\r\n            _httpCallAuthenticated(fileUrl, {\r\n              onComplete: (response) => {\r\n                if (onDone)\r\n                  onDone({\r\n                    objectId: data.id,\r\n                    fileName,\r\n                    data: JSON.parse(response),\r\n                  });\r\n              },\r\n              onFailure: (error) => {\r\n                console.log(\"error http\", error);\r\n              },\r\n            });\r\n          } catch (err) {\r\n            console.log(err);\r\n            if (onError) onError(err);\r\n          }\r\n        });\r\n      }\r\n    },\r\n    onFailure(response) {\r\n      console.log(response);\r\n      if (onError) onError(response);\r\n    },\r\n  });\r\n}\r\n\r\n// MATURITY\r\n/**\r\n * @description Cette fonction JavaScript récupère les prochains états possibles pour un objet donné dans un espace\r\n * 3D.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space » et « ctx ».\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} credentials.ctx - L'ID du contexte de travail.\r\n * @param {String} objectId - Le paramètre `objectId` est l'identifiant de l'objet dont vous souhaitez récupérer\r\n * les prochains états. Il est utilisé pour spécifier l'objet pour lequel vous souhaitez obtenir les\r\n * états suivants dans l'espace 3D.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque la demande sera terminée avec\r\n * succès. Il recevra la réponse en paramètre.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction. Il s'agit d'un paramètre facultatif, donc s'il n'est pas\r\n * fourni, il sera par défaut «non défini».\r\n * @return {Promise}\r\n */\r\nexport function _3DSpace_lifecycle_getNextStates(\r\n  credentials,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  return new Promise((result) => {\r\n    if (credentials.token === \"\") {\r\n      _3DSpace_csrf(credentials);\r\n    }\r\n    if (objectId !== undefined && objectId !== \"\" && objectId !== null) {\r\n      const url = `${credentials.space}/resources/v1/modeler/dslc/maturity/getNextStates`;\r\n\r\n      _3DSpace_get_securityContexts(\r\n        credentials.space,\r\n        \"ESPACE COMMUN\",\r\n        [\"VPLMProjectLeader\", \"VPLMCreator\"],\r\n        undefined,\r\n        (ctx) => (credentials[\"ctx\"] = ctx),\r\n        (err) => {\r\n          console.log(\"onError =>\", err);\r\n        },\r\n      );\r\n      let options = {\r\n        method: \"POST\",\r\n        headers: {\r\n          SecurityContext: \"ctx::\" + credentials.ctx,\r\n          ENO_CSRF_TOKEN: credentials.token,\r\n          Accept: \"application/json\",\r\n          \"Content-Type\": \"application/json\",\r\n        },\r\n        data: JSON.stringify({\r\n          data: [\r\n            {\r\n              id: objectId,\r\n            },\r\n          ],\r\n        }),\r\n        type: \"json\",\r\n        onComplete(response) {\r\n          if (onDone) onDone(response);\r\n        },\r\n        onFailure(response) {\r\n          if (onError) onError(response);\r\n        },\r\n      };\r\n      _httpCallAuthenticated(url, options);\r\n    }\r\n  });\r\n}\r\n/**\r\n * @description Cette fonction permet de changer l'état d'un objet dans un espace 3D.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space » et « ctx ».\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} credentials.ctx - L'ID du contexte de travail.\r\n * @param {String} objectId - Le paramètre objectId est l'identifiant de l'objet dont l'état doit être modifié.\r\n * Il s'agit d'un identifiant unique qui représente un objet spécifique dans le système.\r\n * @param {Function} [nextState] - Le paramètre `nextState` est l'état souhaité vers lequel vous souhaitez modifier\r\n * l'objet. Il représente l'état suivant du cycle de vie de l'objet.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque l'opération de changement d'état\r\n * sera terminée avec succès. Il prend la réponse comme argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3dspace_lifecyle_changeState`. C'est un paramètre\r\n * facultatif, donc s'il n'est pas fourni, la fonction ne fera rien en cas de problème.\r\n * @returns une promesse.\r\n */\r\nexport function _3DSpace_lifecycle_changeState(\r\n  credentials,\r\n  objectId,\r\n  nextState,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  return new Promise((result) => {\r\n    if (credentials.token === \"\") {\r\n      _3DSpace_csrf(credentials);\r\n    }\r\n    if (objectId !== undefined && objectId !== \"\" && objectId !== null) {\r\n      const url = `${credentials.space}/resources/v1/modeler/dslc/maturity/changeState`;\r\n\r\n      _3DSpace_get_securityContexts(\r\n        credentials.space,\r\n        \"ESPACE COMMUN\",\r\n        [\"VPLMProjectLeader\", \"VPLMCreator\"],\r\n        undefined,\r\n        (ctx) => (credentials[\"ctx\"] = ctx),\r\n        (err) => {\r\n          console.log(\"onError =>\", err);\r\n        },\r\n      );\r\n      let options = {\r\n        method: \"POST\",\r\n        headers: {\r\n          SecurityContext: \"ctx::\" + credentials.ctx,\r\n          ENO_CSRF_TOKEN: credentials.token,\r\n          Accept: \"application/json\",\r\n          \"Content-Type\": \"application/json\",\r\n        },\r\n        data: JSON.stringify({\r\n          data: [\r\n            {\r\n              id: objectId,\r\n              nextState,\r\n            },\r\n          ],\r\n        }),\r\n        type: \"json\",\r\n        onComplete(response) {\r\n          if (onDone) onDone(response);\r\n        },\r\n        onFailure(response) {\r\n          if (onError) onError(response);\r\n        },\r\n      };\r\n      _httpCallAuthenticated(url, options);\r\n    }\r\n  });\r\n}\r\n// RESERVATION\r\n//TODO -\r\nfunction _3DSpace_lifecyle_reserve(\r\n  host,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // ...\r\n}\r\n//TODO -\r\nfunction _3DSpace_lifecyle_unreserve(\r\n  host,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // ...\r\n}\r\n// SHARING\r\n//TODO -\r\nfunction _3DSpace_lifecyle_getSharing(\r\n  host,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // ...\r\n}\r\n//TODO -\r\nfunction _3DSpace_lifecyle_setSharing(\r\n  host,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // ...\r\n}\r\n// VERSIONING\r\n/**\r\n * @description La fonction `_3DSpace_lifecycle_getGraph` récupère un graphique du cycle de vie d'un objet spatial\r\n * 3D à l'aide des informations d'identification et de l'ID d'objet fournis.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier la demande.\r\n *  Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} credentials.ctx - L'ID du contexte de travail.\r\n * @param {String} objectId - Le paramètre objectId est l'identifiant de l'objet pour lequel vous souhaitez\r\n * récupérer le graphique. Il est utilisé pour spécifier l'objet pour lequel vous souhaitez obtenir le\r\n * graphique de version.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque la récupération du graphique sera\r\n * réussie. Il prend la réponse comme argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSpace_lifecycle_getGraph`. C'est un paramètre\r\n * facultatif, donc s'il n'est pas fourni, la fonction ne fera rien en cas d'erreur.\r\n * @returns une promesse.\r\n */\r\nexport function _3DSpace_lifecycle_getGraph(\r\n  credentials,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // A VALIDER\r\n  return new Promise((result) => {\r\n    if (credentials.token === \"\") {\r\n      _3DSpace_csrf(credentials);\r\n    }\r\n    if (objectId !== undefined && objectId !== \"\" && objectId !== null) {\r\n      const url = `${credentials.space}/resources/v1/dslc/versiongraph?withThumbnail=0&withIsLastVersion=0&withAttributes=0&withCopyFrom=0&tenant=${credentials.tenant}`;\r\n\r\n      _3DSpace_get_securityContexts(\r\n        credentials.space,\r\n        \"ESPACE COMMUN\",\r\n        [\"VPLMProjectLeader\", \"VPLMCreator\"],\r\n        undefined,\r\n        (ctx) => (credentials[\"ctx\"] = ctx),\r\n        (err) => {\r\n          console.log(\"onError =>\", err);\r\n        },\r\n      );\r\n      let options = {\r\n        method: \"POST\",\r\n        headers: {\r\n          securitycontext: \"ctx::\" + credentials.ctx,\r\n          ENO_CSRF_TOKEN: credentials.token,\r\n          Accept: \"application/json\",\r\n          \"Content-Type\": \"application/json\",\r\n        },\r\n        data: JSON.stringify({\r\n          graphRequests: [\r\n            {\r\n              id: objectId,\r\n            },\r\n          ],\r\n        }),\r\n        type: \"json\",\r\n        onComplete(response) {\r\n          if (onDone) onDone(response);\r\n        },\r\n        onFailure(response) {\r\n          if (onError) onError(response);\r\n        },\r\n      };\r\n      _httpCallAuthenticated(url, options);\r\n    }\r\n  });\r\n}\r\n// REVISION\r\n/**\r\n * @description La fonction `_3DSpace_lifecycle_getNextRevision` permet de récupérer la prochaine révision d'un\r\n * document dans un espace 3D.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} credentials.ctx - L'ID du contexte de travail.\r\n * @param {String} objectId - Le paramètre `objectId` est l'identifiant unique de l'objet pour lequel vous\r\n * souhaitez obtenir la prochaine révision. Il est utilisé pour spécifier l'objet qui doit être révisé.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque l'opération sera terminée avec\r\n * succès. Il prend la réponse comme argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSpace_lifecycle_getNextRevision`. Il s'agit d'un\r\n * paramètre facultatif, donc s'il n'est pas fourni, il sera par défaut «non défini».\r\n * @returns Une promesse est renvoyée.\r\n */\r\nexport function _3DSpace_lifecycle_getNextRevision(\r\n  credentials,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  return new Promise((result) => {\r\n    if (credentials.token === \"\") {\r\n      _3DSpace_csrf(credentials);\r\n    }\r\n    if (objectId !== undefined && objectId !== \"\" && objectId !== null) {\r\n      const url = `${credentials.space}/resources/lifecycle/revise/prepare_revise_maskattributes?tenant=${credentials.tenant}`;\r\n\r\n      _3DSpace_get_securityContexts(\r\n        credentials.space,\r\n        \"ESPACE COMMUN\",\r\n        [\"VPLMProjectLeader\", \"VPLMCreator\"],\r\n        undefined,\r\n        (ctx) => (credentials[\"ctx\"] = ctx),\r\n        (err) => {\r\n          console.log(\"onError =>\", err);\r\n        },\r\n      );\r\n      let options = {\r\n        method: \"POST\",\r\n        headers: {\r\n          SecurityContext: \"ctx::\" + credentials.ctx,\r\n          ENO_CSRF_TOKEN: credentials.token,\r\n          Accept: \"application/json\",\r\n          \"Content-Type\": \"application/json\",\r\n        },\r\n        data: JSON.stringify({\r\n          data: [\r\n            {\r\n              \"attribute[PLMReference.V_versionComment]\": null,\r\n              physicalid: objectId,\r\n              type: \"Document\",\r\n              tenant: credentials.tenant,\r\n              objectId,\r\n              policy: \"Document Release\",\r\n              availableSemantic: [\"E\", \"LAST\", \"NEW\", \"DUP\"],\r\n            },\r\n          ],\r\n        }),\r\n        type: \"json\",\r\n        onComplete(response) {\r\n          if (onDone) onDone(response);\r\n        },\r\n        onFailure(response) {\r\n          if (onError) onError(response);\r\n        },\r\n      };\r\n      _httpCallAuthenticated(url, options);\r\n    }\r\n  });\r\n}\r\n/**\r\n * @description La fonction `_3DSpace_lifecycle_changeRevision` est utilisée pour changer la révision d'un objet\r\n * dans un espace 3D.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {String} credentials.ctx - L'ID du contexte de travail.\r\n * @param {String} objectId - Le paramètre objectId représente l'identifiant unique de l'objet dans l'espace 3D.\r\n * Il est utilisé pour spécifier quelle révision de l'objet doit être modifiée.\r\n * @param {Function} nextRevision - Le paramètre `nextRevision` est le numéro de révision qui sera attribué à\r\n * l'objet après le changement de révision.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque l'opération sera terminée avec\r\n * succès. Il prend la réponse comme argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSpace_lifecycle_changeRevision`. Il vous permet de\r\n * gérer toutes les erreurs qui se produisent et d’effectuer toute gestion ou journalisation des\r\n * erreurs nécessaire.\r\n * @returns une promesse.\r\n */\r\nexport function _3DSpace_lifecycle_changeRevision(\r\n  credentials,\r\n  objectId,\r\n  nextRevision,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  return new Promise((result) => {\r\n    if (credentials.token === \"\") {\r\n      _3DSpace_csrf(credentials);\r\n    }\r\n    if (objectId !== undefined && objectId !== \"\" && objectId !== null) {\r\n      const url = `${credentials.space}/resources/lifecycle/revise/major?tenant=${credentials.tenant}`;\r\n\r\n      _3DSpace_get_securityContexts(\r\n        credentials.space,\r\n        \"ESPACE COMMUN\",\r\n        [\"VPLMProjectLeader\", \"VPLMCreator\"],\r\n        undefined,\r\n        (ctx) => (credentials[\"ctx\"] = ctx),\r\n        (err) => {\r\n          console.log(\"onError =>\", err);\r\n        },\r\n      );\r\n      let options = {\r\n        method: \"POST\",\r\n        headers: {\r\n          securitycontext: \"ctx::\" + credentials.ctx,\r\n          ENO_CSRF_TOKEN: credentials.token,\r\n          Accept: \"application/json\",\r\n          \"Content-Type\": \"application/json\",\r\n        },\r\n        data: JSON.stringify({\r\n          data: [\r\n            {\r\n              physicalid: objectId,\r\n              proposedRevision: nextRevision,\r\n              modifiedAttributes: {\r\n                revision: nextRevision,\r\n              },\r\n            },\r\n          ],\r\n          folderid: null,\r\n          notificationTimeout: 600,\r\n        }),\r\n        type: \"json\",\r\n        onComplete(response) {\r\n          if (onDone) onDone(response);\r\n        },\r\n        onFailure(response) {\r\n          if (onError) onError(response);\r\n        },\r\n      };\r\n      _httpCallAuthenticated(url, options);\r\n    }\r\n  });\r\n}\r\n// SECTION: BOOKMARKS\r\n// ANCHOR: _3dspace_bookmark_getChildren\r\n// TODO : A finir , manque la FN _3dspace_get_multiDocInfo()\r\n// function _3DSpace_bookmark_getChildren(\r\n//   credentials,\r\n//   objIdBookmark,\r\n//   onDone = undefined,\r\n//   onError = undefined,\r\n// ) {\r\n//   return new Promise((resolve, reject) => {\r\n//     // const store = mainStore();\r\n\r\n//     const url = `${credentials.space}/resources/v1/modeler/dsbks/dsbks:Bookmark/${objIdBookmark}?$mask=dsbks:BksMask.Items`;\r\n//     _httpCallAuthenticated(url, {\r\n//       headers: {\r\n//         SecurityContext: `ctx::${credentials.ctx}`,\r\n//       },\r\n//       onComplete: (response) => {\r\n//         let tryParse;\r\n//         try {\r\n//           tryParse = JSON.parse(response);\r\n//         } catch (error) {\r\n//           tryParse = response;\r\n//         }\r\n//         if (typeof tryParse === \"object\") {\r\n//           let items = tryParse?.member[0]?.items?.member;\r\n//           if (items) {\r\n//             const listObjIds = items.map((e) => {\r\n//               if (e?.referencedObject?.identifier) {\r\n//                 return e.referencedObject.identifier;\r\n//               }\r\n//             });\r\n//             if (listObjIds.length) {\r\n//               _3DSpace_get_multiDocInfo(host, listObjIds, (res) => {\r\n//                 console.log(\"_3dspace_get_multiDocInfo Response : \", {\r\n//                   ...res,\r\n//                 });\r\n//                 if (res?.data.length) {\r\n//                   const listResponses = res.data;\r\n//                   listResponses.forEach((r) => {\r\n//                     let currentObject = items.find(\r\n//                       (o) => o.referencedObject.identifier === r.identifier,\r\n//                     );\r\n//                     if (currentObject) {\r\n//                       currentObject.referencedObject[\"dataelements\"] =\r\n//                         r.dataelements;\r\n//                     }\r\n//                   });\r\n//                 }\r\n//               });\r\n//             }\r\n//           }\r\n//         }\r\n\r\n//         if (onDone) onDone(tryParse);\r\n//         resolve = tryParse;\r\n//         return resolve;\r\n//       },\r\n//       onFailure(response) {\r\n//         if (onError) onError(response);\r\n//         reject = response;\r\n//         return reject;\r\n//       },\r\n//     });\r\n//   });\r\n// }\r\n//!SECTION\r\n\r\n// module.exports = {\r\n\r\n//   _3DSpace_bookmark_getChildren,\r\n// };\r\n","import { _httpCallAuthenticated } from \"./3dexperience_api\";\r\n\r\n/**\r\n * @description La fonction `getCSRFToken` est une fonction asynchrone qui récupère un jeton CSRF à partir d'une URL\r\n * spécifiée et appelle le rappel `onDone` avec le jeton en cas de succès, ou le rappel `onError` avec\r\n * une erreur en cas d'échec.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space » et « ctx ».\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n *\r\n * @param {Function} onDone - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le jeton\r\n * CSRF sera récupéré avec succès. Il faut un argument, qui est la valeur du jeton CSRF.\r\n * @param {Function} onError - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une erreur lors de la requête HTTP. Il est facultatif et peut être utilisé pour gérer les erreurs qui se produisent lors de la demande.\r\n *\r\n *\r\n */\r\nexport async function getCSRFToken(credentials, onDone, onError) {\r\n  const url = `${credentials.space}/resources/v1/application/CSRF`;\r\n  _httpCallAuthenticated(url, {\r\n    onComplete(response) {\r\n      response = JSON.parse(response);\r\n      if (onDone) onDone(response.csrf);\r\n    },\r\n    onFailure(error, headers, xhr) {\r\n      const infos = { error, headers, xhr };\r\n      if (onError) onError(infos);\r\n    },\r\n  });\r\n}\r\n","import { _httpCallAuthenticated } from \"./3dexperience_api\";\r\n\r\n/**\r\n * @description La fonction `getAllContextSecurity` effectue une requête HTTP GET authentifiée pour récupérer toutes\r\n * les ressources de sécurité du contexte.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier la demande.\r\n *  Il inclut généralement des propriétés telles qu'ici « space » et « tenant ».(ex: credentials.space, credentials.tenant).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque la requête HTTP sera terminée avec\r\n * succès. Il prend deux paramètres: \"rep\" (la réponse JSON analysée) et \"headers\" (les en-têtes de\r\n * réponse).\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de la requête HTTP. Il faut trois arguments : « réponse », « en-têtes » et « xhr ».\r\n * L'argument `response` contient le corps de la réponse d'erreur, l'argument `headers` contient les en-têtes de réponse,\r\n *\r\n */\r\nexport function getAllContextSecurity(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const URL = {\r\n    base: `${credentials.space}`,\r\n    uri: \"/resources/bps/cspaces\",\r\n    optTenant: `tenant=${credentials.tenant}`,\r\n  };\r\n\r\n  const url = `${URL.base}${URL.uri}?${URL.optTenant}`;\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"GET\",\r\n    headers: {\r\n      Accept: \"application/json,text/javascript,*/*\",\r\n      \"Content-Type\": \"application/ds-json\",\r\n    },\r\n    onComplete(response, headers) {\r\n      const rep = JSON.parse(response);\r\n\r\n      if (onDone) onDone(rep, headers);\r\n    },\r\n    onFailure(response, headers, xhr) {\r\n      if (onError) onError({ response, headers, xhr });\r\n    },\r\n  });\r\n}\r\n","import { _httpCallAuthenticated } from \"./3dexperience_api\";\r\nimport { _3DSpace_file_url } from \"./3dspace_api\";\r\n/**\r\n * @description La fonction `getDataFrom3DSpace` récupère les données d'un espace 3D en utilisant les informations\r\n * d'identification fournies et les préférences du widget, et appelle le rappel `onDone` avec la\r\n * réponse ou le rappel `onError` avec toutes les erreurs rencontrées.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token » et « space ».(ex: credentials.token, credentials.space, credentials.tenant, credentials.ctx)\r\n * @property space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace, 3DSwym, 3DCompass...)\r\n * @property token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n *\r\n * @param widgetPreference - Le paramètre `widgetPreference` est un objet qui contient les préférences\r\n * du widget. Il peut inclure des propriétés telles que la taille, la couleur, la position du widget ou\r\n * toute autre personnalisation spécifique au widget.\r\n * @param onDone - Une fonction de rappel qui sera appelée lorsque la récupération des données sera\r\n * réussie. Il prend la réponse comme paramètre.\r\n * @param onError - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `getDataFrom3DSpace`. Il est utilisé pour gérer et traiter\r\n * les erreurs qui surviennent.\r\n */\r\nexport function getDataFrom3DSpace(\r\n  credentials,\r\n  widgetPreference,\r\n  onDone,\r\n  onError,\r\n) {\r\n  _3DSpace_file_url(\r\n    credentials.space,\r\n    widgetPreference,\r\n    (response) => {\r\n      _httpCallAuthenticated(response, {\r\n        header: { ENO_CSRF_TOKEN: credentials.token },\r\n        onComplete: (response) => {\r\n          if (onDone) onDone(response);\r\n        },\r\n        onFailure: (error) => {\r\n          console.log(\"error http\", error);\r\n          if (onError) onError(error);\r\n        },\r\n      });\r\n    },\r\n    (error) => {\r\n      console.log(\"error file URL\", error);\r\n      if (onError) onError(error);\r\n    },\r\n  );\r\n}\r\n","import { _3DSpace_file_url } from \"./3dspace_api\";\r\nimport { _httpCallAuthenticated } from \"./3dexperience_api\";\r\n/**\r\n * @description La fonction `getDownloadDocument` est une fonction asynchrone qui récupère un document à télécharger\r\n * à partir d'un espace et d'un ID de document spécifiés.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace, 3DSwym, 3DCompass...)\r\n * @param {String} docId - L'ID du document du fichier que vous souhaitez télécharger.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée une fois le\r\n * téléchargement terminé et réussi. Les données de réponse seront transmises comme argument. Il prend trois arguments : « reponse », « headers » et « xhr ».\r\n *\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur pendant le processus de téléchargement. Il prend trois arguments : « error », « headers » et « xhr ».\r\n *\r\n * @returns un objet Promesse.\r\n */\r\nexport async function getDownloadDocument(\r\n  credentials,\r\n  docId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  return new Promise((result) => {\r\n    //TODO - a test ? manque l'URL\r\n    _3DSpace_file_url(credentials.space, docId, (reponse) => {\r\n      _httpCallAuthenticated(reponse, {\r\n        onComplete: (reponse, headers, xhr) => {\r\n          result(JSON.parse(reponse));\r\n          if (onDone) onDone(JSON.parse(reponse), headers, xhr);\r\n          return result;\r\n        },\r\n        onFailure: (error, headers, xhr) => {\r\n          if (onError) onError(error, headers, xhr);\r\n          console.log(error, headers?.errormsg);\r\n        },\r\n      });\r\n    });\r\n  });\r\n}\r\n","import { _3DSpace_get_csrf, _3DSpace_file_update } from \"./3dspace_api\";\r\n\r\n/**\r\n * @description La fonction « pushDataIn3DSpace » est utilisée pour pousser les données dans le 3DSpace à l'aide\r\n * des informations d'identification et de l'ID d'objet fournis.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification nécessaires à\r\n * l'authentification dans une fonction interne(_3DSpace_get_downloadTicket_multidoc). Il doit avoir les propriétés suivantes: space, token, tenant\r\n * @param {String} [credentials.space] - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace :(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia) , 3DSwym, 3DCompass...)\r\n \r\n * @param {Object} dataBase - Le paramètre `dataBase` est un objet qui contient les données que vous souhaitez\r\n * transférer dans l'espace 3D. Il sera converti au format JSON et enregistré sous forme de fichier\r\n * dans l'espace 3D.\r\n * @param {String} objectId - Le paramètre objectId est l'identifiant unique de l'objet dans l'espace 3D où les\r\n * données seront poussées.\r\n * @param {Function} [onDone] - Le paramètre onDone est une fonction de rappel qui sera appelée lorsque les\r\n * données seront correctement poussées vers l'espace 3D. Il faut un argument, qui est le résultat de\r\n * l'opération.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée si une erreur\r\n * survient lors de l'exécution de la fonction `pushDataIn3DSpace`. Il vous permet de gérer et de\r\n * répondre à toute erreur pouvant survenir.\r\n */\r\nexport function pushDataIn3DSpace(\r\n  credentials,\r\n  dataBase,\r\n  objectId,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const jsonFile = new Blob([JSON.stringify(dataBase)], { type: \"text/plain\" });\r\n\r\n  _3DSpace_get_csrf(\r\n    credentials,\r\n    objectId,\r\n    (data) => {\r\n      const fileId = data.data[0].relateddata.files[0].id;\r\n      const fileName =\r\n        data.data[0].dataelements.secondaryTitle !== \"\"\r\n          ? data.data[0].dataelements.secondaryTitle\r\n          : data.data[0].dataelements.title;\r\n\r\n      _3DSpace_file_update(\r\n        credentials,\r\n        objectId,\r\n        fileId,\r\n        jsonFile,\r\n        fileName,\r\n        (result) => {\r\n          if (onDone) onDone(result);\r\n        },\r\n        (err) => {\r\n          if (onError) onError(err);\r\n        },\r\n      );\r\n    },\r\n    (error) => {\r\n      console.log(\"En cas d'erreur nous avons :\", error);\r\n      alert(\"Erreur lors de la sauvegarde, Veuillez réessayez\");\r\n      if (onError) onError(error);\r\n    },\r\n  );\r\n}\r\n","import {\r\n  _3DSpace_download_doc,\r\n  _3DSpace_download_multidoc,\r\n  _3DSpace_get_csrf,\r\n  _3DSpace_csrf,\r\n} from \"./3dspace_api\";\r\n\r\nlet listObjectId, datas;\r\n\r\nconst mixedDatas = [];\r\n\r\n/**\r\n * @description La fonction `get_3DSpace_csrf` récupère un jeton CSRF du 3DSpace en utilisant les  informations d'identification fournies.(Anciennement loadDatas())\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici' « objID », « space ».\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.objID - Le paramètre objID correspond à un object ID contant les objets Id des bases de données)(se base sur un tenant).\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le jeton\r\n * CSRF sera récupéré avec succès. Il faut un argument, qui est la valeur du jeton CSRF.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée si une erreur\r\n * survient lors de l'exécution de la fonction `get_3DSpace_csrf`. C'est un paramètre facultatif, donc\r\n * s'il n'est pas fourni, la fonction ne fera rien en cas d'erreur.\r\n */\r\nexport async function get_3DSpace_csrf(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  if (credentials.objID && credentials.objID !== \"\") {\r\n    _3DSpace_get_csrf(\r\n      credentials,\r\n\r\n      (response) => {\r\n        if (onDone) onDone(response);\r\n      },\r\n      (err) => {\r\n        if (onError) onError(err);\r\n      },\r\n    );\r\n  } else if (credentials.objID === null) {\r\n    _3DSpace_csrf(\r\n      credentials,\r\n      (rep) => {\r\n        const msg = \"Pas d'objID, ou invalide\";\r\n        const info = { rep, msg };\r\n        if (onDone) onDone(info);\r\n      },\r\n      (err) => {\r\n        const msg = \"Pas d'objID et erreur sur le Space\";\r\n        const infos = { msg, err };\r\n        if (onError) onError(infos);\r\n      },\r\n    );\r\n  }\r\n}\r\n\r\n/**\r\n * @description La fonction `getDatasByTenant` est une fonction asynchrone qui télécharge des documents à partir d'un espace 3D à l'aide des informations d'identification fournies et appelle le rappel `onDone`\r\n * avec les données téléchargées ou le rappel `onError` avec une erreur le cas échéant. (anciennement getDocuments())\r\n\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant \r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {ArrayOfObject} credentials.objIds - Tableau d'objets des objets Id des bases de données et leur nom.(ex: credentials.objIds=[{objId:\"xxx\",name:\"xxx\"},{objId:\"xxx\",name:\"xxx\"}] ) (name disponible dans le module : \r\n * - dbClients, \r\n * - dbCatalogs, \r\n * - dbProjets )\r\n\r\n * @param {Function} [onDone] - Le paramètre onDone est une fonction de rappel qui sera appelée lorsque les\r\n * données seront téléchargées avec succès. Il faut un argument, qui correspond aux données\r\n * téléchargées.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée si une erreur\r\n * survient lors de l'exécution de la fonction `_3DSpace_download_doc`. Il vous permet de gérer et de\r\n * répondre à toute erreur pouvant survenir.\r\n */\r\nexport async function getDatasByTenant(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  console.log(\"getDatasByTenant\", credentials);\r\n  await _3DSpace_download_doc(\r\n    credentials,\r\n    (data) => {\r\n      const _datas = {};\r\n      _datas[\"obj\"] = data;\r\n      getDatasFrom3DSpace(\r\n        credentials,\r\n        (reponse) => {\r\n          _datas[\"datas\"] = reponse;\r\n          if (onDone) onDone(_datas);\r\n        },\r\n        (err) => {\r\n          if (onError) onError(err);\r\n        },\r\n      );\r\n    },\r\n    (err) => {\r\n      if (onError) onError(err);\r\n    },\r\n  );\r\n}\r\n\r\n/**\r\n * @description La fonction `getDatasFrom3DSpace` récupère les données d'un espace 3D en utilisant les informations\r\n * d'identification fournies et appelle le rappel `onDone` avec les données récupérées ou le rappel\r\n * `onError` avec une erreur le cas échéant.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n * @param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param {ArrayOfObject} credentials.objIds - Tableau d'objets des objets Id des bases de données et leur nom.(ex: credentials.objIds=[{objId:\"xxx\",name:\"xxx\"},{objId:\"xxx\",name:\"xxx\"}] ) (name disponible dans le module :\r\n * - dbClients,\r\n * - dbCatalogs,\r\n * - dbProjets )\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque toutes\r\n * les données auront été téléchargées avec succès depuis l'espace 3D. Il faut un argument, qui est un\r\n * tableau d’objets. Chaque objet du tableau représente un document téléchargé et possède deux\r\n * propriétés: le nom du document\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSpace_download_doc`. Il vous permet de gérer et de\r\n * répondre à toute erreur qui se produit.\r\n */\r\nexport function getDatasFrom3DSpace(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const bbds = [];\r\n  credentials.objIds.forEach((obj, i) => {\r\n    _3DSpace_download_doc(\r\n      credentials,\r\n      obj.objId,\r\n      (data) => {\r\n        bbds.push({ [obj.name]: data });\r\n        if (obj.name === \"dbProjets\") {\r\n          listObjectId = data.affaires.map((aff) => {\r\n            return aff.objectID;\r\n          });\r\n          dataMixing(credentials, datas);\r\n        }\r\n        if (i === credentials.objIds.length - 1) {\r\n          if (onDone) onDone(bbds);\r\n        }\r\n      },\r\n      (err) => {\r\n        if (onError) onError(err);\r\n      },\r\n    );\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `dataMixing` prend en compte les informations d'identification, les données et les\r\n * rappels facultatifs, télécharge les données à partir d'un espace 3D, les mélange avec les données\r\n * d'entrée et renvoie les données mélangées.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles qu'ici « token » et « space ».(ex: credentials.space, credentials.tenant, credentials.token...).\r\n@param {String} credentials.space - (3DSpace) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant \r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} credentials.token - Le paramètre token est le jeton CSRF. (headers ex: ENO_CSRF_TOKEN:token)\r\n * @param _datas - Le paramètre `_datas` est un tableau d'objets ID d'Affaires\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque le\r\n * processus de mélange des données sera terminé avec succès. Il prend un argument, `mixedDatas`, qui\r\n * est un tableau contenant les données mixtes.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée en cas\r\n * d'erreur lors du processus de mélange des données. Il faut un argument, qui est l'objet d'erreur.\r\n */\r\nexport function dataMixing(\r\n  credentials,\r\n  _datas,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  _3DSpace_download_multidoc(\r\n    credentials,\r\n    listObjectId,\r\n    (result) => {\r\n      const copyData = [..._datas];\r\n      copyData.find((e) => e.objectID === result.objectId)[\"data\"] =\r\n        result.data;\r\n      datas = copyData;\r\n\r\n      mixedDatas.push(result.data);\r\n      if (onDone) onDone(mixedDatas);\r\n    },\r\n    (err) => {\r\n      if (onError) onError(err), console.log(err);\r\n    },\r\n  );\r\n}\r\n","import { _httpCallAuthenticated } from \"../main/3dexperience_api\";\r\nimport { _3DSpace_get_docInfo } from \"../main/3dspace_api\";\r\nimport { UUID } from \"../../api/index\";\r\n\r\n// LINK - https://media.3ds.com/support/documentation/developer/Cloud/en/English/CAA3DSpaceREST/CAA6WRestServicePrinciples.htm\r\n// Doc de test sur tenant BEAM3 PROD\r\nconst objIDTEST = \"B70C12CDAE0415006579A93200061A14\";\r\n// Doc de test sur tenant Pivetau TEST\r\nconst objIDTEST2 = \"FA35FB9B177A28006580190400193C20\";\r\nconst objIDTEST3 = \"FA35FB9B177A280065800EA0000F599C\";\r\n\r\nconst sourcesSearching = [\r\n  \"swym\",\r\n  \"3dspace\",\r\n  \"drive\",\r\n  \"usersgroup\",\r\n  \"3dplan\",\r\n  \"dashboard\",\r\n];\r\n\r\nconst listPredicates = {\r\n  how: \"ds6w:how\",\r\n  what: \"ds6w:what\",\r\n  when: \"ds6w:when\",\r\n  where: \"ds6w:where\",\r\n  who: \"ds6w:who\",\r\n  why: \"ds6w:why\",\r\n};\r\nconst objToTag = {\r\n  objId: objIDTEST3,\r\n  pred: \"who\",\r\n  order_by: \"desc\",\r\n  tag: \"testTag\",\r\n};\r\n\r\n/**\r\n * @description La fonction `addTagToDoc` est utilisée pour ajouter une balise à un document dans un espace 3D en\r\n * utilisant les informations d'identification et les informations sur l'objet fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Object} credentials.currentUser.username - Le paramètre `currentUser` est un qui contient les informations de l'utilisateur qui envoie le message(appeler depuis la fonction `_3DSwym_get_currentuser`), une chaîne de caractère contenant le nom d'utilisateur.\r\n *\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n * @param {Object} obj - Le paramètre `obj` est un objet qui contient les propriétés suivantes :\r\n * @param {String} obj.info.name - L'identifiant de l'objet que vous souhaitez marquer. (ex: B70C12CDAE0415006579A93200061A14)\r\n * @param {String} obj.pred - La propriété de l'objet que vous souhaitez marquer. (ex: how, what, when, where, who, why)\r\n * @param {String} obj.tag - Le tag que vous souhaitez ajouter à l'objet.\r\n * @param {String} obj.order_by - L'ordre de la balise que vous souhaitez ajouter à l'objet. (ex: asc, desc)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque\r\n * l'opération de marquage sera terminée avec succès. La réponse du serveur lui sera transmise en\r\n * argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `addTagToDoc`. Il vous permet de gérer et de traiter\r\n * l'erreur de manière personnalisée.\r\n * @example credentials={space: \"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\", currentUser: { username: \"Yan\" }, tenant: \"R1132100968447\"}\r\n * @example obj={objId: \"B70C12CDAE0415006579A93200061A14\", pred: \"what\", tag: \"testTag\"}\r\n *\r\n */\r\nexport function addTagToDoc(\r\n  credentials,\r\n  obj,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space, tenant } = credentials;\r\n  const { objId, pred, tag } = obj;\r\n\r\n  const URL = {\r\n    uri: \"/resources/6w/tags\",\r\n    otpCTX: \"SecurityContext=preferred\",\r\n    optTenant: `tenant=${tenant}`,\r\n  };\r\n  const url = `${space}${URL.uri}?${URL.otpCTX}&${URL.optTenant}`;\r\n  const dataTest = {\r\n    tag: [\r\n      {\r\n        subject: [\r\n          {\r\n            uri: `pid://${objId}`,\r\n          },\r\n        ],\r\n        predicate: listPredicates[pred],\r\n        object: {\r\n          literal: tag,\r\n        },\r\n      },\r\n    ],\r\n  };\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"PUT\",\r\n    headers: {\r\n      \"Content-Type\": \"application/json\",\r\n      Accept: \"application/json\",\r\n    },\r\n    data: JSON.stringify(dataTest),\r\n    onComplete(response) {\r\n      const resp = JSON.parse(response);\r\n      const info = {};\r\n      setTimeout(() => {\r\n        _3DSpace_get_docInfo(\r\n          credentials,\r\n          objId,\r\n          (rep) => {\r\n            const docName = rep.data[0].dataelements.title;\r\n            const docExt =\r\n              rep.data[0].dataelements.fileExtension !== undefined\r\n                ? rep.data[0].dataelements.fileExtension\r\n                : \"\";\r\n            const createBy =\r\n              rep.data[0].relateddata.ownerInfo[0].dataelements.name;\r\n            info[\"name\"] = docName;\r\n            info[\"ext\"] = docExt;\r\n            info[\"createBy\"] = createBy;\r\n            obj.info = { ...info };\r\n            getActualTagsOnDoc(\r\n              credentials,\r\n              obj,\r\n              (rep) => {\r\n                if (onDone) onDone(rep);\r\n              },\r\n              (err) => {\r\n                if (onError) onError(err);\r\n              },\r\n            );\r\n          },\r\n          (response, headers) => {\r\n            const info = response;\r\n            info[\"msg\"] = headers.errormsg;\r\n            info[\"errCode\"] = headers.errorcode;\r\n            console.log(\"❌ sendDirectMessage => \", info);\r\n            if (onError) onError(info);\r\n          },\r\n        );\r\n      }, 2000);\r\n    },\r\n    onFailure(response, headers) {\r\n      const info = response;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n      console.log(\"❌ sendDirectMessage => \", info);\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n/**\r\n * @description La fonction `getActualTagsOnDoc` récupère les balises réelles d'un document en utilisant les\r\n * informations d'identification et les informations sur l'objet fournies. Appeler depuis `addTagToDoc()`\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n * @param {Object} credentials.currentUser.username - Le paramètre `currentUser` est un qui contient les informations de l'utilisateur qui envoie le message(appeler depuis la fonction `_3DSwym_get_currentuser`).\r\n * @param {Object} credentials.ctx  - L'ID du contexte de travail.\r\n * @param obj - Le paramètre `obj` est un objet qui contient des informations sur le document. Il\r\n * possède les propriétés suivantes :\r\n * @param {String} obj.info.name - Le nom du document.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque\r\n * l'opération de marquage sera terminée avec succès. La réponse du serveur lui sera transmise en\r\n * argument.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `addTagToDoc`. Il vous permet de gérer et de traiter\r\n * l'erreur de manière personnalisée.\r\n */\r\nexport function getActualTagsOnDoc(\r\n  credentials,\r\n  obj,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // const nomFichier = \"beam_cube_TEST_BDD\";\r\n  console.log(\"obj \", obj);\r\n  const nomFichier = obj.info.name;\r\n  const URL = {\r\n    baseUrl: `https://${credentials.tenant.toLowerCase()}-eu1-fedsearch.3dexperience.3ds.com`,\r\n    uri: \"/federated/search\",\r\n  };\r\n  const url = `${URL.baseUrl}${URL.uri}`;\r\n  const headers = {\r\n    \"Content-Type\": \"application/json\",\r\n    Accept: \"application/json,text/javascript,*/*\",\r\n  };\r\n  const uuid = UUID();\r\n  const dataPattern = {\r\n    with_indexing_date: true,\r\n    with_synthesis: true,\r\n    with_nls: false,\r\n    label: `3DSearch-${credentials.currentUser.username}-AjoutDeTagBeam-${uuid}`,\r\n    locale: \"fr\",\r\n    select_predicate: [\r\n      \"ds6w:label\",\r\n      \"ds6w:type\",\r\n      \"ds6w:description\",\r\n      \"ds6w:identifier\",\r\n      \"ds6w:modified\",\r\n      \"ds6w:created\",\r\n      \"ds6wg:revision\",\r\n      \"ds6w:status\",\r\n      \"ds6w:responsible\",\r\n      \"owner\",\r\n      \"ds6w:responsibleUid\",\r\n      \"ds6wg:filesize\",\r\n      \"ds6w:project\",\r\n      \"ds6w:dataSource\",\r\n      \"ds6w:community\",\r\n      \"ds6w:originator\",\r\n      \"dsgeo:referential\",\r\n      \"ds6w:lastModifiedBy\",\r\n      \"ds6w:repository\",\r\n      \"dcterms:title\",\r\n      \"dcterms:description\",\r\n      \"ds6w:containerUid\",\r\n    ],\r\n    with_synthesis_hierarchical: true,\r\n    select_file: [\"icon\", \"thumbnail_2d\"],\r\n    query: nomFichier,\r\n    specific_source_parameter: {\r\n      \"3dspace\": {\r\n        additional_query:\r\n          ' AND NOT (owner:\"ENOVIA_CLOUD\" OR owner:\"Service Creator\" OR owner:\"Corporate\" OR owner:\"User Agent\" OR owner:\"SLMInstallerAdmin\" OR owner:\"Creator\" OR owner:\"VPLMAdminUser\") AND (ds6w_58_islastrevisionperstate:true OR NOT listoffields:ds6w_58_islastrevisionperstate)',\r\n      },\r\n      drive: {\r\n        additional_query:\r\n          ' AND NOT ([flattenedtaxonomies]:\"types/DriveNode\" AND ( [current]:\"Trashed\" OR [policy]:\"Drive File Iteration\") )',\r\n      },\r\n    },\r\n    select_exclude_synthesis: [\"ds6w:what/ds6w:topic\"],\r\n    order_by: objToTag.order_by,\r\n    order_field: \"relevance\",\r\n    select_snippets: [\r\n      \"ds6w:snippet\",\r\n      \"ds6w:label:snippet\",\r\n      \"ds6w:responsible:snippet\",\r\n      \"ds6w:community:snippet\",\r\n      \"swym:message_text:snippet\",\r\n    ],\r\n    nresults: 40,\r\n    start: \"0\",\r\n    source: sourcesSearching,\r\n    tenant: credentials.tenant,\r\n    login: {\r\n      \"3dspace\": {\r\n        SecurityContext: credentials.ctx,\r\n      },\r\n    },\r\n  };\r\n  console.log(\"dataPattern => \", dataPattern);\r\n  _httpCallAuthenticated(url, {\r\n    method: \"POST\",\r\n    headers: headers,\r\n    data: JSON.stringify(dataPattern),\r\n    onComplete(response) {\r\n      const info = JSON.parse(response);\r\n      onDone(info);\r\n    },\r\n    onFailure(err, headers) {\r\n      const info = err;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n      console.log(\"❌ sendDirectMessage => \", info);\r\n      if (onError) onError(info);\r\n      console.log(\"Erreur de recuperation d'id du doc et des tags\", err);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `removeTagToDoc` est utilisée pour supprimer une balise spécifique d'un document en\r\n * utilisant les informations d'identification et les informations sur l'objet fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {String} credentials.tenant - L'identifiant du tenant sur lequel l'API est déployée.(ex: R1132100968447)\r\n *\r\n * @param {Object} obj - Le paramètre `obj` est un objet qui contient les propriétés suivantes :\r\n * @param {String} obj.objId - L'identifiant unique de l'objet pour lequel vous souhaitez supprimer la balise.\r\n * @param {String} obj.pred - L'identifiant de la relation entre l'objet et la balise. (ex: how, what, when, where, who, why).\r\n * @param {String} obj.tag - Le nom du tag à supprimer.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * suppression de la balise du document sera terminée avec succès. Il faut un argument, qui est la\r\n * réponse du serveur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `removeTagToDoc`. Il vous permet de gérer et de traiter\r\n * l'erreur de manière personnalisée.\r\n */\r\nexport function removeTagToDoc(\r\n  credentials,\r\n  obj,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { objId, pred, tag } = obj;\r\n\r\n  const URL = {\r\n    uri: \"/resources/6w/tags\",\r\n    otpCTX: \"SecurityContext=preferred\",\r\n    optTenant: `tenant=${credentials.tenant}`,\r\n  };\r\n  const url = `${credentials.space}${URL.uri}?${URL.otpCTX}&${URL.optTenant}`;\r\n  const dataTest = {\r\n    tag: [\r\n      {\r\n        subject: [\r\n          {\r\n            uri: `pid://${objId}`,\r\n          },\r\n        ],\r\n        predicate: listPredicates[pred],\r\n        object: {\r\n          literal: tag,\r\n        },\r\n      },\r\n    ],\r\n  };\r\n  _httpCallAuthenticated(url, {\r\n    method: \"DELETE\",\r\n    data: JSON.stringify(dataTest),\r\n    headers: {\r\n      \"Content-Type\": \"application/json\",\r\n      Accept: \"application/json,text/javascript,*/*\",\r\n    },\r\n    onComplete(response) {\r\n      if (onDone) onDone(response);\r\n    },\r\n    onFailure(err, headers) {\r\n      const info = err;\r\n      info[\"msg\"] = headers.errormsg;\r\n      info[\"errCode\"] = headers.errorcode;\r\n      console.log(\"❌ sendDirectMessage => \", info);\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction « getInfoDocTags » effectue un appel HTTP pour récupérer des informations sur les\r\n * documents en fonction des informations d'identification et des identifiants de document fournis.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {String} [str] - Le paramètre `str` est une chaîne qui représente l'ID du documents pour lesquels\r\n * vous souhaitez récupérer des informations.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête HTTP sera terminée avec succès. Il prend un argument, qui correspond aux données de réponse\r\n * de la requête.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `getInfoDocTags`. Il vous permet de gérer et de traiter\r\n * les informations d'erreur.\r\n * @returns La fonction ne renvoie explicitement rien.\r\n */\r\nexport function getInfoDocTags(\r\n  credentials,\r\n  str = \"\",\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { space } = credentials;\r\n  if (str === \"\") return;\r\n\r\n  const URL = {\r\n    uri: \"/enovia/resources/v1/modeler/documents\",\r\n  };\r\n\r\n  const headers = {\r\n    \"Content-Type\": \"application/x-www-form-urlencoded; charset=UTF-8\",\r\n    Accept: \"application/json,text/javascript,*/*\",\r\n  };\r\n  const url = `${space}${URL.uri}`;\r\n\r\n  const dataTest = `$include=none,lockerInfo,ownerInfo,originatorInfo,files,ownerInfo,originatorInfo&$fields=none,title,name,typeNLS,collabSpaceTitle,revision,isLatestRevision,files,lockStatus,lockerInfo.name,lockerInfo.firstname,lockerInfo.lastname,owner,ownerInfo.name,ownerInfo.firstname,ownerInfo.lastname,stateNLS,modified,policy,state,organizationTitle,originator,originatorInfo.name,originatorInfo.firstname,originatorInfo.lastname,hasModifyAccess,fileExtension,files.name,files.title,files.revision,files.locker,ownerInfo,ownerInfo.name,ownerInfo.firstname,ownerInfo.lastname,originatorInfo,originatorInfo.name,originatorInfo.firstname,originatorInfo.lastname&$ids=${str}`;\r\n\r\n  _httpCallAuthenticated(url, {\r\n    method: \"POST\",\r\n    headers: headers,\r\n    data: dataTest,\r\n    onComplete(response) {\r\n      if (onDone) onDone(JSON.parse(response));\r\n    },\r\n    onFailure(err, header) {\r\n      const info = err;\r\n      info[\"msg\"] = header.error;\r\n      if (onError) onError(info);\r\n    },\r\n  });\r\n}\r\n","import { _httpCallAuthenticated } from \"../main/3dexperience_api\";\r\n\r\n/**\r\n * @description La fonction `_3DSwym_get_version` récupère le token du 3DSwym et effectue des actions supplémentaires si nécessaire. Obligatoire pour chaque appel d'API du Swym.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque les\r\n * informations de version seront récupérées avec succès. Il prend un argument, `tokenInfo`, qui est la\r\n * réponse contenant les informations de version. Le token est aussi envoyé dans une nouvelle propriété : `credentials.token`\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de la requête HTTP. Il est facultatif et peut être indéfini.\r\n */\r\nexport async function _3DSwym_get_version(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url = credentials.space + \"/api/index/tk\";\r\n\r\n  return _httpCallAuthenticated(url, {\r\n    onComplete(response, headers, xhr) {\r\n      const tokenInfo = JSON.parse(response);\r\n\r\n      if (onDone) {\r\n        onDone(tokenInfo);\r\n        return (credentials[\"token\"] = tokenInfo?.result?.ServerToken);\r\n      }\r\n    },\r\n\r\n    onFailure(response) {\r\n      if (onError) onError(response);\r\n    },\r\n  });\r\n}\r\n\r\n/**\r\n * La fonction `_3DSwym_getAllNews` récupère toutes les actualités d'une plateforme 3DExperience en\r\n * utilisant les informations d'identification fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête sera terminée avec succès. Il prend deux arguments : « réponse » et « en-têtes ». L'argument\r\n * `response` contient les données de réponse du serveur et l'argument `headers` contient les en-têtes\r\n * de réponse.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_getAllNews`. Il prend deux paramètres : « réponse\r\n * » et « en-têtes ». Le paramètre `response` contient les données de réponse à l'erreur et le\r\n */\r\nexport function _3DSwym_getAllNews(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // ! Attention beaucoup d'infos à trier et checker\r\n  // voir aussi les possibilités des params\r\n\r\n  const url = `${credentials.space}/api/exalead/whatsnew`;\r\n  const data = {\r\n    params: {\r\n      community_id: null,\r\n      hash_key: null,\r\n      legacyFormat: false,\r\n      nresults: 1,\r\n      query: \"#all\",\r\n      start: 0,\r\n    },\r\n  };\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(url, {\r\n      method: \"POST\",\r\n      headers: {\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n        \"Content-type\": \"application/json;charset=UTF-8\",\r\n        Accept: \"application/json\",\r\n      },\r\n      data: JSON.stringify(data),\r\n      type: \"json\",\r\n      onComplete(response, headers) {\r\n        if (onDone) onDone(response, headers);\r\n      },\r\n      onFailure(response, headers) {\r\n        if (onError) onError(response, headers);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * La fonction `_3DSwym_getFamiliarPeople` récupère une liste de personnes familières en fonction du\r\n * profil de l'utilisateur actuel.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque l'appel\r\n * d'API réussit et que les données sont récupérées. Il faut deux arguments : `myContacts` et\r\n * `response`. `myContacts` est un tableau d'objets contenant le login et le nom complet des personnes\r\n * familières. `réponse\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_getFamiliarPeople`. Il prend deux paramètres : «\r\n * réponse » et « en-têtes ». Le paramètre `response` contient la réponse d'erreur du serveur\r\n */\r\nexport function _3DSwym_getFamiliarPeople(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url = `${credentials.space}/api/Recommendation/getpeoplefamiliartocurrentuser`;\r\n  const _data = {\r\n    params: {\r\n      idsToFilterArr: [],\r\n      mode: \"offline\",\r\n      limit: 30,\r\n      itemType: \"User\",\r\n      maxNbOfCommonElements: \"5\",\r\n    },\r\n  };\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(url, {\r\n      method: \"POST\",\r\n      headers: {\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n        \"Content-type\": \"application/json;charset=UTF-8\",\r\n        Accept: \"application/json\",\r\n      },\r\n      data: JSON.stringify(_data),\r\n      type: \"json\",\r\n      onComplete(response, headers) {\r\n        const myContacts = response.result.hits.map((contact) => {\r\n          return { login: contact.login, fullName: contact.name };\r\n        });\r\n\r\n        if (onDone) onDone(myContacts, response);\r\n      },\r\n      onFailure(response, headers) {\r\n        if (onError) onError(response, headers);\r\n      },\r\n    });\r\n  });\r\n}\r\n","import { _httpCallAuthenticated } from \"../../main/3dexperience_api\";\r\nimport { _3DSwym_get_version } from \"../3dswym_api\";\r\n\r\n/**\r\n * @description La fonction `_3dSwim_getAllCommunities` récupère une liste de communautés à partir d'une plateforme\r\n * 3D Swim en utilisant les informations d'identification fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Number} credentials.limit - Le paramètre `limit` est un nombre entier qui indique le nombre maximum de communautés à recevoir. Par défaut, il est de 10, mais vous pouvez le changer jusqu'à 128, au delà on change de page.\r\n * @param {Number} credentials.page - Le paramètre `page` est un nombre entier qui indique la page courante. Par défaut, il est à 1.\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée une fois l'opération terminée. Il prend la\r\n * liste des communautés comme paramètre.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3dSwim_getAllCommunities`. Il vous permet de gérer et de\r\n * répondre à toute erreur qui se produit.\r\n */\r\nexport function _3DSwim_getAllCommunities(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const URL = {\r\n    base: credentials.space,\r\n    uri: \"/api/community/listmycommunities\",\r\n    limit: `/limit/${credentials.limit ? credentials.limit : 128}`,\r\n    page: `/page/${credentials.page ? credentials.page : \"1\"}`,\r\n  };\r\n\r\n  const url = `${URL.base}${URL.uri}${URL.limit}${URL.page}`;\r\n  const communautes = [];\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(url, {\r\n      method: \"GET\",\r\n      headers: {\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n      onComplete(response, headers, xhr) {\r\n        const info = JSON.parse(response);\r\n        const _communitiesInfo = info.result;\r\n        let count = 0;\r\n\r\n        _communitiesInfo.forEach((commu) => {\r\n          const _communaute = {\r\n            description: commu.description,\r\n            id: commu.id,\r\n            title: commu.title,\r\n            owner: commu.owner,\r\n            role: commu.role,\r\n            access: commu.access,\r\n          };\r\n          _3DSwim_getMembersCommunity(\r\n            credentials,\r\n            commu.id,\r\n            (data) => {\r\n              count++;\r\n              _communaute[\"members\"] = data;\r\n              communautes.push(_communaute);\r\n              if (count === _communitiesInfo.length && onDone) {\r\n                onDone(communautes);\r\n              }\r\n            },\r\n            (err) => onError(err),\r\n          );\r\n        });\r\n      },\r\n      onFailure(response, headers) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwim_getMembersCommunity` récupère une liste des membres d'une communauté en utilisant les informations d'identification et l'ID de communauté fournis.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Number} credentials.limit - Le paramètre `limit` est un nombre entier qui indique le nombre maximum de communautés à recevoir. Par défaut, il est de 50, mais vous pouvez le changer jusqu'à 128, au delà on change de page.\r\n * @param {Number} credentials.page - Le paramètre `page` est un nombre entier qui indique la page courante. Par défaut, il est à 1.\r\n * @param {String} idCommu - L'identifiant de la communauté dont vous souhaitez récupérer les membres. (ex: \"YXdA5x4DSUKtlAi2wmnyTA\")\r\n * @param {Function} onDone - Une fonction de rappel qui sera appelée lorsque l'appel d'API réussit et renvoie les\r\n * données de réponse. Les données de réponse seront transmises en argument à cette fonction.\r\n * @param {Function} onError - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwim_getMembersCommunity`. Il est utilisé pour gérer\r\n * toutes les erreurs qui se produisent et fournir une gestion des erreurs ou des messages d'erreur\r\n * appropriés à l'appelant de la fonction.\r\n */\r\nexport function _3DSwim_getMembersCommunity(\r\n  credentials,\r\n  idCommu,\r\n  onDone,\r\n  onError,\r\n) {\r\n  const URL = `${credentials.space}/api/community/listmembers`;\r\n\r\n  const datas = {\r\n    params: {\r\n      page: credentials.page ? credentials.page : 1,\r\n      limit: credentials.limit ? credentials.limit : 50,\r\n      community_id: idCommu,\r\n    },\r\n  };\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(URL, {\r\n      method: \"POST\",\r\n      headers: {\r\n        \"Content-type\": \"application/json;charset=UTF-8\",\r\n        Accept: \"application/json\",\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n      data: JSON.stringify(datas),\r\n      type: \"json\",\r\n      onComplete(response, headers, xhr) {\r\n        const info = response;\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response, headers) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwym_getIdeaStatusMaturity` récupère le statut et la maturité d'une idée d'une\r\n * communauté 3DExperience à l'aide des informations d'identification fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {String} credentials.commu_id - L'ID de communauté 3DExperience (ex:\"YXdA5x4DSUKtlAi2wmnyTA\")\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête API sera terminée avec succès. Il prend un argument, « info », qui correspond aux données de\r\n * réponse de l'API.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_getIdeaStatusMaturity`. Il vous permet de gérer\r\n * et de traiter l'erreur de manière personnalisée.\r\n */\r\nexport function _3DSwym_getIdeaStatusMaturity(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const commuID = \"YXdA5x4DSUKtlAi2wmnyTA\";\r\n  if (!credentials.commu_id) credentials.commu_id = commuID;\r\n  const URL = `${credentials.space}/api/v2/communities/${credentials.commu_id}/ideas/statuses`;\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(URL, {\r\n      method: \"GET\",\r\n      headers: {\r\n        \"Content-type\": \"application/json;charset=UTF-8\",\r\n        Accept: \"application/json\",\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n\r\n      onComplete(response) {\r\n        const info = JSON.parse(response);\r\n\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response, headers) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n// TEST\r\nconst contentMSG = {\r\n  receipt: [\"c00005701637\"], // Liste des personnes à qui envoyer le message\r\n  msg: \"TESTS Beam ³ DEV, Happy new year ! ヾ(⌐■_■)ノ♪\", // Message à envoyer\r\n};\r\n\r\n// CREATION DE MESSAGES DIRECT OU INSTANTANÉ\r\n\r\n/**\r\n * @description La fonction `_3DSwym_buildDirectMessage` permet d'envoyer un message direct à un ou plusieurs utilisateurs dans un espace plateforme 3DExperience.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Object} [credentials.currentUser] - Le paramètre `currentUser` est un qui contient les informations de l'utilisateur qui envoie le message(appeler depuis la fonction `_3DSwym_get_currentuser`).\r\n * @param {string} [credentials.currentUser.login] - Le paramètre `login` est l'identifiant d'envois du message\r\n * @param {string} [credentials.currentUser.first_name] - Le paramètre `first_name` est l'identifiant d'envois du message\r\n * @param {string} [credentials.currentUser.last_name] - Le paramètre `last_name` est l'identifiant d'envois du message.\r\n *\r\n * @param {Object} [datas] - Le paramètre `datas` est un objet qui contient les données du messages.\r\n * @param {String} [datas.msg] - Le paramètre `msg` est une chaîne de caractères qui contient le message à envoyer.\r\n *\r\n * @param {Array} [datas.receipt] - La liste des utilisateurs à qui envoyer le message (login). La liste des personnes accessible est générer par la fonction _3DSwym_getFamiliarPeople. (ex: [\"bem3_yan.coquoz\",\"bem_bob_Dylan\"])\r\n *\r\n * @param {Function} [onDone] - Une fonction de rappel qui sera appelée lorsque le message direct sera envoyé avec\r\n * succès. Il prend un argument, qui est un objet contenant des informations sur la réponse du serveur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_buildDirectMessage`. Il est facultatif et peut\r\n * être indéfini.\r\n */\r\nexport function _3DSwym_buildDirectMessage(\r\n  credentials,\r\n  datas,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const { listAllContacts, currentUser } = credentials;\r\n  console.log(\"__listAllContacts\", listAllContacts.hits);\r\n  const _URL = `${credentials.space}/api/directmessages`;\r\n\r\n  const _data = {\r\n    users: [currentUser.login].concat(datas.receipt),\r\n  };\r\n\r\n  const MSGData = {\r\n    id_msg: \"\",\r\n    senderId: credentials.currentUser.login,\r\n    senderName: `${credentials.currentUser.first_name} ${credentials.currentUser.last_name}`,\r\n    msg: formatedMessage(datas.msg),\r\n  };\r\n  let otherCommunity = false;\r\n  _3DSwym_findCommunityToInstantMSG(\r\n    _data.users,\r\n    (rep) => {\r\n      if (rep !== undefined) {\r\n        MSGData[\"id_msg\"] = rep.id;\r\n        otherCommunity = true;\r\n        _3DSwym_sendMessageData(credentials, MSGData);\r\n      }\r\n    },\r\n    (err) => {\r\n      otherCommunity = false;\r\n      console.log(\"_3dSwym_findCommunityToInstantMSG callback\", err);\r\n      if (onError) onError(err);\r\n      MSGData[\"id_msg\"] = \"\";\r\n    },\r\n  );\r\n\r\n  if (otherCommunity === false) {\r\n    setTimeout(() => {\r\n      if (otherCommunity === false) {\r\n        _3DSwym_get_version(credentials, (token) => {\r\n          _httpCallAuthenticated(_URL, {\r\n            method: \"POST\",\r\n            headers: {\r\n              \"Content-Type\": \"application/json\",\r\n              Accept: \"application/json\",\r\n              \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n            },\r\n            data: JSON.stringify(_data),\r\n            type: \"json\",\r\n            onComplete(response, headers, xhr) {\r\n              const info = response;\r\n              info[\"reponse\"] = JSON.parse(xhr.response);\r\n              info[\"status\"] = xhr.status;\r\n              if (onDone) onDone(info);\r\n              MSGData[\"id_msg\"] = info.result.id;\r\n              _3DSwym_sendMessageData(credentials, MSGData);\r\n            },\r\n            onFailure(response, headers, xhr) {\r\n              const info = response;\r\n              info[\"msg\"] = headers.errormsg;\r\n              info[\"status\"] = headers.status;\r\n\r\n              if (onError) onError(info);\r\n            },\r\n          });\r\n        });\r\n      }\r\n    }, 500);\r\n  }\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwym_findCommunityToInstantMSG` est utilisée pour rechercher une communauté dans une\r\n * plateforme 3DExperience pour la messagerie instantanée en fonction des informations d'identification\r\n * et des données fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {Array} datas - Le paramètre `datas` est un tableau qui contient les données à utiliser pour trouver une communauté pour envoyer un message instantané.\r\n * @param {Function} onDone - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque\r\n * l'opération sera terminée avec succès. Il faut un argument, qui est le résultat de l'opération.\r\n * @param {Function} onError - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_findCommunityToInstantMSG`. Il est facultatif et\r\n * peut être omis s’il n’est pas nécessaire.\r\n */\r\nexport function _3DSwym_findCommunityToInstantMSG(\r\n  credentials,\r\n  datas,\r\n  onDone,\r\n  onError,\r\n) {\r\n  const URL = `${credentials.space}/api/directmessages/lite?with_favorites=false`;\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(URL, {\r\n      method: \"GET\",\r\n      headers: {\r\n        Accept: \"application/json,text/javascript,*/*\",\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n      onComplete(response) {\r\n        const info = JSON.parse(response);\r\n        const infoSortedByLengths = [];\r\n        info.result.forEach((com) => {\r\n          com.users = com.users.sort((a, b) => {\r\n            return a.login.localeCompare(b.login);\r\n          });\r\n          if (com.users.length === datas.length) {\r\n            infoSortedByLengths.push(com);\r\n          }\r\n        });\r\n        const sortedDatas = datas.sort();\r\n\r\n        const _datas = infoSortedByLengths.find((com) => {\r\n          const logins = [];\r\n          com.users.forEach((user) => {\r\n            logins.push(user.login);\r\n          });\r\n          return JSON.stringify(logins) === JSON.stringify(sortedDatas);\r\n        });\r\n\r\n        if (onDone && _datas !== undefined) {\r\n          onDone(_datas);\r\n        } else if (onError || _datas === undefined) {\r\n          onError(_datas);\r\n        }\r\n      },\r\n      onFailure(response) {\r\n        const info = response;\r\n        info[\"msg\"] = headers.errormsg;\r\n        info[\"errCode\"] = headers.errorcode;\r\n        console.log(\"❌ sendDirectMessageLite => \", info);\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwym_sendMessageData` envoie un message direct avec les informations\r\n * d'identification et le contenu donnés, et appelle les rappels `onDone` ou `onError` en fonction du\r\n * succès ou de l'échec de la requête.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param content - Le paramètre `content` est un objet qui contient les propriétés suivantes :\r\n * @param {String} content.id_msg - L'identifiant du message à envoyer.\r\n * @param {String} content.senderId - L'identifiant de l'utilisateur qui envoie le message.\r\n * @param {String} content.senderName - Le nom de l'utilisateur qui envoie le message.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque l'envoi\r\n * du message sera terminé avec succès. Il prend un argument, qui est un objet contenant des\r\n * informations sur la réponse du serveur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_sendMessageData`. Il vous permet de gérer et de\r\n * traiter les informations d'erreur.\r\n */\r\nexport function _3DSwym_sendMessageData(\r\n  credentials,\r\n  content,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const URL = {\r\n    base: credentials.space,\r\n    uri: \"/api/community\",\r\n    id_msg: `${content.id_msg}`,\r\n    endUri: \"/instantmessages\",\r\n  };\r\n\r\n  const url = `${URL.base}${URL.uri}/${URL.id_msg}${URL.endUri}`;\r\n\r\n  const datas = {\r\n    author: { login: content.senderId, displayName: content.senderName },\r\n    accessState: null,\r\n    commentUri: null,\r\n    comments: null,\r\n    endorsements: null,\r\n    moderationState: null,\r\n    parentCommentUri: null,\r\n    richMessage: content.msg,\r\n  };\r\n  console.log(\"_3dSwym_sendDirectMessageData url \", url);\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(url, {\r\n      method: \"POST\",\r\n      headers: {\r\n        \"Content-Type\": \"application/json\",\r\n        Accept: \"application/json\",\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n      data: JSON.stringify(datas),\r\n      type: \"json\",\r\n      onComplete(response, headers, xhr) {\r\n        const info = response;\r\n        info[\"status\"] = xhr.status;\r\n        info[\"response\"] = JSON.parse(xhr.response);\r\n        console.log(\"✅ _3dSwym_sendDirectMessageData => \", info);\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response, headers) {\r\n        const info = response;\r\n        info[\"msg\"] = headers.errormsg;\r\n        info[\"errCode\"] = headers.errorcode;\r\n        console.log(\"❌ sendDirectMessage => \", info);\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `formatedMessage` renvoie un message formaté avec la date et l'heure actuelles.\r\n * @param {String} message - Le paramètre `message` est une chaîne qui représente le contenu du message que vous souhaitez envoyer.\r\n *\r\n * @returns un message formaté avec la date et l'heure actuelles. Le message est enveloppé dans une balise de paragraphe, suivie d'un saut de ligne et d'une règle horizontale.\r\n *   En dessous, il comprend une phrase indiquant quand le message a été envoyé, y compris la date et l'heure.\r\n *\r\n */\r\nfunction formatedMessage(message) {\r\n  const _dates = new Date().toLocaleDateString();\r\n  const time = new Date().toLocaleTimeString();\r\n  return `<p>${message} </p>\r\n  <br/>\r\n  <hr/>\r\n  <p><u>envoyer :</u>Le <b>${_dates} à ${time}</b></p>`;\r\n}\r\n\r\nexport default {\r\n  _3DSwim_getAllCommunities,\r\n  _3DSwim_getMembersCommunity,\r\n  _3DSwym_getIdeaStatusMaturity,\r\n  _3DSwym_buildDirectMessage,\r\n  _3DSwym_findCommunityToInstantMSG,\r\n  _3DSwym_sendMessageData,\r\n};\r\n","import { _httpCallAuthenticated } from \"../../main/3dexperience_api\";\r\nimport { _3DSwym_get_version } from \"../3dswym_api\";\r\n/*\r\n * @exemple dataTest\r\n */\r\nconst dataTest = {\r\n  title: \"TEST DEV COMMUNITY IDEA\", // titre du post\r\n  community_id: \"YXdA5x4DSUKtlAi2wmnyTA\", // STATUT PROJETS - Phase commerciale,  tenant PIVETEAU TEST\r\n  community_title: \"TEST DEV COMMUNITY\", // Possibilité de recherche par titre de la communauté (option)\r\n  idee_id: \"THhRI8rlQNWKRxpv3Xqqug\", // id de l'idee qui est créer au post (_3dSwym_postIdea)\r\n};\r\n\r\n/**\r\n * @description La fonction `_3DSwym_postIdea` est utilisée pour publier une idée sur une communauté 3DSwym en utilisant les informations d'identification et les données fournies.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n\r\n * @param {Array} credentials.swymCommunities tableau des communautés issue de la fonction `_3DSwim_getAllCommunities`\r\n * @param {Object} data - Le paramètre `data` est un objet qui contient les propriétés suivantes: `title`, `community_id` et `community_title` Ce dernier est optionnel.\r\n * @param {String} data.title - Le titre de l'idée.\r\n * @param {String} data.community_id - L'ID de la communauté sur laquelle l'idée doit être publiee.(ex: \"YXdA5x4DSUKtlAi2wmnyTA\")\r\n * @param {String} data.community_title - Le titre de la communauté sur laquelle l'idée doit être publiee.(optionnel, ex: TEST DEV COMMUNITY)\r\n * @param {String} data.text_html - Le message HTML de l'idée (Optionnel sur les tenants Piveteau Prod et test)\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la fonction `_3DSwym_postIdea` terminera avec succès son exécution. Il prend un argument, « info », qui contient les données de réponse de l'appel API.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une erreur lors de l'exécution de la fonction `_3DSwym_postIdea`. Il s'agit d'un paramètre facultatif, donc s'il n'est pas fourni, il sera par défaut « non défini ».\r\n *\r\n */\r\nexport function _3DSwym_postIdea(\r\n  credentials,\r\n  data,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const URL = `${credentials.space}/api/idea/add`;\r\n\r\n  const findByID = credentials.swymCommunities.find(\r\n    (commu) => commu.id === data.community_id,\r\n  );\r\n  const findByTitle = credentials.swymCommunities.find(\r\n    (commu) => commu.title.toLowerCase() === data.community_title.toLowerCase(),\r\n  );\r\n\r\n  const formatedData = {\r\n    params: {\r\n      title: data.title, // String, le nom de l'affaire\r\n      community_id: findByID?.id !== undefined ? findByID.id : findByTitle.id, // String, l'id de la communauté\r\n      message: templateAffaireMessage(data.text_html), // STRING =>  le contenue du message doit être au format HTML\r\n      published: 1, // 1 publier, 0 non publier\r\n    },\r\n  };\r\n\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    const headers = {\r\n      \"Content-type\": \"application/json;charset=UTF-8\",\r\n      Accept: \"application/json\",\r\n      \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n    };\r\n\r\n    _httpCallAuthenticated(URL, {\r\n      method: \"POST\",\r\n      headers: headers,\r\n      data: JSON.stringify(formatedData),\r\n      type: \"json\",\r\n      onComplete(response, headers, xhr) {\r\n        const info = JSON.parse(response);\r\n        info[\"status\"] = xhr.status;\r\n        info[\"response\"] = xhr.response;\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response, headers, xhr) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwym_deleteIdea` est utilisée pour supprimer une idée dans une communauté 3DExperience en utilisant les informations d'identification et les données fournies.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n \r\n * @param data - Le paramètre `data` est un objet qui contient les propriétés suivantes:\r\n * `community_id` et 'idee_id'\r\n * @param {String} data.community_id - L'ID de la communauté sur laquelle l'idée doit être supprimée.(ex: \"YXdA5x4DSUKtlAi2wmnyTA\")\r\n * @param {String} data.idee_id - L'ID de l'idée que vous souhaitez supprimer (ex: \"THhRI8rlQNWKRxpv3Xqqug\")\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * suppression de l'idée sera terminée avec succès. Il prend un argument, «info», qui contient des\r\n * informations sur la réponse du serveur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_deleteIdea`. Il vous permet de gérer et de\r\n * traiter les informations d'erreur.\r\n */\r\nexport function _3DSwym_deleteIdea(\r\n  credentials,\r\n  data,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const URL = `${credentials.space}/api/idea/delete`;\r\n  const formatedData = {\r\n    params: {\r\n      community_id: data.community_id,\r\n      ideationIds: [data.idee_id],\r\n    },\r\n  };\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(URL, {\r\n      method: \"POST\",\r\n      headers: {\r\n        \"Content-type\": \"application/json;charset=UTF-8\",\r\n        Accept: \"application/json\",\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n      data: JSON.stringify(formatedData),\r\n      type: \"json\",\r\n      onComplete(response, headers, xhr) {\r\n        const info = response;\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response, headers, xhr) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description Cette fonction JavaScript récupère une idée SWYM à l'aide des informations d'identification et de l'ID de publication fournis.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {String} [idPost] - L'identifiant de la publication ou de l'idée que vous souhaitez récupérer. Si aucun identifiant n'est fourni, il s'agira par défaut de l'identifiant de l'idée de modèle. (actuellement => Piveteau prod :\"tFtz0G4MR6qNtKgJjNfTog\", Piveteau test :\"Qpv3HN-tTDOsU-7_c5DnDg\").\r\n *\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la requête API sera terminée avec succès. Il prend un argument, « info », qui contient les données de réponse de l'appel API. (info.msg : template récupérer lors de la création d'une Affaire et utiliser dans la fonction `_3DSwym_postIdea()`).\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_getSWYMIdea`. Il vous permet de gérer et de\r\n * traiter l'erreur de manière personnalisée.\r\n */\r\nexport function _3DSwym_getSWYMIdea(\r\n  credentials,\r\n  idPost = \"\",\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  // Tenant PIVETEAU TEST template id || tenant PIVETEAU PROD\r\n  const templateIdeaId =\r\n    credentials.tenant.toLowerCase() === \"r1132101716373\"\r\n      ? \"tFtz0G4MR6qNtKgJjNfTog\"\r\n      : credentials.tenant.toLowerCase() === \"r1132101286859\"\r\n      ? \"Qpv3HN-tTDOsU-7_c5DnDg\"\r\n      : \"Template_d'idée_à_créer\"; // template créer à la creation d'une Affaire\r\n  if (idPost === \"\") {\r\n    idPost = templateIdeaId;\r\n  }\r\n\r\n  const URL = `${credentials.space}/api/idea/get`;\r\n  const datas = {\r\n    params: {\r\n      id: idPost,\r\n    },\r\n  };\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(URL, {\r\n      method: \"POST\",\r\n      headers: {\r\n        \"Content-type\": \"application/json;charset=UTF-8\",\r\n        Accept: \"application/json\",\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n      data: JSON.stringify(datas),\r\n      type: \"json\",\r\n      onComplete(response) {\r\n        const info = response;\r\n        info[\"msg\"] = info.result.message;\r\n\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwym_get_AllSWYMIdeas` récupère toutes les idées SWYM en utilisant les informations d'identification fournies et les paramètres facultatifs.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier\r\n * la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(3DSpace, 3DSwym, 3DCompass,...etc)\r\n * @example pour le 3DSpace {space:\"https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia\"}\r\n * @param {String} credentials.tenant - le tenant courant\r\n * @example {tenant:\"R1132100968447\"}\r\n * @param {Object} [data] - Le paramètre `data` est un objet qui contient des données supplémentaires pour la requête API. Il possède les propriétés suivantes :\r\n * @param {String} data.community_id - L'ID de la communauté sur laquelle l'idée doit être recherchée.(ex: \"YXdA5x4DSUKtlAi2wmnyTA\")\r\n * @param {Number} data.limit - Le nombre d'idées à renvoyer (optionnel, par défaut 10 (10 premières idées))\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque la\r\n * requête API sera terminée avec succès. Il prend un argument, «info», qui correspond aux données de\r\n * réponse de l'API.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'exécution de la fonction `_3DSwym_get_AllSWYMIdeas`. Il est facultatif et peut être\r\n * indéfini. S'il est fourni, il sera appelé avec les informations d'erreur sous forme de\r\n */\r\nexport function _3DSwym_get_AllSWYMIdeas(\r\n  credentials,\r\n  data = dataTest,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const URL = {\r\n    uri: \"/api/idea/list\",\r\n    comId: `/community_id/${\r\n      credentials.tenant.toLowerCase() === \"r1132101716373\"\r\n        ? data.community_id\r\n        : \"bgnIsG74SUWswyGzS6NC6g\"\r\n    }`,\r\n    limit: `/limit/${data.limit ? data.limit : 10}`,\r\n  };\r\n  const url = `${credentials.space}${URL.uri}${URL.comId}${URL.limit}`;\r\n  _3DSwym_get_version(credentials, (token) => {\r\n    _httpCallAuthenticated(url, {\r\n      method: \"GET\",\r\n      headers: {\r\n        \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken,\r\n      },\r\n\r\n      onComplete(response) {\r\n        const info = JSON.parse(response);\r\n\r\n        if (onDone) onDone(info);\r\n      },\r\n      onFailure(response, headers) {\r\n        const info = response;\r\n        info[\"status\"] = headers.status;\r\n        info[\"response\"] = headers.errormsg;\r\n        if (onError) onError(info);\r\n      },\r\n    });\r\n  });\r\n}\r\n\r\nfunction templateAffaireMessage(txt) {\r\n  // TEMPLATE AFFAIRES\r\n  if (!txt || txt === \"\") {\r\n    const message = `<h2><u>INFORMATIONS AFFAIRE :</u></h2>\r\n  <p><u>|⚠️<em> Merci de respecter l&#39;écriture des tags, en MAJUSCULES, nom complet, pas de caractères</em></u></p>\r\n  <p><u><em>|spéciaux, séparation par &#34;_&#34; si besoin !</em></u></p>\r\n  <p><strong>Référence client </strong>:  <em>\r\n  <a data-predicate=\"ds6w:who\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">CLIENT</a> \r\n  </em></p>\r\n  <p><strong>Référence projet </strong>: <em>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">NOM AFFAIRE</a> \r\n  <a data-predicate=\"ds6w:where\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">VILLE</a> \r\n  <a data-predicate=\"ds6w:where\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">DPT</a> \r\n  </em></p>\r\n  <p>&#x1f4dd; <strong>Base documentaire</strong> : LIEN projet</p>\r\n  <p>&#x1f4dd; <strong>Fiche COCLICO</strong> : LIEN projet<em><strong></strong>\r\n  </em></p>\r\n  <p><br /></p>\r\n  <table border=\"1\">\r\n  <tbody>\r\n  <tr><td><strong>Description projet </strong>:\r\n  <br /><br /></td></tr>\r\n  </tbody>\r\n  </table>\r\n  <p><br /></p>\r\n  <p><br /></p>\r\n  <p><strong>Produit :<em> </em></strong><em>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Hexapli Usiné</a>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Hexapli MP</a>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Lamwood</a>\r\n  </em></p>\r\n  <p><strong>Type de Bâtiment :</strong><em>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Logements</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">BUP</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">ERP</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Plateforme Logistique</a> \r\n  </em></p>\r\n  <p><strong>Essence :</strong> <em>\r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">DOUGLAS</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">PIN</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">MIXTE</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">EPICEA</a> \r\n  </em></p>\r\n  <p><strong>Qualité : </strong><em>\r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">NVI</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">VI1F</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">VI2F</a> \r\n  </em><strong></strong></p>\r\n  <p><strong>Traitement : </strong><em>\r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">PARKA</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">CT2</a> \r\n  </em></p>\r\n  <p><strong>Type de Paroi : </strong><em>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Murs Intérieurs</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Murs Extérieurs</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Planchers</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Couverture</a> \r\n  </em></p>\r\n  <p><em>\r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Etanchéité Accessible</a> \r\n  <a data-predicate=\"ds6w:what\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Etanchéité Non-Accessible</a> \r\n  </em></p>\r\n  <p><strong>Hauteur Dernier Plancher :</strong><em><strong> </strong> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">Hauteur &lt;8m</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">8m&lt; Hauteur &lt;28m</a> \r\n  <a data-predicate=\"ds6w:how\" data-type=\"internal\" class=\"s6m-tag-link s6m-link\">28m&lt; Hauteur &lt;50m</a> \r\n  </em></p>\r\n  <h2><br /></h2>\r\n  <h2><u>EQUIPE PIVETEAU :</u></h2>\r\n  <table border=\"1\">\r\n  <tbody>\r\n  <tr><td><strong>Chargé d&#39;Affaires</strong></td><td><br /></td></tr>\r\n  <tr><td><strong>Service études de prix</strong></td><td><br /></td></tr>\r\n  </tbody></table>\r\n  <p>\r\n  </p>`;\r\n    return message;\r\n  } else {\r\n    return txt;\r\n  }\r\n}\r\n","import { _httpCallAuthenticated } from \"../../main/3dexperience_api\";\r\nimport { _3DSwym_get_version } from \"../3dswym_api.js\";\r\n/**\r\n * @description La fonction `_3DSwym_get_currentUser` est utilisée pour récupérer des informations sur l'utilisateur actuel dans une plateforme 3DExperience.\r\n *\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n *\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...), Attention ici le space prend bien le 3DSwym\r\n *\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque l'appel\r\n * API réussit et que les informations utilisateur sont récupérées. Il prend un argument, qui est\r\n * l'objet d'informations utilisateur.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'appel de l'API. Il prend un paramètre, qui est la réponse d'erreur de l'API.\r\n */\r\nexport function _3DSwym_get_currentUser(\r\n  credentials,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url = credentials.space + \"/api/user/getcurrent/\";\r\n  _3DSwym_get_version(\r\n    credentials,\r\n    (token) => {\r\n      _httpCallAuthenticated(url, {\r\n        method: \"GET\",\r\n        headers: { \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken },\r\n        onComplete(response, headers, xhr) {\r\n          const info = JSON.parse(response);\r\n          if (onDone) onDone(info.result);\r\n        },\r\n\r\n        onFailure(response, headers, xhr) {\r\n          const infos = { response, headers, xhr };\r\n          if (onError) onError(infos);\r\n        },\r\n      });\r\n    },\r\n    onError,\r\n  );\r\n}\r\n\r\n/**\r\n * @description La fonction `_3DSwym_get_findUser` est utilisée pour rechercher un utilisateur par son identifiant\r\n * dans un espace 3DSwym en utilisant les informations d'identification fournies.\r\n * @param {Object} credentials - Un objet contenant les informations d'identification requises pour authentifier la demande. Il inclut généralement des propriétés telles que « token », « space », « tenant » et « ctx ».\r\n *\r\n * @param {String} credentials.space - (3DSwym) L'URL du serveur sur lequel l'API est déployée.(ex: 3DSpace =>(https://r1132100968447-eu1-space.3dexperience.3ds.com/enovia), 3DSwym, 3DCompass...)\r\n * @param {String} userLogin - Le paramètre userLogin est le nom de login de l'utilisateur que vous souhaitez\r\n * retrouver dans la plateforme 3DSwym.\r\n * @param {Function} [onDone] - Le paramètre `onDone` est une fonction de rappel qui sera appelée lorsque l'appel\r\n * API sera terminé avec succès. Il prend un argument, « info », qui correspond aux données de réponse\r\n * renvoyées par l'API.\r\n * @param {Function} [onError] - Le paramètre `onError` est une fonction de rappel qui sera appelée s'il y a une\r\n * erreur lors de l'appel de l'API. Il prend un paramètre, qui est la réponse d'erreur de l'API.\r\n */\r\nexport function _3DSwym_get_findUser(\r\n  credentials,\r\n  userLogin,\r\n  onDone = undefined,\r\n  onError = undefined,\r\n) {\r\n  const url = credentials.space + \"/api/user/find/login/\" + userLogin;\r\n  _3DSwym_get_version(\r\n    credentials,\r\n    (token) => {\r\n      _httpCallAuthenticated(url, {\r\n        method: \"GET\",\r\n        headers: { \"X-DS-SWYM-CSRFTOKEN\": token.result.ServerToken },\r\n        onComplete(response, headers, xhr) {\r\n          const info = JSON.parse(response);\r\n\r\n          if (onDone) onDone(info);\r\n        },\r\n\r\n        onFailure(response) {\r\n          if (onError) onError(response);\r\n        },\r\n      });\r\n    },\r\n    onError,\r\n  );\r\n}\r\n\r\nexport default {\r\n  _3DSwym_get_currentUser,\r\n  _3DSwym_get_findUser,\r\n};\r\n","/**\r\n * @description Fonction Test permettant de tester l'installation de la librairie\r\n *\r\n * @param   {String}  _name  une simple chaine\r\n *\r\n * @return  {String}\r\n */\r\nexport function sayHello(_name) {\r\n  const name = \"Hello \" + _name;\r\n  console.log(name);\r\n  return name;\r\n}\r\n"],"names":["UUID","uuid","couleurs","getCommunes","cp","onDone","onError","codePostal","response","json","error","findAdresse","query","getDataFromGouvFr","events","colors","year","DateTime","loadedEvents","sortedData","formatData","date","i","data","each","event","updateEvent","add","index","val","a","b","_httpCallAuthenticated","url","options","requirejs","WAFData","_setDraggable","elem","strData","onDrag","DataDragAndDrop","_setupTagger","tags","onTaggerFilter","TagNavigatorProxy","taggerProxy","widget","_setDroppable","drop","_getPlatformServices","platformId","onComplete","onFailure","i3DXCompassServices","_getPlateformInfos","retourAPI","plAPI","tenant","user","appsConfiguration","appConf","compass_getListAdditionalApps","credentials","URL","headers","xhr","info","formatedInfos","app","name","id","_AppMngt_get_users","_AppMngt_get_info_user","topHeader","createUserGroups","datas","space","currentUser","templateData","err","getComplementUG","uri","baseURL","URI","OPTs","getUsersGroupRules","OPTS","OPTsH","getUserGroupsList","opts","repUG","reponse","UG","element","iamOwner","iamMember","iam","rules","deleteUserGroups","patchUserGroups","dataMembers","dataMembersSTR","patchUserGroupsControl","_datas","readUserGroupControl","_rep","_3DSpace_get_docInfo","docid","_3DSpace","_3DSpace_get_csrf","_3DSpace_csrf","_3DSpace_file_url","file_url","head","_3DSpace_file_url_csr","csr","_3DSpace_file_update","docId","fileId","filename","_3DSpace_file_update_csr","formData","tempId","_3DSpace_Create_Doc","desc","_space","ctx","jsonFile","urls","ticket","handleSuccess","handleError","_3DSpace_get_securityContexts","cs","role","organization","contexts","context","finalCs","finalOrg","finalRole","oCS","e","couples","value","self","t","r","defineSingleItem","couple","_3DSpace_download_doc","message","objectId","result","_3DSpace_download_multidoc","objectIds","listDiv","chunk","loop","_3DSpace_get_downloadTicket_multidoc","done","onNext","compilData","fileName","fileUrl","_3DSpace_lifecycle_getNextStates","_3DSpace_lifecycle_changeState","nextState","_3DSpace_lifecycle_getGraph","_3DSpace_lifecycle_getNextRevision","_3DSpace_lifecycle_changeRevision","nextRevision","getCSRFToken","getAllContextSecurity","rep","getDataFrom3DSpace","widgetPreference","getDownloadDocument","pushDataIn3DSpace","dataBase","listObjectId","mixedDatas","get_3DSpace_csrf","getDatasByTenant","getDatasFrom3DSpace","bbds","obj","aff","dataMixing","copyData","objIDTEST3","sourcesSearching","listPredicates","objToTag","addTagToDoc","objId","pred","tag","dataTest","docName","docExt","createBy","getActualTagsOnDoc","nomFichier","dataPattern","removeTagToDoc","getInfoDocTags","str","header","_3DSwym_get_version","tokenInfo","_3DSwym_getAllNews","token","_3DSwym_getFamiliarPeople","_data","myContacts","contact","_3DSwim_getAllCommunities","communautes","_communitiesInfo","count","commu","_communaute","_3DSwim_getMembersCommunity","idCommu","_3DSwym_getIdeaStatusMaturity","commuID","_3DSwym_buildDirectMessage","listAllContacts","_URL","MSGData","formatedMessage","otherCommunity","_3DSwym_findCommunityToInstantMSG","_3DSwym_sendMessageData","infoSortedByLengths","com","sortedDatas","logins","content","_dates","time","_3DSwym_postIdea","findByID","findByTitle","formatedData","templateAffaireMessage","_3DSwym_deleteIdea","_3DSwym_getSWYMIdea","idPost","templateIdeaId","_3DSwym_get_AllSWYMIdeas","txt","_3DSwym_get_currentUser","_3DSwym_get_findUser","userLogin","sayHello","_name"],"mappings":"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"}
79
+ //# sourceMappingURL=wb3Api.umd.cjs.map