@descope/user-management-widget 0.2.4 → 0.4.0

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.
package/dist/esm/index.js CHANGED
@@ -1,3 +1,6 @@
1
- // @descope/user-management-widget v0.2.4
2
- import{__classPrivateFieldGet as e,__classPrivateFieldSet as t,__awaiter as i,__rest as s}from"tslib";import{createSelector as o}from"reselect";import{createSlice as n,configureStore as r,unwrapResult as a,createAsyncThunk as l}from"@reduxjs/toolkit";import d from"@descope/web-js-sdk";import c from"libphonenumber-js/min";function u(...e){return t=>e.reduce(((e,t)=>t(e)),t)}const h=e=>{const t=Symbol((e=>{const t=e.toString();let i=0;for(let e=0;e<t.length;e++)i=(i<<5)-i+t.charCodeAt(e),i&=i;return i.toString(16)})(e));return i=>{if(i[t])return i;const s=e(i);return s[t]=!0,s}},v=h((s=>{var o,n;return n=class extends s{constructor(){super(...arguments),o.set(this,!0)}connectedCallback(){var i,s;null===(i=super.connectedCallback)||void 0===i||i.call(this),(null===(s=this.shadowRoot)||void 0===s?void 0:s.isConnected)&&e(this,o,"f")&&(t(this,o,!1,"f"),this.init())}init(){return i(this,void 0,void 0,(function*(){}))}},o=new WeakMap,n})),g=["error","warn","info","debug"],m=h((i=>{var s,o,n,r;return r=class extends i{constructor(){super(...arguments),s.add(this),o.set(this,e(this,s,"m",n).call(this,console))}set logger(i){t(this,o,e(this,s,"m",n).call(this,i),"f")}get logger(){return e(this,o,"f")}onLogEvent(e,t){}},o=new WeakMap,s=new WeakSet,n=function(e){return g.reduce(((t,i)=>(t[i]=(...t)=>{var s;this.onLogEvent(i,t),null===(s=e[i])||void 0===s||s.call(e,...t)},t)),{})},r})),p=h((s=>{var o,n,r,a,l,d,c;return c=class extends(u(v,m)(s)){constructor(){super(...arguments),o.add(this),n.set(this,void 0),this.attributeChangedCallback=(t,i,s)=>{var n;null===(n=super.attributeChangedCallback)||void 0===n||n.call(this,t,i,s),"debug"===t&&e(this,o,"m",l).call(this)}}get debug(){return"true"===this.getAttribute("debug")}onLogEvent(t,i){var s;null===(s=super.onLogEvent)||void 0===s||s.call(this,t,i),"error"===t&&e(this,o,"m",d).call(this,i[0]||"Error",i[1])}init(){const t=Object.create(null,{init:{get:()=>super.init}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.init)||void 0===s?void 0:s.call(this),e(this,o,"m",l).call(this)}))}},n=new WeakMap,o=new WeakSet,r=function(){var i;null===(i=e(this,n,"f"))||void 0===i||i.remove(),t(this,n,null,"f")},a=function(){return i(this,void 0,void 0,(function*(){t(this,n,document.createElement("descope-debugger"),"f"),Object.assign(e(this,n,"f").style,{position:"fixed",top:"0",right:"0",height:"100vh",width:"100vw",pointerEvents:"none",zIndex:99999}),yield import("./debugger-wc-6f11e405.js"),document.body.appendChild(e(this,n,"f"))}))},l=function(){this.debug?e(this,o,"m",a).call(this):e(this,o,"m",r).call(this)},d=function(t,i){var s;t&&(null===(s=e(this,n,"f"))||void 0===s||s.updateData({title:t,description:i}))},c})),f=(e,t)=>e.length===t.length&&e.every(((e,i)=>e===t[i])),b=e=>{let t,i;return(...s)=>(t&&f(t,s)||(t=s,i=e(...s)),i)},y=e=>(t,...i)=>t.reduce(((t,s,o)=>{var n;return`${t}${s}${(null===(n=null==i?void 0:i[o])||void 0===n?void 0:n[e>1?1:0])||""}`}),""),w=(e,t=500)=>{let i;return function(...s){clearTimeout(i),i=setTimeout((()=>e.apply(this,s)),t)}},C="undefined"!=typeof localStorage,M=C&&localStorage.getItem("base.content.url")||"https://static.descope.com/pages",R=(e,t)=>!t&&`${e} cannot be empty`,x=h((t=>{var s,o;const n=u(m,v)(t);return o=class extends n{constructor(){super(...arguments),s.set(this,{})}init(){const t=Object.create(null,{init:{get:()=>super.init}});var o;return i(this,void 0,void 0,(function*(){var i,n;yield null===(o=t.init)||void 0===o?void 0:o.call(this),i=this,n=t=>{var i;null===(i=e(this,s,"f")[t])||void 0===i||i.forEach((e=>{e(t,this.getAttribute(t))}))},Array.from(i.attributes).forEach((e=>n(e.name))),new MutationObserver((e=>{e.forEach((e=>{"attributes"===e.type&&n(e.attributeName)}))})).observe(i,{attributes:!0})}))}observeAttribute(t,i){e(this,s,"f")[t]||(e(this,s,"f")[t]=[]);const o=e(this,s,"f")[t].push(i);return()=>e(this,s,"f")[t].splice(o,1)}observeAttributes(e,t){const i=e.reduce(((e,i)=>(e.push(this.observeAttribute(i,t)),e)),[]);return()=>i.forEach((e=>e()))}},s=new WeakMap,o})),U=t=>s=>{var o,n,r;const a=u(m,v,x)(s),l=Object.keys(t);return r=class extends a{constructor(...t){super(...t),o.add(this),this.observeAttributes(l,e(this,o,"m",n).bind(this))}init(){const t=Object.create(null,{init:{get:()=>super.init}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.init)||void 0===s?void 0:s.call(this),l.forEach((t=>e(this,o,"m",n).call(this,t,this.getAttribute(t))))}))}},o=new WeakSet,n=function(e,i){const s=t[e],o="function"==typeof s?s(e,i):s;o&&this.logger.error(o)},r},k=h((e=>{const t=u(U({"project-id":R}))(e);return class extends t{get projectId(){return this.getAttribute("project-id")}}}));const j=h((e=>{const t=u(m,k)(e);return class extends t{fetchStaticResource(e,t){return i(this,void 0,void 0,(function*(){const i=function(e,t,i="v2-beta"){const s=new URL(M);return s.pathname=((...e)=>e.join("/").replace(/\/+/g,"/"))(s.pathname,e,i,t),s.toString()}(this.projectId,e),s=yield fetch(i,{cache:"default"});return s.ok||this.logger.error(`Error fetching URL ${i} [${s.status}]`),{body:yield s[t](),headers:Object.fromEntries(s.headers.entries())}}))}}})),W=h((s=>{var o,n,r;const a=u(j)(s);return r=class extends a{constructor(){super(...arguments),o.set(this,void 0),n.set(this,(()=>i(this,void 0,void 0,(function*(){try{const{body:e,headers:t}=yield this.fetchStaticResource("config.json","json");return{projectConfig:e,executionContext:{geo:t["x-geo"]}}}catch(e){this.logger.error("Cannot fetch config file","make sure that your projectId & flowId are correct")}}))))}get config(){return e(this,o,"f")||t(this,o,e(this,n,"f").call(this),"f"),e(this,o,"f")}},o=new WeakMap,n=new WeakMap,r})),S="load-descope-ui",I="base.ui.components.url",E=C&&localStorage.getItem(I)||"https://static.descope.com/npm/@descope/web-components-ui@<version>/dist/umd/index.js",L=C&&localStorage.getItem(I)||"https://cdn.jsdelivr.net/npm/@descope/web-components-ui@<version>/dist/umd/index.js",O=e=>{const t=document.createElement("script");return t.id=e,t},A=(e,t)=>e.replace("<version>",t),N=h((s=>{var o,n,r,a,l,d,c,h,v,g,p,f;const b=u(m,W)(s);return f=class extends b{constructor(){super(...arguments),o.add(this),n.set(this,Symbol("errorCbs")),r.set(this,Symbol("loadCbs")),v.set(this,void 0)}get descopeUi(){return e(this,v,"f")||t(this,v,e(this,o,"m",p).call(this),"f"),e(this,v,"f")}loadDescopeUiComponents(t){return i(this,void 0,void 0,(function*(){const i=Array.isArray(t)?t:(s=t,[...Array.from(s.content.querySelectorAll("*")).reduce(((e,t)=>t.localName.startsWith("descope-")?e.add(t.localName):e),new Set)]);var s;return Promise.all(i.map((t=>e(this,o,"m",g).call(this,t))))}))}},n=new WeakMap,r=new WeakMap,v=new WeakMap,o=new WeakSet,a=function(){var e;return i(this,void 0,void 0,(function*(){const t=yield this.config,i=null===(e=null==t?void 0:t.projectConfig)||void 0===e?void 0:e.componentsVersion;return i?this.logger.debug(`Got component version "${i}"`):this.logger.error("Could not get components version"),i}))},l=function(t){const i=e(this,n,"f"),s=e(this,r,"f");t[i]=[],t[s]=[],Object.defineProperty(t,"onerror",{set(e){t[i].push(e)}}),Object.defineProperty(t,"onload",{set(e){t[s].push(e)}})},d=function(t,s){return i(this,void 0,void 0,(function*(){this.logger.debug("Trying to load DescopeUI from a fallback URL");const i=O("load-descope-ui-fallback-script");document.body.append(i),i.addEventListener("error",(()=>{t.forEach((e=>e(`Cannot load DescopeUI from fallback URL, Make sure this URL is valid and return the correct script: "${i.src}"`)))})),i.addEventListener("load",(()=>{s.forEach((e=>e()))})),i.src=A(L,yield e(this,o,"m",a).call(this))}))},c=function(t){t.addEventListener("error",(()=>{t[e(this,n,"f")].forEach((e=>e(`Cannot load DescopeUI from main URL, Make sure this URL is valid and return the correct script: "${t.src}"`))),e(this,o,"m",d).call(this,t[e(this,n,"f")],t[e(this,r,"f")])})),t.addEventListener("load",(()=>{t[e(this,r,"f")].forEach((e=>e()))}))},h=function(){return i(this,void 0,void 0,(function*(){if(document.querySelector(`script#${S}`))this.logger.debug("DescopeUI loading script already exists",this);else{this.logger.debug("DescopeUI loading script does not exist, creating it",this);const t=O(S);document.body.append(t),e(this,o,"m",l).call(this,t),e(this,o,"m",c).call(this,t),t.src=A(E,yield e(this,o,"m",a).call(this))}return document.getElementById(S)}))},g=function(e){return i(this,void 0,void 0,(function*(){if(!!customElements.get(e))return void this.logger.debug(`Loading component "${e}" is skipped as it is already defined`);const t=yield this.descopeUi;if(t[e])try{return yield t[e]()}catch(t){if("NotSupportedError"!==t.name)throw t;console.debug(`Encountered an error while attempting to define the "${e}" component, it is likely that this component is already defined`)}else this.logger.error(`Cannot load UI component "${e}"`,`Descope UI does not have a component named "${e}", available components are: "${Object.keys(t).join(", ")}"`)}))},p=function(){return new Promise((t=>{globalThis.DescopeUI&&t(globalThis.DescopeUI),e(this,o,"m",h).call(this).then((e=>{e.onerror=this.logger.error,e.onload=()=>{this.logger.debug("DescopeUI was loaded"),t(globalThis.DescopeUI)},setTimeout((()=>{globalThis.DescopeUI&&t(globalThis.DescopeUI)}))}))}))},f})),P="content-root",$="root",D=h((e=>class extends e{constructor(...e){var t,i;super(...e),this.attachShadow({mode:"open"}).innerHTML=`\n\n <style>\n #${$}, #${P} {\n height: 100%;\n }\n </style>\n <div id="${$}">\n <div id="${P}"></div>\n </div>\n `,this.contentRootElement=null===(t=this.shadowRoot)||void 0===t?void 0:t.getElementById(P),this.rootElement=null===(i=this.shadowRoot)||void 0===i?void 0:i.getElementById($)}})),T=(e,t)=>!!t&&"light"!==t&&"dark"!==t&&'Supported theme values are "light", "dark", or leave empty for using the OS theme',F=h((s=>{var o,n,r,a,l,d,c,h,g;const m=u(U({theme:T}),j,v,N,W,D)(s);return g=class extends m{constructor(){super(...arguments),o.add(this),n.set(this,void 0)}get theme(){var e,t;const i=this.getAttribute("theme");if("os"===i){return window.matchMedia&&(null===(t=null===(e=window.matchMedia)||void 0===e?void 0:e.call(window,"(prefers-color-scheme: dark)"))||void 0===t?void 0:t.matches)?"dark":"light"}return i||"light"}init(){const t=Object.create(null,{init:{get:()=>super.init}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.init)||void 0===s?void 0:s.call(this),e(this,o,"m",l).call(this),e(this,o,"m",d).call(this),e(this,o,"m",c).call(this),e(this,o,"m",h).call(this)}))}},n=new WeakMap,o=new WeakSet,r=function(){return i(this,void 0,void 0,(function*(){try{const{body:e}=yield this.fetchStaticResource("theme.json","json");return e}catch(e){this.logger.error("Cannot fetch theme file","make sure that your projectId & flowId are correct")}}))},a=function(){return e(this,n,"f")||(t(this,n,e(this,o,"m",r).call(this),"f"),e(this,n,"f").then((e=>this.logger.debug("Fetched theme",e)))),e(this,n,"f")},l=function(){var t,s;return i(this,void 0,void 0,(function*(){const i=yield e(this,o,"a",a);if(!i)return;const n=document.createElement("style");n.innerText=((null===(t=null==i?void 0:i.light)||void 0===t?void 0:t.globals)||"")+((null===(s=null==i?void 0:i.dark)||void 0===s?void 0:s.globals)||""),this.shadowRoot.appendChild(n)}))},d=function(){var t,s;return i(this,void 0,void 0,(function*(){const i=Object.assign({},yield e(this,o,"a",a));if(!i)return;const n=yield this.descopeUi;(null==n?void 0:n.componentsThemeManager)&&(n.componentsThemeManager.themes={light:null===(t=null==i?void 0:i.light)||void 0===t?void 0:t.components,dark:null===(s=null==i?void 0:i.dark)||void 0===s?void 0:s.components})}))},c=function(){var e,t;return i(this,void 0,void 0,(function*(){const{projectConfig:i}=yield this.config,s=null===(t=null===(e=null==i?void 0:i.cssTemplate)||void 0===e?void 0:e[this.theme])||void 0===t?void 0:t.fonts;s&&Object.values(s).forEach((e=>{e.url&&(this.logger.debug(`Loading font from URL "${e.url}"`),(e=>{const t=document.createElement("link");t.href=e,t.rel="stylesheet",document.head.appendChild(t)})(e.url))}))}))},h=function(){return i(this,void 0,void 0,(function*(){this.rootElement.setAttribute("data-theme",this.theme);const e=yield this.descopeUi;(null==e?void 0:e.componentsThemeManager)&&(e.componentsThemeManager.currentThemeName=this.theme)}))},g}));var q;class B{constructor(e,i){q.set(this,void 0),this.nodeName="",t(this,q,e,"f"),this.logger=i.logger}get asyncEle(){return t=e(this,q,"f"),s=1e3,i(void 0,void 0,void 0,(function*(){return new Promise((e=>{const i=setInterval((()=>{const s="function"==typeof t?t():t;s&&(clearInterval(i),e(s))}),100);setTimeout((()=>{clearInterval(i),e(null)}),s)}))}));var t,s}get ele(){var t,i;const s="function"==typeof e(this,q,"f")?e(this,q,"f").call(this):e(this,q,"f");return s?(null==s?void 0:s.localName)!==this.nodeName?(null===(i=this.logger)||void 0===i||i.debug(`node name do not match, expected "${this.nodeName}", received "${s.localName}" `,Error()),null):s:(null===(t=this.logger)||void 0===t||t.debug("no element for driver ",this.constructor.name,new Error),null)}}q=new WeakMap;class H extends B{constructor(){super(...arguments),this.nodeName="descope-button"}onClick(e){var t;return null===(t=this.ele)||void 0===t||t.addEventListener("click",e),()=>{var t;return null===(t=this.ele)||void 0===t?void 0:t.removeEventListener("click",e)}}disable(){var e;null===(e=this.ele)||void 0===e||e.setAttribute("disabled","true")}enable(){var e;null===(e=this.ele)||void 0===e||e.removeAttribute("disabled")}}const V=e=>{const t=document.createElement("template");return t.innerHTML=e,t},Z=h((e=>class extends(m(e)){validateForm(e){return this.getFormInputs(e).every((e=>{var t,i;return null===(t=e.reportValidity)||void 0===t||t.call(e),null===(i=e.checkValidity)||void 0===i?void 0:i.call(e)}))}getFormInputs(e){return e?Array.from(e.querySelectorAll("[name]")):(this.logger.debug("cannot get form inputs, no root element was received"),[])}getFormData(e){return this.getFormInputs(e).reduce(((e,t)=>Object.assign(e,{[t.getAttribute("name")]:t.value})),{})}setFormData(e,t){this.getFormInputs(e).forEach((e=>{t.hasOwnProperty(e.getAttribute("name"))&&(e.value=t[e.getAttribute("name")])}))}resetFormData(e){this.getFormInputs(e).forEach((e=>{e.value=""}))}})),z="descope-modal";var J;class G extends B{constructor(){super(...arguments),J.set(this,void 0),this.nodeName="descope-modal"}close(){var e,t;null===(e=this.ele)||void 0===e||e.removeAttribute("opened"),null===(t=this.afterClose)||void 0===t||t.call(this)}open(){var e,t;return i(this,void 0,void 0,(function*(){yield null===(e=this.beforeOpen)||void 0===e?void 0:e.call(this),null===(t=this.ele)||void 0===t||t.setAttribute("opened","true")}))}reset(){var t;this.ele&&(this.ele.innerHTML=""),e(this,J,"f")&&(null===(t=this.ele)||void 0===t||t.append(e(this,J,"f").content.cloneNode(!0)))}setContent(e){t(this,J,e,"f"),this.reset()}remove(){var e;null===(e=this.ele)||void 0===e||e.remove()}}J=new WeakMap;const K=h((t=>{var s,o;const n=u(v,D,N)(t);return o=class extends n{constructor(){super(...arguments),s.set(this,(()=>{const e=this.loadDescopeUiComponents.bind(this);return class extends G{setContent(t){e(t),super.setContent(t)}}})())}createModal(t){const i=((e={})=>{const t=document.createElement(z);return Object.keys(e).forEach((i=>{t.setAttribute(i,e[i])})),t})(Object.assign(Object.assign({},{}),t));return this.rootElement.append(i),new(e(this,s,"f"))(i,{logger:this.logger})}init(){const e=Object.create(null,{init:{get:()=>super.init}});var t;return i(this,void 0,void 0,(function*(){this.loadDescopeUiComponents([z]),yield null===(t=e.init)||void 0===t?void 0:t.call(this)}))}},s=new WeakMap,o}));class Q extends B{constructor(){super(...arguments),this.nodeName="descope-multi-select-combo-box"}setData(e){var t;return i(this,void 0,void 0,(function*(){null===(t=yield this.asyncEle)||void 0===t||t.setAttribute("data",JSON.stringify(e.sort()))}))}}const X={enabled:"active"},Y=e=>e.tenantRoles.data,_=e=>e.selectedUsersLoginIds,ee=e=>e.notifications,te=o((e=>e.usersList.data),(e=>e.map((e=>Object.assign(Object.assign({},e),{status:X[e.status]||e.status,roles:e.roleNames}))))),ie=o(te,_,((e,t)=>e.filter((e=>t.includes(e.loginIds))).map((e=>e.userId)))),se=o(_,te,((e,t)=>t.filter((t=>e.includes(t.loginIds))))),oe=o(_,(e=>!!e.length)),ne=o(_,(e=>1===e.length)),re=o(se,(e=>1===e.length?e[0].email:`${e.length} users`)),ae=e=>h((t=>{const s=n(e),o=Object.assign(Object.assign({},s.actions),e.asyncActions);return class extends(u(m)(t)){constructor(...e){super(...e);const t=r({reducer:s.reducer,middleware:e=>e({thunk:{extraArgument:this},serializableCheck:!1}),devTools:!1}),n=e=>(...s)=>i(this,void 0,void 0,(function*(){const i=yield t.dispatch(e(...s));try{a(i)}catch(e){this.logger.error(e.message,i.type,e.stack)}return i})),l=Object.keys(o).reduce(((e,t)=>(e[t]=n(o[t]),e)),{});this.actions=l,this.subscribe=(e,i=(e=>e))=>t.subscribe((()=>e(i(t.getState()))))}}})),le=e=>(...t)=>i=>{i.addCase(e.pending,((e,i)=>{t.forEach((({onPending:t})=>{null==t||t(e,i)}))})),i.addCase(e.fulfilled,((e,i)=>{t.forEach((({onFulfilled:t})=>{null==t||t(e,i)}))})),i.addCase(e.rejected,((e,i)=>{t.forEach((({onRejected:t})=>{null==t||t(e,i)}))}))},de=e=>({onFulfilled:t=>{e(t).loading=!1},onPending:t=>{e(t).loading=!0,e(t).error=null},onRejected:(t,i)=>{e(t).loading=!1,e(t).error=i.error}}),ce=({getErrorMsg:e,getSuccessMsg:t})=>({onFulfilled:(e,i)=>{t&&e.notifications.push({type:"success",msg:t(i)})},onRejected:(t,i)=>{e&&t.notifications.push({type:"error",msg:e(i)})}}),ue=l("users/create",((e,{extra:{api:t}})=>t.user.create(e))),he=le(ue)({onFulfilled:(e,t)=>{e.usersList.data.unshift(t.payload)}},de((e=>e.createUser)),ce({getSuccessMsg:()=>"User created successfully",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to create user</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}})),ve={action:ue,reducer:he},ge=l("users/delete",((e,{extra:{api:t}})=>t.user.deleteBatch(e))),me=le(ge)({onFulfilled:(e,t)=>{e.usersList.data=e.usersList.data.filter((e=>!t.meta.arg.includes(e.userId))),e.selectedUsersLoginIds=[]}},de((e=>e.deleteUser)),ce({getSuccessMsg:e=>y(e.meta.arg.length)`${["",e.meta.arg.length]} ${["U","u"]}ser${["","s"]} deleted successfully`,getErrorMsg:e=>y(e.meta.arg.length)`Failed to delete user${["","s"]}`})),pe={action:ge,reducer:me},fe=l("users/expirePassword",((e,{extra:{api:t}})=>t.user.expirePassword(e))),be={action:fe,reducer:le(fe)(de((e=>e.expireUserPassword)))},ye=l("users/getCustomAttributes",((e,{extra:{api:t}})=>t.user.getCustomAttributes())),we=le(ye)({onFulfilled:(e,t)=>{e.customAttributes.data=t.payload}},de((e=>e.customAttributes))),Ce={action:ye,reducer:we},Me=l("users/search",((e,{extra:{api:t},getState:i})=>{const s=i().searchParams;return t.user.search(Object.assign(Object.assign({},s),e))})),Re=le(Me)({onPending:(e,t)=>{e.searchParams=Object.assign(Object.assign({},e.searchParams),t.meta.arg)},onFulfilled:(e,t)=>{e.usersList.data=t.payload}},de((e=>e.usersList))),xe={action:Me,reducer:Re},Ue=l("tenant/getTenantRoles",((e,{extra:{api:t}})=>t.tenant.getTenantRoles())),ke=le(Ue)({onFulfilled:(e,t)=>{e.tenantRoles.data=t.payload.roles}},de((e=>e.tenantRoles))),je={action:Ue,reducer:ke},We=l("users/update",((e,{extra:{api:t}})=>t.user.update(e))),Se={action:We,reducer:le(We)({onFulfilled:(e,t)=>{const i=e.usersList.data.findIndex((e=>f(e.loginIds,t.payload.loginIds)));-1!==i&&(e.usersList.data[i]=t.payload)}},de((e=>e.updateUser)),ce({getSuccessMsg:()=>"User updated successfully",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to update user</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}}))},Ie={usersList:{data:[],loading:!1,error:null},createUser:{loading:!1,error:null},updateUser:{loading:!1,error:null},deleteUser:{loading:!1,error:null},expireUserPassword:{loading:!1,error:null},customAttributes:{loading:!1,error:null,data:{}},tenantRoles:{loading:!1,error:null,data:[]},searchParams:{text:"",sort:[]},selectedUsersLoginIds:[],notifications:[]},Ee={search:"/v1/mgmt/user/search",deleteBatch:"/v1/mgmt/user/delete/batch",create:"/v1/mgmt/user/create",update:"/v1/mgmt/user/update",expirePassword:"/v1/mgmt/user/password/expire",customAttributes:"/v1/mgmt/user/customattributes"},Le={roles:"/v1/mgmt/role/all"},Oe=e=>i(void 0,void 0,void 0,(function*(){const t=yield e.text(),i=JSON.parse(t);if(!e.ok){const t=`${i.errorDescription}${i.errorMessage?`: ${i.errorMessage}`:""}`;throw Error(t||`${e.status} ${e.statusText}`)}e.json=()=>Promise.resolve(i),e.text=()=>Promise.resolve(t)})),Ae=({httpClient:e,tenant:t})=>({search:({page:s,limit:o=1e4,customAttributes:n,statuses:r,emails:a,phones:l,text:d,sort:c}={})=>i(void 0,void 0,void 0,(function*(){const i=yield e.post(Ee.search,{limit:o,page:s,withTestUser:!1,customAttributes:n,statuses:r,emails:a,phones:l,text:d,sort:c},{queryParams:{tenant:t}});yield Oe(i);return(yield i.json()).users})),deleteBatch:s=>i(void 0,void 0,void 0,(function*(){const i=yield e.post(Ee.deleteBatch,{userIds:s},{queryParams:{tenant:t}});return yield Oe(i),i.json()})),create:({loginId:s,email:o,phone:n,displayName:r,roles:a,customAttributes:l,picture:d,verifiedEmail:c,verifiedPhone:u,givenName:h,middleName:v,familyName:g,additionalLoginIds:m,sendSMS:p,sendMail:f,inviteUrl:b,invite:y})=>i(void 0,void 0,void 0,(function*(){const i=yield e.post(Ee.create,{loginId:s,email:o,phone:n,displayName:r,givenName:h,middleName:v,familyName:g,roleNames:a,userTenants:[{tenantId:t}],customAttributes:l,picture:d,verifiedEmail:c,verifiedPhone:u,additionalLoginIds:m,sendSMS:p,sendMail:f,inviteUrl:b,invite:y},{queryParams:{tenant:t}});yield Oe(i);return(yield i.json()).user})),update:({loginId:s,email:o,phone:n,displayName:r,roles:a,customAttributes:l,picture:d,verifiedEmail:c,verifiedPhone:u,givenName:h,middleName:v,familyName:g,additionalLoginIds:m})=>i(void 0,void 0,void 0,(function*(){const i=yield e.post(Ee.update,{loginId:s,email:o,phone:n,displayName:r,givenName:h,middleName:v,familyName:g,roleNames:a,customAttributes:l,picture:d,verifiedEmail:c,verifiedPhone:u,additionalLoginIds:m},{queryParams:{tenant:t}});yield Oe(i);return(yield i.json()).user})),expirePassword:s=>i(void 0,void 0,void 0,(function*(){const i=yield e.post(Ee.expirePassword,{loginId:s[0]},{queryParams:{tenant:t}});return yield Oe(i),i.json()})),getCustomAttributes:()=>i(void 0,void 0,void 0,(function*(){const i=yield e.get(Ee.customAttributes,{queryParams:{tenant:t}});return yield Oe(i),i.json()}))}),Ne=({httpClient:e,tenant:t})=>({getTenantRoles:()=>i(void 0,void 0,void 0,(function*(){const i=yield e.get(Le.roles,{queryParams:{tenant:t}});return yield Oe(i),i.json()}))}),Pe=h((s=>{var o,n,r,a;const l=u(k,x,m,U({tenant:R}))(s);return a=class extends l{constructor(){super(...arguments),o.add(this),n.set(this,void 0)}get baseUrl(){return this.getAttribute("base-url")}get tenant(){return this.getAttribute("tenant")}get api(){return e(this,n,"f")||e(this,o,"m",r).call(this),e(this,n,"f")}init(){const t=Object.create(null,{init:{get:()=>super.init}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.init)||void 0===s?void 0:s.call(this),this.observeAttributes(["project-id","base-url","tenant"],(()=>{e(this,n,"f")&&e(this,o,"m",r).call(this)}))}))}},n=new WeakMap,o=new WeakSet,r=function(){this.logger.debug("creating an sdk instance"),t(this,n,((e,t)=>{const i=d(Object.assign(Object.assign({},e),{persistTokens:!0}));return{user:Ae({httpClient:i.httpClient,tenant:t}),tenant:Ne({httpClient:i.httpClient,tenant:t})}})({projectId:this.projectId,baseUrl:this.baseUrl},this.tenant),"f")},a})),$e=h((e=>{const t=u(ae({name:"widget",initialState:Ie,reducers:{setSelectedUsersIds:(e,{payload:t})=>{e.selectedUsersLoginIds=t},clearNotifications:e=>{e.notifications=[]}},extraReducers:e=>{ve.reducer(e),Se.reducer(e),pe.reducer(e),xe.reducer(e),be.reducer(e),Ce.reducer(e),je.reducer(e)},asyncActions:{searchUsers:xe.action,createUser:ve.action,updateUser:Se.action,deleteUsers:pe.action,expireUserPassword:be.action,getCustomAttributes:Ce.action,getTenantRoles:je.action}}),v,m,Pe)(e);return class extends t{constructor(...e){super(...e),this.state=Ie,this.subscribe((e=>{this.logger.debug("State update:",e),this.state=e}))}}})),De=h((e=>{const t=u(j,U({"widget-id":R}))(e);return class extends t{get widgetId(){return this.getAttribute("widget-id")}fetchWidgetPage(e){return i(this,void 0,void 0,(function*(){return(yield this.fetchStaticResource(`user-management-widget/${this.widgetId}/${e}`,"text")).body}))}}})),Te=h((t=>{var s,o,n;return n=class extends(u(m,v,N,D,De,$e)(t)){constructor(){super(...arguments),s.add(this)}onWidgetRootReady(){return i(this,void 0,void 0,(function*(){}))}init(){const t=Object.create(null,{init:{get:()=>super.init}});var n;return i(this,void 0,void 0,(function*(){yield null===(n=t.init)||void 0===n?void 0:n.call(this),yield Promise.all([e(this,s,"m",o).call(this),this.actions.searchUsers(),this.actions.getTenantRoles()]),this.onWidgetRootReady()}))}},s=new WeakSet,o=function(){return i(this,void 0,void 0,(function*(){const e=V(yield this.fetchWidgetPage("root.html"));yield this.loadDescopeUiComponents(e),this.contentRootElement.append(e.content.cloneNode(!0))}))},n})),Fe=h((s=>{var o,n,r,a,l;return l=class extends(u($e,K,Z,m,Te)(s)){constructor(){super(...arguments),o.add(this),n.set(this,void 0),a.set(this,(()=>i(this,void 0,void 0,(function*(){yield e(this,n,"f").setData(Y(this.state).map((({name:e})=>({value:e,label:e}))))}))))}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.onWidgetRootReady)||void 0===s?void 0:s.call(this),e(this,o,"m",r).call(this)}))}},n=new WeakMap,a=new WeakMap,o=new WeakSet,r=function(){return i(this,void 0,void 0,(function*(){this.createUserModal=this.createModal(),this.createUserModal.setContent(V(yield this.fetchWidgetPage("create-user-modal.html")));const s=new H((()=>{var e;return null===(e=this.createUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});s.onClick((()=>{this.createUserModal.close(),this.resetFormData(this.createUserModal.ele)}));const o=new H((()=>{var e;return null===(e=this.createUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});o.onClick((()=>i(this,void 0,void 0,(function*(){this.validateForm(this.createUserModal.ele)&&(this.actions.createUser(Object.assign(Object.assign({},this.getFormData(this.createUserModal.ele)),{invite:!0,verifiedEmail:!0,verifiedPhone:!0})),this.createUserModal.close(),this.resetFormData(this.createUserModal.ele))})))),t(this,n,new Q((()=>{var e;return null===(e=this.createUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="roles-multiselect"]')}),{logger:this.logger}),"f"),e(this,a,"f").call(this)}))},l})),qe=h((t=>{var s,o,n;return n=class extends(u(m,Fe,Te)(t)){constructor(){super(...arguments),s.add(this)}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var n;return i(this,void 0,void 0,(function*(){yield null===(n=t.onWidgetRootReady)||void 0===n?void 0:n.call(this),e(this,s,"m",o).call(this)}))}},s=new WeakSet,o=function(){var e;this.createButton=new H(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="create-user"]'),{logger:this.logger}),this.createButton.onClick((()=>this.createUserModal.open()))},n}));class Be extends B{constructor(){super(...arguments),this.nodeName="descope-text"}get ele(){return super.ele}get text(){var e;return null===(e=this.ele)||void 0===e?void 0:e.innerText}set text(e){this.ele&&(this.ele.innerText=e)}}const He=h((t=>{var s,o,n;return n=class extends(u($e,K,m,Te)(t)){constructor(){super(...arguments),s.add(this)}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var n;return i(this,void 0,void 0,(function*(){yield null===(n=t.onWidgetRootReady)||void 0===n?void 0:n.call(this),yield e(this,s,"m",o).call(this)}))}},s=new WeakSet,o=function(){var e;return i(this,void 0,void 0,(function*(){this.deleteUsersModal=this.createModal(),this.deleteUsersModal.setContent(V(yield this.fetchWidgetPage("delete-users-modal.html")));const t=new H((()=>{var e;return null===(e=this.deleteUsersModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});t.onClick((()=>this.deleteUsersModal.close()));const i=new H((()=>{var e;return null===(e=this.deleteUsersModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});i.onClick((()=>{const e=ie(this.state);this.actions.deleteUsers(e),this.deleteUsersModal.close()}));const s=new Be(null===(e=this.deleteUsersModal.ele)||void 0===e?void 0:e.querySelector('[data-id="body-text"]'),{logger:this.logger});this.deleteUsersModal.beforeOpen=()=>{const e=re(this.state);s.text=`Delete ${e}?`}}))},n})),Ve=h((t=>{var s,o,n,r;return r=class extends(u(m,Te,$e,He)(t)){constructor(){super(...arguments),s.add(this),n.set(this,b((e=>{e?this.deleteButton.enable():this.deleteButton.disable()})))}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var r;return i(this,void 0,void 0,(function*(){yield null===(r=t.onWidgetRootReady)||void 0===r?void 0:r.call(this),e(this,s,"m",o).call(this),this.subscribe(e(this,n,"f").bind(this),oe)}))}},n=new WeakMap,s=new WeakSet,o=function(){var e;this.deleteButton=new H(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="delete-users"]'),{logger:this.logger}),this.deleteButton.disable(),this.deleteButton.onClick((()=>{this.deleteUsersModal.open()}))},r}));class Ze extends B{constructor(){super(...arguments),this.nodeName="descope-text-field"}onInput(e){var t;return null===(t=this.ele)||void 0===t||t.addEventListener("input",e),()=>{var t;return null===(t=this.ele)||void 0===t?void 0:t.removeEventListener("input",e)}}get value(){var e;return null===(e=this.ele)||void 0===e?void 0:e.value}set value(e){this.ele&&(this.ele.value=e)}disable(){var e;null===(e=this.ele)||void 0===e||e.setAttribute("disabled","true")}enable(){var e;null===(e=this.ele)||void 0===e||e.removeAttribute("disabled")}}const ze=h((t=>{var s,o,n,r;return r=class extends(u(m,Te,$e)(t)){constructor(){super(...arguments),s.add(this),o.set(this,w((()=>{this.actions.searchUsers({text:this.searchInput.value})})))}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var o;return i(this,void 0,void 0,(function*(){yield null===(o=t.onWidgetRootReady)||void 0===o?void 0:o.call(this),e(this,s,"m",n).call(this)}))}},o=new WeakMap,s=new WeakSet,n=function(){var t;this.searchInput=new Ze(null===(t=this.shadowRoot)||void 0===t?void 0:t.querySelector('[data-id="search-input"]'),{logger:this.logger}),this.searchInput.onInput(e(this,o,"f"))},r})),Je="descope-notification";class Ge extends B{constructor(){super(...arguments),this.nodeName="descope-notification"}close(){var e;null===(e=this.ele)||void 0===e||e.removeAttribute("opened")}show(){var e;null===(e=this.ele)||void 0===e||e.setAttribute("opened","true")}setContent(e){this.ele.innerHTML="",this.ele.appendChild(e.content.cloneNode(!0))}remove(){var e;null===(e=this.ele)||void 0===e||e.remove()}}const Ke=h((t=>{var s,o;const n=u(v,D,N)(t);return o=class extends n{constructor(){super(...arguments),s.set(this,(()=>{const e=this.loadDescopeUiComponents.bind(this);return class extends Ge{setContent(t){const i="string"==typeof t?V(t):t;e(i),super.setContent(i)}}})())}createNotification(t){const i=((e={})=>{const t=document.createElement(Je);return Object.keys(e).forEach((i=>{t.setAttribute(i,e[i])})),t})(Object.assign(Object.assign({},{}),t));return this.rootElement.append(i),new(e(this,s,"f"))(i,{logger:this.logger})}init(){const e=Object.create(null,{init:{get:()=>super.init}});var t;return i(this,void 0,void 0,(function*(){yield null===(t=e.init)||void 0===t?void 0:t.call(this),this.loadDescopeUiComponents([Je])}))}},s=new WeakMap,o}));const Qe={success:(new DOMParser).parseFromString('<svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">\n<g id="Checkmark">\n<path id="Shape" d="M10.0485 15.6396C9.5799 15.171 8.8201 15.171 8.35147 15.6396C7.88284 16.1082 7.88284 16.868 8.35147 17.3367L12.7072 21.6924C13.1759 22.1611 13.9357 22.1611 14.4043 21.6924L24.7152 11.3815C25.1838 10.9129 25.1838 10.1531 24.7152 9.68448C24.2466 9.21585 23.4868 9.21585 23.0181 9.68448L13.5558 19.1469L10.0485 15.6396Z" fill="white"/>\n</g>\n</svg>\n',"image/svg+xml").firstChild,error:(new DOMParser).parseFromString('<svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">\n<g id="Icon">\n<path id="Vector" d="M15.9998 26.6558C10.1118 26.6558 5.34375 21.8878 5.34375 15.9998C5.34375 10.1118 10.1118 5.34375 15.9998 5.34375C21.8878 5.34375 26.6558 10.1118 26.6558 15.9998C26.6558 21.8878 21.8878 26.6558 15.9998 26.6558ZM15.9998 24.4798C20.6718 24.4798 24.4798 20.7038 24.4798 15.9998C24.4798 11.3278 20.7038 7.51975 15.9998 7.51975C11.3278 7.51975 7.51975 11.2958 7.51975 15.9998C7.51975 20.6718 11.2958 24.4798 15.9998 24.4798ZM15.3278 9.34375H16.6718C17.0558 9.34375 17.3438 9.63175 17.3118 9.98375L16.9598 16.9278C16.9598 17.1838 16.7678 17.3438 16.5438 17.3438H15.4558C15.2318 17.3438 15.0398 17.1518 15.0398 16.9278L14.6878 9.98375C14.6878 9.63175 14.9758 9.34375 15.3278 9.34375ZM15.4558 19.4558H16.5438C16.9278 19.4558 17.2158 19.7438 17.1838 20.1278V21.1838C17.1838 21.5678 16.8958 21.8558 16.5438 21.8558H15.4558C15.0718 21.8558 14.7838 21.5678 14.7838 21.1838V20.1278C14.7838 19.7438 15.0718 19.4558 15.4558 19.4558Z" fill="#FFDFDD"/>\n</g>\n</svg>\n',"image/svg+xml").firstChild},Xe=h((t=>{var s,o,n,r,a;return a=class extends(u(m,$e,Ke,v)(t)){constructor(){super(...arguments),s.add(this),r.set(this,b((t=>{t.length&&(t.forEach((({type:t,msg:i})=>{const r=e(this,s,"m",n).call(this,t);r.setContent(e(this,s,"m",o).call(this,{type:t,msg:i})),r.show()})),setTimeout((()=>this.actions.clearNotifications())))})))}init(){const t=Object.create(null,{init:{get:()=>super.init}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.init)||void 0===s?void 0:s.call(this),this.subscribe(e(this,r,"f").bind(this),ee)}))}},r=new WeakMap,s=new WeakSet,o=function({type:e,msg:t}){const i=Qe[e],s=Object.assign((new DOMParser).parseFromString('<svg width="2em" height="2em" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">\n<g id="Icon">\n<path id="Shape" d="M10.6712 12L7.27521 8.60406C6.90826 8.23711 6.90826 7.64216 7.27521 7.27521C7.64216 6.90826 8.23711 6.90826 8.60406 7.27521L12 10.6712L15.3959 7.27521C15.7629 6.90826 16.3578 6.90826 16.7248 7.27521C17.0917 7.64216 17.0917 8.23711 16.7248 8.60406L13.3288 12L16.7248 15.3959C17.0917 15.7629 17.0917 16.3578 16.7248 16.7248C16.3578 17.0917 15.7629 17.0917 15.3959 16.7248L12 13.3288L8.60406 16.7248C8.23711 17.0917 7.64216 17.0917 7.27521 16.7248C6.90826 16.3578 6.90826 15.7629 7.27521 15.3959L10.6712 12Z" fill="white"/>\n</g>\n</svg>\n',"image/svg+xml").firstChild,{slot:"close"});return`${(null==i?void 0:i.outerHTML)||""}${t}${s.outerHTML}`},n=function(e){return this.createNotification({mode:e,duration:"error"===e?0:3e3,position:"bottom-start",size:"sm"})},a}));const Ye=/^descope-grid-([^-]+)-column$/,_e={text:class extends B{constructor(){super(...arguments),this.nodeName="descope-grid-text-column"}onSortDirectionChange(e){var t;return null===(t=this.ele)||void 0===t||t.addEventListener("direction-changed",e),()=>{var t;return null===(t=this.ele)||void 0===t?void 0:t.removeEventListener("selected-items-changed",e)}}},custom:class extends B{constructor(){super(...arguments),this.nodeName="descope-grid-custom-column"}onSortDirectionChange(e){var t;return null===(t=this.ele)||void 0===t||t.addEventListener("direction-changed",e),()=>{var t;return null===(t=this.ele)||void 0===t?void 0:t.removeEventListener("selected-items-changed",e)}}}};class et extends B{constructor(){super(...arguments),this.nodeName="descope-grid"}onSelectedItemsChange(e){var t;return null===(t=this.ele)||void 0===t||t.addEventListener("selected-items-changed",e),()=>{var t;return null===(t=this.ele)||void 0===t?void 0:t.removeEventListener("selected-items-changed",e)}}get ele(){return super.ele}get data(){var e;return null===(e=this.ele)||void 0===e?void 0:e.data}set data(e){this.ele&&(this.ele.data=e)}get columns(){return this.ele?Array.from(this.ele.children).reduce(((e,t)=>{var i;const s=null===(i=Ye.exec(t.localName))||void 0===i?void 0:i[1],o=_e[s];return o?(e.push(new o(t,{logger:this.logger})),e):e}),[]):[]}}const tt=h((t=>{var s,o,n,r,a;return a=class extends(u($e,m,Te)(t)){constructor(){super(...arguments),s.add(this),n.set(this,b((e=>{this.usersTable.data=e}))),r.set(this,w(((e,t)=>{const i=[],{value:s}=t;if(s){const t=e.path;i.push({field:t,desc:"desc"===s})}this.actions.searchUsers({sort:i})})))}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var a;return i(this,void 0,void 0,(function*(){yield null===(a=t.onWidgetRootReady)||void 0===a?void 0:a.call(this),e(this,s,"m",o).call(this),this.usersTable.columns.forEach((t=>{t.onSortDirectionChange((t=>{e(this,r,"f").call(this,t.target,t.detail)}))})),e(this,n,"f").call(this,te(this.state)),this.subscribe(e(this,n,"f").bind(this),te)}))}},n=new WeakMap,r=new WeakMap,s=new WeakSet,o=function(){var e;this.usersTable=new et(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="users-table"]'),{logger:this.logger}),this.usersTable.onSelectedItemsChange((e=>{this.actions.setSelectedUsersIds(e.detail.value.map((({loginIds:e})=>e)))}))},a})),it=e=>{if(!e)return e;const t=c(e),i=new RegExp(`(\\+?${t.countryCallingCode})(.*)`);return t.number.replace(i,"$1-$2")},st=h((o=>{var n,r,a,l,d,c,h,v,g;return g=class extends(u($e,K,m,Z,Te)(o)){constructor(){super(...arguments),n.add(this),r.set(this,void 0),a.set(this,void 0),c.set(this,(()=>i(this,void 0,void 0,(function*(){yield e(this,a,"f").setData(Y(this.state).map((({name:e})=>({value:e,label:e}))))})))),h.set(this,(()=>{var e,t;const i=null===(e=se(this.state))||void 0===e?void 0:e[0],s={loginId:null===(t=null==i?void 0:i.loginIds)||void 0===t?void 0:t.join(", "),displayName:null==i?void 0:i.name,email:null==i?void 0:i.email,phone:it(null==i?void 0:i.phone),roles:null==i?void 0:i.roles};this.setFormData(this.editUserModal.ele,s)}))}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return i(this,void 0,void 0,(function*(){yield null===(s=t.onWidgetRootReady)||void 0===s?void 0:s.call(this),yield e(this,n,"m",v).call(this)}))}},r=new WeakMap,a=new WeakMap,c=new WeakMap,h=new WeakMap,n=new WeakSet,l=function(){const e=new H((()=>{var e;return null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>this.editUserModal.close()))},d=function(){const e=new H((()=>{var e;return null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});e.onClick((()=>{if(this.validateForm(this.editUserModal.ele)){const e=this.getFormData(this.editUserModal.ele),{loginId:t}=e,i=s(e,["loginId"]);this.actions.updateUser(Object.assign({loginId:t.split(", ")[0]},i)),this.editUserModal.close(),this.resetFormData(this.editUserModal.ele)}}))},v=function(){var s;return i(this,void 0,void 0,(function*(){this.editUserModal=this.createModal(),this.editUserModal.setContent(V(yield this.fetchWidgetPage("edit-user-modal.html"))),e(this,n,"m",l).call(this),e(this,n,"m",d).call(this),t(this,r,new Ze(null===(s=this.editUserModal.ele)||void 0===s?void 0:s.querySelector('[name="loginId"]'),{logger:this.logger}),"f"),t(this,a,new Q((()=>{var e;return null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="roles-multiselect"]')}),{logger:this.logger}),"f"),this.editUserModal.beforeOpen=()=>i(this,void 0,void 0,(function*(){yield e(this,c,"f").call(this),e(this,r,"f").disable(),e(this,h,"f").call(this)}))}))},g})),ot=h((t=>{var s,o,n,r;return r=class extends(u(m,Te,$e,st,Z)(t)){constructor(){super(...arguments),s.add(this),n.set(this,b((e=>{e?this.editButton.enable():this.editButton.disable()})))}onWidgetRootReady(){const t=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var r;return i(this,void 0,void 0,(function*(){yield null===(r=t.onWidgetRootReady)||void 0===r?void 0:r.call(this),e(this,s,"m",o).call(this),this.subscribe(e(this,n,"f").bind(this),ne)}))}},n=new WeakMap,s=new WeakSet,o=function(){var e;this.editButton=new H(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="edit-user"]'),{logger:this.logger}),this.editButton.disable(),this.editButton.onClick((()=>{this.editUserModal.open()}))},r})),nt=h((e=>class extends(u(p,F,tt,qe,Ve,ot,ze,Xe)(e)){init(){const e=Object.create(null,{init:{get:()=>super.init}});var t;return i(this,void 0,void 0,(function*(){yield null===(t=e.init)||void 0===t?void 0:t.call(this)}))}})),rt=u((e=>class extends(nt(e)){}))(HTMLElement);customElements.define("descope-user-management-widget",rt);export{rt as default};
1
+
2
+ /**
3
+ * @descope/user-management-widget v0.4.0
4
+ */
5
+ import{pluralize as e,compareArrays as t,createSingletonMixin as s,compose as i,createTemplate as o,withMemCache as r,debounce as a}from"@descope/sdk-helpers";import{__awaiter as n,__classPrivateFieldGet as d,__classPrivateFieldSet as l,__rest as u}from"tslib";import{projectIdMixin as c,observeAttributesMixin as h,loggerMixin as v,createValidateAttributesMixin as g,createStateManagementMixin as m,initLifecycleMixin as p,staticResourcesMixin as y,descopeUiMixin as f,initElementMixin as b,modalMixin as w,formMixin as R,notificationsMixin as M,debuggerMixin as W,themeMixin as P}from"@descope/sdk-mixins";import{ButtonDriver as k,MultiSelectDriver as U,TextDriver as C,TextFieldDriver as S,GridDriver as x}from"@descope/sdk-component-drivers";import{createSelector as I}from"reselect";import{createAsyncThunk as j}from"@reduxjs/toolkit";import N from"@descope/web-js-sdk";import L from"libphonenumber-js/min";const O={enabled:"active",disabled:"disabled",invited:"invited"},T=e=>e.tenantRoles.data,q=e=>e.selectedUsersLoginIds,A=e=>e.notifications,$=e=>e.customAttributes.data,F=I((e=>e.usersList.data),(e=>e.map((e=>Object.assign(Object.assign({},e),{status:O[e.status]||e.status,roles:e.roleNames}))))),B=I(q,F,((e,t)=>t.filter((t=>e.includes(t.loginIds))))),E=I(B,(e=>e.map((e=>e.userId)))),D=I(B,(e=>e.map((e=>e.status)))),H=I(B,(e=>e.every((e=>e.editable))));I(q,(e=>!!e.length));const Z=I(q,(e=>1===e.length)),V=I(q,(e=>{var t;return null===(t=null==e?void 0:e[0])||void 0===t?void 0:t[0]})),z=I(Z,D,((e,t)=>e&&t.every((e=>e===O.enabled)))),J=I(D,(e=>e.every((e=>e===O.disabled)))),G=I(B,(e=>1===e.length?e[0].email:`${e.length} users`)),K=I(Z,J,H,((e,t,s)=>e&&t&&s)),Q=I(Z,z,H,((e,t,s)=>e&&t&&s)),X=I(Z,H,((e,t)=>e&&t)),Y=I(Z,H,((e,t)=>e&&t)),_=I(Z,H,((e,t)=>e&&t)),ee=I(H,(e=>e)),te=e=>(...t)=>s=>{s.addCase(e.pending,((e,s)=>{t.forEach((({onPending:t})=>{null==t||t(e,s)}))})),s.addCase(e.fulfilled,((e,s)=>{t.forEach((({onFulfilled:t})=>{null==t||t(e,s)}))})),s.addCase(e.rejected,((e,s)=>{t.forEach((({onRejected:t})=>{null==t||t(e,s)}))}))},se=e=>({onFulfilled:t=>{e(t).loading=!1},onPending:t=>{e(t).loading=!0,e(t).error=null},onRejected:(t,s)=>{e(t).loading=!1,e(t).error=s.error}}),ie=({getErrorMsg:e,getSuccessMsg:t})=>({onFulfilled:(e,s)=>{t&&e.notifications.push({type:"success",msg:t(s)})},onRejected:(t,s)=>{e&&t.notifications.push({type:"error",msg:e(s)})}}),oe=j("users/create",((e,{extra:{api:t}})=>t.user.create(e))),re=te(oe)({onFulfilled:(e,t)=>{e.usersList.data.unshift(t.payload)}},se((e=>e.createUser)),ie({getSuccessMsg:()=>"User created successfully",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to create user</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}})),ae={action:oe,reducer:re},ne=j("users/delete",((e,{extra:{api:t}})=>t.user.deleteBatch(e))),de=te(ne)({onFulfilled:(e,t)=>{e.usersList.data=e.usersList.data.filter((e=>!t.meta.arg.includes(e.userId))),e.selectedUsersLoginIds=[]}},se((e=>e.deleteUser)),ie({getSuccessMsg:t=>e(t.meta.arg.length)`${["",t.meta.arg.length]} ${["U","u"]}ser${["","s"]} deleted successfully`,getErrorMsg:t=>e(t.meta.arg.length)`Failed to delete user${["","s"]}`})),le={action:ne,reducer:de},ue=j("users/setTempPassword",((e,{extra:{api:t}})=>t.user.setTempPassword(e))),ce=te(ue)(se((e=>e.setTempUserPassword)),ie({getSuccessMsg:()=>"Successfully reset user password",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to reset user's password</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}})),he={action:ue,reducer:ce},ve=j("users/getCustomAttributes",((e,{extra:{api:t}})=>t.user.getCustomAttributes())),ge=te(ve)({onFulfilled:(e,t)=>{e.customAttributes.data=t.payload}},se((e=>e.customAttributes))),me={action:ve,reducer:ge},pe=j("users/search",((e,{extra:{api:t},getState:s})=>{const i=s().searchParams;return t.user.search(Object.assign(Object.assign({},i),e))})),ye=te(pe)({onPending:(e,t)=>{e.searchParams=Object.assign(Object.assign({},e.searchParams),t.meta.arg)},onFulfilled:(e,t)=>{e.usersList.data=t.payload}},se((e=>e.usersList))),fe={action:pe,reducer:ye},be=j("tenant/getTenantRoles",((e,{extra:{api:t}})=>t.tenant.getTenantRoles())),we=te(be)({onFulfilled:(e,t)=>{e.tenantRoles.data=t.payload.roles}},se((e=>e.tenantRoles))),Re={action:be,reducer:we},Me=j("users/update",((e,{extra:{api:t}})=>t.user.update(e))),We=te(Me)({onFulfilled:(e,s)=>{const i=e.usersList.data.findIndex((e=>t(e.loginIds,s.payload.loginIds)));-1!==i&&(e.usersList.data[i]=s.payload)}},se((e=>e.updateUser)),ie({getSuccessMsg:()=>"User updated successfully",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to update user</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}})),Pe={action:Me,reducer:We},ke=j("users/enable",((e,{extra:{api:t}})=>t.user.enable(e))),Ue=te(ke)({onFulfilled:(e,s)=>{const i=e.usersList.data.findIndex((e=>t(e.loginIds,s.payload.user.loginIds)));-1!==i&&(e.usersList.data[i]=s.payload.user)}},se((e=>e.enableUser)),ie({getSuccessMsg:()=>"User enabled successfully",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to enable user</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}})),Ce={action:ke,reducer:Ue},Se=j("users/disable",((e,{extra:{api:t}})=>t.user.disable(e))),xe=te(Se)({onFulfilled:(e,s)=>{const i=e.usersList.data.findIndex((e=>t(e.loginIds,s.payload.user.loginIds)));-1!==i&&(e.usersList.data[i]=s.payload.user)}},se((e=>e.disableUser)),ie({getSuccessMsg:()=>"User disabled successfully",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to disable user</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}})),Ie={action:Se,reducer:xe},je=j("users/removePasskey",((e,{extra:{api:t}})=>t.user.removePasskey(e))),Ne={action:je,reducer:te(je)(se((e=>e.removePasskey)),ie({getSuccessMsg:()=>"Successfully removed user's passkey",getErrorMsg:e=>{var t;return`\n <div>\n <div>Failed to remove user's passkey</div>\n ${null===(t=e.error)||void 0===t?void 0:t.message}\n </div>`}}))},Le={usersList:{data:[],loading:!1,error:null},createUser:{loading:!1,error:null},updateUser:{loading:!1,error:null},deleteUser:{loading:!1,error:null},enableUser:{loading:!1,error:null},disableUser:{loading:!1,error:null},removePasskey:{loading:!1,error:null},setTempUserPassword:{loading:!1,error:null},customAttributes:{loading:!1,error:null,data:[]},tenantRoles:{loading:!1,error:null,data:[]},searchParams:{text:"",sort:[]},selectedUsersLoginIds:[],notifications:[]},Oe={search:"/v1/mgmt/user/search",deleteBatch:"/v1/mgmt/user/delete/batch",create:"/v1/mgmt/user/create",update:"/v1/mgmt/user/update",status:"/v1/mgmt/user/update/status",setTempPassword:"/v1/mgmt/user/password/set/temporary",removePasskey:"/v1/mgmt/user/passkeys/delete",customAttributes:"/v1/mgmt/user/customattributes"},Te={roles:"/v1/mgmt/role/all"},qe=e=>n(void 0,void 0,void 0,(function*(){const t=yield e.text(),s=JSON.parse(t);if(!e.ok){const t=`${s.errorDescription}${s.errorMessage?`: ${s.errorMessage}`:""}`;throw Error(t||`${e.status} ${e.statusText}`)}e.json=()=>Promise.resolve(s),e.text=()=>Promise.resolve(t)})),Ae=({text:e,sort:t})=>n(void 0,void 0,void 0,(function*(){return new Promise((s=>{const i=[];for(let e=1;e<9;e+=1)i.push({loginIds:[`user${e}@company.com`],externalIds:[`user${e}@company.com`],userId:`user-${e}`,name:`User ${e}`,email:`user${e}@company.com`,roleNames:[`Role ${e}`],phone:`+1-202-555-010${e}`,verifiedEmail:!0,verifiedPhone:!0,userTenants:[],status:"enabled",editable:!0,createdTime:(new Date).getTime(),customAttributes:{},familyName:"",givenName:"",middleName:"",picture:"",password:!0,SAML:!1,test:!1,TOTP:!1,webauthn:!1});t.forEach((e=>{i.sort(((t,s)=>{var i,o;return e.desc?null===(o=s[e.field])||void 0===o?void 0:o.localeCompare(t[e.field]):null===(i=t[e.field])||void 0===i?void 0:i.localeCompare(s[e.field])}))})),s(i.filter((t=>t.name.toLowerCase().includes(e.toLowerCase())||t.phone.toLowerCase().includes(e.toLowerCase())||t.status.toLowerCase().includes(e.toLowerCase())||t.familyName.toLowerCase().includes(e.toLowerCase())||t.givenName.toLowerCase().includes(e.toLowerCase())||t.middleName.toLowerCase().includes(e.toLowerCase())||t.email.toLowerCase().includes(e.toLowerCase()))))}))})),$e=({loginId:e,email:t,phone:s,displayName:i,roles:o,customAttributes:r,picture:a,verifiedEmail:d,verifiedPhone:l,givenName:u,middleName:c,familyName:h})=>n(void 0,void 0,void 0,(function*(){return new Promise((n=>{const v=Math.random().toString(10).substring(15);n({loginIds:[e],externalIds:[e],userId:`user-${v}`,email:t,phone:s,name:i,roleNames:o,customAttributes:r,picture:a,verifiedEmail:d,verifiedPhone:l,givenName:u,middleName:c,familyName:h,createdTime:(new Date).getTime(),editable:!0,password:!0,SAML:!1,status:"enabled",test:!1,TOTP:!1,userTenants:[],webauthn:!1})}))})),Fe=({loginId:e,email:t,phone:s,displayName:i,roles:o,customAttributes:r,picture:a,verifiedEmail:d,verifiedPhone:l,givenName:u,middleName:c,familyName:h})=>n(void 0,void 0,void 0,(function*(){return new Promise((n=>{n({loginIds:[e],externalIds:[e],userId:e,email:t,phone:s,name:i,roleNames:o,customAttributes:r,picture:a,verifiedEmail:d,verifiedPhone:l,givenName:u,middleName:c,familyName:h,createdTime:(new Date).getTime(),editable:!0,password:!0,SAML:!1,status:"enabled",test:!1,TOTP:!1,userTenants:[],webauthn:!1})}))})),Be=()=>n(void 0,void 0,void 0,(function*(){})),Ee=()=>n(void 0,void 0,void 0,(function*(){return new Promise((e=>{e({cleartext:Math.random().toString(20).substring(2)})}))})),De=()=>n(void 0,void 0,void 0,(function*(){})),He=()=>n(void 0,void 0,void 0,(function*(){})),Ze=()=>n(void 0,void 0,void 0,(function*(){})),Ve=()=>n(void 0,void 0,void 0,(function*(){return new Promise((e=>{e([])}))})),ze=e=>new Promise((t=>{const s=[];for(let t=1;t<5;t+=1)s.push({name:`Role ${t}`,description:`Role description ${t}`,createdTime:new Date,permissionNames:[`Permission ${t}`],tenantId:e});t({roles:s})})),Je=({httpClient:e,tenant:t,mock:s})=>({search:({page:i,limit:o=1e4,customAttributes:r,statuses:a,emails:d,phones:l,text:u,sort:c}={})=>n(void 0,void 0,void 0,(function*(){if(s)return Ae({page:i,limit:o,customAttributes:r,statuses:a,emails:d,phones:l,text:u,sort:c});const n=yield e.post(Oe.search,{limit:o,page:i,withTestUser:!1,customAttributes:r,statuses:a,emails:d,phones:l,text:u,sort:c},{queryParams:{tenant:t}});yield qe(n);return(yield n.json()).users})),deleteBatch:i=>n(void 0,void 0,void 0,(function*(){if(s)return Be();const o=yield e.post(Oe.deleteBatch,{userIds:i},{queryParams:{tenant:t}});return yield qe(o),o.json()})),create:({loginId:i,email:o,phone:r,displayName:a,roles:d,customAttributes:l,picture:u,verifiedEmail:c,verifiedPhone:h,givenName:v,middleName:g,familyName:m,additionalLoginIds:p,sendSMS:y,sendMail:f,inviteUrl:b,invite:w})=>n(void 0,void 0,void 0,(function*(){if(s)return $e({loginId:i,email:o,phone:r,displayName:a,roles:d,customAttributes:l,picture:u,verifiedEmail:c,verifiedPhone:h,givenName:v,middleName:g,familyName:m,additionalLoginIds:p,sendSMS:y,sendMail:f,inviteUrl:b,invite:w});const n=yield e.post(Oe.create,{loginId:i,email:o,phone:r,displayName:a,givenName:v,middleName:g,familyName:m,roleNames:d,userTenants:[{tenantId:t}],customAttributes:l,picture:u,verifiedEmail:c,verifiedPhone:h,additionalLoginIds:p,sendSMS:y,sendMail:f,inviteUrl:b,invite:w},{queryParams:{tenant:t}});yield qe(n);return(yield n.json()).user})),update:({loginId:i,email:o,phone:r,displayName:a,roles:d,customAttributes:l,picture:u,verifiedEmail:c,verifiedPhone:h,givenName:v,middleName:g,familyName:m,additionalLoginIds:p})=>n(void 0,void 0,void 0,(function*(){if(s)return Fe({loginId:i,email:o,phone:r,displayName:a,roles:d,customAttributes:l,picture:u,verifiedEmail:c,verifiedPhone:h,givenName:v,middleName:g,familyName:m,additionalLoginIds:p});const n=yield e.post(Oe.update,{loginId:i,email:o,phone:r,displayName:a,givenName:v,middleName:g,familyName:m,roleNames:d,customAttributes:l,picture:u,verifiedEmail:c,verifiedPhone:h,additionalLoginIds:p},{queryParams:{tenant:t}});yield qe(n);return(yield n.json()).user})),enable:i=>n(void 0,void 0,void 0,(function*(){if(s)return He();const o=yield e.post(Oe.status,{loginId:i,status:"enabled"},{queryParams:{tenant:t}});return yield qe(o),o.json()})),disable:i=>n(void 0,void 0,void 0,(function*(){if(s)return Ze();const o=yield e.post(Oe.status,{loginId:i,status:"disabled"},{queryParams:{tenant:t}});return yield qe(o),o.json()})),removePasskey:i=>n(void 0,void 0,void 0,(function*(){if(s)return De();const o=yield e.post(Oe.removePasskey,{loginId:i},{queryParams:{tenant:t}});return yield qe(o),o.json()})),setTempPassword:i=>n(void 0,void 0,void 0,(function*(){if(s)return Ee();const o=yield e.post(Oe.setTempPassword,{loginId:i},{queryParams:{tenant:t}});return yield qe(o),o.json()})),getCustomAttributes:()=>n(void 0,void 0,void 0,(function*(){if(s)return Ve();const i=yield e.get(Oe.customAttributes,{queryParams:{tenant:t}});yield qe(i);return(yield i.json()).data}))}),Ge=({httpClient:e,tenant:t,mock:s})=>({getTenantRoles:()=>n(void 0,void 0,void 0,(function*(){if(s)return ze(t);const i=yield e.get(Te.roles,{queryParams:{tenant:t}});return yield qe(i),i.json()}))}),Ke=s((e=>{var t,s,o,r;const a=i(c,h,v,g({tenant:g.missingAttrValidator}))(e);return r=class extends a{constructor(){super(...arguments),t.add(this),s.set(this,void 0)}get baseUrl(){return this.getAttribute("base-url")}get tenant(){return this.getAttribute("tenant")}get mock(){return this.getAttribute("mock")}get api(){return d(this,s,"f")||d(this,t,"m",o).call(this),d(this,s,"f")}init(){const e=Object.create(null,{init:{get:()=>super.init}});var i;return n(this,void 0,void 0,(function*(){yield null===(i=e.init)||void 0===i?void 0:i.call(this),this.observeAttributes(["project-id","base-url","tenant"],(()=>{d(this,s,"f")&&d(this,t,"m",o).call(this)}))}))}},s=new WeakMap,t=new WeakSet,o=function(){this.logger.debug("creating an sdk instance"),l(this,s,((e,t,s)=>{const i=N(Object.assign(Object.assign({},e),{persistTokens:!0}));return{user:Je({httpClient:i.httpClient,tenant:t,mock:s}),tenant:Ge({httpClient:i.httpClient,tenant:t,mock:s})}})({projectId:this.projectId,baseUrl:this.baseUrl},this.tenant,"true"===this.mock),"f")},r})),Qe=s((e=>{const t=i(m({name:"widget",initialState:Le,reducers:{setSelectedUsersIds:(e,{payload:t})=>{e.selectedUsersLoginIds=t},clearNotifications:e=>{e.notifications=[]}},extraReducers:e=>{ae.reducer(e),Pe.reducer(e),Ce.reducer(e),Ie.reducer(e),le.reducer(e),fe.reducer(e),he.reducer(e),Ne.reducer(e),me.reducer(e),Re.reducer(e)},asyncActions:{searchUsers:fe.action,createUser:ae.action,updateUser:Pe.action,enableUser:Ce.action,disableUser:Ie.action,deleteUsers:le.action,removePasskey:Ne.action,getCustomAttributes:me.action,getTenantRoles:Re.action,setTempUserPassword:he.action}}),p,v,Ke)(e);return class extends t{constructor(...e){super(...e),this.state=Le,this.subscribe((e=>{this.logger.debug("State update:",e),this.state=e}))}}})),Xe=s((e=>{const t=i(y,g({"widget-id":g.missingAttrValidator}))(e);return class extends t{get widgetId(){return this.getAttribute("widget-id")}fetchWidgetPage(e){return n(this,void 0,void 0,(function*(){return(yield this.fetchStaticResource(`user-management-widget/${this.widgetId}/${e}`,"text")).body}))}}})),Ye=s((e=>{var t,s,r;return r=class extends(i(v,p,f,b,Xe,Qe)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){return n(this,void 0,void 0,(function*(){}))}init(){const e=Object.create(null,{init:{get:()=>super.init}});var i;return n(this,void 0,void 0,(function*(){yield null===(i=e.init)||void 0===i?void 0:i.call(this),yield Promise.all([d(this,t,"m",s).call(this),this.actions.searchUsers(),this.actions.getTenantRoles(),this.actions.getCustomAttributes()]),this.onWidgetRootReady()}))}},t=new WeakSet,s=function(){return n(this,void 0,void 0,(function*(){const e=o(yield this.fetchWidgetPage("root.html"));yield this.loadDescopeUiComponents(e),this.contentRootElement.append(e.content.cloneNode(!0))}))},r})),_e=s((e=>{var t,s,r,a,u;return u=class extends(i(Qe,w,R,v,Ye)(e)){constructor(){super(...arguments),t.add(this),s.set(this,void 0),a.set(this,(()=>n(this,void 0,void 0,(function*(){yield d(this,s,"f").setData(T(this.state).map((({name:e})=>({value:e,label:e}))))}))))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),d(this,t,"m",r).call(this)}))}},s=new WeakMap,a=new WeakMap,t=new WeakSet,r=function(){return n(this,void 0,void 0,(function*(){this.createUserModal=this.createModal(),this.createUserModal.setContent(o(yield this.fetchWidgetPage("create-user-modal.html")));const e=new k((()=>{var e;return null===(e=this.createUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>{this.createUserModal.close(),this.resetFormData(this.createUserModal.ele)}));const t=new k((()=>{var e;return null===(e=this.createUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});t.onClick((()=>n(this,void 0,void 0,(function*(){this.validateForm(this.createUserModal.ele)&&(this.actions.createUser(Object.assign(Object.assign({},this.getFormData(this.createUserModal.ele)),{invite:!0,verifiedEmail:!0,verifiedPhone:!0})),this.createUserModal.close(),this.resetFormData(this.createUserModal.ele))})))),l(this,s,new U((()=>{var e;return null===(e=this.createUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="roles-multiselect"]')}),{logger:this.logger}),"f"),d(this,a,"f").call(this)}))},u})),et=s((e=>{var t,s,o;return o=class extends(i(v,_e,Ye)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),d(this,t,"m",s).call(this)}))}},t=new WeakSet,s=function(){var e;this.createButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="create-user"]'),{logger:this.logger}),this.createButton.onClick((()=>this.createUserModal.open()))},o})),tt=s((e=>{var t,s,r;return r=class extends(i(Qe,w,v,Ye)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),yield d(this,t,"m",s).call(this)}))}},t=new WeakSet,s=function(){var e;return n(this,void 0,void 0,(function*(){this.deleteUsersModal=this.createModal(),this.deleteUsersModal.setContent(o(yield this.fetchWidgetPage("delete-users-modal.html")));const t=new k((()=>{var e;return null===(e=this.deleteUsersModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});t.onClick((()=>this.deleteUsersModal.close()));const s=new k((()=>{var e;return null===(e=this.deleteUsersModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});s.onClick((()=>{const e=E(this.state);this.actions.deleteUsers(e),this.deleteUsersModal.close()}));const i=new C(null===(e=this.deleteUsersModal.ele)||void 0===e?void 0:e.querySelector('[data-id="body-text"]'),{logger:this.logger});this.deleteUsersModal.beforeOpen=()=>{const e=G(this.state);i.text=`Delete ${e}?`}}))},r})),st=s((e=>{var t,s,o,a;return a=class extends(i(v,Ye,Qe,tt)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{e?this.deleteButton.enable():this.deleteButton.disable()})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){d(this,t,"m",s).call(this),yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),this.subscribe(d(this,o,"f").bind(this),ee)}))}},o=new WeakMap,t=new WeakSet,s=function(){var e;this.deleteButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="delete-users"]'),{logger:this.logger}),this.deleteButton.disable(),this.deleteButton.onClick((()=>{this.deleteUsersModal.open()}))},a})),it=s((e=>{var t,s,r,a,l;return l=class extends(i(Qe,w,v,R,Ye)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),yield d(this,t,"m",a).call(this)}))}},t=new WeakSet,s=function(){const e=new k((()=>{var e;return null===(e=this.disableUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>this.disableUserModal.close()))},r=function(){const e=new k((()=>{var e;return null===(e=this.disableUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});e.onClick((()=>{const e=V(this.state);this.actions.disableUser(e),this.disableUserModal.close()}))},a=function(){var e;return n(this,void 0,void 0,(function*(){this.disableUserModal=this.createModal(),this.disableUserModal.setContent(o(yield this.fetchWidgetPage("disable-user-modal.html"))),d(this,t,"m",s).call(this),d(this,t,"m",r).call(this);const i=new C(null===(e=this.disableUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="body-text"]'),{logger:this.logger});this.disableUserModal.beforeOpen=()=>n(this,void 0,void 0,(function*(){const e=G(this.state);i.text=`Disable ${e}?`}))}))},l})),ot=s((e=>{var t,s,o,a;return a=class extends(i(v,Ye,Qe,it,R)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{e?this.disableButton.enable():this.disableButton.disable()})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){d(this,t,"m",s).call(this),yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),this.subscribe(d(this,o,"f").bind(this),Q)}))}},o=new WeakMap,t=new WeakSet,s=function(){var e;this.disableButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="disable-user"]'),{logger:this.logger}),this.disableButton.disable(),this.disableButton.onClick((()=>{this.disableUserModal.open()}))},a})),rt=["customAttributes"],at=e=>{if(!e)return e;const t=L(e),s=new RegExp(`(\\+?${null==t?void 0:t.countryCallingCode})(.*)`);return t.number.replace(s,"$1-$2")},nt=s((e=>{var t,s,r,a,c,h,g,m,p,y;return y=class extends(i(Qe,w,v,R,Ye)(e)){constructor(){super(...arguments),t.add(this),s.set(this,void 0),r.set(this,void 0),h.set(this,(()=>n(this,void 0,void 0,(function*(){yield d(this,r,"f").setData(T(this.state).map((({name:e})=>({value:e,label:e}))))})))),m.set(this,(()=>{var e,t;const s=null===(e=B(this.state))||void 0===e?void 0:e[0],i=Object.assign({loginId:null===(t=null==s?void 0:s.loginIds)||void 0===t?void 0:t.join(", "),displayName:null==s?void 0:s.name,email:null==s?void 0:s.email,phone:at(null==s?void 0:s.phone),roles:null==s?void 0:s.roles},(o=s.customAttributes,r="customAttributes.",Object.fromEntries(Object.entries(o).map((([e,t])=>[`${r}${e}`,t])))));var o,r;this.setFormData(this.editUserModal.ele,i)}))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),yield d(this,t,"m",p).call(this)}))}},s=new WeakMap,r=new WeakMap,h=new WeakMap,m=new WeakMap,t=new WeakSet,a=function(){const e=new k((()=>{var e;return null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>this.editUserModal.close()))},c=function(){const e=new k((()=>{var e;return null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});e.onClick((()=>{if(this.validateForm(this.editUserModal.ele)){const e=this.getFormData(this.editUserModal.ele),{loginId:t}=e,s=u(e,["loginId"]);this.actions.updateUser(Object.assign({loginId:t.split(", ")[0]},(e=>Object.entries(e).reduce(((e,[t,s])=>{const[i,...o]=t.split(".");return rt.includes(i)?(e[i]||(e[i]={}),e[i][o.join(".")]=s,e):Object.assign(e,{[t]:s})}),{}))(s))),this.editUserModal.close(),this.resetFormData(this.editUserModal.ele)}}))},g=function(){const e=$(this.state);this.getFormFieldNames(this.editUserModal.ele).forEach((t=>{const[s,i]=t.split(".");if("customAttributes"!==s)return;const o=e.find((e=>e.name===i));o?o.editable||this.disableFormField(this.editUserModal.ele,t):this.removeFormField(this.editUserModal.ele,t)}))},p=function(){var e;return n(this,void 0,void 0,(function*(){this.editUserModal=this.createModal(),this.editUserModal.setContent(o(yield this.fetchWidgetPage("edit-user-modal.html"))),d(this,t,"m",a).call(this),d(this,t,"m",c).call(this),l(this,s,new S(null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[name="loginId"]'),{logger:this.logger}),"f"),l(this,r,new U((()=>{var e;return null===(e=this.editUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="roles-multiselect"]')}),{logger:this.logger}),"f"),this.editUserModal.beforeOpen=()=>n(this,void 0,void 0,(function*(){yield d(this,h,"f").call(this),d(this,s,"f").disable(),d(this,m,"f").call(this),d(this,t,"m",g).call(this)}))}))},y})),dt=s((e=>{var t,s,o,a;return a=class extends(i(v,Ye,Qe,nt,R)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{e?this.editButton.enable():this.editButton.disable()})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){d(this,t,"m",s).call(this),yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),this.subscribe(d(this,o,"f").bind(this),X)}))}},o=new WeakMap,t=new WeakSet,s=function(){var e;this.editButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="edit-user"]'),{logger:this.logger}),this.editButton.disable(),this.editButton.onClick((()=>{this.editUserModal.open()}))},a})),lt=s((e=>{var t,s,r,a,l;return l=class extends(i(Qe,w,v,R,Ye)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),yield d(this,t,"m",a).call(this)}))}},t=new WeakSet,s=function(){const e=new k((()=>{var e;return null===(e=this.enableUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>this.enableUserModal.close()))},r=function(){const e=new k((()=>{var e;return null===(e=this.enableUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});e.onClick((()=>{const e=V(this.state);this.actions.enableUser(e),this.enableUserModal.close()}))},a=function(){var e;return n(this,void 0,void 0,(function*(){this.enableUserModal=this.createModal(),this.enableUserModal.setContent(o(yield this.fetchWidgetPage("enable-user-modal.html"))),d(this,t,"m",s).call(this),d(this,t,"m",r).call(this);const i=new C(null===(e=this.enableUserModal.ele)||void 0===e?void 0:e.querySelector('[data-id="body-text"]'),{logger:this.logger});this.enableUserModal.beforeOpen=()=>n(this,void 0,void 0,(function*(){const e=G(this.state);i.text=`Activate ${e}?`}))}))},l})),ut=s((e=>{var t,s,o,a;return a=class extends(i(v,Ye,Qe,lt,R)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{e?this.enableButton.enable():this.enableButton.disable()})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){d(this,t,"m",s).call(this),yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),this.subscribe(d(this,o,"f").bind(this),K)}))}},o=new WeakMap,t=new WeakSet,s=function(){var e;this.enableButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="enable-user"]'),{logger:this.logger}),this.enableButton.disable(),this.enableButton.onClick((()=>{this.enableUserModal.open()}))},a})),ct=s((e=>{var t,s,o,r;return r=class extends(i(v,Ye,Qe)(e)){constructor(){super(...arguments),t.add(this),s.set(this,a((()=>{this.actions.searchUsers({text:this.searchInput.value})})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),d(this,t,"m",o).call(this)}))}},s=new WeakMap,t=new WeakSet,o=function(){var e;this.searchInput=new S(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="search-input"]'),{logger:this.logger}),this.searchInput.onInput(d(this,s,"f"))},r}));const ht={success:(new DOMParser).parseFromString('<svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">\n<g id="Checkmark">\n<path id="Shape" d="M10.0485 15.6396C9.5799 15.171 8.8201 15.171 8.35147 15.6396C7.88284 16.1082 7.88284 16.868 8.35147 17.3367L12.7072 21.6924C13.1759 22.1611 13.9357 22.1611 14.4043 21.6924L24.7152 11.3815C25.1838 10.9129 25.1838 10.1531 24.7152 9.68448C24.2466 9.21585 23.4868 9.21585 23.0181 9.68448L13.5558 19.1469L10.0485 15.6396Z" fill="white"/>\n</g>\n</svg>\n',"image/svg+xml").firstChild,error:(new DOMParser).parseFromString('<svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">\n<g id="Icon">\n<path id="Vector" d="M15.9998 26.6558C10.1118 26.6558 5.34375 21.8878 5.34375 15.9998C5.34375 10.1118 10.1118 5.34375 15.9998 5.34375C21.8878 5.34375 26.6558 10.1118 26.6558 15.9998C26.6558 21.8878 21.8878 26.6558 15.9998 26.6558ZM15.9998 24.4798C20.6718 24.4798 24.4798 20.7038 24.4798 15.9998C24.4798 11.3278 20.7038 7.51975 15.9998 7.51975C11.3278 7.51975 7.51975 11.2958 7.51975 15.9998C7.51975 20.6718 11.2958 24.4798 15.9998 24.4798ZM15.3278 9.34375H16.6718C17.0558 9.34375 17.3438 9.63175 17.3118 9.98375L16.9598 16.9278C16.9598 17.1838 16.7678 17.3438 16.5438 17.3438H15.4558C15.2318 17.3438 15.0398 17.1518 15.0398 16.9278L14.6878 9.98375C14.6878 9.63175 14.9758 9.34375 15.3278 9.34375ZM15.4558 19.4558H16.5438C16.9278 19.4558 17.2158 19.7438 17.1838 20.1278V21.1838C17.1838 21.5678 16.8958 21.8558 16.5438 21.8558H15.4558C15.0718 21.8558 14.7838 21.5678 14.7838 21.1838V20.1278C14.7838 19.7438 15.0718 19.4558 15.4558 19.4558Z" fill="#FFDFDD"/>\n</g>\n</svg>\n',"image/svg+xml").firstChild},vt=s((e=>{var t,s,o,a,l;return l=class extends(i(v,Qe,M,p)(e)){constructor(){super(...arguments),t.add(this),a.set(this,r((e=>{e.length&&(e.forEach((({type:e,msg:i})=>{const r=d(this,t,"m",o).call(this,e);r.setContent(d(this,t,"m",s).call(this,{type:e,msg:i})),r.show()})),setTimeout((()=>this.actions.clearNotifications())))})))}init(){const e=Object.create(null,{init:{get:()=>super.init}});var t;return n(this,void 0,void 0,(function*(){yield null===(t=e.init)||void 0===t?void 0:t.call(this),this.subscribe(d(this,a,"f").bind(this),A)}))}},a=new WeakMap,t=new WeakSet,s=function({type:e,msg:t}){const s=ht[e],i=Object.assign((new DOMParser).parseFromString('<svg width="2em" height="2em" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">\n<g id="Icon">\n<path id="Shape" d="M10.6712 12L7.27521 8.60406C6.90826 8.23711 6.90826 7.64216 7.27521 7.27521C7.64216 6.90826 8.23711 6.90826 8.60406 7.27521L12 10.6712L15.3959 7.27521C15.7629 6.90826 16.3578 6.90826 16.7248 7.27521C17.0917 7.64216 17.0917 8.23711 16.7248 8.60406L13.3288 12L16.7248 15.3959C17.0917 15.7629 17.0917 16.3578 16.7248 16.7248C16.3578 17.0917 15.7629 17.0917 15.3959 16.7248L12 13.3288L8.60406 16.7248C8.23711 17.0917 7.64216 17.0917 7.27521 16.7248C6.90826 16.3578 6.90826 15.7629 7.27521 15.3959L10.6712 12Z" fill="white"/>\n</g>\n</svg>\n',"image/svg+xml").firstChild,{slot:"close"});return`${(null==s?void 0:s.outerHTML)||""}${t}${i.outerHTML}`},o=function(e){return this.createNotification({mode:e,duration:"error"===e?0:3e3,position:"bottom-start",size:"sm"})},l})),gt=s((e=>{var t,s,r,a,l;return l=class extends(i(Qe,w,v,R,Ye)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),yield d(this,t,"m",a).call(this)}))}},t=new WeakSet,s=function(){const e=new k((()=>{var e;return null===(e=this.removePasskeyModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>this.removePasskeyModal.close()))},r=function(){const e=new k((()=>{var e;return null===(e=this.removePasskeyModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});e.onClick((()=>{const e=V(this.state);this.actions.removePasskey(e),this.removePasskeyModal.close()}))},a=function(){var e;return n(this,void 0,void 0,(function*(){this.removePasskeyModal=this.createModal(),this.removePasskeyModal.setContent(o(yield this.fetchWidgetPage("remove-passkey-modal.html"))),d(this,t,"m",s).call(this),d(this,t,"m",r).call(this);const i=new C(null===(e=this.removePasskeyModal.ele)||void 0===e?void 0:e.querySelector('[data-id="body-text"]'),{logger:this.logger});this.removePasskeyModal.beforeOpen=()=>n(this,void 0,void 0,(function*(){const e=G(this.state);i.text=`Remove passkey for ${e}?`}))}))},l})),mt=s((e=>{var t,s,o,a;return a=class extends(i(v,Ye,Qe,gt,R)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{e?this.removePasskeyButton.enable():this.removePasskeyButton.disable()})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){d(this,t,"m",s).call(this),yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),this.subscribe(d(this,o,"f").bind(this),Y)}))}},o=new WeakMap,t=new WeakSet,s=function(){var e;this.removePasskeyButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="remove-passkey"]'),{logger:this.logger}),this.removePasskeyButton.disable(),this.removePasskeyButton.onClick((()=>{this.removePasskeyModal.open()}))},a})),pt=s((e=>{var t,s,o,l,u,c;return c=class extends(i(Qe,v,Ye)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{this.usersTable.data=e}))),l.set(this,a(((e,t)=>{const s=[],{value:i}=t;if(i){const t=e.path;s.push({field:t,desc:"desc"===i})}this.actions.searchUsers({sort:s})}))),u.set(this,r((e=>{this.usersTable.filterColumns((t=>{var s;const[i,o]=(null===(s=t.path)||void 0===s?void 0:s.split("."))||[];return"customAttributes"!==i||!!e.find((e=>e.name===o))}))})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),d(this,t,"m",s).call(this),this.usersTable.columns.forEach((e=>{e.onSortDirectionChange((e=>{d(this,l,"f").call(this,e.target,e.detail)}))})),d(this,o,"f").call(this,F(this.state)),d(this,u,"f").call(this,$(this.state)),this.subscribe(d(this,u,"f").bind(this),$),this.subscribe(d(this,o,"f").bind(this),F)}))}},o=new WeakMap,l=new WeakMap,u=new WeakMap,t=new WeakSet,s=function(){var e;this.usersTable=new x(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="users-table"]'),{logger:this.logger}),this.usersTable.onSelectedItemsChange((e=>{this.actions.setSelectedUsersIds(e.detail.value.map((({loginIds:e})=>e)))}))},c})),yt=s((e=>{var t,s,r;return r=class extends(i(Qe,w,v,R,Ye)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),yield d(this,t,"m",s).call(this)}))}},t=new WeakSet,s=function(){return n(this,void 0,void 0,(function*(){this.generatedPasswordModal=this.createModal(),this.generatedPasswordModal.setContent(o(yield this.fetchWidgetPage("generated-password-modal.html")));const e=new k((()=>{var e;return null===(e=this.generatedPasswordModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-close"]')}),{logger:this.logger});e.onClick((()=>{navigator.clipboard.writeText(this.getFormData(this.generatedPasswordModal.ele)["generated-password"]),this.resetFormData(this.generatedPasswordModal.ele),this.generatedPasswordModal.close()}))}))},r})),ft=s((e=>{var t,s,r,a,l;return l=class extends(i(Qe,w,v,R,Ye,yt)(e)){constructor(){super(...arguments),t.add(this)}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var s;return n(this,void 0,void 0,(function*(){yield null===(s=e.onWidgetRootReady)||void 0===s?void 0:s.call(this),yield d(this,t,"m",a).call(this)}))}},t=new WeakSet,s=function(){const e=new k((()=>{var e;return null===(e=this.resetPasswordModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-cancel"]')}),{logger:this.logger});e.onClick((()=>this.resetPasswordModal.close()))},r=function(){const e=new k((()=>{var e;return null===(e=this.resetPasswordModal.ele)||void 0===e?void 0:e.querySelector('[data-id="modal-submit"]')}),{logger:this.logger});e.onClick((()=>n(this,void 0,void 0,(function*(){var e;const t=V(this.state),s=yield this.actions.setTempUserPassword(t);this.resetPasswordModal.close(),this.setFormData(this.generatedPasswordModal.ele,{"generated-password":null===(e=null==s?void 0:s.payload)||void 0===e?void 0:e.cleartext}),this.generatedPasswordModal.open()}))))},a=function(){var e;return n(this,void 0,void 0,(function*(){this.resetPasswordModal=this.createModal(),this.resetPasswordModal.setContent(o(yield this.fetchWidgetPage("reset-password-modal.html"))),d(this,t,"m",s).call(this),d(this,t,"m",r).call(this);const i=new C(null===(e=this.resetPasswordModal.ele)||void 0===e?void 0:e.querySelector('[data-id="body-text"]'),{logger:this.logger});this.resetPasswordModal.beforeOpen=()=>n(this,void 0,void 0,(function*(){const e=G(this.state);i.text=`Reset password for ${e}?`}))}))},l})),bt=s((e=>{var t,s,o,a;return a=class extends(i(v,Ye,Qe,ft,R)(e)){constructor(){super(...arguments),t.add(this),o.set(this,r((e=>{e?this.resetPasswordButton.enable():this.resetPasswordButton.disable()})))}onWidgetRootReady(){const e=Object.create(null,{onWidgetRootReady:{get:()=>super.onWidgetRootReady}});var i;return n(this,void 0,void 0,(function*(){d(this,t,"m",s).call(this),yield null===(i=e.onWidgetRootReady)||void 0===i?void 0:i.call(this),this.subscribe(d(this,o,"f").bind(this),_)}))}},o=new WeakMap,t=new WeakSet,s=function(){var e;this.resetPasswordButton=new k(null===(e=this.shadowRoot)||void 0===e?void 0:e.querySelector('[data-id="reset-password"]'),{logger:this.logger}),this.resetPasswordButton.disable(),this.resetPasswordButton.onClick((()=>{this.resetPasswordModal.open()}))},a})),wt=s((e=>class extends(i(W,P,pt,et,st,dt,ut,ot,bt,mt,ct,vt)(e)){init(){const e=Object.create(null,{init:{get:()=>super.init}});var t;return n(this,void 0,void 0,(function*(){yield null===(t=e.init)||void 0===t?void 0:t.call(this)}))}})),Rt=i((e=>class extends(wt(e)){}))(HTMLElement);customElements.define("descope-user-management-widget",Rt);export{Rt as default};
3
6
  //# sourceMappingURL=index.js.map