diff --git a/apps/appstore/src/components/AppStoreSidebar/AppDetailsTab.vue b/apps/appstore/src/components/AppStoreSidebar/AppDetailsTab.vue
index 2f1669f835084..c21063d850b4a 100644
--- a/apps/appstore/src/components/AppStoreSidebar/AppDetailsTab.vue
+++ b/apps/appstore/src/components/AppStoreSidebar/AppDetailsTab.vue
@@ -12,103 +12,6 @@
- {{ t('appstore', 'Default Deploy daemon is not accessible') }} -
-+ {{ t('settings', 'Default Deploy daemon is not accessible') }} +
+0&&e[c-1][2]>o;c--)e[c]=e[c-1];e[c]=[a,r,o]},s.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return s.d(t,{a:t}),t},s.d=(e,t)=>{for(var a in t)s.o(t,a)&&!s.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:t[a]})},s.f={},s.e=e=>Promise.all(Object.keys(s.f).reduce((t,a)=>(s.f[a](e,t),t),[])),s.u=e=>(4529===e?"settings-apps-view":e)+"-"+e+".js?v="+{55:"680212f4ff82f0f08ba9",1140:"490e17ed9c8948d5a9e8",2221:"428c2ff62c4b8b3c97fc",4529:"712c0bec6b23bc0b194f",5448:"71cfe268d6f1213c4735",6015:"ebcb6885c1fc8c461988",7859:"740587c0c8c350dad157",7910:"de857920f8beb5205bbc",8394:"afffd43f559fd65e2a14",8815:"9a5c507c75429c9c04e4",9849:"cf17f23d4655df0fe9a4"}[e],s.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},r="nextcloud-ui-legacy:",s.l=(e,t,o,p)=>{if(a[e])a[e].push(t);else{var n,i;if(void 0!==o)for(var d=document.getElementsByTagName("script"),c=0;c 0&&e[c-1][2]>o;c--)e[c]=e[c-1];e[c]=[a,r,o]},s.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return s.d(t,{a:t}),t},s.d=(e,t)=>{for(var a in t)s.o(t,a)&&!s.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:t[a]})},s.f={},s.e=e=>Promise.all(Object.keys(s.f).reduce((t,a)=>(s.f[a](e,t),t),[])),s.u=e=>(4529===e?"settings-apps-view":e)+"-"+e+".js?v="+{55:"680212f4ff82f0f08ba9",1140:"490e17ed9c8948d5a9e8",2221:"428c2ff62c4b8b3c97fc",4529:"86d8d135dabd6320195a",5448:"71cfe268d6f1213c4735",6015:"ebcb6885c1fc8c461988",7859:"740587c0c8c350dad157",7910:"de857920f8beb5205bbc",8394:"afffd43f559fd65e2a14",8815:"9a5c507c75429c9c04e4",9849:"cf17f23d4655df0fe9a4"}[e],s.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},r="nextcloud-ui-legacy:",s.l=(e,t,o,p)=>{if(a[e])a[e].push(t);else{var n,i;if(void 0!==o)for(var d=document.getElementsByTagName("script"),c=0;c \\n\\t\\t\\t\\t{{ configuredDeployOptions === null ? t('settings', 'Edit ExApp deploy options before installation') : t('settings', 'Configured ExApp deploy options. Can be set only during installation') }}.\\n\\t\\t\\t\\t\\n\\t\\t\\t\\t\\t{{ t('settings', 'Learn more') }}\\n\\t\\t\\t\\t\\n\\t\\t\\t \\n\\t\\t\\t\\t\\t\\t{{ envVar.description }}\\n\\t\\t\\t\\t\\t \\n\\t\\t\\t\\t\\t{{ t('settings', 'No environment variables defined') }}\\n\\t\\t\\t\\t \\n\\t\\t\\t\\t\\t{{ t('settings', 'Define host folder mounts to bind to the ExApp container') }}\\n\\t\\t\\t\\t \\n\\t\\t\\t\\t\\t{{ t('settings', 'ExApp container mounts') }}\\n\\t\\t\\t\\t \\n\\t\\t\\t\\t{{ t('settings', 'No mounts defined') }}\\n\\t\\t\\t \n\t\t\t\t{{ configuredDeployOptions === null ? t('settings', 'Edit ExApp deploy options before installation') : t('settings', 'Configured ExApp deploy options. Can be set only during installation') }}.\n\t\t\t\t\n\t\t\t\t\t{{ t('settings', 'Learn more') }}\n\t\t\t\t\n\t\t\t \n\t\t\t\t\t\t{{ envVar.description }}\n\t\t\t\t\t \n\t\t\t\t\t{{ t('settings', 'No environment variables defined') }}\n\t\t\t\t \n\t\t\t\t\t{{ t('settings', 'Define host folder mounts to bind to the ExApp container') }}\n\t\t\t\t \n\t\t\t\t\t{{ t('settings', 'ExApp container mounts') }}\n\t\t\t\t \n\t\t\t\t{{ t('settings', 'No mounts defined') }}\n\t\t\t \n\t\t\t\t\t{{ t('appstore', 'Default Deploy daemon is not accessible') }}\n\t\t\t\t \n\t\t\t\t\t{{ appAuthors }}\n\t\t\t\t \n\t\t\t\t\t{{ appCategories }}\n\t\t\t\t \\n\\t\\t\\t\\t{{ configuredDeployOptions === null ? t('settings', 'Edit ExApp deploy options before installation') : t('settings', 'Configured ExApp deploy options. Can be set only during installation') }}.\\n\\t\\t\\t\\t\\n\\t\\t\\t\\t\\t{{ t('settings', 'Learn more') }}\\n\\t\\t\\t\\t\\n\\t\\t\\t \\n\\t\\t\\t\\t\\t\\t{{ envVar.description }}\\n\\t\\t\\t\\t\\t \\n\\t\\t\\t\\t\\t{{ t('settings', 'No environment variables defined') }}\\n\\t\\t\\t\\t \\n\\t\\t\\t\\t\\t{{ t('settings', 'Define host folder mounts to bind to the ExApp container') }}\\n\\t\\t\\t\\t \\n\\t\\t\\t\\t\\t{{ t('settings', 'ExApp container mounts') }}\\n\\t\\t\\t\\t \\n\\t\\t\\t\\t{{ t('settings', 'No mounts defined') }}\\n\\t\\t\\t \n\t\t\t\t\t{{ appAuthors }}\n\t\t\t\t \n\t\t\t\t\t{{ appCategories }}\n\t\t\t\t \n\t\t\t\t{{ configuredDeployOptions === null ? t('settings', 'Edit ExApp deploy options before installation') : t('settings', 'Configured ExApp deploy options. Can be set only during installation') }}.\n\t\t\t\t\n\t\t\t\t\t{{ t('settings', 'Learn more') }}\n\t\t\t\t\n\t\t\t \n\t\t\t\t\t\t{{ envVar.description }}\n\t\t\t\t\t \n\t\t\t\t\t{{ t('settings', 'No environment variables defined') }}\n\t\t\t\t \n\t\t\t\t\t{{ t('settings', 'Define host folder mounts to bind to the ExApp container') }}\n\t\t\t\t \n\t\t\t\t\t{{ t('settings', 'ExApp container mounts') }}\n\t\t\t\t \n\t\t\t\t{{ t('settings', 'No mounts defined') }}\n\t\t\t \n\t\t\t{{ t('settings', 'Default Deploy daemon is not accessible') }}\n\t\t
"+a.error.response.data.data.message,{isHTML:!0}),s.A.error("An error occurred during the request. Unable to proceed.",{state:e,error:a})},initCategories(e,{categories:t,updateCount:a}){e.categories=t,e.updateCount=a},updateCategories(e,t){e.gettingCategoriesPromise=t},setUpdateCount(e,t){e.updateCount=t},addCategory(e,t){e.categories.push(t)},appendCategories(e,t){e.categories=t},setAllApps(e,t){e.apps=t},setError(e,{appId:t,error:a}){Array.isArray(t)||(t=[t]),t.forEach(t=>{e.apps.find(e=>e.id===t).error=a})},clearError(e,{appId:t}){e.apps.find(e=>e.id===t).error=null},enableApp(e,{appId:t,groups:a}){const r=e.apps.find(e=>e.id===t);r.active=!0,l.Ay.set(r,"groups",[...a]),"app_api"===r.id&&(e.appApiEnabled=!0)},setInstallState(e,{appId:t,canInstall:a}){const r=e.apps.find(e=>e.id===t);r&&(r.canInstall=!0===a)},disableApp(e,t){const a=e.apps.find(e=>e.id===t);a.active=!1,a.groups=[],a.removable&&(a.canUnInstall=!0),"app_api"===a.id&&(e.appApiEnabled=!1)},uninstallApp(e,t){e.apps.find(e=>e.id===t).active=!1,e.apps.find(e=>e.id===t).groups=[],e.apps.find(e=>e.id===t).needsDownload=!0,e.apps.find(e=>e.id===t).installed=!1,e.apps.find(e=>e.id===t).canUnInstall=!1,e.apps.find(e=>e.id===t).canInstall=!0,"app_api"===t&&(e.appApiEnabled=!1)},updateApp(e,t){const a=e.apps.find(e=>e.id===t),r=a.update;a.update=null,a.version=r,e.updateCount--},resetApps(e){e.apps=[]},reset(e){e.apps=[],e.categories=[],e.updateCount=0},startLoading(e,t){Array.isArray(t)?t.forEach(t=>{l.Ay.set(e.loading,t,!0)}):l.Ay.set(e.loading,t,!0)},stopLoading(e,t){Array.isArray(t)?t.forEach(t=>{l.Ay.set(e.loading,t,!1)}):l.Ay.set(e.loading,t,!1)}},A={enableApp(e,{appId:a,groups:r}){let p;p=Array.isArray(a)?a:[a],e.commit("startLoading",p),e.commit("startLoading","install");const s={};p.forEach(t=>{const a=e.state.apps.find(e=>e.id===t);a&&(s[t]={active:a.active,groups:[...a.groups||[]]},e.commit("enableApp",{appId:t,groups:r}))});const i=(0,c.KT)("apps/appstore/api/v1/apps/enable");return Promise.all(p.map(a=>u.A.post(i,{appId:a,groups:r},{confirmPassword:d.mH.Strict}).then(r=>(e.commit("stopLoading",p),e.commit("stopLoading","install"),n.Ay.get((0,c.Jv)("apps/files/")).then(()=>{r.data.update_required&&((0,o.cf)(t("appstore","The app has been enabled but needs to be updated. You will be redirected to the update page in 5 seconds."),{onClick:()=>window.location.reload(),close:!1}),setTimeout(function(){location.reload()},5e3))}).catch(()=>{Array.isArray(a)||((0,o.Qg)(t("appstore","Error: This app cannot be enabled because it makes the server unstable")),e.commit("setError",{appId:p,error:t("appstore","Error: This app cannot be enabled because it makes the server unstable")}),e.dispatch("disableApp",{appId:a}))}))).catch(t=>{e.commit("stopLoading",p),e.commit("stopLoading","install"),p.forEach(t=>{s[t]&&(e.commit("enableApp",{appId:t,groups:s[t].groups}),s[t].active||e.commit("disableApp",t))});const r=t.response?.data?.data?.message;r&&(e.commit("setError",{appId:p,error:r}),e.commit("APPS_API_FAILURE",{appId:a,error:t}))})))},forceEnableApp(e,{appId:t}){let a;return a=Array.isArray(t)?t:[t],u.A.requireAdmin().then(()=>{e.commit("startLoading",a),e.commit("startLoading","install");const r=(0,c.KT)("apps/appstore/api/v1/apps/enable");return u.A.post(r,{appId:t,force:!0},{confirmPassword:d.mH.Strict}).then(()=>{e.commit("setInstallState",{appId:t,canInstall:!0})}).catch(r=>{e.commit("stopLoading",a),e.commit("stopLoading","install"),e.commit("setError",{appId:a,error:r.response.data.data.message}),e.commit("APPS_API_FAILURE",{appId:t,error:r})}).finally(()=>{e.commit("stopLoading",a),e.commit("stopLoading","install")})}).catch(a=>e.commit("API_FAILURE",{appId:t,error:a}))},disableApp(e,{appId:t}){let a;return a=Array.isArray(t)?t:[t],u.A.requireAdmin().then(()=>{e.commit("startLoading",a);const t=(0,c.KT)("apps/appstore/api/v1/apps/disable");return Promise.all(a.map(r=>u.A.post(t,{appId:r}).then(()=>(e.commit("stopLoading",a),a.forEach(t=>{e.commit("disableApp",t)}),!0)).catch(t=>{e.commit("stopLoading",a),e.commit("APPS_API_FAILURE",{appId:r,error:t})})))}).catch(a=>e.commit("API_FAILURE",{appId:t,error:a}))},uninstallApp:(e,{appId:t})=>u.A.requireAdmin().then(()=>{e.commit("startLoading",t);const a=(0,c.KT)("apps/appstore/api/v1/apps/uninstall");return u.A.post(a,{appId:t}).then(()=>(e.commit("stopLoading",t),e.commit("uninstallApp",t),!0)).catch(a=>{e.commit("stopLoading",t),e.commit("APPS_API_FAILURE",{appId:t,error:a})})}).catch(a=>e.commit("API_FAILURE",{appId:t,error:a})),updateApp:(e,{appId:t})=>u.A.requireAdmin().then(()=>{e.commit("startLoading",t),e.commit("startLoading","install");const a=(0,c.KT)("apps/appstore/api/v1/apps/update");return u.A.post(a,{appId:t},{confirmPassword:d.mH.Strict}).then(()=>(e.commit("stopLoading","install"),e.commit("stopLoading",t),e.commit("updateApp",t),!0)).catch(a=>{e.commit("stopLoading",t),e.commit("stopLoading","install"),e.commit("APPS_API_FAILURE",{appId:t,error:a})})}).catch(a=>e.commit("API_FAILURE",{appId:t,error:a})),getAllApps(e){e.commit("startLoading","list");const t=(0,c.KT)("apps/appstore/api/v1/apps");return u.A.get(t).then(t=>{const a=t.data.ocs.data;return e.commit("setAllApps",a),e.commit("stopLoading","list"),!0}).catch(t=>e.commit("API_FAILURE",t))},async getCategories(e,{shouldRefetchCategories:t=!1}={}){if(t||!e.state.gettingCategoriesPromise){e.commit("startLoading","categories");try{const t=u.A.get((0,c.KT)("apps/appstore/api/v1/apps/categories"));e.commit("updateCategories",t);const a=(await t).data.ocs;return a.data.length>0?(e.commit("appendCategories",a.data),e.commit("stopLoading","categories"),!0):(e.commit("stopLoading","categories"),!1)}catch(t){e.commit("API_FAILURE",t)}}return e.state.gettingCategoriesPromise}},h={state:m,mutations:g,getters:{isAppApiEnabled:e=>e.appApiEnabled,loading:e=>function(t){return e.loading[t]},getCategories:e=>e.categories,getAllApps:e=>e.apps,getAppBundles:e=>e.bundles,getUpdateCount:e=>e.updateCount,getCategoryById:e=>t=>e.categories.find(e=>e.id===t)},actions:A},f={API_FAILURE(e,a){try{const e=a.error.response.data.ocs.meta.message;(0,o.Qg)(t("appstore","An error occurred during the request. Unable to proceed.")+"
"+e,{isHTML:!0})}catch{(0,o.Qg)(t("appstore","An error occurred during the request. Unable to proceed."))}s.A.error("An error occurred during the request.",{state:e,error:a})}};let b=null;function v(){return null===b&&(b=new p.il({modules:{apps:h},strict:!1,mutations:f})),b}},60792(e,t,a){"use strict";var r=a(21777),o=a(53334),p=a(10810),s=a(80284),n=a(85471),i=a(95353),d=a(58723),c=a(22378);const l=(0,n.pM)({__name:"App",setup:e=>({__sfc:!0,NcContent:c.A})}),u=(0,a(14486).A)(l,function(){var e=this,t=e._self._c;return t(e._self._setupProxy.NcContent,{attrs:{"app-name":"settings"}},[t("router-view",{attrs:{name:"navigation"}}),e._v(" "),t("router-view"),e._v(" "),t("router-view",{attrs:{name:"sidebar"}})],1)},[],!1,null,null,null).exports;var m=a(63814),g=a(40173);const A=[{path:"/:index(index.php/)?settings/apps",name:"apps",redirect:{name:"apps-category",params:{category:(0,a(81222).C)("settings","appstoreEnabled",!0)?"discover":"installed"}},components:{default:()=>Promise.all([a.e(4208),a.e(4529)]).then(a.bind(a,84020)),navigation:()=>Promise.all([a.e(4208),a.e(4529)]).then(a.bind(a,67276)),sidebar:()=>Promise.all([a.e(4208),a.e(4529)]).then(a.bind(a,19859))},children:[{path:":category",name:"apps-category",children:[{path:":id",name:"apps-details"}]}]}];n.Ay.use(g.Ay);const h=new g.Ay({mode:"history",base:(0,m.Jv)(""),linkActiveClass:"active",routes:A});var f=a(72135);a.nc=(0,r.aV)(),n.Ay.prototype.t=o.t,n.Ay.prototype.n=o.n,n.Ay.use(p.R2),n.Ay.use(s.Ay,{defaultHtml:!1}),n.Ay.use(i.Ay);const b=(0,f.P)();(0,d.O)(b,h);const v=(0,p.Ey)();new n.Ay({router:h,store:b,pinia:v,render:e=>e(u),el:"#content"})},11615(e,t,a){"use strict";a.d(t,{A:()=>r});const r=(0,a(35947).YK)().setApp("appstore").detectUser().build()},58723(e,t){function a(e,t){var r={name:e.name,path:e.path,hash:e.hash,query:e.query,params:e.params,fullPath:e.fullPath,meta:e.meta};return t&&(r.from=a(t)),Object.freeze(r)}t.O=function(e,t,r){var o=(r||{}).moduleName||"route";e.registerModule(o,{namespaced:!0,state:a(t.currentRoute),mutations:{ROUTE_CHANGED:function(t,r){e.state[o]=a(r.to,r.from)}}});var p,s=!1,n=e.watch(function(e){return e[o]},function(e){var a=e.fullPath;a!==p&&(null!=p&&(s=!0,t.push(e)),p=a)},{sync:!0}),i=t.afterEach(function(t,a){s?s=!1:(p=t.fullPath,e.commit(o+"/ROUTE_CHANGED",{to:t,from:a}))});return function(){null!=i&&i(),null!=n&&n(),e.unregisterModule(o)}}}},p={};function s(e){var t=p[e];if(void 0!==t)return t.exports;var a=p[e]={id:e,loaded:!1,exports:{}};return o[e].call(a.exports,a,a.exports,s),a.loaded=!0,a.exports}s.m=o,e=[],s.O=(t,a,r,o)=>{if(!a){var p=1/0;for(c=0;c
' + error.error.response.data.data.message, { isHTML: true })\n\t\tlogger.error('An error occurred during the request. Unable to proceed.', { state, error })\n\t},\n\n\tinitCategories(state, { categories, updateCount }) {\n\t\tstate.categories = categories\n\t\tstate.updateCount = updateCount\n\t},\n\n\tupdateCategories(state, categoriesPromise) {\n\t\tstate.gettingCategoriesPromise = categoriesPromise\n\t},\n\n\tsetUpdateCount(state, updateCount) {\n\t\tstate.updateCount = updateCount\n\t},\n\n\taddCategory(state, category) {\n\t\tstate.categories.push(category)\n\t},\n\n\tappendCategories(state, categoriesArray) {\n\t\t// convert obj to array\n\t\tstate.categories = categoriesArray\n\t},\n\n\tsetAllApps(state, apps) {\n\t\tstate.apps = apps\n\t},\n\n\tsetError(state, { appId, error }) {\n\t\tif (!Array.isArray(appId)) {\n\t\t\tappId = [appId]\n\t\t}\n\t\tappId.forEach((_id) => {\n\t\t\tconst app = state.apps.find((app) => app.id === _id)\n\t\t\tapp.error = error\n\t\t})\n\t},\n\n\tclearError(state, { appId }) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tapp.error = null\n\t},\n\n\tenableApp(state, { appId, groups }) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tapp.active = true\n\t\tVue.set(app, 'groups', [...groups])\n\t\tif (app.id === 'app_api') {\n\t\t\tstate.appApiEnabled = true\n\t\t}\n\t},\n\n\tsetInstallState(state, { appId, canInstall }) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tif (app) {\n\t\t\tapp.canInstall = canInstall === true\n\t\t}\n\t},\n\n\tdisableApp(state, appId) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tapp.active = false\n\t\tapp.groups = []\n\t\tif (app.removable) {\n\t\t\tapp.canUnInstall = true\n\t\t}\n\t\tif (app.id === 'app_api') {\n\t\t\tstate.appApiEnabled = false\n\t\t}\n\t},\n\n\tuninstallApp(state, appId) {\n\t\tstate.apps.find((app) => app.id === appId).active = false\n\t\tstate.apps.find((app) => app.id === appId).groups = []\n\t\tstate.apps.find((app) => app.id === appId).needsDownload = true\n\t\tstate.apps.find((app) => app.id === appId).installed = false\n\t\tstate.apps.find((app) => app.id === appId).canUnInstall = false\n\t\tstate.apps.find((app) => app.id === appId).canInstall = true\n\t\tif (appId === 'app_api') {\n\t\t\tstate.appApiEnabled = false\n\t\t}\n\t},\n\n\tupdateApp(state, appId) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tconst version = app.update\n\t\tapp.update = null\n\t\tapp.version = version\n\t\tstate.updateCount--\n\t},\n\n\tresetApps(state) {\n\t\tstate.apps = []\n\t},\n\treset(state) {\n\t\tstate.apps = []\n\t\tstate.categories = []\n\t\tstate.updateCount = 0\n\t},\n\tstartLoading(state, id) {\n\t\tif (Array.isArray(id)) {\n\t\t\tid.forEach((_id) => {\n\t\t\t\tVue.set(state.loading, _id, true)\n\t\t\t})\n\t\t} else {\n\t\t\tVue.set(state.loading, id, true)\n\t\t}\n\t},\n\tstopLoading(state, id) {\n\t\tif (Array.isArray(id)) {\n\t\t\tid.forEach((_id) => {\n\t\t\t\tVue.set(state.loading, _id, false)\n\t\t\t})\n\t\t} else {\n\t\t\tVue.set(state.loading, id, false)\n\t\t}\n\t},\n}\n\nconst getters = {\n\tisAppApiEnabled(state) {\n\t\treturn state.appApiEnabled\n\t},\n\tloading(state) {\n\t\treturn function(id) {\n\t\t\treturn state.loading[id]\n\t\t}\n\t},\n\tgetCategories(state) {\n\t\treturn state.categories\n\t},\n\tgetAllApps(state) {\n\t\treturn state.apps\n\t},\n\tgetAppBundles(state) {\n\t\treturn state.bundles\n\t},\n\tgetUpdateCount(state) {\n\t\treturn state.updateCount\n\t},\n\tgetCategoryById: (state) => (selectedCategoryId) => {\n\t\treturn state.categories.find((category) => category.id === selectedCategoryId)\n\t},\n}\n\nconst actions = {\n\n\tenableApp(context, { appId, groups }) {\n\t\tlet apps\n\t\tif (Array.isArray(appId)) {\n\t\t\tapps = appId\n\t\t} else {\n\t\t\tapps = [appId]\n\t\t}\n\t\tcontext.commit('startLoading', apps)\n\t\tcontext.commit('startLoading', 'install')\n\n\t\tconst previousState = {}\n\t\tapps.forEach((_appId) => {\n\t\t\tconst app = context.state.apps.find((app) => app.id === _appId)\n\t\t\tif (app) {\n\t\t\t\tpreviousState[_appId] = {\n\t\t\t\t\tactive: app.active,\n\t\t\t\t\tgroups: [...(app.groups || [])],\n\t\t\t\t}\n\t\t\t\tcontext.commit('enableApp', { appId: _appId, groups })\n\t\t\t}\n\t\t})\n\n\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/enable')\n\t\treturn Promise.all(apps.map((appId) => api\n\t\t\t.post(url, { appId, groups }, { confirmPassword: PwdConfirmationMode.Strict })\n\t\t\t.then((response) => {\n\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\tcontext.commit('stopLoading', 'install')\n\n\t\t\t\t// check for server health\n\t\t\t\treturn axios.get(generateUrl('apps/files/'))\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\tif (response.data.update_required) {\n\t\t\t\t\t\t\tshowInfo(\n\t\t\t\t\t\t\t\tt(\n\t\t\t\t\t\t\t\t\t'appstore',\n\t\t\t\t\t\t\t\t\t'The app has been enabled but needs to be updated. You will be redirected to the update page in 5 seconds.',\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tonClick: () => window.location.reload(),\n\t\t\t\t\t\t\t\t\tclose: false,\n\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\tsetTimeout(function() {\n\t\t\t\t\t\t\t\tlocation.reload()\n\t\t\t\t\t\t\t}, 5000)\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t\t.catch(() => {\n\t\t\t\t\t\tif (!Array.isArray(appId)) {\n\t\t\t\t\t\t\tshowError(t('appstore', 'Error: This app cannot be enabled because it makes the server unstable'))\n\t\t\t\t\t\t\tcontext.commit('setError', {\n\t\t\t\t\t\t\t\tappId: apps,\n\t\t\t\t\t\t\t\terror: t('appstore', 'Error: This app cannot be enabled because it makes the server unstable'),\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\tcontext.dispatch('disableApp', { appId })\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t})\n\t\t\t.catch((error) => {\n\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\tcontext.commit('stopLoading', 'install')\n\n\t\t\t\tapps.forEach((_appId) => {\n\t\t\t\t\tif (previousState[_appId]) {\n\t\t\t\t\t\tcontext.commit('enableApp', {\n\t\t\t\t\t\t\tappId: _appId,\n\t\t\t\t\t\t\tgroups: previousState[_appId].groups,\n\t\t\t\t\t\t})\n\t\t\t\t\t\tif (!previousState[_appId].active) {\n\t\t\t\t\t\t\tcontext.commit('disableApp', _appId)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\n\t\t\t\tconst message = error.response?.data?.data?.message\n\t\t\t\tif (message) {\n\t\t\t\t\tcontext.commit('setError', {\n\t\t\t\t\t\tappId: apps,\n\t\t\t\t\t\terror: message,\n\t\t\t\t\t})\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t}\n\t\t\t})))\n\t},\n\tforceEnableApp(context, { appId }) {\n\t\tlet apps\n\t\tif (Array.isArray(appId)) {\n\t\t\tapps = appId\n\t\t} else {\n\t\t\tapps = [appId]\n\t\t}\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', apps)\n\t\t\tcontext.commit('startLoading', 'install')\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/enable')\n\t\t\treturn api.post(url, { appId, force: true }, { confirmPassword: PwdConfirmationMode.Strict })\n\t\t\t\t.then(() => {\n\t\t\t\t\tcontext.commit('setInstallState', { appId, canInstall: true })\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t\tcontext.commit('setError', {\n\t\t\t\t\t\tappId: apps,\n\t\t\t\t\t\terror: error.response.data.data.message,\n\t\t\t\t\t})\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t})\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\tdisableApp(context, { appId }) {\n\t\tlet apps\n\t\tif (Array.isArray(appId)) {\n\t\t\tapps = appId\n\t\t} else {\n\t\t\tapps = [appId]\n\t\t}\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', apps)\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/disable')\n\t\t\treturn Promise.all(apps.map((appId) => {\n\t\t\t\treturn api.post(url, { appId })\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\t\tapps.forEach((_appId) => {\n\t\t\t\t\t\t\tcontext.commit('disableApp', _appId)\n\t\t\t\t\t\t})\n\t\t\t\t\t\treturn true\n\t\t\t\t\t})\n\t\t\t\t\t.catch((error) => {\n\t\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t\t})\n\t\t\t}))\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\tuninstallApp(context, { appId }) {\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', appId)\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/uninstall')\n\t\t\treturn api.post(url, { appId })\n\t\t\t\t.then(() => {\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('uninstallApp', appId)\n\t\t\t\t\treturn true\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t})\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\n\tupdateApp(context, { appId }) {\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', appId)\n\t\t\tcontext.commit('startLoading', 'install')\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/update')\n\t\t\treturn api.post(url, { appId }, { confirmPassword: PwdConfirmationMode.Strict })\n\t\t\t\t.then(() => {\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('updateApp', appId)\n\t\t\t\t\treturn true\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t})\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\n\tgetAllApps(context) {\n\t\tcontext.commit('startLoading', 'list')\n\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps')\n\t\treturn api.get(url)\n\t\t\t.then((response) => {\n\t\t\t\tconst apps = response.data.ocs.data\n\t\t\t\tcontext.commit('setAllApps', apps)\n\t\t\t\tcontext.commit('stopLoading', 'list')\n\t\t\t\treturn true\n\t\t\t})\n\t\t\t.catch((error) => context.commit('API_FAILURE', error))\n\t},\n\n\tasync getCategories(context, { shouldRefetchCategories = false } = {}) {\n\t\tif (shouldRefetchCategories || !context.state.gettingCategoriesPromise) {\n\t\t\tcontext.commit('startLoading', 'categories')\n\t\t\ttry {\n\t\t\t\tconst categoriesPromise = api.get(generateOcsUrl('apps/appstore/api/v1/apps/categories'))\n\t\t\t\tcontext.commit('updateCategories', categoriesPromise)\n\t\t\t\tconst categoriesPromiseResponse = (await categoriesPromise).data.ocs\n\t\t\t\tif (categoriesPromiseResponse.data.length > 0) {\n\t\t\t\t\tcontext.commit('appendCategories', categoriesPromiseResponse.data)\n\t\t\t\t\tcontext.commit('stopLoading', 'categories')\n\t\t\t\t\treturn true\n\t\t\t\t}\n\t\t\t\tcontext.commit('stopLoading', 'categories')\n\t\t\t\treturn false\n\t\t\t} catch (error) {\n\t\t\t\tcontext.commit('API_FAILURE', error)\n\t\t\t}\n\t\t}\n\t\treturn context.state.gettingCategoriesPromise\n\t},\n\n}\n\nexport default { state, mutations, getters, actions }\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nimport { showError } from '@nextcloud/dialogs'\nimport { Store } from 'vuex'\nimport logger from '../utils/logger.js'\nimport apps from './apps.js'\n\nconst mutations = {\n\tAPI_FAILURE(state, error) {\n\t\ttry {\n\t\t\tconst message = error.error.response.data.ocs.meta.message\n\t\t\tshowError(t('appstore', 'An error occurred during the request. Unable to proceed.') + '
' + message, { isHTML: true })\n\t\t} catch {\n\t\t\tshowError(t('appstore', 'An error occurred during the request. Unable to proceed.'))\n\t\t}\n\t\tlogger.error('An error occurred during the request.', { state, error })\n\t},\n}\n\nlet store = null\n\n/**\n *\n */\nexport function useStore() {\n\tif (store === null) {\n\t\tstore = new Store({\n\t\t\tmodules: {\n\t\t\t\tapps,\n\t\t\t},\n\t\t\tstrict: !PRODUCTION,\n\t\t\tmutations,\n\t\t})\n\t}\n\treturn store\n}\n","var render = function render(){var _vm=this,_c=_vm._self._c,_setup=_vm._self._setupProxy;return _c(_setup.NcContent,{attrs:{\"app-name\":\"settings\"}},[_c('router-view',{attrs:{\"name\":\"navigation\"}}),_vm._v(\" \"),_c('router-view'),_vm._v(\" \"),_c('router-view',{attrs:{\"name\":\"sidebar\"}})],1)\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import mod from \"-!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/ts-loader/index.js??clonedRuleSet-6.use[1]!../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./App.vue?vue&type=script&setup=true&lang=ts\"; export default mod; export * from \"-!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/ts-loader/index.js??clonedRuleSet-6.use[1]!../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./App.vue?vue&type=script&setup=true&lang=ts\"","import { render, staticRenderFns } from \"./App.vue?vue&type=template&id=30acb651\"\nimport script from \"./App.vue?vue&type=script&setup=true&lang=ts\"\nexport * from \"./App.vue?vue&type=script&setup=true&lang=ts\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","import { loadState } from '@nextcloud/initial-state';\nconst appstoreEnabled = loadState('settings', 'appstoreEnabled', true);\n// Dynamic loading\nconst AppStore = () => import(/* webpackChunkName: 'settings-apps-view' */ '../views/AppStore.vue');\nconst AppStoreNavigation = () => import(/* webpackChunkName: 'settings-apps-view' */ '../views/AppStoreNavigation.vue');\nconst AppStoreSidebar = () => import(/* webpackChunkName: 'settings-apps-view' */ '../views/AppStoreSidebar.vue');\nconst routes = [\n {\n path: '/:index(index.php/)?settings/apps',\n name: 'apps',\n redirect: {\n name: 'apps-category',\n params: {\n category: appstoreEnabled ? 'discover' : 'installed',\n },\n },\n components: {\n default: AppStore,\n navigation: AppStoreNavigation,\n sidebar: AppStoreSidebar,\n },\n children: [\n {\n path: ':category',\n name: 'apps-category',\n children: [\n {\n path: ':id',\n name: 'apps-details',\n },\n ],\n },\n ],\n },\n];\nexport default routes;\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport { generateUrl } from '@nextcloud/router';\nimport Vue from 'vue';\nimport Router from 'vue-router';\nimport routes from './routes.ts';\nVue.use(Router);\nconst router = new Router({\n mode: 'history',\n // if index.php is in the url AND we got this far, then it's working:\n // let's keep using index.php in the url\n base: generateUrl(''),\n linkActiveClass: 'active',\n routes,\n});\nexport default router;\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport { getCSPNonce } from '@nextcloud/auth';\nimport { n, t } from '@nextcloud/l10n';\nimport { createPinia, PiniaVuePlugin } from 'pinia';\nimport VTooltipPlugin from 'v-tooltip';\nimport Vue from 'vue';\nimport Vuex from 'vuex';\nimport { sync } from 'vuex-router-sync';\nimport App from './views/App.vue';\nimport router from './router/index.ts';\nimport { useStore } from './store/index.js';\n// CSP config for webpack dynamic chunk loading\n__webpack_nonce__ = getCSPNonce();\n// bind to window\nVue.prototype.t = t;\nVue.prototype.n = n;\nVue.use(PiniaVuePlugin);\nVue.use(VTooltipPlugin, { defaultHtml: false });\nVue.use(Vuex);\nconst store = useStore();\nsync(store, router);\nconst pinia = createPinia();\nexport default new Vue({\n router,\n store,\n pinia,\n render: (h) => h(App),\n el: '#content',\n});\n","/**\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport { getLoggerBuilder } from '@nextcloud/logger';\nexport default getLoggerBuilder()\n .setApp('appstore')\n .detectUser()\n .build();\n","exports.sync = function (store, router, options) {\n var moduleName = (options || {}).moduleName || 'route'\n\n store.registerModule(moduleName, {\n namespaced: true,\n state: cloneRoute(router.currentRoute),\n mutations: {\n 'ROUTE_CHANGED': function ROUTE_CHANGED (state, transition) {\n store.state[moduleName] = cloneRoute(transition.to, transition.from)\n }\n }\n })\n\n var isTimeTraveling = false\n var currentPath\n\n // sync router on store change\n var storeUnwatch = store.watch(\n function (state) { return state[moduleName]; },\n function (route) {\n var fullPath = route.fullPath;\n if (fullPath === currentPath) {\n return\n }\n if (currentPath != null) {\n isTimeTraveling = true\n router.push(route)\n }\n currentPath = fullPath\n },\n { sync: true }\n )\n\n // sync store on router navigation\n var afterEachUnHook = router.afterEach(function (to, from) {\n if (isTimeTraveling) {\n isTimeTraveling = false\n return\n }\n currentPath = to.fullPath\n store.commit(moduleName + '/ROUTE_CHANGED', { to: to, from: from })\n })\n\n return function unsync () {\n // On unsync, remove router hook\n if (afterEachUnHook != null) {\n afterEachUnHook()\n }\n\n // On unsync, remove store watch\n if (storeUnwatch != null) {\n storeUnwatch()\n }\n\n // On unsync, unregister Module with store\n store.unregisterModule(moduleName)\n }\n}\n\nfunction cloneRoute (to, from) {\n var clone = {\n name: to.name,\n path: to.path,\n hash: to.hash,\n query: to.query,\n params: to.params,\n fullPath: to.fullPath,\n meta: to.meta\n }\n if (from) {\n clone.from = cloneRoute(from)\n }\n return Object.freeze(clone)\n}\n\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + (chunkId === 4529 ? \"settings-apps-view\" : chunkId) + \"-\" + chunkId + \".js?v=\" + {\"55\":\"680212f4ff82f0f08ba9\",\"1140\":\"490e17ed9c8948d5a9e8\",\"2221\":\"428c2ff62c4b8b3c97fc\",\"4529\":\"712c0bec6b23bc0b194f\",\"5448\":\"71cfe268d6f1213c4735\",\"6015\":\"ebcb6885c1fc8c461988\",\"7859\":\"740587c0c8c350dad157\",\"7910\":\"de857920f8beb5205bbc\",\"8394\":\"afffd43f559fd65e2a14\",\"8815\":\"9a5c507c75429c9c04e4\",\"9849\":\"cf17f23d4655df0fe9a4\"}[chunkId] + \"\";\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.j = 1303;","var scriptUrl;\nif (globalThis.importScripts) scriptUrl = globalThis.location + \"\";\nvar document = globalThis.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT')\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && (!scriptUrl || !/^http(s?):/.test(scriptUrl))) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/^blob:/, \"\").replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = (typeof document !== 'undefined' && document.baseURI) || self.location.href;\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t1303: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0);\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = globalThis[\"webpackChunknextcloud_ui_legacy\"] = globalThis[\"webpackChunknextcloud_ui_legacy\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","__webpack_require__.nc = undefined;","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [4208], () => (__webpack_require__(60792)))\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["deferred","inProgress","dataWebpackPrefix","sanitize","url","replace","addPasswordConfirmationInterceptors","axios","requireAdmin","confirmPassword","get","options","post","data","patch","put","delete","params","state","apps","bundles","loadState","categories","updateCount","loading","gettingCategoriesPromise","appApiEnabled","mutations","APPS_API_FAILURE","error","showError","t","response","message","isHTML","logger","initCategories","updateCategories","categoriesPromise","setUpdateCount","addCategory","category","push","appendCategories","categoriesArray","setAllApps","setError","appId","Array","isArray","forEach","_id","find","app","id","clearError","enableApp","groups","active","Vue","setInstallState","canInstall","disableApp","removable","canUnInstall","uninstallApp","needsDownload","installed","updateApp","version","update","resetApps","reset","startLoading","stopLoading","actions","context","commit","previousState","_appId","generateOcsUrl","Promise","all","map","api","PwdConfirmationMode","Strict","then","generateUrl","update_required","showInfo","onClick","window","location","reload","close","setTimeout","catch","dispatch","forceEnableApp","force","finally","getAllApps","ocs","getCategories","shouldRefetchCategories","categoriesPromiseResponse","length","getters","isAppApiEnabled","getAppBundles","getUpdateCount","getCategoryById","selectedCategoryId","API_FAILURE","meta","store","useStore","Store","modules","strict","_defineComponent","__name","setup","__props","__sfc","NcContent","_vm","this","_c","_self","_setupProxy","attrs","_v","path","name","redirect","components","default","AppStore","navigation","AppStoreNavigation","sidebar","AppStoreSidebar","children","use","Router","mode","base","linkActiveClass","routes","__webpack_nonce__","getCSPNonce","prototype","n","PiniaVuePlugin","VTooltipPlugin","defaultHtml","Vuex","sync","router","pinia","createPinia","render","h","App","el","getLoggerBuilder","setApp","detectUser","build","cloneRoute","to","from","clone","hash","query","fullPath","Object","freeze","exports","moduleName","registerModule","namespaced","currentRoute","transition","currentPath","isTimeTraveling","storeUnwatch","watch","route","afterEachUnHook","afterEach","unregisterModule","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","module","loaded","__webpack_modules__","call","m","O","result","chunkIds","fn","priority","notFulfilled","Infinity","i","fulfilled","j","keys","every","key","splice","r","getter","__esModule","d","a","definition","o","defineProperty","enumerable","f","e","chunkId","reduce","promises","u","obj","prop","hasOwnProperty","l","done","script","needAttach","scripts","document","getElementsByTagName","s","getAttribute","createElement","charset","nc","setAttribute","src","onScriptComplete","prev","event","onerror","onload","clearTimeout","timeout","doneFns","parentNode","removeChild","bind","type","target","head","appendChild","Symbol","toStringTag","value","nmd","paths","scriptUrl","globalThis","importScripts","currentScript","tagName","toUpperCase","test","Error","p","b","baseURI","self","href","installedChunks","installedChunkData","promise","resolve","reject","errorType","realSrc","request","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","__webpack_exports__"],"sourceRoot":""}
\ No newline at end of file
+{"version":3,"file":"appstore-main.js?v=6e144fe36ef3e8d3591a","mappings":"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","sources":["webpack:///nextcloud/webpack/runtime/chunk loaded","webpack:///nextcloud/webpack/runtime/load script","webpack:///nextcloud/apps/appstore/src/store/api.js","webpack:///nextcloud/apps/appstore/src/store/apps.js","webpack:///nextcloud/apps/appstore/src/store/index.js","webpack:///nextcloud/apps/appstore/src/views/App.vue","webpack:///nextcloud/apps/appstore/src/views/App.vue?vue&type=script&setup=true&lang=ts","webpack://nextcloud/./apps/appstore/src/views/App.vue?ffda","webpack:///nextcloud/apps/appstore/src/router/routes.ts","webpack:///nextcloud/apps/appstore/src/router/index.ts","webpack:///nextcloud/apps/appstore/src/main.ts","webpack:///nextcloud/apps/appstore/src/utils/logger.ts","webpack:///nextcloud/node_modules/vuex-router-sync/index.js","webpack:///nextcloud/webpack/bootstrap","webpack:///nextcloud/webpack/runtime/compat get default export","webpack:///nextcloud/webpack/runtime/define property getters","webpack:///nextcloud/webpack/runtime/ensure chunk","webpack:///nextcloud/webpack/runtime/get javascript chunk filename","webpack:///nextcloud/webpack/runtime/hasOwnProperty shorthand","webpack:///nextcloud/webpack/runtime/make namespace object","webpack:///nextcloud/webpack/runtime/node module decorator","webpack:///nextcloud/webpack/runtime/runtimeId","webpack:///nextcloud/webpack/runtime/publicPath","webpack:///nextcloud/webpack/runtime/jsonp chunk loading","webpack:///nextcloud/webpack/runtime/nonce","webpack:///nextcloud/webpack/startup"],"sourcesContent":["var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var inProgress = {};\nvar dataWebpackPrefix = \"nextcloud-ui-legacy:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = (url, done, key, chunkId) => {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = (prev, event) => {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach((fn) => (fn(event)));\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nimport axios from '@nextcloud/axios'\nimport { addPasswordConfirmationInterceptors, confirmPassword } from '@nextcloud/password-confirmation'\n\naddPasswordConfirmationInterceptors(axios)\n\n/**\n * @param {string} url - The url to sanitize\n */\nfunction sanitize(url) {\n\treturn url.replace(/\\/$/, '') // Remove last url slash\n}\n\nexport default {\n\n\t/**\n\t * This Promise is used to chain a request that require an admin password confirmation\n\t * Since chaining Promise have a very precise behavior concerning catch and then,\n\t * you'll need to be careful when using it.\n\t * e.g\n\t * // store\n\t * action(context) {\n\t * return api.requireAdmin().then((response) => {\n\t * return api.get('url')\n\t * .then((response) => {API success})\n\t * .catch((error) => {API failure});\n\t * }).catch((error) => {requireAdmin failure});\n\t * }\n\t * // vue\n\t * this.$store.dispatch('action').then(() => {always executed})\n\t *\n\t * Since Promise.then().catch().then() will always execute the last then\n\t * this.$store.dispatch('action').then will always be executed\n\t *\n\t * If you want requireAdmin failure to also catch the API request failure\n\t * you will need to throw a new error in the api.get.catch()\n\t *\n\t * e.g\n\t * api.requireAdmin().then((response) => {\n\t * api.get('url')\n\t * .then((response) => {API success})\n\t * .catch((error) => {throw error;});\n\t * }).catch((error) => {requireAdmin OR API failure});\n\t *\n\t * @return {Promise}\n\t */\n\trequireAdmin() {\n\t\treturn confirmPassword()\n\t},\n\tget(url, options) {\n\t\treturn axios.get(sanitize(url), options)\n\t},\n\tpost(url, data, options) {\n\t\treturn axios.post(sanitize(url), data, options)\n\t},\n\tpatch(url, data) {\n\t\treturn axios.patch(sanitize(url), data)\n\t},\n\tput(url, data) {\n\t\treturn axios.put(sanitize(url), data)\n\t},\n\tdelete(url, data) {\n\t\treturn axios.delete(sanitize(url), { params: data })\n\t},\n}\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nimport axios from '@nextcloud/axios'\nimport { showError, showInfo } from '@nextcloud/dialogs'\nimport { loadState } from '@nextcloud/initial-state'\nimport { PwdConfirmationMode } from '@nextcloud/password-confirmation'\nimport { generateOcsUrl, generateUrl } from '@nextcloud/router'\nimport Vue from 'vue'\nimport logger from '../utils/logger.ts'\nimport api from './api.js'\n\nconst state = {\n\tapps: [],\n\tbundles: loadState('appstore', 'appstoreBundles', []),\n\tcategories: [],\n\tupdateCount: loadState('appstore', 'appstoreUpdateCount', 0),\n\tloading: {},\n\tgettingCategoriesPromise: null,\n\tappApiEnabled: loadState('appstore', 'appApiEnabled', false),\n}\n\nconst mutations = {\n\n\tAPPS_API_FAILURE(state, error) {\n\t\tshowError(t('appstore', 'An error occurred during the request. Unable to proceed.') + '
' + error.error.response.data.data.message, { isHTML: true })\n\t\tlogger.error('An error occurred during the request. Unable to proceed.', { state, error })\n\t},\n\n\tinitCategories(state, { categories, updateCount }) {\n\t\tstate.categories = categories\n\t\tstate.updateCount = updateCount\n\t},\n\n\tupdateCategories(state, categoriesPromise) {\n\t\tstate.gettingCategoriesPromise = categoriesPromise\n\t},\n\n\tsetUpdateCount(state, updateCount) {\n\t\tstate.updateCount = updateCount\n\t},\n\n\taddCategory(state, category) {\n\t\tstate.categories.push(category)\n\t},\n\n\tappendCategories(state, categoriesArray) {\n\t\t// convert obj to array\n\t\tstate.categories = categoriesArray\n\t},\n\n\tsetAllApps(state, apps) {\n\t\tstate.apps = apps\n\t},\n\n\tsetError(state, { appId, error }) {\n\t\tif (!Array.isArray(appId)) {\n\t\t\tappId = [appId]\n\t\t}\n\t\tappId.forEach((_id) => {\n\t\t\tconst app = state.apps.find((app) => app.id === _id)\n\t\t\tapp.error = error\n\t\t})\n\t},\n\n\tclearError(state, { appId }) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tapp.error = null\n\t},\n\n\tenableApp(state, { appId, groups }) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tapp.active = true\n\t\tVue.set(app, 'groups', [...groups])\n\t\tif (app.id === 'app_api') {\n\t\t\tstate.appApiEnabled = true\n\t\t}\n\t},\n\n\tsetInstallState(state, { appId, canInstall }) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tif (app) {\n\t\t\tapp.canInstall = canInstall === true\n\t\t}\n\t},\n\n\tdisableApp(state, appId) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tapp.active = false\n\t\tapp.groups = []\n\t\tif (app.removable) {\n\t\t\tapp.canUnInstall = true\n\t\t}\n\t\tif (app.id === 'app_api') {\n\t\t\tstate.appApiEnabled = false\n\t\t}\n\t},\n\n\tuninstallApp(state, appId) {\n\t\tstate.apps.find((app) => app.id === appId).active = false\n\t\tstate.apps.find((app) => app.id === appId).groups = []\n\t\tstate.apps.find((app) => app.id === appId).needsDownload = true\n\t\tstate.apps.find((app) => app.id === appId).installed = false\n\t\tstate.apps.find((app) => app.id === appId).canUnInstall = false\n\t\tstate.apps.find((app) => app.id === appId).canInstall = true\n\t\tif (appId === 'app_api') {\n\t\t\tstate.appApiEnabled = false\n\t\t}\n\t},\n\n\tupdateApp(state, appId) {\n\t\tconst app = state.apps.find((app) => app.id === appId)\n\t\tconst version = app.update\n\t\tapp.update = null\n\t\tapp.version = version\n\t\tstate.updateCount--\n\t},\n\n\tresetApps(state) {\n\t\tstate.apps = []\n\t},\n\treset(state) {\n\t\tstate.apps = []\n\t\tstate.categories = []\n\t\tstate.updateCount = 0\n\t},\n\tstartLoading(state, id) {\n\t\tif (Array.isArray(id)) {\n\t\t\tid.forEach((_id) => {\n\t\t\t\tVue.set(state.loading, _id, true)\n\t\t\t})\n\t\t} else {\n\t\t\tVue.set(state.loading, id, true)\n\t\t}\n\t},\n\tstopLoading(state, id) {\n\t\tif (Array.isArray(id)) {\n\t\t\tid.forEach((_id) => {\n\t\t\t\tVue.set(state.loading, _id, false)\n\t\t\t})\n\t\t} else {\n\t\t\tVue.set(state.loading, id, false)\n\t\t}\n\t},\n}\n\nconst getters = {\n\tisAppApiEnabled(state) {\n\t\treturn state.appApiEnabled\n\t},\n\tloading(state) {\n\t\treturn function(id) {\n\t\t\treturn state.loading[id]\n\t\t}\n\t},\n\tgetCategories(state) {\n\t\treturn state.categories\n\t},\n\tgetAllApps(state) {\n\t\treturn state.apps\n\t},\n\tgetAppBundles(state) {\n\t\treturn state.bundles\n\t},\n\tgetUpdateCount(state) {\n\t\treturn state.updateCount\n\t},\n\tgetCategoryById: (state) => (selectedCategoryId) => {\n\t\treturn state.categories.find((category) => category.id === selectedCategoryId)\n\t},\n}\n\nconst actions = {\n\n\tenableApp(context, { appId, groups }) {\n\t\tlet apps\n\t\tif (Array.isArray(appId)) {\n\t\t\tapps = appId\n\t\t} else {\n\t\t\tapps = [appId]\n\t\t}\n\t\tcontext.commit('startLoading', apps)\n\t\tcontext.commit('startLoading', 'install')\n\n\t\tconst previousState = {}\n\t\tapps.forEach((_appId) => {\n\t\t\tconst app = context.state.apps.find((app) => app.id === _appId)\n\t\t\tif (app) {\n\t\t\t\tpreviousState[_appId] = {\n\t\t\t\t\tactive: app.active,\n\t\t\t\t\tgroups: [...(app.groups || [])],\n\t\t\t\t}\n\t\t\t\tcontext.commit('enableApp', { appId: _appId, groups })\n\t\t\t}\n\t\t})\n\n\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/enable')\n\t\treturn Promise.all(apps.map((appId) => api\n\t\t\t.post(url, { appId, groups }, { confirmPassword: PwdConfirmationMode.Strict })\n\t\t\t.then((response) => {\n\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\tcontext.commit('stopLoading', 'install')\n\n\t\t\t\t// check for server health\n\t\t\t\treturn axios.get(generateUrl('apps/files/'))\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\tif (response.data.update_required) {\n\t\t\t\t\t\t\tshowInfo(\n\t\t\t\t\t\t\t\tt(\n\t\t\t\t\t\t\t\t\t'appstore',\n\t\t\t\t\t\t\t\t\t'The app has been enabled but needs to be updated. You will be redirected to the update page in 5 seconds.',\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tonClick: () => window.location.reload(),\n\t\t\t\t\t\t\t\t\tclose: false,\n\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\tsetTimeout(function() {\n\t\t\t\t\t\t\t\tlocation.reload()\n\t\t\t\t\t\t\t}, 5000)\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t\t.catch(() => {\n\t\t\t\t\t\tif (!Array.isArray(appId)) {\n\t\t\t\t\t\t\tshowError(t('appstore', 'Error: This app cannot be enabled because it makes the server unstable'))\n\t\t\t\t\t\t\tcontext.commit('setError', {\n\t\t\t\t\t\t\t\tappId: apps,\n\t\t\t\t\t\t\t\terror: t('appstore', 'Error: This app cannot be enabled because it makes the server unstable'),\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\tcontext.dispatch('disableApp', { appId })\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t})\n\t\t\t.catch((error) => {\n\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\tcontext.commit('stopLoading', 'install')\n\n\t\t\t\tapps.forEach((_appId) => {\n\t\t\t\t\tif (previousState[_appId]) {\n\t\t\t\t\t\tcontext.commit('enableApp', {\n\t\t\t\t\t\t\tappId: _appId,\n\t\t\t\t\t\t\tgroups: previousState[_appId].groups,\n\t\t\t\t\t\t})\n\t\t\t\t\t\tif (!previousState[_appId].active) {\n\t\t\t\t\t\t\tcontext.commit('disableApp', _appId)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\n\t\t\t\tconst message = error.response?.data?.data?.message\n\t\t\t\tif (message) {\n\t\t\t\t\tcontext.commit('setError', {\n\t\t\t\t\t\tappId: apps,\n\t\t\t\t\t\terror: message,\n\t\t\t\t\t})\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t}\n\t\t\t})))\n\t},\n\tforceEnableApp(context, { appId }) {\n\t\tlet apps\n\t\tif (Array.isArray(appId)) {\n\t\t\tapps = appId\n\t\t} else {\n\t\t\tapps = [appId]\n\t\t}\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', apps)\n\t\t\tcontext.commit('startLoading', 'install')\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/enable')\n\t\t\treturn api.post(url, { appId, force: true }, { confirmPassword: PwdConfirmationMode.Strict })\n\t\t\t\t.then(() => {\n\t\t\t\t\tcontext.commit('setInstallState', { appId, canInstall: true })\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t\tcontext.commit('setError', {\n\t\t\t\t\t\tappId: apps,\n\t\t\t\t\t\terror: error.response.data.data.message,\n\t\t\t\t\t})\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t})\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\tdisableApp(context, { appId }) {\n\t\tlet apps\n\t\tif (Array.isArray(appId)) {\n\t\t\tapps = appId\n\t\t} else {\n\t\t\tapps = [appId]\n\t\t}\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', apps)\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/disable')\n\t\t\treturn Promise.all(apps.map((appId) => {\n\t\t\t\treturn api.post(url, { appId })\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\t\tapps.forEach((_appId) => {\n\t\t\t\t\t\t\tcontext.commit('disableApp', _appId)\n\t\t\t\t\t\t})\n\t\t\t\t\t\treturn true\n\t\t\t\t\t})\n\t\t\t\t\t.catch((error) => {\n\t\t\t\t\t\tcontext.commit('stopLoading', apps)\n\t\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t\t})\n\t\t\t}))\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\tuninstallApp(context, { appId }) {\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', appId)\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/uninstall')\n\t\t\treturn api.post(url, { appId })\n\t\t\t\t.then(() => {\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('uninstallApp', appId)\n\t\t\t\t\treturn true\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t})\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\n\tupdateApp(context, { appId }) {\n\t\treturn api.requireAdmin().then(() => {\n\t\t\tcontext.commit('startLoading', appId)\n\t\t\tcontext.commit('startLoading', 'install')\n\t\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps/update')\n\t\t\treturn api.post(url, { appId }, { confirmPassword: PwdConfirmationMode.Strict })\n\t\t\t\t.then(() => {\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('updateApp', appId)\n\t\t\t\t\treturn true\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tcontext.commit('stopLoading', appId)\n\t\t\t\t\tcontext.commit('stopLoading', 'install')\n\t\t\t\t\tcontext.commit('APPS_API_FAILURE', { appId, error })\n\t\t\t\t})\n\t\t}).catch((error) => context.commit('API_FAILURE', { appId, error }))\n\t},\n\n\tgetAllApps(context) {\n\t\tcontext.commit('startLoading', 'list')\n\t\tconst url = generateOcsUrl('apps/appstore/api/v1/apps')\n\t\treturn api.get(url)\n\t\t\t.then((response) => {\n\t\t\t\tconst apps = response.data.ocs.data\n\t\t\t\tcontext.commit('setAllApps', apps)\n\t\t\t\tcontext.commit('stopLoading', 'list')\n\t\t\t\treturn true\n\t\t\t})\n\t\t\t.catch((error) => context.commit('API_FAILURE', error))\n\t},\n\n\tasync getCategories(context, { shouldRefetchCategories = false } = {}) {\n\t\tif (shouldRefetchCategories || !context.state.gettingCategoriesPromise) {\n\t\t\tcontext.commit('startLoading', 'categories')\n\t\t\ttry {\n\t\t\t\tconst categoriesPromise = api.get(generateOcsUrl('apps/appstore/api/v1/apps/categories'))\n\t\t\t\tcontext.commit('updateCategories', categoriesPromise)\n\t\t\t\tconst categoriesPromiseResponse = (await categoriesPromise).data.ocs\n\t\t\t\tif (categoriesPromiseResponse.data.length > 0) {\n\t\t\t\t\tcontext.commit('appendCategories', categoriesPromiseResponse.data)\n\t\t\t\t\tcontext.commit('stopLoading', 'categories')\n\t\t\t\t\treturn true\n\t\t\t\t}\n\t\t\t\tcontext.commit('stopLoading', 'categories')\n\t\t\t\treturn false\n\t\t\t} catch (error) {\n\t\t\t\tcontext.commit('API_FAILURE', error)\n\t\t\t}\n\t\t}\n\t\treturn context.state.gettingCategoriesPromise\n\t},\n\n}\n\nexport default { state, mutations, getters, actions }\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n\nimport { showError } from '@nextcloud/dialogs'\nimport { Store } from 'vuex'\nimport logger from '../utils/logger.js'\nimport apps from './apps.js'\n\nconst mutations = {\n\tAPI_FAILURE(state, error) {\n\t\ttry {\n\t\t\tconst message = error.error.response.data.ocs.meta.message\n\t\t\tshowError(t('appstore', 'An error occurred during the request. Unable to proceed.') + '
' + message, { isHTML: true })\n\t\t} catch {\n\t\t\tshowError(t('appstore', 'An error occurred during the request. Unable to proceed.'))\n\t\t}\n\t\tlogger.error('An error occurred during the request.', { state, error })\n\t},\n}\n\nlet store = null\n\n/**\n *\n */\nexport function useStore() {\n\tif (store === null) {\n\t\tstore = new Store({\n\t\t\tmodules: {\n\t\t\t\tapps,\n\t\t\t},\n\t\t\tstrict: !PRODUCTION,\n\t\t\tmutations,\n\t\t})\n\t}\n\treturn store\n}\n","var render = function render(){var _vm=this,_c=_vm._self._c,_setup=_vm._self._setupProxy;return _c(_setup.NcContent,{attrs:{\"app-name\":\"settings\"}},[_c('router-view',{attrs:{\"name\":\"navigation\"}}),_vm._v(\" \"),_c('router-view'),_vm._v(\" \"),_c('router-view',{attrs:{\"name\":\"sidebar\"}})],1)\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import mod from \"-!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/ts-loader/index.js??clonedRuleSet-6.use[1]!../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./App.vue?vue&type=script&setup=true&lang=ts\"; export default mod; export * from \"-!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/ts-loader/index.js??clonedRuleSet-6.use[1]!../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./App.vue?vue&type=script&setup=true&lang=ts\"","import { render, staticRenderFns } from \"./App.vue?vue&type=template&id=30acb651\"\nimport script from \"./App.vue?vue&type=script&setup=true&lang=ts\"\nexport * from \"./App.vue?vue&type=script&setup=true&lang=ts\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","import { loadState } from '@nextcloud/initial-state';\nconst appstoreEnabled = loadState('settings', 'appstoreEnabled', true);\n// Dynamic loading\nconst AppStore = () => import(/* webpackChunkName: 'settings-apps-view' */ '../views/AppStore.vue');\nconst AppStoreNavigation = () => import(/* webpackChunkName: 'settings-apps-view' */ '../views/AppStoreNavigation.vue');\nconst AppStoreSidebar = () => import(/* webpackChunkName: 'settings-apps-view' */ '../views/AppStoreSidebar.vue');\nconst routes = [\n {\n path: '/:index(index.php/)?settings/apps',\n name: 'apps',\n redirect: {\n name: 'apps-category',\n params: {\n category: appstoreEnabled ? 'discover' : 'installed',\n },\n },\n components: {\n default: AppStore,\n navigation: AppStoreNavigation,\n sidebar: AppStoreSidebar,\n },\n children: [\n {\n path: ':category',\n name: 'apps-category',\n children: [\n {\n path: ':id',\n name: 'apps-details',\n },\n ],\n },\n ],\n },\n];\nexport default routes;\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport { generateUrl } from '@nextcloud/router';\nimport Vue from 'vue';\nimport Router from 'vue-router';\nimport routes from './routes.ts';\nVue.use(Router);\nconst router = new Router({\n mode: 'history',\n // if index.php is in the url AND we got this far, then it's working:\n // let's keep using index.php in the url\n base: generateUrl(''),\n linkActiveClass: 'active',\n routes,\n});\nexport default router;\n","/**\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport { getCSPNonce } from '@nextcloud/auth';\nimport { n, t } from '@nextcloud/l10n';\nimport { createPinia, PiniaVuePlugin } from 'pinia';\nimport VTooltipPlugin from 'v-tooltip';\nimport Vue from 'vue';\nimport Vuex from 'vuex';\nimport { sync } from 'vuex-router-sync';\nimport App from './views/App.vue';\nimport router from './router/index.ts';\nimport { useStore } from './store/index.js';\n// CSP config for webpack dynamic chunk loading\n__webpack_nonce__ = getCSPNonce();\n// bind to window\nVue.prototype.t = t;\nVue.prototype.n = n;\nVue.use(PiniaVuePlugin);\nVue.use(VTooltipPlugin, { defaultHtml: false });\nVue.use(Vuex);\nconst store = useStore();\nsync(store, router);\nconst pinia = createPinia();\nexport default new Vue({\n router,\n store,\n pinia,\n render: (h) => h(App),\n el: '#content',\n});\n","/**\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport { getLoggerBuilder } from '@nextcloud/logger';\nexport default getLoggerBuilder()\n .setApp('appstore')\n .detectUser()\n .build();\n","exports.sync = function (store, router, options) {\n var moduleName = (options || {}).moduleName || 'route'\n\n store.registerModule(moduleName, {\n namespaced: true,\n state: cloneRoute(router.currentRoute),\n mutations: {\n 'ROUTE_CHANGED': function ROUTE_CHANGED (state, transition) {\n store.state[moduleName] = cloneRoute(transition.to, transition.from)\n }\n }\n })\n\n var isTimeTraveling = false\n var currentPath\n\n // sync router on store change\n var storeUnwatch = store.watch(\n function (state) { return state[moduleName]; },\n function (route) {\n var fullPath = route.fullPath;\n if (fullPath === currentPath) {\n return\n }\n if (currentPath != null) {\n isTimeTraveling = true\n router.push(route)\n }\n currentPath = fullPath\n },\n { sync: true }\n )\n\n // sync store on router navigation\n var afterEachUnHook = router.afterEach(function (to, from) {\n if (isTimeTraveling) {\n isTimeTraveling = false\n return\n }\n currentPath = to.fullPath\n store.commit(moduleName + '/ROUTE_CHANGED', { to: to, from: from })\n })\n\n return function unsync () {\n // On unsync, remove router hook\n if (afterEachUnHook != null) {\n afterEachUnHook()\n }\n\n // On unsync, remove store watch\n if (storeUnwatch != null) {\n storeUnwatch()\n }\n\n // On unsync, unregister Module with store\n store.unregisterModule(moduleName)\n }\n}\n\nfunction cloneRoute (to, from) {\n var clone = {\n name: to.name,\n path: to.path,\n hash: to.hash,\n query: to.query,\n params: to.params,\n fullPath: to.fullPath,\n meta: to.meta\n }\n if (from) {\n clone.from = cloneRoute(from)\n }\n return Object.freeze(clone)\n}\n\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + (chunkId === 4529 ? \"settings-apps-view\" : chunkId) + \"-\" + chunkId + \".js?v=\" + {\"55\":\"680212f4ff82f0f08ba9\",\"1140\":\"490e17ed9c8948d5a9e8\",\"2221\":\"428c2ff62c4b8b3c97fc\",\"4529\":\"86d8d135dabd6320195a\",\"5448\":\"71cfe268d6f1213c4735\",\"6015\":\"ebcb6885c1fc8c461988\",\"7859\":\"740587c0c8c350dad157\",\"7910\":\"de857920f8beb5205bbc\",\"8394\":\"afffd43f559fd65e2a14\",\"8815\":\"9a5c507c75429c9c04e4\",\"9849\":\"cf17f23d4655df0fe9a4\"}[chunkId] + \"\";\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.j = 1303;","var scriptUrl;\nif (globalThis.importScripts) scriptUrl = globalThis.location + \"\";\nvar document = globalThis.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT')\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && (!scriptUrl || !/^http(s?):/.test(scriptUrl))) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/^blob:/, \"\").replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = (typeof document !== 'undefined' && document.baseURI) || self.location.href;\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t1303: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0);\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = globalThis[\"webpackChunknextcloud_ui_legacy\"] = globalThis[\"webpackChunknextcloud_ui_legacy\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","__webpack_require__.nc = undefined;","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [4208], () => (__webpack_require__(60792)))\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["deferred","inProgress","dataWebpackPrefix","sanitize","url","replace","addPasswordConfirmationInterceptors","axios","requireAdmin","confirmPassword","get","options","post","data","patch","put","delete","params","state","apps","bundles","loadState","categories","updateCount","loading","gettingCategoriesPromise","appApiEnabled","mutations","APPS_API_FAILURE","error","showError","t","response","message","isHTML","logger","initCategories","updateCategories","categoriesPromise","setUpdateCount","addCategory","category","push","appendCategories","categoriesArray","setAllApps","setError","appId","Array","isArray","forEach","_id","find","app","id","clearError","enableApp","groups","active","Vue","setInstallState","canInstall","disableApp","removable","canUnInstall","uninstallApp","needsDownload","installed","updateApp","version","update","resetApps","reset","startLoading","stopLoading","actions","context","commit","previousState","_appId","generateOcsUrl","Promise","all","map","api","PwdConfirmationMode","Strict","then","generateUrl","update_required","showInfo","onClick","window","location","reload","close","setTimeout","catch","dispatch","forceEnableApp","force","finally","getAllApps","ocs","getCategories","shouldRefetchCategories","categoriesPromiseResponse","length","getters","isAppApiEnabled","getAppBundles","getUpdateCount","getCategoryById","selectedCategoryId","API_FAILURE","meta","store","useStore","Store","modules","strict","_defineComponent","__name","setup","__props","__sfc","NcContent","_vm","this","_c","_self","_setupProxy","attrs","_v","path","name","redirect","components","default","AppStore","navigation","AppStoreNavigation","sidebar","AppStoreSidebar","children","use","Router","mode","base","linkActiveClass","routes","__webpack_nonce__","getCSPNonce","prototype","n","PiniaVuePlugin","VTooltipPlugin","defaultHtml","Vuex","sync","router","pinia","createPinia","render","h","App","el","getLoggerBuilder","setApp","detectUser","build","cloneRoute","to","from","clone","hash","query","fullPath","Object","freeze","exports","moduleName","registerModule","namespaced","currentRoute","transition","currentPath","isTimeTraveling","storeUnwatch","watch","route","afterEachUnHook","afterEach","unregisterModule","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","module","loaded","__webpack_modules__","call","m","O","result","chunkIds","fn","priority","notFulfilled","Infinity","i","fulfilled","j","keys","every","key","splice","r","getter","__esModule","d","a","definition","o","defineProperty","enumerable","f","e","chunkId","reduce","promises","u","obj","prop","hasOwnProperty","l","done","script","needAttach","scripts","document","getElementsByTagName","s","getAttribute","createElement","charset","nc","setAttribute","src","onScriptComplete","prev","event","onerror","onload","clearTimeout","timeout","doneFns","parentNode","removeChild","bind","type","target","head","appendChild","Symbol","toStringTag","value","nmd","paths","scriptUrl","globalThis","importScripts","currentScript","tagName","toUpperCase","test","Error","p","b","baseURI","self","href","installedChunks","installedChunkData","promise","resolve","reject","errorType","realSrc","request","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","__webpack_exports__"],"sourceRoot":""}
\ No newline at end of file
diff --git a/dist/settings-apps-view-4529.js b/dist/settings-apps-view-4529.js
index 680d107568c74..ada4c465b360e 100644
--- a/dist/settings-apps-view-4529.js
+++ b/dist/settings-apps-view-4529.js
@@ -1,2 +1,2 @@
-"use strict";(globalThis.webpackChunknextcloud_ui_legacy=globalThis.webpackChunknextcloud_ui_legacy||[]).push([[4529],{81720(t,e,n){n.d(e,{l:()=>i});var a=n(53334);const i=Object.freeze({discover:(0,a.Tl)("settings","Discover"),installed:(0,a.Tl)("settings","Your apps"),enabled:(0,a.Tl)("settings","Active apps"),disabled:(0,a.Tl)("settings","Disabled apps"),updates:(0,a.Tl)("settings","Updates"),"app-bundles":(0,a.Tl)("settings","App bundles"),featured:(0,a.Tl)("settings","Featured apps"),supported:(0,a.Tl)("settings","Supported apps")})},54143(e,n,a){a.d(n,{A:()=>c});var i=a(85168),o=a(19051),s=a(61338),r=a(63814);async function p(){const{data:t}=await o.Ay.get((0,r.KT)("core/navigation/apps?format=json"));200===t.ocs.meta.statuscode&&((0,s.Ic)("nextcloud:app-menu.refresh",{apps:t.ocs.data}),window.dispatchEvent(new Event("resize")))}const l=window.OC.theme.productName,c={computed:{appGroups(){return this.app.groups.map(t=>({id:t,name:t}))},installing(){return this.app?.app_api?this.app&&!0===this?.appApiStore.getLoading("install"):this.$store.getters.loading("install")},isLoading(){return this.app?.app_api?this.app&&!0===this?.appApiStore.getLoading(this.app.id):this.app&&this.$store.getters.loading(this.app.id)},isInitializing(){return!!this.app?.app_api&&this.app&&("init"===this.app?.status?.action||"healthcheck"===this.app?.status?.action)},isDeploying(){return!!this.app?.app_api&&this.app&&"deploy"===this.app?.status?.action},isManualInstall(){return!!this.app?.app_api&&"manual-install"===this.app?.daemon?.accepts_deploy_id},updateButtonText(){return this.app?.app_api&&"manual-install"===this.app?.daemon?.accepts_deploy_id?t("settings","Manually installed apps cannot be updated"):t("settings","Update to {version}",{version:this.app?.update})},enableButtonText(){return this.app?.app_api?this.app&&this.app?.status?.action&&"deploy"===this.app?.status?.action?t("settings","{progress}% Deploying …",{progress:this.app?.status?.deploy??0}):this.app&&this.app?.status?.action&&"init"===this.app?.status?.action?t("settings","{progress}% Initializing …",{progress:this.app?.status?.init??0}):this.app&&this.app?.status?.action&&"healthcheck"===this.app?.status?.action?t("settings","Health checking"):this.app.needsDownload?t("settings","Deploy and Enable"):t("settings","Enable"):this.app.needsDownload?t("settings","Download and enable"):t("settings","Enable")},disableButtonText(){if(this.app?.app_api){if(this.app&&this.app?.status?.action&&"deploy"===this.app?.status?.action)return t("settings","{progress}% Deploying …",{progress:this.app?.status?.deploy});if(this.app&&this.app?.status?.action&&"init"===this.app?.status?.action)return t("settings","{progress}% Initializing …",{progress:this.app?.status?.init});if(this.app&&this.app?.status?.action&&"healthcheck"===this.app?.status?.action)return t("settings","Health checking")}return t("settings","Disable")},forceEnableButtonText(){return this.app.needsDownload,t("settings","Allow untested app")},enableButtonTooltip(){return!this.app?.app_api&&this.app.needsDownload?t("settings","The app will be downloaded from the App Store"):null},forceEnableButtonTooltip(){const e=t("settings","This app is not marked as compatible with your {productName} version.",{productName:l})+" "+t("settings","If you continue you will still be able to install the app. Note that the app might not work as expected.");return this.app.needsDownload?e+" "+t("settings","The app will be downloaded from the App Store"):e},defaultDeployDaemonAccessible(){return!this.app?.app_api||!(!this.app?.daemon||"manual-install"!==this.app?.daemon?.accepts_deploy_id)||("docker-install"===this.app?.daemon?.accepts_deploy_id&&this.appApiStore.getDefaultDaemon?.name===this.app?.daemon?.name?!0===this?.appApiStore.getDaemonAccessible:this?.appApiStore.getDaemonAccessible)}},data:()=>({groupCheckedAppsData:!1}),mounted(){this.app&&this.app.groups&&this.app.groups.length>0&&(this.groupCheckedAppsData=!0)},methods:{asyncFindGroup(t){return this.$store.dispatch("getGroups",{search:t,limit:5,offset:0})},isLimitedToGroups(){return!this.app?.app_api&&(this.app.groups.length||this.groupCheckedAppsData)},setGroupLimit(){this.app?.app_api||this.groupCheckedAppsData||this.$store.dispatch("enableApp",{appId:this.app.id,groups:[]})},canLimitToGroups:t=>!(t.types&&t.types.includes("filesystem")||t.types.includes("prelogin")||t.types.includes("authentication")||t.types.includes("logging")||t.types.includes("prevent_group_restriction")||t?.app_api),addGroupLimitation(t){if(this.app?.app_api)return;const e=t.pop(),n=this.app.groups.concat([]).concat([e.id]);this.store&&this.store.updateAppGroups&&this.store.updateAppGroups(this.app.id,n),this.$store.dispatch("enableApp",{appId:this.app.id,groups:n})},removeGroupLimitation(t){if(this.app?.app_api)return;const e=this.app.groups.concat([]),n=e.indexOf(t.id);n>-1&&e.splice(n,1),this.store&&this.store.updateAppGroups&&this.store.updateAppGroups(this.app.id,e),0===e.length&&(this.groupCheckedAppsData=!1),this.$store.dispatch("enableApp",{appId:this.app.id,groups:e})},forceEnable(t){this.app?.app_api?this.appApiStore.forceEnableApp(t).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)}):this.$store.dispatch("forceEnableApp",{appId:t,groups:[]}).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)})},enable(t,e=null,n={}){this.app?.app_api?this.appApiStore.enableApp(t,e,n).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)}):this.$store.dispatch("enableApp",{appId:t,groups:[]}).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)})},disable(t){this.app?.app_api?this.appApiStore.disableApp(t).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)}):this.$store.dispatch("disableApp",{appId:t}).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)})},async remove(t,e=!1){try{this.app?.app_api?await this.appApiStore.uninstallApp(t,e):await this.$store.dispatch("uninstallApp",{appId:t,removeData:e}),await p()}catch(t){(0,i.Qg)(t)}},install(t){this.app?.app_api?this.appApiStore.enableApp(t).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)}):this.$store.dispatch("enableApp",{appId:t}).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)})},update(t){return this.app?.app_api?this.appApiStore.updateApp(t).then(()=>{p()}).catch(t=>{(0,i.Qg)(t)}):this.$store.dispatch("updateApp",{appId:t}).catch(t=>{(0,i.Qg)(t)}).then(()=>{p(),this.store.updateCount=Math.max(this.store.updateCount-1,0)})}}}},50645(t,e,n){n.d(e,{A:()=>i});var a=n(9165);const i=Object.freeze({discover:a.tZc,installed:a.EzL,enabled:a.Tfj,disabled:a.hyP,bundles:a.xR9,supported:a.UD9,featured:a.ZL5,updates:a.XCd,ai:a.aKS,auth:a.Mx_,customization:a.ED,dashboard:a.Knj,files:a.fEr,games:a.v3v,integration:a.bur,monitoring:a.y48,multimedia:a.WI,office:a.Ku3,organization:a.d9V,search:a.U4M,security:a.JiW,social:a.aie,tools:a.QKT,workflow:a.Rt7})},80409(t,e,n){n.d(e,{a:()=>A});var a=n(19051),i=n(85168),o=n(81222),s=n(53334),r=n(77690),p=n(63814),l=n(10810),c=n(85471),d=n(11615),u=n(3057);const A=(0,l.nY)("app-api-apps",{state:()=>({apps:[],updateCount:(0,o.C)("appstore","appstoreExAppUpdateCount",0),loading:{},loadingList:!1,statusUpdater:null,daemonAccessible:(0,o.C)("appstore","defaultDaemonConfigAccessible",!1),defaultDaemon:(0,o.C)("appstore","defaultDaemonConfig",null),dockerDaemons:[]}),getters:{getLoading:t=>e=>t.loading[e]??!1,getAllApps:t=>t.apps,getUpdateCount:t=>t.updateCount,getDaemonAccessible:t=>t.daemonAccessible,getDefaultDaemon:t=>t.defaultDaemon,getAppStatus:t=>e=>t.apps.find(t=>t.id===e)?.status||null,getStatusUpdater:t=>t.statusUpdater,getInitializingOrDeployingApps:t=>t.apps.filter(t=>t?.status?.action&&("deploy"===t?.status?.action||"init"===t.status.action||"healthcheck"===t.status.action)&&""!==t.status.type)},actions:{appsApiFailure(t){(0,i.Qg)((0,s.Tl)("appstore","An error occurred during the request. Unable to proceed.")+"
"+t.error.response.data.data.message,{isHTML:!0}),d.A.error(t)},setLoading(t,e){c.Ay.set(this.loading,t,e)},setError(t,e){(Array.isArray(t)?t:[t]).forEach(t=>{const n=this.apps.find(e=>e.id===t);n&&(n.error=e)})},enableApp(t,e,n){return this.setLoading(t,!0),this.setLoading("install",!0),(0,r.C5)().then(()=>a.Ay.post((0,p.Jv)(`/apps/app_api/apps/enable/${t}/${e.name}`),{deployOptions:n}).then(n=>{this.setLoading(t,!1),this.setLoading("install",!1);const o=this.apps.find(e=>e.id===t);return o&&(o.installed||(o.installed=!0,o.needsDownload=!1,o.daemon=e,o.status={type:"install",action:"deploy",init:0,deploy:0}),o.active=!0,o.canUnInstall=!1,o.removable=!0,o.error=""),this.updateAppsStatus(),a.Ay.get((0,p.Jv)("apps/files")).then(()=>{n.data.update_required&&((0,i.cf)((0,s.Tl)("appstore","The app has been enabled but needs to be updated."),{onClick:()=>window.location.reload(),close:!1}),setTimeout(()=>{location.reload()},5e3))}).catch(()=>{this.setError(t,(0,s.Tl)("appstore","Error: This app cannot be enabled because it makes the server unstable"))})}).catch(e=>{this.setLoading(t,!1),this.setLoading("install",!1),this.setError(t,e.response.data.data.message),this.appsApiFailure({appId:t,error:e})})).catch(()=>{this.setLoading(t,!1),this.setLoading("install",!1)})},forceEnableApp(t){return this.setLoading(t,!0),this.setLoading("install",!0),(0,r.C5)().then(()=>u.A.post((0,p.Jv)("/apps/app_api/apps/force"),{appId:t}).then(()=>{location.reload()}).catch(e=>{this.setLoading(t,!1),this.setLoading("install",!1),this.setError(t,e.response.data.data.message),this.appsApiFailure({appId:t,error:e})})).catch(()=>{this.setLoading(t,!1),this.setLoading("install",!1)})},disableApp(t){return this.setLoading(t,!0),(0,r.C5)().then(()=>u.A.get((0,p.Jv)(`apps/app_api/apps/disable/${t}`)).then(()=>{this.setLoading(t,!1);const e=this.apps.find(e=>e.id===t);return e&&(e.active=!1,e.removable&&(e.canUnInstall=!0)),!0}).catch(e=>{this.setLoading(t,!1),this.appsApiFailure({appId:t,error:e})})).catch(()=>{this.setLoading(t,!1)})},uninstallApp(t,e){return this.setLoading(t,!0),(0,r.C5)().then(()=>u.A.get((0,p.Jv)(`/apps/app_api/apps/uninstall/${t}?removeData=${e}`)).then(()=>{this.setLoading(t,!1);const e=this.apps.find(e=>e.id===t);return e&&(e.active=!1,e.needsDownload=!0,e.installed=!1,e.canUnInstall=!1,e.canInstall=!0,e.daemon=null,e.status={},null!==e.update&&this.updateCount--,e.update=void 0),!0}).catch(e=>{this.setLoading(t,!1),this.appsApiFailure({appId:t,error:e})}))},updateApp(t){return this.setLoading(t,!0),this.setLoading("install",!0),(0,r.C5)().then(()=>u.A.get((0,p.Jv)(`/apps/app_api/apps/update/${t}`)).then(()=>{this.setLoading(t,!1),this.setLoading("install",!1);const e=this.apps.find(e=>e.id===t);if(e){const t=e.update;e.update=void 0,e.version=t||e.version,e.status={type:"update",action:"deploy",init:0,deploy:0},e.error=""}return this.updateCount--,this.updateAppsStatus(),!0}).catch(e=>{this.setLoading(t,!1),this.setLoading("install",!1),this.appsApiFailure({appId:t,error:e})})).catch(()=>{this.setLoading(t,!1),this.setLoading("install",!1)})},async fetchAllApps(){this.loadingList=!0;try{const t=await u.A.get((0,p.Jv)("/apps/app_api/apps/list"));return this.apps=t.data.apps,this.loadingList=!1,!0}catch(t){d.A.error(t),(0,i.Qg)((0,s.Tl)("appstore","An error occurred during the request. Unable to proceed.")),this.loadingList=!1}},async fetchAppStatus(t){return u.A.get((0,p.Jv)(`/apps/app_api/apps/status/${t}`)).then(e=>{const n=this.apps.find(e=>e.id===t);n&&(n.status=e.data);const a=this.getInitializingOrDeployingApps;d.A.debug("initializingOrDeployingApps after setAppStatus",{initializingOrDeployingApps:a}),0===a.length&&(d.A.debug("clearing interval"),clearInterval(this.statusUpdater),this.statusUpdater=null),Object.hasOwn(e.data,"error")&&""!==e.data.error&&1===a.length&&(clearInterval(this.statusUpdater),this.statusUpdater=null)}).catch(e=>{this.appsApiFailure({appId:t,error:e}),this.apps=this.apps.filter(e=>e.id!==t),this.updateAppsStatus()})},async fetchDockerDaemons(){try{const{data:t}=await a.Ay.get((0,p.Jv)("/apps/app_api/daemons"));this.defaultDaemon=t.daemons.find(e=>e.name===t.default_daemon_config),this.dockerDaemons=t.daemons.filter(t=>"docker-install"===t.accepts_deploy_id)}catch(t){return d.A.error("[app-api-store] Failed to fetch Docker daemons",{error:t}),!1}return!0},updateAppsStatus(){clearInterval(this.statusUpdater),0!==this.getInitializingOrDeployingApps.length&&(this.statusUpdater=setInterval(()=>{const t=this.getInitializingOrDeployingApps;d.A.debug("initializingOrDeployingApps",{initializingOrDeployingApps:t}),t.forEach(t=>{this.fetchAppStatus(t.id)})},2e3))}}})},52111(t,e,n){n.d(e,{T:()=>u});var a=n(19051),i=n(85168),o=n(81222),s=n(53334),r=n(63814),p=n(10810),l=n(50645),c=n(11615);const d=()=>(0,i.Qg)((0,s.Tl)("appstore","An error occurred during the request. Unable to proceed.")),u=(0,p.nY)("appstore-apps",{state:()=>({apps:[],categories:[],updateCount:(0,o.C)("appstore","appstoreUpdateCount",0),loading:{apps:!1,categories:!1},loadingList:!1,gettingCategoriesPromise:null}),actions:{async loadCategories(t=!1){if(!(this.categories.length>0)||t)try{this.loading.categories=!0;const t=(0,r.KT)("apps/appstore/api/v1/apps/categories"),{data:e}=await a.Ay.get(t),n=e.ocs.data;for(const t of n)t.icon=l.A[t.id]??"";this.$patch({categories:n})}catch(t){c.A.error(t),d()}finally{this.loading.categories=!1}},async loadApps(t=!1){if(!(this.apps.length>0)||t)try{this.loading.apps=!0;const t=(0,r.KT)("apps/appstore/api/v1/apps"),{data:e}=await a.Ay.get(t);this.$patch({apps:e.ocs.data})}catch(t){c.A.error(t),d()}finally{this.loading.apps=!1}},getCategoryById(t){return this.categories.find(({id:e})=>e===t)??null},getAppById(t){return this.apps.find(({id:e})=>e===t)??null},updateAppGroups(t,e){const n=this.apps.find(({id:e})=>e===t);n&&(n.groups=[...e])}}})},99789(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".daemon-selection-list[data-v-168bc683]{max-height:350px;overflow-y:scroll;padding:2rem}.daemon-selection-list__empty-content[data-v-168bc683]{margin-top:0;text-align:center}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppAPI/DaemonSelectionList.vue"],names:[],mappings:"AACA,wCACC,gBAAA,CACA,iBAAA,CACA,YAAA,CAEA,uDACC,YAAA,CACA,iBAAA",sourcesContent:["\n.daemon-selection-list {\n\tmax-height: 350px;\n\toverflow-y: scroll;\n\tpadding: 2rem;\n\n\t&__empty-content {\n\t\tmargin-top: 0;\n\t\ttext-align: center;\n\t}\n}\n"],sourceRoot:""}]);const r=s},18393(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".apps-list[data-v-ceb5cf46]{display:flex;flex-wrap:wrap;align-content:flex-start}.apps-list--move[data-v-ceb5cf46]{transition:transform 1s}.apps-list #app-list-update-all[data-v-ceb5cf46]{margin-inline-start:10px}.apps-list__toolbar[data-v-ceb5cf46]{height:60px;padding:8px;padding-inline-start:60px;width:100%;background-color:var(--color-main-background);position:sticky;top:0;z-index:1;display:flex;align-items:center}.apps-list--list-view[data-v-ceb5cf46]{margin-bottom:100px;position:relative}.apps-list__list-container[data-v-ceb5cf46]{width:100%}.apps-list__store-container[data-v-ceb5cf46]{display:flex;flex-wrap:wrap}.apps-list__bundle-heading[data-v-ceb5cf46]{display:flex;align-items:center;margin-block:20px;margin-inline:0 10px}.apps-list__bundle-header[data-v-ceb5cf46]{color:var(--color-main-text);margin-block:0;margin-inline:50px 10px;font-weight:bold;font-size:20px;line-height:30px}#apps-list-search .app-item h2[data-v-ceb5cf46]{margin-bottom:0}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppList.vue"],names:[],mappings:"AAIA,4BACC,YAAA,CACA,cAAA,CACA,wBAAA,CAGA,kCACC,uBAAA,CAGD,iDACC,wBAAA,CAGD,qCACC,WAjBe,CAkBf,WAnBgB,CAqBhB,yBApBe,CAqBf,UAAA,CACA,6CAAA,CACA,eAAA,CACA,KAAA,CACA,SAAA,CACA,YAAA,CACA,kBAAA,CAGD,uCACC,mBAAA,CAEA,iBAAA,CAGD,4CACC,UAAA,CAGD,6CACC,YAAA,CACA,cAAA,CAGD,4CACC,YAAA,CACA,kBAAA,CACA,iBAAA,CACA,oBAAA,CAGD,2CACC,4BAAA,CACA,cAAA,CACA,uBAAA,CACA,gBAAA,CACA,cAAA,CACA,gBAAA,CAMA,gDACC,eAAA",sourcesContent:["\n$toolbar-padding: 8px;\n$toolbar-height: 44px + $toolbar-padding * 2;\n\n.apps-list {\n\tdisplay: flex;\n\tflex-wrap: wrap;\n\talign-content: flex-start;\n\n\t// For transition group\n\t&--move {\n\t\ttransition: transform 1s;\n\t}\n\n\t#app-list-update-all {\n\t\tmargin-inline-start: 10px;\n\t}\n\n\t&__toolbar {\n\t\theight: $toolbar-height;\n\t\tpadding: $toolbar-padding;\n\t\t// Leave room for app-navigation-toggle\n\t\tpadding-inline-start: $toolbar-height;\n\t\twidth: 100%;\n\t\tbackground-color: var(--color-main-background);\n\t\tposition: sticky;\n\t\ttop: 0;\n\t\tz-index: 1;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t}\n\n\t&--list-view {\n\t\tmargin-bottom: 100px;\n\t\t// For positioning link overlay on rows\n\t\tposition: relative;\n\t}\n\n\t&__list-container {\n\t\twidth: 100%;\n\t}\n\n\t&__store-container {\n\t\tdisplay: flex;\n\t\tflex-wrap: wrap;\n\t}\n\n\t&__bundle-heading {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tmargin-block: 20px;\n\t\tmargin-inline: 0 10px;\n\t}\n\n\t&__bundle-header {\n\t\tcolor: var(--color-main-text);\n\t\tmargin-block: 0;\n\t\tmargin-inline: 50px 10px;\n\t\tfont-weight: bold;\n\t\tfont-size: 20px;\n\t\tline-height: 30px;\n\t}\n}\n\n#apps-list-search {\n\t.app-item {\n\t\th2 {\n\t\t\tmargin-bottom: 0;\n\t\t}\n\t}\n}\n"],sourceRoot:""}]);const r=s},3769(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".app-daemon-badge[data-v-5294293a]{color:var(--color-text-maxcontrast);background-color:rgba(0,0,0,0);border:1px solid var(--color-text-maxcontrast);border-radius:var(--border-radius);display:flex;flex-direction:row;gap:6px;padding:3px 6px;width:fit-content}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppList/AppDaemonBadge.vue"],names:[],mappings:"AACA,mCACC,mCAAA,CACA,8BAAA,CACA,8CAAA,CACA,kCAAA,CAEA,YAAA,CACA,kBAAA,CACA,OAAA,CACA,eAAA,CACA,iBAAA",sourcesContent:["\n.app-daemon-badge {\n\tcolor: var(--color-text-maxcontrast);\n\tbackground-color: transparent;\n\tborder: 1px solid var(--color-text-maxcontrast);\n\tborder-radius: var(--border-radius);\n\n\tdisplay: flex;\n\tflex-direction: row;\n\tgap: 6px;\n\tpadding: 3px 6px;\n\twidth: fit-content;\n}\n"],sourceRoot:""}]);const r=s},38998(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,'/*!\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */.app-item[data-v-55e495e8]{position:relative}.app-item[data-v-55e495e8]:hover{background-color:var(--color-background-dark)}.app-item--list-view[data-v-55e495e8]{--app-item-padding: calc(var(--default-grid-baseline) * 2);--app-item-height: calc(var(--default-clickable-area) + var(--app-item-padding) * 2)}.app-item--list-view.app-item--selected[data-v-55e495e8]{background-color:var(--color-background-dark)}.app-item--list-view>*[data-v-55e495e8]{vertical-align:middle;border-bottom:1px solid var(--color-border);padding:var(--app-item-padding);height:var(--app-item-height)}.app-item--list-view .app-image[data-v-55e495e8]{width:var(--default-clickable-area);height:auto;text-align:end}.app-item--list-view .app-image-icon svg[data-v-55e495e8],.app-item--list-view .app-image-icon .icon-settings-dark[data-v-55e495e8]{margin-top:5px;width:20px;height:20px;opacity:.5;background-size:cover;display:inline-block}.app-item--list-view .app-name[data-v-55e495e8]{padding:0 var(--app-item-padding)}.app-item--list-view .app-name--link[data-v-55e495e8]{height:var(--app-item-height);display:flex;align-items:center}.app-item--list-view .app-name--link[data-v-55e495e8]::after{content:"";position:absolute;inset-inline:0;height:var(--app-item-height)}.app-item--list-view .app-actions[data-v-55e495e8]{display:flex;gap:var(--app-item-padding);flex-wrap:wrap;justify-content:end}.app-item--list-view .app-actions .icon-loading-small[data-v-55e495e8]{display:inline-block;top:4px;margin-inline-end:10px}@media only screen and (max-width: 900px){.app-item--list-view .app-version[data-v-55e495e8],.app-item--list-view .app-level[data-v-55e495e8]{display:none}}@media only screen and (max-width: 512px){.app-item--list-view .app-actions[data-v-55e495e8]{display:none}}.app-item--store-view[data-v-55e495e8]{padding:30px}.app-item--store-view .app-image-icon .icon-settings-dark[data-v-55e495e8]{width:100%;height:150px;background-size:45px;opacity:.5}.app-item--store-view .app-image-icon svg[data-v-55e495e8]{position:absolute;bottom:43px;width:64px;height:64px;opacity:.1}.app-item--store-view .app-name[data-v-55e495e8]{margin:5px 0}.app-item--store-view .app-name--link[data-v-55e495e8]::after{content:"";position:absolute;inset-block:0;inset-inline:0}.app-item--store-view .app-actions[data-v-55e495e8]{margin:10px 0}@media only screen and (min-width: 1601px){.app-item--store-view[data-v-55e495e8]{width:25%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:33%}}@media only screen and (max-width: 1600px){.app-item--store-view[data-v-55e495e8]{width:25%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:33%}}@media only screen and (max-width: 1400px){.app-item--store-view[data-v-55e495e8]{width:33%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:50%}}@media only screen and (max-width: 900px){.app-item--store-view[data-v-55e495e8]{width:50%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:100%}}@media only screen and (max-width: 1024px){.app-item--store-view[data-v-55e495e8]{width:50%}}@media only screen and (max-width: 480px){.app-item--store-view[data-v-55e495e8]{width:100%}}.app-icon[data-v-55e495e8]{filter:var(--background-invert-if-bright)}.app-image[data-v-55e495e8]{position:relative;height:150px;opacity:1;overflow:hidden}.app-image img[data-v-55e495e8]{width:100%}.app-version[data-v-55e495e8]{color:var(--color-text-maxcontrast)}',"",{version:3,sources:["webpack://./core/css/variables.scss","webpack://./apps/appstore/src/components/AppList/AppItem.vue"],names:[],mappings:"AAEA;;;EAAA,CCEA,2BACC,iBAAA,CAEA,iCACC,6CAAA,CAGD,sCACC,0DAAA,CACA,oFAAA,CAEA,yDACC,6CAAA,CAGD,wCACC,qBAAA,CACA,2CAAA,CACA,+BAAA,CACA,6BAAA,CAGD,iDACC,mCAAA,CACA,WAAA,CACA,cAAA,CAGD,oIAEC,cAAA,CACA,UAAA,CACA,WAAA,CACA,UAAA,CACA,qBAAA,CACA,oBAAA,CAGD,gDACC,iCAAA,CAGD,sDACC,6BAAA,CACA,YAAA,CACA,kBAAA,CAMD,6DACC,UAAA,CACA,iBAAA,CACA,cAAA,CACA,6BAAA,CAGD,mDACC,YAAA,CACA,2BAAA,CACA,cAAA,CACA,mBAAA,CAEA,uEACC,oBAAA,CACA,OAAA,CACA,sBAAA,CAKF,0CACC,oGAEC,YAAA,CAAA,CAKF,0CACC,mDACC,YAAA,CAAA,CAKH,uCACC,YAAA,CAEA,2EACC,UAAA,CACA,YAAA,CACA,oBAAA,CACA,UAAA,CAGD,2DACC,iBAAA,CACA,WAAA,CAEA,UAAA,CACA,WAAA,CACA,UAAA,CAGD,iDACC,YAAA,CAGD,8DACC,UAAA,CACA,iBAAA,CACA,aAAA,CACA,cAAA,CAGD,oDACC,aAAA,CAGD,2CAlCD,uCAmCE,SAAA,CAEA,8DACC,SAAA,CAAA,CAIF,2CA1CD,uCA2CE,SAAA,CAEA,8DACC,SAAA,CAAA,CAIF,2CAlDD,uCAmDE,SAAA,CAEA,8DACC,SAAA,CAAA,CAIF,0CA1DD,uCA2DE,SAAA,CAEA,8DACC,UAAA,CAAA,CAIF,2CAlED,uCAmEE,SAAA,CAAA,CAGD,0CAtED,uCAuEE,UAAA,CAAA,CAKH,2BACC,yCAAA,CAGD,4BACC,iBAAA,CACA,YAAA,CACA,SAAA,CACA,eAAA,CAEA,gCACC,UAAA,CAIF,8BACC,mCAAA",sourcesContent:['@use \'sass:color\';\n\n/*!\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\n// SCSS darken/lighten function override\n@function nc-darken($color, $value) {\n\t@return color.adjust($color, $lightness: - $value, $space: hsl);\n}\n\n@function nc-lighten($color, $value) {\n\t@return color.adjust($color, $lightness: $value, $space: hsl);\n}\n\n// SCSS variables\n// DEPRECATED, please use CSS4 vars\n$color-main-text: #222 !default; // Not #000 for better readability\n$color-main-background: #fff !default;\n$color-main-background-translucent: rgba($color-main-background, .97) !default;\n\n// used for different active/hover/focus/disabled states\n$color-background-hover: nc-darken($color-main-background, 4%) !default;\n$color-background-dark: nc-darken($color-main-background, 7%) !default;\n$color-background-darker: nc-darken($color-main-background, 14%) !default;\n\n$color-placeholder-light: nc-darken($color-main-background, 10%) !default;\n$color-placeholder-dark: nc-darken($color-main-background, 20%) !default;\n\n$color-primary: #0082c9 !default;\n$color-primary-hover: color.mix($color-primary, $color-main-background, 80%) !default;\n\n$color-primary-light: color.mix($color-primary, $color-main-background, 10%) !default;\n$color-primary-light-text: $color-primary !default;\n$color-primary-light-hover: color.mix($color-primary-light, $color-main-text, 95%) !default;\n\n$color-primary-text: #ffffff !default;\n// do not use nc-darken/lighten in case of overriding because\n// primary-text is independent of color-main-text\n$color-primary-element-text-dark: color.adjust($color-primary-text, $lightness: -7%, $space: hsl) !default;\n$color-primary-element: $color-primary !default;\n$color-primary-element-hover: color.mix($color-primary-element, $color-main-background, 80%) !default;\n$color-primary-element-light: color.adjust($color-primary-element, $lightness: 15%, $space: hsl) !default;\n\n$color-error: #e9322d;\n$color-error-hover: color.mix($color-error, $color-main-background, 80%) !default;\n$color-warning: #eca700;\n$color-warning-hover: color.mix($color-warning, $color-main-background, 80%) !default;\n$color-success: #46ba61;\n$color-success-hover: color.mix($color-success, $color-main-background, 80%) !default;\n// used for svg\n$color-white: #fff;\n$color-black: #000;\n$color-yellow: #FC0;\n\n// rgb(118, 118, 118) / #767676\n// min. color contrast for normal text on white background according to WCAG AA\n// (Works as well: color: #000; opacity: 0.57;)\n$color-text-maxcontrast: nc-lighten($color-main-text, 33%) !default;\n\n$image-logo: url(\'../img/logo/logo.svg?v=1\') !default;\n$image-login-background: url(\'../img/background.png?v=2\') !default;\n$image-logoheader: url(\'../img/logo/logo.svg?v=1\') !default;\n$image-favicon: url(\'../img/logo/logo.svg?v=1\') !default;\n\n$color-loading-light: #ccc !default;\n$color-loading-dark: #444 !default;\n\n$color-box-shadow: color.adjust(nc-darken($color-main-background, 70%), $alpha: -0.5, $space: hsl) !default;\n\n// light border like file table or app-content list\n$color-border: nc-darken($color-main-background, 7%) !default;\n// darker border like inputs or very visible elements\n$color-border-dark: nc-darken($color-main-background, 14%) !default;\n\n$border-radius: 3px !default;\n$border-radius-large: 10px !default;\n// Pill-style button, value is large so big buttons also have correct roundness\n$border-radius-pill: 100px !default;\n\n$font-face: system-ui, -apple-system, "Segoe UI", Roboto, Oxygen-Sans, Cantarell, Ubuntu, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;\n$default-font-size: 15px;\n\n$default-line-height: 24px;\n\n$animation-quick: 100ms;\n$animation-slow: 300ms;\n\n// various structure data\n$header-height: 50px;\n$navigation-width: 300px;\n$sidebar-min-width: 300px;\n$sidebar-max-width: 500px;\n$list-min-width: 200px;\n$list-max-width: 300px;\n$header-menu-item-height: 44px;\n$header-menu-profile-item-height: 66px;\n\n// mobile. Keep in sync with core/js/js.js\n$breakpoint-mobile: 1024px;\n',"\n@use '../../../../../core/css/variables.scss' as variables;\n@use 'sass:math';\n\n.app-item {\n\tposition: relative;\n\n\t&:hover {\n\t\tbackground-color: var(--color-background-dark);\n\t}\n\n\t&--list-view {\n\t\t--app-item-padding: calc(var(--default-grid-baseline) * 2);\n\t\t--app-item-height: calc(var(--default-clickable-area) + var(--app-item-padding) * 2);\n\n\t\t&.app-item--selected {\n\t\t\tbackground-color: var(--color-background-dark);\n\t\t}\n\n\t\t> * {\n\t\t\tvertical-align: middle;\n\t\t\tborder-bottom: 1px solid var(--color-border);\n\t\t\tpadding: var(--app-item-padding);\n\t\t\theight: var(--app-item-height);\n\t\t}\n\n\t\t.app-image {\n\t\t\twidth: var(--default-clickable-area);\n\t\t\theight: auto;\n\t\t\ttext-align: end;\n\t\t}\n\n\t\t.app-image-icon svg,\n\t\t.app-image-icon .icon-settings-dark {\n\t\t\tmargin-top: 5px;\n\t\t\twidth: 20px;\n\t\t\theight: 20px;\n\t\t\topacity: .5;\n\t\t\tbackground-size: cover;\n\t\t\tdisplay: inline-block;\n\t\t}\n\n\t\t.app-name {\n\t\t\tpadding: 0 var(--app-item-padding);\n\t\t}\n\n\t\t.app-name--link {\n\t\t\theight: var(--app-item-height);\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t}\n\n\t\t// Note: because of Safari bug, we cannot position link overlay relative to the table row\n\t\t// So we need to manually position it relative to the table container and cell\n\t\t// See: https://bugs.webkit.org/show_bug.cgi?id=240961\n\t\t.app-name--link::after {\n\t\t\tcontent: '';\n\t\t\tposition: absolute;\n\t\t\tinset-inline: 0;\n\t\t\theight: var(--app-item-height);\n\t\t}\n\n\t\t.app-actions {\n\t\t\tdisplay: flex;\n\t\t\tgap: var(--app-item-padding);\n\t\t\tflex-wrap: wrap;\n\t\t\tjustify-content: end;\n\n\t\t\t.icon-loading-small {\n\t\t\t\tdisplay: inline-block;\n\t\t\t\ttop: 4px;\n\t\t\t\tmargin-inline-end: 10px;\n\t\t\t}\n\t\t}\n\n\t\t/* hide app version and level on narrower screens */\n\t\t@media only screen and (max-width: 900px) {\n\t\t\t.app-version,\n\t\t\t.app-level {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t}\n\n\t\t/* Hide actions on a small screen. Click on app opens fill-screen sidebar with the buttons */\n\t\t@media only screen and (max-width: math.div(variables.$breakpoint-mobile, 2)) {\n\t\t\t.app-actions {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t}\n\t}\n\n\t&--store-view {\n\t\tpadding: 30px;\n\n\t\t.app-image-icon .icon-settings-dark {\n\t\t\twidth: 100%;\n\t\t\theight: 150px;\n\t\t\tbackground-size: 45px;\n\t\t\topacity: 0.5;\n\t\t}\n\n\t\t.app-image-icon svg {\n\t\t\tposition: absolute;\n\t\t\tbottom: 43px;\n\t\t\t/* position halfway vertically */\n\t\t\twidth: 64px;\n\t\t\theight: 64px;\n\t\t\topacity: .1;\n\t\t}\n\n\t\t.app-name {\n\t\t\tmargin: 5px 0;\n\t\t}\n\n\t\t.app-name--link::after {\n\t\t\tcontent: '';\n\t\t\tposition: absolute;\n\t\t\tinset-block: 0;\n\t\t\tinset-inline: 0;\n\t\t}\n\n\t\t.app-actions {\n\t\t\tmargin: 10px 0;\n\t\t}\n\n\t\t@media only screen and (min-width: 1601px) {\n\t\t\twidth: 25%;\n\n\t\t\t&.app-item--with-sidebar {\n\t\t\t\twidth: 33%;\n\t\t\t}\n\t\t}\n\n\t\t@media only screen and (max-width: 1600px) {\n\t\t\twidth: 25%;\n\n\t\t\t&.app-item--with-sidebar {\n\t\t\t\twidth: 33%;\n\t\t\t}\n\t\t}\n\n\t\t@media only screen and (max-width: 1400px) {\n\t\t\twidth: 33%;\n\n\t\t\t&.app-item--with-sidebar {\n\t\t\t\twidth: 50%;\n\t\t\t}\n\t\t}\n\n\t\t@media only screen and (max-width: 900px) {\n\t\t\twidth: 50%;\n\n\t\t\t&.app-item--with-sidebar {\n\t\t\t\twidth: 100%;\n\t\t\t}\n\t\t}\n\n\t\t@media only screen and (max-width: variables.$breakpoint-mobile) {\n\t\t\twidth: 50%;\n\t\t}\n\n\t\t@media only screen and (max-width: 480px) {\n\t\t\twidth: 100%;\n\t\t}\n\t}\n}\n\n.app-icon {\n\tfilter: var(--background-invert-if-bright);\n}\n\n.app-image {\n\tposition: relative;\n\theight: 150px;\n\topacity: 1;\n\toverflow: hidden;\n\n\timg {\n\t\twidth: 100%;\n\t}\n}\n\n.app-version {\n\tcolor: var(--color-text-maxcontrast);\n}\n"],sourceRoot:""}]);const r=s},67314(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".app-level-badge[data-v-96439520]{color:var(--color-text-maxcontrast);background-color:rgba(0,0,0,0);border:1px solid var(--color-text-maxcontrast);border-radius:var(--border-radius);display:flex;flex-direction:row;gap:6px;padding:3px 6px;width:fit-content}.app-level-badge--supported[data-v-96439520]{background-color:var(--color-success);border-color:var(--color-border-success);color:var(--color-success-text)}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppList/AppLevelBadge.vue"],names:[],mappings:"AACA,kCACC,mCAAA,CACA,8BAAA,CACA,8CAAA,CACA,kCAAA,CAEA,YAAA,CACA,kBAAA,CACA,OAAA,CACA,eAAA,CACA,iBAAA,CAEA,6CACC,qCAAA,CACA,wCAAA,CACA,+BAAA",sourcesContent:["\n.app-level-badge {\n\tcolor: var(--color-text-maxcontrast);\n\tbackground-color: transparent;\n\tborder: 1px solid var(--color-text-maxcontrast);\n\tborder-radius: var(--border-radius);\n\n\tdisplay: flex;\n\tflex-direction: row;\n\tgap: 6px;\n\tpadding: 3px 6px;\n\twidth: fit-content;\n\n\t&--supported {\n\t\tbackground-color: var(--color-success);\n\t\tborder-color: var(--color-border-success);\n\t\tcolor: var(--color-success-text);\n\t}\n}\n"],sourceRoot:""}]);const r=s},14158(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,'.office-suite-switcher[data-v-2e094751]{padding:20px;margin-bottom:30px}.office-suite-switcher__aio-message[data-v-2e094751]{background-color:var(--color-background-dark);border:1px solid var(--color-border);border-radius:var(--border-radius-large);padding:20px;text-align:center}.office-suite-switcher p[data-v-2e094751]{margin:8px 0}.office-suite-switcher p[data-v-2e094751]:first-child{font-weight:600}.office-suite-cards[data-v-2e094751]{display:flex;gap:20px;max-width:1200px}.office-suite-card[data-v-2e094751]{flex:1;background-color:var(--color-main-background);border:2px solid var(--color-border);border-radius:var(--border-radius-large);padding:24px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.office-suite-card *[data-v-2e094751]{cursor:pointer}.office-suite-card[data-v-2e094751]:hover{border-color:var(--color-primary-element);box-shadow:0 4px 12px rgba(0,0,0,.1)}.office-suite-card--selected[data-v-2e094751]{background:linear-gradient(135deg, var(--color-primary-element-light) 0%, var(--color-main-background) 100%);color:var(--color-main-text);border-color:var(--color-primary-element)}.office-suite-card__header[data-v-2e094751]{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.office-suite-card__title[data-v-2e094751]{font-size:24px;font-weight:600;margin:0}.office-suite-card--primary .office-suite-card__check[data-v-2e094751]{color:var(--color-primary-element)}.office-suite-card__features[data-v-2e094751]{list-style:none;padding:0;margin:0 0 20px 0;flex-grow:1}.office-suite-card__features li[data-v-2e094751]{padding:4px 0;padding-inline-start:20px;position:relative;line-height:1.5}.office-suite-card__features li[data-v-2e094751]::before{content:"•";position:absolute;inset-inline-start:0;font-weight:bold}.office-suite-card__link[data-v-2e094751]{display:inline-flex;align-items:center;gap:6px;color:var(--color-main-text);text-decoration:none;font-weight:500;margin-top:auto}.office-suite-card__link[data-v-2e094751]:hover{text-decoration:underline}.office-suite-card--selected .office-suite-card__link[data-v-2e094751]{color:var(--color-main-text)}.office-suite-actions[data-v-2e094751]{margin-top:16px}.office-suite-disable-button[data-v-2e094751]{background:rgba(0,0,0,0);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 12px;font-weight:600;color:var(--color-main-text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.office-suite-disable-button[data-v-2e094751]:disabled{opacity:.5;cursor:default}.office-suite-disable-button[data-v-2e094751]:hover:not(:disabled){border-color:var(--color-primary-element);background:var(--color-background-dark)}@media(max-width: 768px){.office-suite-cards[data-v-2e094751]{flex-direction:column}}',"",{version:3,sources:["webpack://./OfficeSuiteSwitcher.vue","webpack://./apps/appstore/src/components/AppList/OfficeSuiteSwitcher.vue"],names:[],mappings:"AAAA,wCCCA,YACC,CAAA,kBACA,CAAA,qDAEA,6CACC,CAAA,oCACA,CAAA,wCACA,CAAA,YACA,CAAA,iBACA,CAAA,0CAGD,YACC,CAAA,sDAEA,eACC,CAAA,qCAKH,YACC,CAAA,QACA,CAAA,gBACA,CAAA,oCAGD,MACC,CAAA,6CACA,CAAA,oCACA,CAAA,wCACA,CAAA,YACA,CAAA,cACA,CAAA,uBACA,CAAA,YACA,CAAA,qBACA,CAAA,sCAEA,cACC,CAAA,0CAGD,yCACC,CAAA,oCACA,CAAA,8CAGD,4GACC,CAAA,4BACA,CAAA,yCACA,CAAA,4CAGD,YACC,CAAA,6BACA,CAAA,kBACA,CAAA,kBACA,CAAA,2CAGD,cACC,CAAA,eACA,CAAA,QACA,CAAA,uEAGD,kCACC,CAAA,8CAGD,eACC,CAAA,SACA,CAAA,iBACA,CAAA,WACA,CAAA,iDAEA,aACC,CAAA,yBACA,CAAA,iBACA,CAAA,eACA,CAAA,yDAEA,WACC,CAAA,iBACA,CAAA,oBACA,CAAA,gBACA,CAAA,0CAKH,mBACC,CAAA,kBACA,CAAA,OACA,CAAA,4BACA,CAAA,oBACA,CAAA,eACA,CAAA,eACA,CAAA,gDAEA,yBACC,CAAA,uEAIF,4BACC,CAAA,uCAIF,eACC,CAAA,8CAGD,wBACC,CAAA,oCACA,CAAA,wCACA,CAAA,gBACA,CAAA,eACA,CAAA,4BACA,CAAA,cACA,CAAA,sDACA,CAAA,uDAGD,UACC,CAAA,cACA,CAAA,mEAGD,yCACC,CAAA,uCACA,CAAA,yBAGD,qCACC,qBACC,CAAA",sourcesContent:['.office-suite-switcher{padding:20px;margin-bottom:30px}.office-suite-switcher__aio-message{background-color:var(--color-background-dark);border:1px solid var(--color-border);border-radius:var(--border-radius-large);padding:20px;text-align:center}.office-suite-switcher p{margin:8px 0}.office-suite-switcher p:first-child{font-weight:600}.office-suite-cards{display:flex;gap:20px;max-width:1200px}.office-suite-card{flex:1;background-color:var(--color-main-background);border:2px solid var(--color-border);border-radius:var(--border-radius-large);padding:24px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.office-suite-card *{cursor:pointer}.office-suite-card:hover{border-color:var(--color-primary-element);box-shadow:0 4px 12px rgba(0,0,0,.1)}.office-suite-card--selected{background:linear-gradient(135deg, var(--color-primary-element-light) 0%, var(--color-main-background) 100%);color:var(--color-main-text);border-color:var(--color-primary-element)}.office-suite-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.office-suite-card__title{font-size:24px;font-weight:600;margin:0}.office-suite-card--primary .office-suite-card__check{color:var(--color-primary-element)}.office-suite-card__features{list-style:none;padding:0;margin:0 0 20px 0;flex-grow:1}.office-suite-card__features li{padding:4px 0;padding-inline-start:20px;position:relative;line-height:1.5}.office-suite-card__features li::before{content:"•";position:absolute;inset-inline-start:0;font-weight:bold}.office-suite-card__link{display:inline-flex;align-items:center;gap:6px;color:var(--color-main-text);text-decoration:none;font-weight:500;margin-top:auto}.office-suite-card__link:hover{text-decoration:underline}.office-suite-card--selected .office-suite-card__link{color:var(--color-main-text)}.office-suite-actions{margin-top:16px}.office-suite-disable-button{background:rgba(0,0,0,0);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 12px;font-weight:600;color:var(--color-main-text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.office-suite-disable-button:disabled{opacity:.5;cursor:default}.office-suite-disable-button:hover:not(:disabled){border-color:var(--color-primary-element);background:var(--color-background-dark)}@media(max-width: 768px){.office-suite-cards{flex-direction:column}}',"\n.office-suite-switcher {\n\tpadding: 20px;\n\tmargin-bottom: 30px;\n\n\t&__aio-message {\n\t\tbackground-color: var(--color-background-dark);\n\t\tborder: 1px solid var(--color-border);\n\t\tborder-radius: var(--border-radius-large);\n\t\tpadding: 20px;\n\t\ttext-align: center;\n\t}\n\n\tp {\n\t\tmargin: 8px 0;\n\n\t\t&:first-child {\n\t\t\tfont-weight: 600;\n\t\t}\n\t}\n}\n\n.office-suite-cards {\n\tdisplay: flex;\n\tgap: 20px;\n\tmax-width: 1200px;\n}\n\n.office-suite-card {\n\tflex: 1;\n\tbackground-color: var(--color-main-background);\n\tborder: 2px solid var(--color-border);\n\tborder-radius: var(--border-radius-large);\n\tpadding: 24px;\n\tcursor: pointer;\n\ttransition: all 0.2s ease;\n\tdisplay: flex;\n\tflex-direction: column;\n\n\t& * {\n\t\tcursor: pointer;\n\t}\n\n\t&:hover {\n\t\tborder-color: var(--color-primary-element);\n\t\tbox-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\n\t}\n\n\t&--selected {\n\t\tbackground: linear-gradient(135deg, var(--color-primary-element-light) 0%, var(--color-main-background) 100%);\n\t\tcolor: var(--color-main-text);\n\t\tborder-color: var(--color-primary-element);\n\t}\n\n\t&__header {\n\t\tdisplay: flex;\n\t\tjustify-content: space-between;\n\t\talign-items: center;\n\t\tmargin-bottom: 16px;\n\t}\n\n\t&__title {\n\t\tfont-size: 24px;\n\t\tfont-weight: 600;\n\t\tmargin: 0;\n\t}\n\n\t.office-suite-card--primary &__check {\n\t\tcolor: var(--color-primary-element);\n\t}\n\n\t&__features {\n\t\tlist-style: none;\n\t\tpadding: 0;\n\t\tmargin: 0 0 20px 0;\n\t\tflex-grow: 1;\n\n\t\tli {\n\t\t\tpadding: 4px 0;\n\t\t\tpadding-inline-start: 20px;\n\t\t\tposition: relative;\n\t\t\tline-height: 1.5;\n\n\t\t\t&::before {\n\t\t\t\tcontent: '•';\n\t\t\t\tposition: absolute;\n\t\t\t\tinset-inline-start: 0;\n\t\t\t\tfont-weight: bold;\n\t\t\t}\n\t\t}\n\t}\n\n\t&__link {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tgap: 6px;\n\t\tcolor: var(--color-main-text);\n\t\ttext-decoration: none;\n\t\tfont-weight: 500;\n\t\tmargin-top: auto;\n\n\t\t&:hover {\n\t\t\ttext-decoration: underline;\n\t\t}\n\t}\n\n\t.office-suite-card--selected &__link {\n\t\tcolor: var(--color-main-text);\n\t}\n}\n\n.office-suite-actions {\n\tmargin-top: 16px;\n}\n\n.office-suite-disable-button {\n\tbackground: transparent;\n\tborder: 1px solid var(--color-border);\n\tborder-radius: var(--border-radius-small);\n\tpadding: 8px 12px;\n\tfont-weight: 600;\n\tcolor: var(--color-main-text);\n\tcursor: pointer;\n\ttransition: background 0.15s ease, border-color 0.15s ease;\n}\n\n.office-suite-disable-button:disabled {\n\topacity: 0.5;\n\tcursor: default;\n}\n\n.office-suite-disable-button:hover:not(:disabled) {\n\tborder-color: var(--color-primary-element);\n\tbackground: var(--color-background-dark);\n}\n\n@media (max-width: 768px) {\n\t.office-suite-cards {\n\t\tflex-direction: column;\n\t}\n}\n"],sourceRoot:""}]);const r=s},94964(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".app-discover[data-v-277e0eae]{max-width:1008px;margin-inline:auto;padding-inline:54px;padding-block-end:var(--default-clickable-area, 44px);display:flex;flex-direction:column;gap:var(--default-clickable-area, 44px)}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppStoreDiscover/AppStoreDiscoverSection.vue"],names:[],mappings:"AACA,+BACC,gBAAA,CACA,kBAAA,CACA,mBAAA,CAEA,qDAAA,CAEA,YAAA,CACA,qBAAA,CACA,uCAAA",sourcesContent:["\n.app-discover {\n\tmax-width: 1008px; /* 900px + 2x 54px padding for the carousel controls */\n\tmargin-inline: auto;\n\tpadding-inline: 54px;\n\t/* Padding required to make last element not bound to the bottom */\n\tpadding-block-end: var(--default-clickable-area, 44px);\n\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: var(--default-clickable-area, 44px);\n}\n"],sourceRoot:""}]);const r=s},31367(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".daemon[data-v-3d6f45e8]{padding:20px}.daemon h4[data-v-3d6f45e8]{font-weight:bold;margin:10px auto}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppStoreSidebar/AppDeployDaemonTab.vue"],names:[],mappings:"AACA,yBACE,YAAA,CAEA,4BACE,gBAAA,CACA,gBAAA",sourcesContent:["\n.daemon {\n padding: 20px;\n\n h4 {\n font-weight: bold;\n margin: 10px auto;\n }\n}\n"],sourceRoot:""}]);const r=s},62577(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".app-description[data-v-373d80a8]{padding:12px}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppStoreSidebar/AppDescriptionTab.vue"],names:[],mappings:"AACA,kCACC,YAAA",sourcesContent:["\n.app-description {\n\tpadding: 12px;\n}\n"],sourceRoot:""}]);const r=s},51718(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,'.app-details[data-v-2d1d27e2]{padding:20px}.app-details__actions-manage[data-v-2d1d27e2]{display:flex;align-items:center}.app-details__actions-manage input[data-v-2d1d27e2]{flex:0 1 auto;min-width:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.app-details__authors[data-v-2d1d27e2]{color:var(--color-text-maxcontrast)}.app-details__section[data-v-2d1d27e2]{margin-top:15px}.app-details__section h4[data-v-2d1d27e2]{font-size:16px;font-weight:bold;margin-block-end:5px}.app-details__interact[data-v-2d1d27e2]{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px}.app-details__documentation a[data-v-2d1d27e2]{text-decoration:underline}.app-details__documentation li[data-v-2d1d27e2]{padding-inline-start:20px}.app-details__documentation li[data-v-2d1d27e2]::before{width:5px;height:5px;border-radius:100%;background-color:var(--color-main-text);content:"";float:inline-start;margin-inline-start:-13px;position:relative;top:10px}.force[data-v-2d1d27e2]{color:var(--color-text-error);border-color:var(--color-border-error);background:var(--color-main-background)}.force[data-v-2d1d27e2]:hover,.force[data-v-2d1d27e2]:active{color:var(--color-main-background);border-color:var(--color-border-error) !important;background:var(--color-error)}.missing-dependencies[data-v-2d1d27e2]{list-style:initial;list-style-type:initial;list-style-position:inside}',"",{version:3,sources:["webpack://./apps/appstore/src/components/AppStoreSidebar/AppDetailsTab.vue"],names:[],mappings:"AACA,8BACC,YAAA,CAIC,8CAEC,YAAA,CACA,kBAAA,CACA,oDACC,aAAA,CACA,WAAA,CACA,sBAAA,CACA,kBAAA,CACA,eAAA,CAIH,uCACC,mCAAA,CAGD,uCACC,eAAA,CAEA,0CACC,cAAA,CACA,gBAAA,CACA,oBAAA,CAIF,wCACC,YAAA,CACA,kBAAA,CACA,cAAA,CACA,QAAA,CAIA,+CACC,yBAAA,CAED,gDACC,yBAAA,CAEA,wDACC,SAAA,CACA,UAAA,CACA,kBAAA,CACA,uCAAA,CACA,UAAA,CACA,kBAAA,CACA,yBAAA,CACA,iBAAA,CACA,QAAA,CAMJ,wBACC,6BAAA,CACA,sCAAA,CACA,uCAAA,CAGD,6DAEC,kCAAA,CACA,iDAAA,CACA,6BAAA,CAGD,uCACC,kBAAA,CACA,uBAAA,CACA,0BAAA",sourcesContent:['\n.app-details {\n\tpadding: 20px;\n\n\t&__actions {\n\t\t// app management\n\t\t&-manage {\n\t\t\t// if too many, shrink them and ellipsis\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t\tinput {\n\t\t\t\tflex: 0 1 auto;\n\t\t\t\tmin-width: 0;\n\t\t\t\ttext-overflow: ellipsis;\n\t\t\t\twhite-space: nowrap;\n\t\t\t\toverflow: hidden;\n\t\t\t}\n\t\t}\n\t}\n\t&__authors {\n\t\tcolor: var(--color-text-maxcontrast);\n\t}\n\n\t&__section {\n\t\tmargin-top: 15px;\n\n\t\th4 {\n\t\t\tfont-size: 16px;\n\t\t\tfont-weight: bold;\n\t\t\tmargin-block-end: 5px;\n\t\t}\n\t}\n\n\t&__interact {\n\t\tdisplay: flex;\n\t\tflex-direction: row;\n\t\tflex-wrap: wrap;\n\t\tgap: 12px;\n\t}\n\n\t&__documentation {\n\t\ta {\n\t\t\ttext-decoration: underline;\n\t\t}\n\t\tli {\n\t\t\tpadding-inline-start: 20px;\n\n\t\t\t&::before {\n\t\t\t\twidth: 5px;\n\t\t\t\theight: 5px;\n\t\t\t\tborder-radius: 100%;\n\t\t\t\tbackground-color: var(--color-main-text);\n\t\t\t\tcontent: "";\n\t\t\t\tfloat: inline-start;\n\t\t\t\tmargin-inline-start: -13px;\n\t\t\t\tposition: relative;\n\t\t\t\ttop: 10px;\n\t\t\t}\n\t\t}\n\t}\n}\n\n.force {\n\tcolor: var(--color-text-error);\n\tborder-color: var(--color-border-error);\n\tbackground: var(--color-main-background);\n}\n\n.force:hover,\n.force:active {\n\tcolor: var(--color-main-background);\n\tborder-color: var(--color-border-error) !important;\n\tbackground: var(--color-error);\n}\n\n.missing-dependencies {\n\tlist-style: initial;\n\tlist-style-type: initial;\n\tlist-style-position: inside;\n}\n'],sourceRoot:""}]);const r=s},78417(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".app-sidebar-tabs__release h2[data-v-2ac4587b]{border-bottom:1px solid var(--color-border);font-size:24px}.app-sidebar-tabs__release-text[data-v-2ac4587b] h3{font-size:20px}.app-sidebar-tabs__release-text[data-v-2ac4587b] h4{font-size:17px}","",{version:3,sources:["webpack://./apps/appstore/src/components/AppStoreSidebar/AppReleasesTab.vue"],names:[],mappings:"AAEC,+CACC,2CAAA,CACA,cAAA,CAKA,oDACC,cAAA,CAED,oDACC,cAAA",sourcesContent:["\n.app-sidebar-tabs__release {\n\th2 {\n\t\tborder-bottom: 1px solid var(--color-border);\n\t\tfont-size: 24px;\n\t}\n\n\t&-text {\n\t\t// Overwrite changelog heading styles\n\t\t:deep(h3) {\n\t\t\tfont-size: 20px;\n\t\t}\n\t\t:deep(h4) {\n\t\t\tfont-size: 17px;\n\t\t}\n\t}\n}\n"],sourceRoot:""}]);const r=s},68160(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,'.settings-markdown[data-v-72fa808e] a{text-decoration:underline}.settings-markdown[data-v-72fa808e] a::after{content:"↗";padding-inline:calc(var(--default-grid-baseline)/2)}.settings-markdown[data-v-72fa808e] pre{white-space:pre;overflow-x:auto;background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:1em 1.3em;margin-bottom:1em}.settings-markdown[data-v-72fa808e] p code{background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:.1em .3em}.settings-markdown[data-v-72fa808e] li{position:relative}.settings-markdown[data-v-72fa808e] ul,.settings-markdown[data-v-72fa808e] ol{padding-inline-start:10px;margin-inline-start:10px}.settings-markdown[data-v-72fa808e] ul li{list-style-type:disc}.settings-markdown[data-v-72fa808e] ul>li>ul>li{list-style-type:circle}.settings-markdown[data-v-72fa808e] ul>li>ul>li ul li{list-style-type:square}.settings-markdown[data-v-72fa808e] blockquote{padding-inline-start:1em;border-inline-start:4px solid var(--color-primary-element);color:var(--color-text-maxcontrast);margin-inline:0}',"",{version:3,sources:["webpack://./Markdown.vue","webpack://./apps/appstore/src/components/Markdown.vue"],names:[],mappings:"AAAA,sCCEC,yBACC,CAAA,6CACA,WACC,CAAA,mDACA,CAAA,wCAIF,eACC,CAAA,eACA,CAAA,6CACA,CAAA,kCACA,CAAA,iBACA,CAAA,iBACA,CAAA,2CAGD,6CACC,CAAA,kCACA,CAAA,iBACA,CAAA,uCAGD,iBACC,CAAA,8EAGD,yBACC,CAAA,wBACA,CAAA,0CAGD,oBACC,CAAA,gDAGD,sBACC,CAAA,sDAGD,sBACC,CAAA,+CAGD,wBACC,CAAA,0DACA,CAAA,mCACA,CAAA,eACA",sourcesContent:['.settings-markdown :deep a{text-decoration:underline}.settings-markdown :deep a::after{content:"↗";padding-inline:calc(var(--default-grid-baseline)/2)}.settings-markdown :deep pre{white-space:pre;overflow-x:auto;background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:1em 1.3em;margin-bottom:1em}.settings-markdown :deep p code{background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:.1em .3em}.settings-markdown :deep li{position:relative}.settings-markdown :deep ul,.settings-markdown :deep ol{padding-inline-start:10px;margin-inline-start:10px}.settings-markdown :deep ul li{list-style-type:disc}.settings-markdown :deep ul>li>ul>li{list-style-type:circle}.settings-markdown :deep ul>li>ul>li ul li{list-style-type:square}.settings-markdown :deep blockquote{padding-inline-start:1em;border-inline-start:4px solid var(--color-primary-element);color:var(--color-text-maxcontrast);margin-inline:0}',"\n.settings-markdown :deep {\n\ta {\n\t\ttext-decoration: underline;\n\t\t&::after {\n\t\t\tcontent: '↗';\n\t\t\tpadding-inline: calc(var(--default-grid-baseline) / 2);\n\t\t}\n\t}\n\n\tpre {\n\t\twhite-space: pre;\n\t\toverflow-x: auto;\n\t\tbackground-color: var(--color-background-dark);\n\t\tborder-radius: var(--border-radius);\n\t\tpadding: 1em 1.3em;\n\t\tmargin-bottom: 1em;\n\t}\n\n\tp code {\n\t\tbackground-color: var(--color-background-dark);\n\t\tborder-radius: var(--border-radius);\n\t\tpadding: .1em .3em;\n\t}\n\n\tli {\n\t\tposition: relative;\n\t}\n\n\tul, ol {\n\t\tpadding-inline-start: 10px;\n\t\tmargin-inline-start: 10px;\n\t}\n\n\tul li {\n\t\tlist-style-type: disc;\n\t}\n\n\tul > li > ul > li {\n\t\tlist-style-type: circle;\n\t}\n\n\tul > li > ul > li ul li {\n\t\tlist-style-type: square;\n\t}\n\n\tblockquote {\n\t\tpadding-inline-start: 1em;\n\t\tborder-inline-start: 4px solid var(--color-primary-element);\n\t\tcolor: var(--color-text-maxcontrast);\n\t\tmargin-inline: 0;\n\t}\n}\n"],sourceRoot:""}]);const r=s},91203(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,".app-sidebar--with-screenshot[data-v-3473b0d0] .app-sidebar-header__figure{background-size:cover}.app-sidebar__fallback-icon[data-v-3473b0d0]{width:100%;height:100%}.app-sidebar__badges[data-v-3473b0d0]{display:flex;flex-direction:row;gap:12px}.app-sidebar__version[data-v-3473b0d0]{color:var(--color-text-maxcontrast)}","",{version:3,sources:["webpack://./apps/appstore/src/views/AppStoreSidebar.vue"],names:[],mappings:"AAIE,2EACC,qBAAA,CAIF,6CAEC,UAAA,CACA,WAAA,CAGD,sCACC,YAAA,CACA,kBAAA,CACA,QAAA,CAGD,uCACC,mCAAA",sourcesContent:["\n.app-sidebar {\n\t// If a screenshot is available it should cover the whole figure\n\t&--with-screenshot {\n\t\t:deep(.app-sidebar-header__figure) {\n\t\t\tbackground-size: cover;\n\t\t}\n\t}\n\n\t&__fallback-icon {\n\t\t// both 100% to center the icon\n\t\twidth: 100%;\n\t\theight: 100%;\n\t}\n\n\t&__badges {\n\t\tdisplay: flex;\n\t\tflex-direction: row;\n\t\tgap: 12px;\n\t}\n\n\t&__version {\n\t\tcolor: var(--color-text-maxcontrast);\n\t}\n}\n"],sourceRoot:""}]);const r=s},93456(t,e,n){n.d(e,{A:()=>r});var a=n(71354),i=n.n(a),o=n(76314),s=n.n(o)()(i());s.push([t.id,"\n.app-score__wrapper[data-v-ab7c7026] {\n\tdisplay: inline-flex;\n\tcolor: var(--color-favorite, #a08b00);\n> *[data-v-ab7c7026] {\n\t\tvertical-align: text-bottom;\n}\n}\n","",{version:3,sources:["webpack://./apps/appstore/src/components/AppList/AppScore.vue"],names:[],mappings:";AA0EA;CACA,oBAAA;CACA,qCAAA;AAEA;EACA,2BAAA;AACA;AACA",sourcesContent:['\x3c!--\n - SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n - SPDX-License-Identifier: AGPL-3.0-or-later\n--\x3e\n\n\n\t\n\t\t 0 || (configuredDeployOptions !== null && configuredDeployOptions.environment_variables.length > 0)\\\">\\n\\t\\t\\t\\t{{ t('settings', 'Environment variables') }}\\n\\t\\t\\t
\\n\\t\\t\\t\\n\\t\\t\\t\\t{{ t('settings', 'Mounts') }}
\\n\\t\\t\\t\\n\\t\\t\\t\\t\\n\\t\\t\\t\\t\\t\\t{{ t('settings', 'New mount') }}\\n\\t\\t\\t\\t\\t
\\n\\t\\t\\t\\t\\t 0\"\n\t\t\t:aria-label=\"t('settings', 'Registered Deploy daemons list')\">\n\t\t\t
\n\t\t\n\t\t
\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Icon') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Name') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Version') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Level') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Actions') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\n\t\t\t\t\t \n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Icon') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Name') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Version') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Level') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Actions') }}\n\t\t\t\t\t \n\t\t\t\t\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t
\n\t\t 0\" class=\"apps-list__list-container\">\n\t\t\t\t\t
\n\t\t\t\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Icon') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Name') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Version') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Level') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Actions') }}\n\t\t\t\t\t\t \n\t\t\t\t\t{{ t('appstore', 'No apps found for your version') }}
\n\t\t 0 || (configuredDeployOptions !== null && configuredDeployOptions.environment_variables.length > 0)\">\n\t\t\t\t{{ t('settings', 'Environment variables') }}\n\t\t\t
\n\t\t\t\n\t\t\t\t{{ t('settings', 'Mounts') }}
\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t\t{{ t('settings', 'New mount') }}\n\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t
\n\n\t\t\t\n\t\t\t\t\t\t
\n\t\t\t\t\n\t\t\t\t\t{{ t('appstore', 'Latest updated') }}\n\t\t\t\t
\n\t\t\t\t\n\t\t\t\t\t{{ t('appstore', 'Author') }}\n\t\t\t\t
\n\t\t\t\t\n\t\t\t\t\t{{ t('appstore', 'Categories') }}\n\t\t\t\t
\n\t\t\t\t{{ t('appstore', 'Resources') }}
\n\t\t\t\t\n\t\t\t\t\t
\n\t\t\t{{ t('appstore', 'Interact') }}
\n\t\t\t\t
' + error.error.response.data.data.message, { isHTML: true });\n logger.error(error);\n },\n setLoading(id, value) {\n Vue.set(this.loading, id, value);\n },\n setError(appId, error) {\n const appIds = Array.isArray(appId) ? appId : [appId];\n appIds.forEach((_id) => {\n const app = this.apps.find((app) => app.id === _id);\n if (app) {\n app.error = error;\n }\n });\n },\n enableApp(appId, daemon, deployOptions) {\n this.setLoading(appId, true);\n this.setLoading('install', true);\n return confirmPassword().then(() => {\n return axios.post(generateUrl(`/apps/app_api/apps/enable/${appId}/${daemon.name}`), { deployOptions })\n .then((response) => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n const app = this.apps.find((app) => app.id === appId);\n if (app) {\n if (!app.installed) {\n app.installed = true;\n app.needsDownload = false;\n app.daemon = daemon;\n app.status = {\n type: 'install',\n action: 'deploy',\n init: 0,\n deploy: 0,\n };\n }\n app.active = true;\n app.canUnInstall = false;\n app.removable = true;\n app.error = '';\n }\n this.updateAppsStatus();\n return axios.get(generateUrl('apps/files'))\n .then(() => {\n if (response.data.update_required) {\n showInfo(t('appstore', 'The app has been enabled but needs to be updated.'), {\n onClick: () => window.location.reload(),\n close: false,\n });\n setTimeout(() => {\n location.reload();\n }, 5000);\n }\n })\n .catch(() => {\n this.setError(appId, t('appstore', 'Error: This app cannot be enabled because it makes the server unstable'));\n });\n })\n .catch((error) => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n this.setError(appId, error.response.data.data.message);\n this.appsApiFailure({ appId, error });\n });\n }).catch(() => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n });\n },\n forceEnableApp(appId) {\n this.setLoading(appId, true);\n this.setLoading('install', true);\n return confirmPassword().then(() => {\n return api.post(generateUrl('/apps/app_api/apps/force'), { appId })\n .then(() => {\n location.reload();\n })\n .catch((error) => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n this.setError(appId, error.response.data.data.message);\n this.appsApiFailure({ appId, error });\n });\n }).catch(() => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n });\n },\n disableApp(appId) {\n this.setLoading(appId, true);\n return confirmPassword().then(() => {\n return api.get(generateUrl(`apps/app_api/apps/disable/${appId}`))\n .then(() => {\n this.setLoading(appId, false);\n const app = this.apps.find((app) => app.id === appId);\n if (app) {\n app.active = false;\n if (app.removable) {\n app.canUnInstall = true;\n }\n }\n return true;\n })\n .catch((error) => {\n this.setLoading(appId, false);\n this.appsApiFailure({ appId, error });\n });\n }).catch(() => {\n this.setLoading(appId, false);\n });\n },\n uninstallApp(appId, removeData) {\n this.setLoading(appId, true);\n return confirmPassword().then(() => {\n return api.get(generateUrl(`/apps/app_api/apps/uninstall/${appId}?removeData=${removeData}`))\n .then(() => {\n this.setLoading(appId, false);\n const app = this.apps.find((app) => app.id === appId);\n if (app) {\n app.active = false;\n app.needsDownload = true;\n app.installed = false;\n app.canUnInstall = false;\n app.canInstall = true;\n app.daemon = null;\n app.status = {};\n if (app.update !== null) {\n this.updateCount--;\n }\n app.update = undefined;\n }\n return true;\n })\n .catch((error) => {\n this.setLoading(appId, false);\n this.appsApiFailure({ appId, error });\n });\n });\n },\n updateApp(appId) {\n this.setLoading(appId, true);\n this.setLoading('install', true);\n return confirmPassword().then(() => {\n return api.get(generateUrl(`/apps/app_api/apps/update/${appId}`))\n .then(() => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n const app = this.apps.find((app) => app.id === appId);\n if (app) {\n const version = app.update;\n app.update = undefined;\n app.version = version || app.version;\n app.status = {\n type: 'update',\n action: 'deploy',\n init: 0,\n deploy: 0,\n };\n app.error = '';\n }\n this.updateCount--;\n this.updateAppsStatus();\n return true;\n })\n .catch((error) => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n this.appsApiFailure({ appId, error });\n });\n }).catch(() => {\n this.setLoading(appId, false);\n this.setLoading('install', false);\n });\n },\n async fetchAllApps() {\n this.loadingList = true;\n try {\n const response = await api.get(generateUrl('/apps/app_api/apps/list'));\n this.apps = response.data.apps;\n this.loadingList = false;\n return true;\n }\n catch (error) {\n logger.error(error);\n showError(t('appstore', 'An error occurred during the request. Unable to proceed.'));\n this.loadingList = false;\n }\n },\n async fetchAppStatus(appId) {\n return api.get(generateUrl(`/apps/app_api/apps/status/${appId}`))\n .then((response) => {\n const app = this.apps.find((app) => app.id === appId);\n if (app) {\n app.status = response.data;\n }\n const initializingOrDeployingApps = this.getInitializingOrDeployingApps;\n logger.debug('initializingOrDeployingApps after setAppStatus', { initializingOrDeployingApps });\n if (initializingOrDeployingApps.length === 0) {\n logger.debug('clearing interval');\n clearInterval(this.statusUpdater);\n this.statusUpdater = null;\n }\n if (Object.hasOwn(response.data, 'error')\n && response.data.error !== ''\n && initializingOrDeployingApps.length === 1) {\n clearInterval(this.statusUpdater);\n this.statusUpdater = null;\n }\n })\n .catch((error) => {\n this.appsApiFailure({ appId, error });\n this.apps = this.apps.filter((app) => app.id !== appId);\n this.updateAppsStatus();\n });\n },\n async fetchDockerDaemons() {\n try {\n const { data } = await axios.get(generateUrl('/apps/app_api/daemons'));\n this.defaultDaemon = data.daemons.find((daemon) => daemon.name === data.default_daemon_config);\n this.dockerDaemons = data.daemons.filter((daemon) => daemon.accepts_deploy_id === 'docker-install');\n }\n catch (error) {\n logger.error('[app-api-store] Failed to fetch Docker daemons', { error });\n return false;\n }\n return true;\n },\n updateAppsStatus() {\n clearInterval(this.statusUpdater);\n const initializingOrDeployingApps = this.getInitializingOrDeployingApps;\n if (initializingOrDeployingApps.length === 0) {\n return;\n }\n this.statusUpdater = setInterval(() => {\n const initializingOrDeployingApps = this.getInitializingOrDeployingApps;\n logger.debug('initializingOrDeployingApps', { initializingOrDeployingApps });\n initializingOrDeployingApps.forEach((app) => {\n this.fetchAppStatus(app.id);\n });\n }, 2000);\n },\n },\n});\n","/**\n * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nimport axios from '@nextcloud/axios';\nimport { showError } from '@nextcloud/dialogs';\nimport { loadState } from '@nextcloud/initial-state';\nimport { translate as t } from '@nextcloud/l10n';\nimport { generateOcsUrl } from '@nextcloud/router';\nimport { defineStore } from 'pinia';\nimport APPSTORE_CATEGORY_ICONS from '../constants/AppstoreCategoryIcons.ts';\nimport logger from '../utils/logger.ts';\nconst showApiError = () => showError(t('appstore', 'An error occurred during the request. Unable to proceed.'));\nexport const useAppsStore = defineStore('appstore-apps', {\n state: () => ({\n apps: [],\n categories: [],\n updateCount: loadState('appstore', 'appstoreUpdateCount', 0),\n loading: {\n apps: false,\n categories: false,\n },\n loadingList: false,\n gettingCategoriesPromise: null,\n }),\n actions: {\n async loadCategories(force = false) {\n if (this.categories.length > 0 && !force) {\n return;\n }\n try {\n this.loading.categories = true;\n const url = generateOcsUrl('apps/appstore/api/v1/apps/categories');\n const { data } = await axios.get(url);\n const categories = data.ocs.data;\n for (const category of categories) {\n category.icon = APPSTORE_CATEGORY_ICONS[category.id] ?? '';\n }\n this.$patch({\n categories,\n });\n }\n catch (error) {\n logger.error(error);\n showApiError();\n }\n finally {\n this.loading.categories = false;\n }\n },\n async loadApps(force = false) {\n if (this.apps.length > 0 && !force) {\n return;\n }\n try {\n this.loading.apps = true;\n const url = generateOcsUrl('apps/appstore/api/v1/apps');\n const { data } = await axios.get(url);\n this.$patch({\n apps: data.ocs.data,\n });\n }\n catch (error) {\n logger.error(error);\n showApiError();\n }\n finally {\n this.loading.apps = false;\n }\n },\n getCategoryById(categoryId) {\n return this.categories.find(({ id }) => id === categoryId) ?? null;\n },\n getAppById(appId) {\n return this.apps.find(({ id }) => id === appId) ?? null;\n },\n updateAppGroups(appId, groups) {\n const app = this.apps.find(({ id }) => id === appId);\n if (app) {\n app.groups = [...groups];\n }\n },\n },\n});\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.daemon-selection-list[data-v-168bc683]{max-height:350px;overflow-y:scroll;padding:2rem}.daemon-selection-list__empty-content[data-v-168bc683]{margin-top:0;text-align:center}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppAPI/DaemonSelectionList.vue\"],\"names\":[],\"mappings\":\"AACA,wCACC,gBAAA,CACA,iBAAA,CACA,YAAA,CAEA,uDACC,YAAA,CACA,iBAAA\",\"sourcesContent\":[\"\\n.daemon-selection-list {\\n\\tmax-height: 350px;\\n\\toverflow-y: scroll;\\n\\tpadding: 2rem;\\n\\n\\t&__empty-content {\\n\\t\\tmargin-top: 0;\\n\\t\\ttext-align: center;\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.apps-list[data-v-ceb5cf46]{display:flex;flex-wrap:wrap;align-content:flex-start}.apps-list--move[data-v-ceb5cf46]{transition:transform 1s}.apps-list #app-list-update-all[data-v-ceb5cf46]{margin-inline-start:10px}.apps-list__toolbar[data-v-ceb5cf46]{height:60px;padding:8px;padding-inline-start:60px;width:100%;background-color:var(--color-main-background);position:sticky;top:0;z-index:1;display:flex;align-items:center}.apps-list--list-view[data-v-ceb5cf46]{margin-bottom:100px;position:relative}.apps-list__list-container[data-v-ceb5cf46]{width:100%}.apps-list__store-container[data-v-ceb5cf46]{display:flex;flex-wrap:wrap}.apps-list__bundle-heading[data-v-ceb5cf46]{display:flex;align-items:center;margin-block:20px;margin-inline:0 10px}.apps-list__bundle-header[data-v-ceb5cf46]{color:var(--color-main-text);margin-block:0;margin-inline:50px 10px;font-weight:bold;font-size:20px;line-height:30px}#apps-list-search .app-item h2[data-v-ceb5cf46]{margin-bottom:0}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppList.vue\"],\"names\":[],\"mappings\":\"AAIA,4BACC,YAAA,CACA,cAAA,CACA,wBAAA,CAGA,kCACC,uBAAA,CAGD,iDACC,wBAAA,CAGD,qCACC,WAjBe,CAkBf,WAnBgB,CAqBhB,yBApBe,CAqBf,UAAA,CACA,6CAAA,CACA,eAAA,CACA,KAAA,CACA,SAAA,CACA,YAAA,CACA,kBAAA,CAGD,uCACC,mBAAA,CAEA,iBAAA,CAGD,4CACC,UAAA,CAGD,6CACC,YAAA,CACA,cAAA,CAGD,4CACC,YAAA,CACA,kBAAA,CACA,iBAAA,CACA,oBAAA,CAGD,2CACC,4BAAA,CACA,cAAA,CACA,uBAAA,CACA,gBAAA,CACA,cAAA,CACA,gBAAA,CAMA,gDACC,eAAA\",\"sourcesContent\":[\"\\n$toolbar-padding: 8px;\\n$toolbar-height: 44px + $toolbar-padding * 2;\\n\\n.apps-list {\\n\\tdisplay: flex;\\n\\tflex-wrap: wrap;\\n\\talign-content: flex-start;\\n\\n\\t// For transition group\\n\\t&--move {\\n\\t\\ttransition: transform 1s;\\n\\t}\\n\\n\\t#app-list-update-all {\\n\\t\\tmargin-inline-start: 10px;\\n\\t}\\n\\n\\t&__toolbar {\\n\\t\\theight: $toolbar-height;\\n\\t\\tpadding: $toolbar-padding;\\n\\t\\t// Leave room for app-navigation-toggle\\n\\t\\tpadding-inline-start: $toolbar-height;\\n\\t\\twidth: 100%;\\n\\t\\tbackground-color: var(--color-main-background);\\n\\t\\tposition: sticky;\\n\\t\\ttop: 0;\\n\\t\\tz-index: 1;\\n\\t\\tdisplay: flex;\\n\\t\\talign-items: center;\\n\\t}\\n\\n\\t&--list-view {\\n\\t\\tmargin-bottom: 100px;\\n\\t\\t// For positioning link overlay on rows\\n\\t\\tposition: relative;\\n\\t}\\n\\n\\t&__list-container {\\n\\t\\twidth: 100%;\\n\\t}\\n\\n\\t&__store-container {\\n\\t\\tdisplay: flex;\\n\\t\\tflex-wrap: wrap;\\n\\t}\\n\\n\\t&__bundle-heading {\\n\\t\\tdisplay: flex;\\n\\t\\talign-items: center;\\n\\t\\tmargin-block: 20px;\\n\\t\\tmargin-inline: 0 10px;\\n\\t}\\n\\n\\t&__bundle-header {\\n\\t\\tcolor: var(--color-main-text);\\n\\t\\tmargin-block: 0;\\n\\t\\tmargin-inline: 50px 10px;\\n\\t\\tfont-weight: bold;\\n\\t\\tfont-size: 20px;\\n\\t\\tline-height: 30px;\\n\\t}\\n}\\n\\n#apps-list-search {\\n\\t.app-item {\\n\\t\\th2 {\\n\\t\\t\\tmargin-bottom: 0;\\n\\t\\t}\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-daemon-badge[data-v-5294293a]{color:var(--color-text-maxcontrast);background-color:rgba(0,0,0,0);border:1px solid var(--color-text-maxcontrast);border-radius:var(--border-radius);display:flex;flex-direction:row;gap:6px;padding:3px 6px;width:fit-content}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppList/AppDaemonBadge.vue\"],\"names\":[],\"mappings\":\"AACA,mCACC,mCAAA,CACA,8BAAA,CACA,8CAAA,CACA,kCAAA,CAEA,YAAA,CACA,kBAAA,CACA,OAAA,CACA,eAAA,CACA,iBAAA\",\"sourcesContent\":[\"\\n.app-daemon-badge {\\n\\tcolor: var(--color-text-maxcontrast);\\n\\tbackground-color: transparent;\\n\\tborder: 1px solid var(--color-text-maxcontrast);\\n\\tborder-radius: var(--border-radius);\\n\\n\\tdisplay: flex;\\n\\tflex-direction: row;\\n\\tgap: 6px;\\n\\tpadding: 3px 6px;\\n\\twidth: fit-content;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `/*!\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */.app-item[data-v-55e495e8]{position:relative}.app-item[data-v-55e495e8]:hover{background-color:var(--color-background-dark)}.app-item--list-view[data-v-55e495e8]{--app-item-padding: calc(var(--default-grid-baseline) * 2);--app-item-height: calc(var(--default-clickable-area) + var(--app-item-padding) * 2)}.app-item--list-view.app-item--selected[data-v-55e495e8]{background-color:var(--color-background-dark)}.app-item--list-view>*[data-v-55e495e8]{vertical-align:middle;border-bottom:1px solid var(--color-border);padding:var(--app-item-padding);height:var(--app-item-height)}.app-item--list-view .app-image[data-v-55e495e8]{width:var(--default-clickable-area);height:auto;text-align:end}.app-item--list-view .app-image-icon svg[data-v-55e495e8],.app-item--list-view .app-image-icon .icon-settings-dark[data-v-55e495e8]{margin-top:5px;width:20px;height:20px;opacity:.5;background-size:cover;display:inline-block}.app-item--list-view .app-name[data-v-55e495e8]{padding:0 var(--app-item-padding)}.app-item--list-view .app-name--link[data-v-55e495e8]{height:var(--app-item-height);display:flex;align-items:center}.app-item--list-view .app-name--link[data-v-55e495e8]::after{content:\"\";position:absolute;inset-inline:0;height:var(--app-item-height)}.app-item--list-view .app-actions[data-v-55e495e8]{display:flex;gap:var(--app-item-padding);flex-wrap:wrap;justify-content:end}.app-item--list-view .app-actions .icon-loading-small[data-v-55e495e8]{display:inline-block;top:4px;margin-inline-end:10px}@media only screen and (max-width: 900px){.app-item--list-view .app-version[data-v-55e495e8],.app-item--list-view .app-level[data-v-55e495e8]{display:none}}@media only screen and (max-width: 512px){.app-item--list-view .app-actions[data-v-55e495e8]{display:none}}.app-item--store-view[data-v-55e495e8]{padding:30px}.app-item--store-view .app-image-icon .icon-settings-dark[data-v-55e495e8]{width:100%;height:150px;background-size:45px;opacity:.5}.app-item--store-view .app-image-icon svg[data-v-55e495e8]{position:absolute;bottom:43px;width:64px;height:64px;opacity:.1}.app-item--store-view .app-name[data-v-55e495e8]{margin:5px 0}.app-item--store-view .app-name--link[data-v-55e495e8]::after{content:\"\";position:absolute;inset-block:0;inset-inline:0}.app-item--store-view .app-actions[data-v-55e495e8]{margin:10px 0}@media only screen and (min-width: 1601px){.app-item--store-view[data-v-55e495e8]{width:25%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:33%}}@media only screen and (max-width: 1600px){.app-item--store-view[data-v-55e495e8]{width:25%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:33%}}@media only screen and (max-width: 1400px){.app-item--store-view[data-v-55e495e8]{width:33%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:50%}}@media only screen and (max-width: 900px){.app-item--store-view[data-v-55e495e8]{width:50%}.app-item--store-view.app-item--with-sidebar[data-v-55e495e8]{width:100%}}@media only screen and (max-width: 1024px){.app-item--store-view[data-v-55e495e8]{width:50%}}@media only screen and (max-width: 480px){.app-item--store-view[data-v-55e495e8]{width:100%}}.app-icon[data-v-55e495e8]{filter:var(--background-invert-if-bright)}.app-image[data-v-55e495e8]{position:relative;height:150px;opacity:1;overflow:hidden}.app-image img[data-v-55e495e8]{width:100%}.app-version[data-v-55e495e8]{color:var(--color-text-maxcontrast)}`, \"\",{\"version\":3,\"sources\":[\"webpack://./core/css/variables.scss\",\"webpack://./apps/appstore/src/components/AppList/AppItem.vue\"],\"names\":[],\"mappings\":\"AAEA;;;EAAA,CCEA,2BACC,iBAAA,CAEA,iCACC,6CAAA,CAGD,sCACC,0DAAA,CACA,oFAAA,CAEA,yDACC,6CAAA,CAGD,wCACC,qBAAA,CACA,2CAAA,CACA,+BAAA,CACA,6BAAA,CAGD,iDACC,mCAAA,CACA,WAAA,CACA,cAAA,CAGD,oIAEC,cAAA,CACA,UAAA,CACA,WAAA,CACA,UAAA,CACA,qBAAA,CACA,oBAAA,CAGD,gDACC,iCAAA,CAGD,sDACC,6BAAA,CACA,YAAA,CACA,kBAAA,CAMD,6DACC,UAAA,CACA,iBAAA,CACA,cAAA,CACA,6BAAA,CAGD,mDACC,YAAA,CACA,2BAAA,CACA,cAAA,CACA,mBAAA,CAEA,uEACC,oBAAA,CACA,OAAA,CACA,sBAAA,CAKF,0CACC,oGAEC,YAAA,CAAA,CAKF,0CACC,mDACC,YAAA,CAAA,CAKH,uCACC,YAAA,CAEA,2EACC,UAAA,CACA,YAAA,CACA,oBAAA,CACA,UAAA,CAGD,2DACC,iBAAA,CACA,WAAA,CAEA,UAAA,CACA,WAAA,CACA,UAAA,CAGD,iDACC,YAAA,CAGD,8DACC,UAAA,CACA,iBAAA,CACA,aAAA,CACA,cAAA,CAGD,oDACC,aAAA,CAGD,2CAlCD,uCAmCE,SAAA,CAEA,8DACC,SAAA,CAAA,CAIF,2CA1CD,uCA2CE,SAAA,CAEA,8DACC,SAAA,CAAA,CAIF,2CAlDD,uCAmDE,SAAA,CAEA,8DACC,SAAA,CAAA,CAIF,0CA1DD,uCA2DE,SAAA,CAEA,8DACC,UAAA,CAAA,CAIF,2CAlED,uCAmEE,SAAA,CAAA,CAGD,0CAtED,uCAuEE,UAAA,CAAA,CAKH,2BACC,yCAAA,CAGD,4BACC,iBAAA,CACA,YAAA,CACA,SAAA,CACA,eAAA,CAEA,gCACC,UAAA,CAIF,8BACC,mCAAA\",\"sourcesContent\":[\"@use 'sass:color';\\n\\n/*!\\n * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors\\n * SPDX-License-Identifier: AGPL-3.0-or-later\\n */\\n// SCSS darken/lighten function override\\n@function nc-darken($color, $value) {\\n\\t@return color.adjust($color, $lightness: - $value, $space: hsl);\\n}\\n\\n@function nc-lighten($color, $value) {\\n\\t@return color.adjust($color, $lightness: $value, $space: hsl);\\n}\\n\\n// SCSS variables\\n// DEPRECATED, please use CSS4 vars\\n$color-main-text: #222 !default; // Not #000 for better readability\\n$color-main-background: #fff !default;\\n$color-main-background-translucent: rgba($color-main-background, .97) !default;\\n\\n// used for different active/hover/focus/disabled states\\n$color-background-hover: nc-darken($color-main-background, 4%) !default;\\n$color-background-dark: nc-darken($color-main-background, 7%) !default;\\n$color-background-darker: nc-darken($color-main-background, 14%) !default;\\n\\n$color-placeholder-light: nc-darken($color-main-background, 10%) !default;\\n$color-placeholder-dark: nc-darken($color-main-background, 20%) !default;\\n\\n$color-primary: #0082c9 !default;\\n$color-primary-hover: color.mix($color-primary, $color-main-background, 80%) !default;\\n\\n$color-primary-light: color.mix($color-primary, $color-main-background, 10%) !default;\\n$color-primary-light-text: $color-primary !default;\\n$color-primary-light-hover: color.mix($color-primary-light, $color-main-text, 95%) !default;\\n\\n$color-primary-text: #ffffff !default;\\n// do not use nc-darken/lighten in case of overriding because\\n// primary-text is independent of color-main-text\\n$color-primary-element-text-dark: color.adjust($color-primary-text, $lightness: -7%, $space: hsl) !default;\\n$color-primary-element: $color-primary !default;\\n$color-primary-element-hover: color.mix($color-primary-element, $color-main-background, 80%) !default;\\n$color-primary-element-light: color.adjust($color-primary-element, $lightness: 15%, $space: hsl) !default;\\n\\n$color-error: #e9322d;\\n$color-error-hover: color.mix($color-error, $color-main-background, 80%) !default;\\n$color-warning: #eca700;\\n$color-warning-hover: color.mix($color-warning, $color-main-background, 80%) !default;\\n$color-success: #46ba61;\\n$color-success-hover: color.mix($color-success, $color-main-background, 80%) !default;\\n// used for svg\\n$color-white: #fff;\\n$color-black: #000;\\n$color-yellow: #FC0;\\n\\n// rgb(118, 118, 118) / #767676\\n// min. color contrast for normal text on white background according to WCAG AA\\n// (Works as well: color: #000; opacity: 0.57;)\\n$color-text-maxcontrast: nc-lighten($color-main-text, 33%) !default;\\n\\n$image-logo: url('../img/logo/logo.svg?v=1') !default;\\n$image-login-background: url('../img/background.png?v=2') !default;\\n$image-logoheader: url('../img/logo/logo.svg?v=1') !default;\\n$image-favicon: url('../img/logo/logo.svg?v=1') !default;\\n\\n$color-loading-light: #ccc !default;\\n$color-loading-dark: #444 !default;\\n\\n$color-box-shadow: color.adjust(nc-darken($color-main-background, 70%), $alpha: -0.5, $space: hsl) !default;\\n\\n// light border like file table or app-content list\\n$color-border: nc-darken($color-main-background, 7%) !default;\\n// darker border like inputs or very visible elements\\n$color-border-dark: nc-darken($color-main-background, 14%) !default;\\n\\n$border-radius: 3px !default;\\n$border-radius-large: 10px !default;\\n// Pill-style button, value is large so big buttons also have correct roundness\\n$border-radius-pill: 100px !default;\\n\\n$font-face: system-ui, -apple-system, \\\"Segoe UI\\\", Roboto, Oxygen-Sans, Cantarell, Ubuntu, \\\"Helvetica Neue\\\", \\\"Noto Sans\\\", \\\"Liberation Sans\\\", Arial, sans-serif, \\\"Apple Color Emoji\\\", \\\"Segoe UI Emoji\\\", \\\"Segoe UI Symbol\\\", \\\"Noto Color Emoji\\\" !default;\\n$default-font-size: 15px;\\n\\n$default-line-height: 24px;\\n\\n$animation-quick: 100ms;\\n$animation-slow: 300ms;\\n\\n// various structure data\\n$header-height: 50px;\\n$navigation-width: 300px;\\n$sidebar-min-width: 300px;\\n$sidebar-max-width: 500px;\\n$list-min-width: 200px;\\n$list-max-width: 300px;\\n$header-menu-item-height: 44px;\\n$header-menu-profile-item-height: 66px;\\n\\n// mobile. Keep in sync with core/js/js.js\\n$breakpoint-mobile: 1024px;\\n\",\"\\n@use '../../../../../core/css/variables.scss' as variables;\\n@use 'sass:math';\\n\\n.app-item {\\n\\tposition: relative;\\n\\n\\t&:hover {\\n\\t\\tbackground-color: var(--color-background-dark);\\n\\t}\\n\\n\\t&--list-view {\\n\\t\\t--app-item-padding: calc(var(--default-grid-baseline) * 2);\\n\\t\\t--app-item-height: calc(var(--default-clickable-area) + var(--app-item-padding) * 2);\\n\\n\\t\\t&.app-item--selected {\\n\\t\\t\\tbackground-color: var(--color-background-dark);\\n\\t\\t}\\n\\n\\t\\t> * {\\n\\t\\t\\tvertical-align: middle;\\n\\t\\t\\tborder-bottom: 1px solid var(--color-border);\\n\\t\\t\\tpadding: var(--app-item-padding);\\n\\t\\t\\theight: var(--app-item-height);\\n\\t\\t}\\n\\n\\t\\t.app-image {\\n\\t\\t\\twidth: var(--default-clickable-area);\\n\\t\\t\\theight: auto;\\n\\t\\t\\ttext-align: end;\\n\\t\\t}\\n\\n\\t\\t.app-image-icon svg,\\n\\t\\t.app-image-icon .icon-settings-dark {\\n\\t\\t\\tmargin-top: 5px;\\n\\t\\t\\twidth: 20px;\\n\\t\\t\\theight: 20px;\\n\\t\\t\\topacity: .5;\\n\\t\\t\\tbackground-size: cover;\\n\\t\\t\\tdisplay: inline-block;\\n\\t\\t}\\n\\n\\t\\t.app-name {\\n\\t\\t\\tpadding: 0 var(--app-item-padding);\\n\\t\\t}\\n\\n\\t\\t.app-name--link {\\n\\t\\t\\theight: var(--app-item-height);\\n\\t\\t\\tdisplay: flex;\\n\\t\\t\\talign-items: center;\\n\\t\\t}\\n\\n\\t\\t// Note: because of Safari bug, we cannot position link overlay relative to the table row\\n\\t\\t// So we need to manually position it relative to the table container and cell\\n\\t\\t// See: https://bugs.webkit.org/show_bug.cgi?id=240961\\n\\t\\t.app-name--link::after {\\n\\t\\t\\tcontent: '';\\n\\t\\t\\tposition: absolute;\\n\\t\\t\\tinset-inline: 0;\\n\\t\\t\\theight: var(--app-item-height);\\n\\t\\t}\\n\\n\\t\\t.app-actions {\\n\\t\\t\\tdisplay: flex;\\n\\t\\t\\tgap: var(--app-item-padding);\\n\\t\\t\\tflex-wrap: wrap;\\n\\t\\t\\tjustify-content: end;\\n\\n\\t\\t\\t.icon-loading-small {\\n\\t\\t\\t\\tdisplay: inline-block;\\n\\t\\t\\t\\ttop: 4px;\\n\\t\\t\\t\\tmargin-inline-end: 10px;\\n\\t\\t\\t}\\n\\t\\t}\\n\\n\\t\\t/* hide app version and level on narrower screens */\\n\\t\\t@media only screen and (max-width: 900px) {\\n\\t\\t\\t.app-version,\\n\\t\\t\\t.app-level {\\n\\t\\t\\t\\tdisplay: none;\\n\\t\\t\\t}\\n\\t\\t}\\n\\n\\t\\t/* Hide actions on a small screen. Click on app opens fill-screen sidebar with the buttons */\\n\\t\\t@media only screen and (max-width: math.div(variables.$breakpoint-mobile, 2)) {\\n\\t\\t\\t.app-actions {\\n\\t\\t\\t\\tdisplay: none;\\n\\t\\t\\t}\\n\\t\\t}\\n\\t}\\n\\n\\t&--store-view {\\n\\t\\tpadding: 30px;\\n\\n\\t\\t.app-image-icon .icon-settings-dark {\\n\\t\\t\\twidth: 100%;\\n\\t\\t\\theight: 150px;\\n\\t\\t\\tbackground-size: 45px;\\n\\t\\t\\topacity: 0.5;\\n\\t\\t}\\n\\n\\t\\t.app-image-icon svg {\\n\\t\\t\\tposition: absolute;\\n\\t\\t\\tbottom: 43px;\\n\\t\\t\\t/* position halfway vertically */\\n\\t\\t\\twidth: 64px;\\n\\t\\t\\theight: 64px;\\n\\t\\t\\topacity: .1;\\n\\t\\t}\\n\\n\\t\\t.app-name {\\n\\t\\t\\tmargin: 5px 0;\\n\\t\\t}\\n\\n\\t\\t.app-name--link::after {\\n\\t\\t\\tcontent: '';\\n\\t\\t\\tposition: absolute;\\n\\t\\t\\tinset-block: 0;\\n\\t\\t\\tinset-inline: 0;\\n\\t\\t}\\n\\n\\t\\t.app-actions {\\n\\t\\t\\tmargin: 10px 0;\\n\\t\\t}\\n\\n\\t\\t@media only screen and (min-width: 1601px) {\\n\\t\\t\\twidth: 25%;\\n\\n\\t\\t\\t&.app-item--with-sidebar {\\n\\t\\t\\t\\twidth: 33%;\\n\\t\\t\\t}\\n\\t\\t}\\n\\n\\t\\t@media only screen and (max-width: 1600px) {\\n\\t\\t\\twidth: 25%;\\n\\n\\t\\t\\t&.app-item--with-sidebar {\\n\\t\\t\\t\\twidth: 33%;\\n\\t\\t\\t}\\n\\t\\t}\\n\\n\\t\\t@media only screen and (max-width: 1400px) {\\n\\t\\t\\twidth: 33%;\\n\\n\\t\\t\\t&.app-item--with-sidebar {\\n\\t\\t\\t\\twidth: 50%;\\n\\t\\t\\t}\\n\\t\\t}\\n\\n\\t\\t@media only screen and (max-width: 900px) {\\n\\t\\t\\twidth: 50%;\\n\\n\\t\\t\\t&.app-item--with-sidebar {\\n\\t\\t\\t\\twidth: 100%;\\n\\t\\t\\t}\\n\\t\\t}\\n\\n\\t\\t@media only screen and (max-width: variables.$breakpoint-mobile) {\\n\\t\\t\\twidth: 50%;\\n\\t\\t}\\n\\n\\t\\t@media only screen and (max-width: 480px) {\\n\\t\\t\\twidth: 100%;\\n\\t\\t}\\n\\t}\\n}\\n\\n.app-icon {\\n\\tfilter: var(--background-invert-if-bright);\\n}\\n\\n.app-image {\\n\\tposition: relative;\\n\\theight: 150px;\\n\\topacity: 1;\\n\\toverflow: hidden;\\n\\n\\timg {\\n\\t\\twidth: 100%;\\n\\t}\\n}\\n\\n.app-version {\\n\\tcolor: var(--color-text-maxcontrast);\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-level-badge[data-v-96439520]{color:var(--color-text-maxcontrast);background-color:rgba(0,0,0,0);border:1px solid var(--color-text-maxcontrast);border-radius:var(--border-radius);display:flex;flex-direction:row;gap:6px;padding:3px 6px;width:fit-content}.app-level-badge--supported[data-v-96439520]{background-color:var(--color-success);border-color:var(--color-border-success);color:var(--color-success-text)}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppList/AppLevelBadge.vue\"],\"names\":[],\"mappings\":\"AACA,kCACC,mCAAA,CACA,8BAAA,CACA,8CAAA,CACA,kCAAA,CAEA,YAAA,CACA,kBAAA,CACA,OAAA,CACA,eAAA,CACA,iBAAA,CAEA,6CACC,qCAAA,CACA,wCAAA,CACA,+BAAA\",\"sourcesContent\":[\"\\n.app-level-badge {\\n\\tcolor: var(--color-text-maxcontrast);\\n\\tbackground-color: transparent;\\n\\tborder: 1px solid var(--color-text-maxcontrast);\\n\\tborder-radius: var(--border-radius);\\n\\n\\tdisplay: flex;\\n\\tflex-direction: row;\\n\\tgap: 6px;\\n\\tpadding: 3px 6px;\\n\\twidth: fit-content;\\n\\n\\t&--supported {\\n\\t\\tbackground-color: var(--color-success);\\n\\t\\tborder-color: var(--color-border-success);\\n\\t\\tcolor: var(--color-success-text);\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.office-suite-switcher[data-v-2e094751]{padding:20px;margin-bottom:30px}.office-suite-switcher__aio-message[data-v-2e094751]{background-color:var(--color-background-dark);border:1px solid var(--color-border);border-radius:var(--border-radius-large);padding:20px;text-align:center}.office-suite-switcher p[data-v-2e094751]{margin:8px 0}.office-suite-switcher p[data-v-2e094751]:first-child{font-weight:600}.office-suite-cards[data-v-2e094751]{display:flex;gap:20px;max-width:1200px}.office-suite-card[data-v-2e094751]{flex:1;background-color:var(--color-main-background);border:2px solid var(--color-border);border-radius:var(--border-radius-large);padding:24px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.office-suite-card *[data-v-2e094751]{cursor:pointer}.office-suite-card[data-v-2e094751]:hover{border-color:var(--color-primary-element);box-shadow:0 4px 12px rgba(0,0,0,.1)}.office-suite-card--selected[data-v-2e094751]{background:linear-gradient(135deg, var(--color-primary-element-light) 0%, var(--color-main-background) 100%);color:var(--color-main-text);border-color:var(--color-primary-element)}.office-suite-card__header[data-v-2e094751]{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.office-suite-card__title[data-v-2e094751]{font-size:24px;font-weight:600;margin:0}.office-suite-card--primary .office-suite-card__check[data-v-2e094751]{color:var(--color-primary-element)}.office-suite-card__features[data-v-2e094751]{list-style:none;padding:0;margin:0 0 20px 0;flex-grow:1}.office-suite-card__features li[data-v-2e094751]{padding:4px 0;padding-inline-start:20px;position:relative;line-height:1.5}.office-suite-card__features li[data-v-2e094751]::before{content:\"•\";position:absolute;inset-inline-start:0;font-weight:bold}.office-suite-card__link[data-v-2e094751]{display:inline-flex;align-items:center;gap:6px;color:var(--color-main-text);text-decoration:none;font-weight:500;margin-top:auto}.office-suite-card__link[data-v-2e094751]:hover{text-decoration:underline}.office-suite-card--selected .office-suite-card__link[data-v-2e094751]{color:var(--color-main-text)}.office-suite-actions[data-v-2e094751]{margin-top:16px}.office-suite-disable-button[data-v-2e094751]{background:rgba(0,0,0,0);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 12px;font-weight:600;color:var(--color-main-text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.office-suite-disable-button[data-v-2e094751]:disabled{opacity:.5;cursor:default}.office-suite-disable-button[data-v-2e094751]:hover:not(:disabled){border-color:var(--color-primary-element);background:var(--color-background-dark)}@media(max-width: 768px){.office-suite-cards[data-v-2e094751]{flex-direction:column}}`, \"\",{\"version\":3,\"sources\":[\"webpack://./OfficeSuiteSwitcher.vue\",\"webpack://./apps/appstore/src/components/AppList/OfficeSuiteSwitcher.vue\"],\"names\":[],\"mappings\":\"AAAA,wCCCA,YACC,CAAA,kBACA,CAAA,qDAEA,6CACC,CAAA,oCACA,CAAA,wCACA,CAAA,YACA,CAAA,iBACA,CAAA,0CAGD,YACC,CAAA,sDAEA,eACC,CAAA,qCAKH,YACC,CAAA,QACA,CAAA,gBACA,CAAA,oCAGD,MACC,CAAA,6CACA,CAAA,oCACA,CAAA,wCACA,CAAA,YACA,CAAA,cACA,CAAA,uBACA,CAAA,YACA,CAAA,qBACA,CAAA,sCAEA,cACC,CAAA,0CAGD,yCACC,CAAA,oCACA,CAAA,8CAGD,4GACC,CAAA,4BACA,CAAA,yCACA,CAAA,4CAGD,YACC,CAAA,6BACA,CAAA,kBACA,CAAA,kBACA,CAAA,2CAGD,cACC,CAAA,eACA,CAAA,QACA,CAAA,uEAGD,kCACC,CAAA,8CAGD,eACC,CAAA,SACA,CAAA,iBACA,CAAA,WACA,CAAA,iDAEA,aACC,CAAA,yBACA,CAAA,iBACA,CAAA,eACA,CAAA,yDAEA,WACC,CAAA,iBACA,CAAA,oBACA,CAAA,gBACA,CAAA,0CAKH,mBACC,CAAA,kBACA,CAAA,OACA,CAAA,4BACA,CAAA,oBACA,CAAA,eACA,CAAA,eACA,CAAA,gDAEA,yBACC,CAAA,uEAIF,4BACC,CAAA,uCAIF,eACC,CAAA,8CAGD,wBACC,CAAA,oCACA,CAAA,wCACA,CAAA,gBACA,CAAA,eACA,CAAA,4BACA,CAAA,cACA,CAAA,sDACA,CAAA,uDAGD,UACC,CAAA,cACA,CAAA,mEAGD,yCACC,CAAA,uCACA,CAAA,yBAGD,qCACC,qBACC,CAAA\",\"sourcesContent\":[\".office-suite-switcher{padding:20px;margin-bottom:30px}.office-suite-switcher__aio-message{background-color:var(--color-background-dark);border:1px solid var(--color-border);border-radius:var(--border-radius-large);padding:20px;text-align:center}.office-suite-switcher p{margin:8px 0}.office-suite-switcher p:first-child{font-weight:600}.office-suite-cards{display:flex;gap:20px;max-width:1200px}.office-suite-card{flex:1;background-color:var(--color-main-background);border:2px solid var(--color-border);border-radius:var(--border-radius-large);padding:24px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.office-suite-card *{cursor:pointer}.office-suite-card:hover{border-color:var(--color-primary-element);box-shadow:0 4px 12px rgba(0,0,0,.1)}.office-suite-card--selected{background:linear-gradient(135deg, var(--color-primary-element-light) 0%, var(--color-main-background) 100%);color:var(--color-main-text);border-color:var(--color-primary-element)}.office-suite-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.office-suite-card__title{font-size:24px;font-weight:600;margin:0}.office-suite-card--primary .office-suite-card__check{color:var(--color-primary-element)}.office-suite-card__features{list-style:none;padding:0;margin:0 0 20px 0;flex-grow:1}.office-suite-card__features li{padding:4px 0;padding-inline-start:20px;position:relative;line-height:1.5}.office-suite-card__features li::before{content:\\\"•\\\";position:absolute;inset-inline-start:0;font-weight:bold}.office-suite-card__link{display:inline-flex;align-items:center;gap:6px;color:var(--color-main-text);text-decoration:none;font-weight:500;margin-top:auto}.office-suite-card__link:hover{text-decoration:underline}.office-suite-card--selected .office-suite-card__link{color:var(--color-main-text)}.office-suite-actions{margin-top:16px}.office-suite-disable-button{background:rgba(0,0,0,0);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 12px;font-weight:600;color:var(--color-main-text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.office-suite-disable-button:disabled{opacity:.5;cursor:default}.office-suite-disable-button:hover:not(:disabled){border-color:var(--color-primary-element);background:var(--color-background-dark)}@media(max-width: 768px){.office-suite-cards{flex-direction:column}}\",\"\\n.office-suite-switcher {\\n\\tpadding: 20px;\\n\\tmargin-bottom: 30px;\\n\\n\\t&__aio-message {\\n\\t\\tbackground-color: var(--color-background-dark);\\n\\t\\tborder: 1px solid var(--color-border);\\n\\t\\tborder-radius: var(--border-radius-large);\\n\\t\\tpadding: 20px;\\n\\t\\ttext-align: center;\\n\\t}\\n\\n\\tp {\\n\\t\\tmargin: 8px 0;\\n\\n\\t\\t&:first-child {\\n\\t\\t\\tfont-weight: 600;\\n\\t\\t}\\n\\t}\\n}\\n\\n.office-suite-cards {\\n\\tdisplay: flex;\\n\\tgap: 20px;\\n\\tmax-width: 1200px;\\n}\\n\\n.office-suite-card {\\n\\tflex: 1;\\n\\tbackground-color: var(--color-main-background);\\n\\tborder: 2px solid var(--color-border);\\n\\tborder-radius: var(--border-radius-large);\\n\\tpadding: 24px;\\n\\tcursor: pointer;\\n\\ttransition: all 0.2s ease;\\n\\tdisplay: flex;\\n\\tflex-direction: column;\\n\\n\\t& * {\\n\\t\\tcursor: pointer;\\n\\t}\\n\\n\\t&:hover {\\n\\t\\tborder-color: var(--color-primary-element);\\n\\t\\tbox-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\\n\\t}\\n\\n\\t&--selected {\\n\\t\\tbackground: linear-gradient(135deg, var(--color-primary-element-light) 0%, var(--color-main-background) 100%);\\n\\t\\tcolor: var(--color-main-text);\\n\\t\\tborder-color: var(--color-primary-element);\\n\\t}\\n\\n\\t&__header {\\n\\t\\tdisplay: flex;\\n\\t\\tjustify-content: space-between;\\n\\t\\talign-items: center;\\n\\t\\tmargin-bottom: 16px;\\n\\t}\\n\\n\\t&__title {\\n\\t\\tfont-size: 24px;\\n\\t\\tfont-weight: 600;\\n\\t\\tmargin: 0;\\n\\t}\\n\\n\\t.office-suite-card--primary &__check {\\n\\t\\tcolor: var(--color-primary-element);\\n\\t}\\n\\n\\t&__features {\\n\\t\\tlist-style: none;\\n\\t\\tpadding: 0;\\n\\t\\tmargin: 0 0 20px 0;\\n\\t\\tflex-grow: 1;\\n\\n\\t\\tli {\\n\\t\\t\\tpadding: 4px 0;\\n\\t\\t\\tpadding-inline-start: 20px;\\n\\t\\t\\tposition: relative;\\n\\t\\t\\tline-height: 1.5;\\n\\n\\t\\t\\t&::before {\\n\\t\\t\\t\\tcontent: '•';\\n\\t\\t\\t\\tposition: absolute;\\n\\t\\t\\t\\tinset-inline-start: 0;\\n\\t\\t\\t\\tfont-weight: bold;\\n\\t\\t\\t}\\n\\t\\t}\\n\\t}\\n\\n\\t&__link {\\n\\t\\tdisplay: inline-flex;\\n\\t\\talign-items: center;\\n\\t\\tgap: 6px;\\n\\t\\tcolor: var(--color-main-text);\\n\\t\\ttext-decoration: none;\\n\\t\\tfont-weight: 500;\\n\\t\\tmargin-top: auto;\\n\\n\\t\\t&:hover {\\n\\t\\t\\ttext-decoration: underline;\\n\\t\\t}\\n\\t}\\n\\n\\t.office-suite-card--selected &__link {\\n\\t\\tcolor: var(--color-main-text);\\n\\t}\\n}\\n\\n.office-suite-actions {\\n\\tmargin-top: 16px;\\n}\\n\\n.office-suite-disable-button {\\n\\tbackground: transparent;\\n\\tborder: 1px solid var(--color-border);\\n\\tborder-radius: var(--border-radius-small);\\n\\tpadding: 8px 12px;\\n\\tfont-weight: 600;\\n\\tcolor: var(--color-main-text);\\n\\tcursor: pointer;\\n\\ttransition: background 0.15s ease, border-color 0.15s ease;\\n}\\n\\n.office-suite-disable-button:disabled {\\n\\topacity: 0.5;\\n\\tcursor: default;\\n}\\n\\n.office-suite-disable-button:hover:not(:disabled) {\\n\\tborder-color: var(--color-primary-element);\\n\\tbackground: var(--color-background-dark);\\n}\\n\\n@media (max-width: 768px) {\\n\\t.office-suite-cards {\\n\\t\\tflex-direction: column;\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-discover[data-v-277e0eae]{max-width:1008px;margin-inline:auto;padding-inline:54px;padding-block-end:var(--default-clickable-area, 44px);display:flex;flex-direction:column;gap:var(--default-clickable-area, 44px)}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppStoreDiscover/AppStoreDiscoverSection.vue\"],\"names\":[],\"mappings\":\"AACA,+BACC,gBAAA,CACA,kBAAA,CACA,mBAAA,CAEA,qDAAA,CAEA,YAAA,CACA,qBAAA,CACA,uCAAA\",\"sourcesContent\":[\"\\n.app-discover {\\n\\tmax-width: 1008px; /* 900px + 2x 54px padding for the carousel controls */\\n\\tmargin-inline: auto;\\n\\tpadding-inline: 54px;\\n\\t/* Padding required to make last element not bound to the bottom */\\n\\tpadding-block-end: var(--default-clickable-area, 44px);\\n\\n\\tdisplay: flex;\\n\\tflex-direction: column;\\n\\tgap: var(--default-clickable-area, 44px);\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.daemon[data-v-3d6f45e8]{padding:20px}.daemon h4[data-v-3d6f45e8]{font-weight:bold;margin:10px auto}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppStoreSidebar/AppDeployDaemonTab.vue\"],\"names\":[],\"mappings\":\"AACA,yBACE,YAAA,CAEA,4BACE,gBAAA,CACA,gBAAA\",\"sourcesContent\":[\"\\n.daemon {\\n padding: 20px;\\n\\n h4 {\\n font-weight: bold;\\n margin: 10px auto;\\n }\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-description[data-v-373d80a8]{padding:12px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppStoreSidebar/AppDescriptionTab.vue\"],\"names\":[],\"mappings\":\"AACA,kCACC,YAAA\",\"sourcesContent\":[\"\\n.app-description {\\n\\tpadding: 12px;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-details[data-v-499d846c]{padding:20px}.app-details__authors[data-v-499d846c]{color:var(--color-text-maxcontrast)}.app-details__section[data-v-499d846c]{margin-top:15px}.app-details__section h4[data-v-499d846c]{font-size:16px;font-weight:bold;margin-block-end:5px}.app-details__interact[data-v-499d846c]{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px}.app-details__documentation a[data-v-499d846c]{text-decoration:underline}.app-details__documentation li[data-v-499d846c]{padding-inline-start:20px}.app-details__documentation li[data-v-499d846c]::before{width:5px;height:5px;border-radius:100%;background-color:var(--color-main-text);content:\"\";float:inline-start;margin-inline-start:-13px;position:relative;top:10px}.force[data-v-499d846c]{color:var(--color-text-error);border-color:var(--color-border-error);background:var(--color-main-background)}.force[data-v-499d846c]:hover,.force[data-v-499d846c]:active{color:var(--color-main-background);border-color:var(--color-border-error) !important;background:var(--color-error)}.missing-dependencies[data-v-499d846c]{list-style:initial;list-style-type:initial;list-style-position:inside}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppStoreSidebar/AppDetailsTab.vue\"],\"names\":[],\"mappings\":\"AACA,8BACC,YAAA,CAEA,uCACC,mCAAA,CAGD,uCACC,eAAA,CAEA,0CACC,cAAA,CACA,gBAAA,CACA,oBAAA,CAIF,wCACC,YAAA,CACA,kBAAA,CACA,cAAA,CACA,QAAA,CAIA,+CACC,yBAAA,CAED,gDACC,yBAAA,CAEA,wDACC,SAAA,CACA,UAAA,CACA,kBAAA,CACA,uCAAA,CACA,UAAA,CACA,kBAAA,CACA,yBAAA,CACA,iBAAA,CACA,QAAA,CAMJ,wBACC,6BAAA,CACA,sCAAA,CACA,uCAAA,CAGD,6DAEC,kCAAA,CACA,iDAAA,CACA,6BAAA,CAGD,uCACC,kBAAA,CACA,uBAAA,CACA,0BAAA\",\"sourcesContent\":[\"\\n.app-details {\\n\\tpadding: 20px;\\n\\n\\t&__authors {\\n\\t\\tcolor: var(--color-text-maxcontrast);\\n\\t}\\n\\n\\t&__section {\\n\\t\\tmargin-top: 15px;\\n\\n\\t\\th4 {\\n\\t\\t\\tfont-size: 16px;\\n\\t\\t\\tfont-weight: bold;\\n\\t\\t\\tmargin-block-end: 5px;\\n\\t\\t}\\n\\t}\\n\\n\\t&__interact {\\n\\t\\tdisplay: flex;\\n\\t\\tflex-direction: row;\\n\\t\\tflex-wrap: wrap;\\n\\t\\tgap: 12px;\\n\\t}\\n\\n\\t&__documentation {\\n\\t\\ta {\\n\\t\\t\\ttext-decoration: underline;\\n\\t\\t}\\n\\t\\tli {\\n\\t\\t\\tpadding-inline-start: 20px;\\n\\n\\t\\t\\t&::before {\\n\\t\\t\\t\\twidth: 5px;\\n\\t\\t\\t\\theight: 5px;\\n\\t\\t\\t\\tborder-radius: 100%;\\n\\t\\t\\t\\tbackground-color: var(--color-main-text);\\n\\t\\t\\t\\tcontent: \\\"\\\";\\n\\t\\t\\t\\tfloat: inline-start;\\n\\t\\t\\t\\tmargin-inline-start: -13px;\\n\\t\\t\\t\\tposition: relative;\\n\\t\\t\\t\\ttop: 10px;\\n\\t\\t\\t}\\n\\t\\t}\\n\\t}\\n}\\n\\n.force {\\n\\tcolor: var(--color-text-error);\\n\\tborder-color: var(--color-border-error);\\n\\tbackground: var(--color-main-background);\\n}\\n\\n.force:hover,\\n.force:active {\\n\\tcolor: var(--color-main-background);\\n\\tborder-color: var(--color-border-error) !important;\\n\\tbackground: var(--color-error);\\n}\\n\\n.missing-dependencies {\\n\\tlist-style: initial;\\n\\tlist-style-type: initial;\\n\\tlist-style-position: inside;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-sidebar-tabs__release h2[data-v-2ac4587b]{border-bottom:1px solid var(--color-border);font-size:24px}.app-sidebar-tabs__release-text[data-v-2ac4587b] h3{font-size:20px}.app-sidebar-tabs__release-text[data-v-2ac4587b] h4{font-size:17px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppStoreSidebar/AppReleasesTab.vue\"],\"names\":[],\"mappings\":\"AAEC,+CACC,2CAAA,CACA,cAAA,CAKA,oDACC,cAAA,CAED,oDACC,cAAA\",\"sourcesContent\":[\"\\n.app-sidebar-tabs__release {\\n\\th2 {\\n\\t\\tborder-bottom: 1px solid var(--color-border);\\n\\t\\tfont-size: 24px;\\n\\t}\\n\\n\\t&-text {\\n\\t\\t// Overwrite changelog heading styles\\n\\t\\t:deep(h3) {\\n\\t\\t\\tfont-size: 20px;\\n\\t\\t}\\n\\t\\t:deep(h4) {\\n\\t\\t\\tfont-size: 17px;\\n\\t\\t}\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-sidebar-manage__actions-manage[data-v-08e3b856]{display:flex;align-items:center}.app-sidebar-manage__actions-manage input[data-v-08e3b856]{flex:0 1 auto;min-width:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.force[data-v-08e3b856]{color:var(--color-text-error);border-color:var(--color-border-error);background:var(--color-main-background)}.force[data-v-08e3b856]:hover,.force[data-v-08e3b856]:active{color:var(--color-main-background);border-color:var(--color-border-error) !important;background:var(--color-error)}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppStoreSidebar/AppStoreSidebarActions.vue\"],\"names\":[],\"mappings\":\"AAGE,qDACC,YAAA,CACA,kBAAA,CACA,2DACC,aAAA,CACA,WAAA,CACA,sBAAA,CACA,kBAAA,CACA,eAAA,CAMJ,wBACC,6BAAA,CACA,sCAAA,CACA,uCAAA,CAGD,6DAEC,kCAAA,CACA,iDAAA,CACA,6BAAA\",\"sourcesContent\":[\"\\n.app-sidebar-manage {\\n\\t&__actions {\\n\\t\\t&-manage {\\n\\t\\t\\tdisplay: flex;\\n\\t\\t\\talign-items: center;\\n\\t\\t\\tinput {\\n\\t\\t\\t\\tflex: 0 1 auto;\\n\\t\\t\\t\\tmin-width: 0;\\n\\t\\t\\t\\ttext-overflow: ellipsis;\\n\\t\\t\\t\\twhite-space: nowrap;\\n\\t\\t\\t\\toverflow: hidden;\\n\\t\\t\\t}\\n\\t\\t}\\n\\t}\\n}\\n\\n.force {\\n\\tcolor: var(--color-text-error);\\n\\tborder-color: var(--color-border-error);\\n\\tbackground: var(--color-main-background);\\n}\\n\\n.force:hover,\\n.force:active {\\n\\tcolor: var(--color-main-background);\\n\\tborder-color: var(--color-border-error) !important;\\n\\tbackground: var(--color-error);\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.settings-markdown[data-v-72fa808e] a{text-decoration:underline}.settings-markdown[data-v-72fa808e] a::after{content:\"↗\";padding-inline:calc(var(--default-grid-baseline)/2)}.settings-markdown[data-v-72fa808e] pre{white-space:pre;overflow-x:auto;background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:1em 1.3em;margin-bottom:1em}.settings-markdown[data-v-72fa808e] p code{background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:.1em .3em}.settings-markdown[data-v-72fa808e] li{position:relative}.settings-markdown[data-v-72fa808e] ul,.settings-markdown[data-v-72fa808e] ol{padding-inline-start:10px;margin-inline-start:10px}.settings-markdown[data-v-72fa808e] ul li{list-style-type:disc}.settings-markdown[data-v-72fa808e] ul>li>ul>li{list-style-type:circle}.settings-markdown[data-v-72fa808e] ul>li>ul>li ul li{list-style-type:square}.settings-markdown[data-v-72fa808e] blockquote{padding-inline-start:1em;border-inline-start:4px solid var(--color-primary-element);color:var(--color-text-maxcontrast);margin-inline:0}`, \"\",{\"version\":3,\"sources\":[\"webpack://./Markdown.vue\",\"webpack://./apps/appstore/src/components/Markdown.vue\"],\"names\":[],\"mappings\":\"AAAA,sCCEC,yBACC,CAAA,6CACA,WACC,CAAA,mDACA,CAAA,wCAIF,eACC,CAAA,eACA,CAAA,6CACA,CAAA,kCACA,CAAA,iBACA,CAAA,iBACA,CAAA,2CAGD,6CACC,CAAA,kCACA,CAAA,iBACA,CAAA,uCAGD,iBACC,CAAA,8EAGD,yBACC,CAAA,wBACA,CAAA,0CAGD,oBACC,CAAA,gDAGD,sBACC,CAAA,sDAGD,sBACC,CAAA,+CAGD,wBACC,CAAA,0DACA,CAAA,mCACA,CAAA,eACA\",\"sourcesContent\":[\".settings-markdown :deep a{text-decoration:underline}.settings-markdown :deep a::after{content:\\\"↗\\\";padding-inline:calc(var(--default-grid-baseline)/2)}.settings-markdown :deep pre{white-space:pre;overflow-x:auto;background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:1em 1.3em;margin-bottom:1em}.settings-markdown :deep p code{background-color:var(--color-background-dark);border-radius:var(--border-radius);padding:.1em .3em}.settings-markdown :deep li{position:relative}.settings-markdown :deep ul,.settings-markdown :deep ol{padding-inline-start:10px;margin-inline-start:10px}.settings-markdown :deep ul li{list-style-type:disc}.settings-markdown :deep ul>li>ul>li{list-style-type:circle}.settings-markdown :deep ul>li>ul>li ul li{list-style-type:square}.settings-markdown :deep blockquote{padding-inline-start:1em;border-inline-start:4px solid var(--color-primary-element);color:var(--color-text-maxcontrast);margin-inline:0}\",\"\\n.settings-markdown :deep {\\n\\ta {\\n\\t\\ttext-decoration: underline;\\n\\t\\t&::after {\\n\\t\\t\\tcontent: '↗';\\n\\t\\t\\tpadding-inline: calc(var(--default-grid-baseline) / 2);\\n\\t\\t}\\n\\t}\\n\\n\\tpre {\\n\\t\\twhite-space: pre;\\n\\t\\toverflow-x: auto;\\n\\t\\tbackground-color: var(--color-background-dark);\\n\\t\\tborder-radius: var(--border-radius);\\n\\t\\tpadding: 1em 1.3em;\\n\\t\\tmargin-bottom: 1em;\\n\\t}\\n\\n\\tp code {\\n\\t\\tbackground-color: var(--color-background-dark);\\n\\t\\tborder-radius: var(--border-radius);\\n\\t\\tpadding: .1em .3em;\\n\\t}\\n\\n\\tli {\\n\\t\\tposition: relative;\\n\\t}\\n\\n\\tul, ol {\\n\\t\\tpadding-inline-start: 10px;\\n\\t\\tmargin-inline-start: 10px;\\n\\t}\\n\\n\\tul li {\\n\\t\\tlist-style-type: disc;\\n\\t}\\n\\n\\tul > li > ul > li {\\n\\t\\tlist-style-type: circle;\\n\\t}\\n\\n\\tul > li > ul > li ul li {\\n\\t\\tlist-style-type: square;\\n\\t}\\n\\n\\tblockquote {\\n\\t\\tpadding-inline-start: 1em;\\n\\t\\tborder-inline-start: 4px solid var(--color-primary-element);\\n\\t\\tcolor: var(--color-text-maxcontrast);\\n\\t\\tmargin-inline: 0;\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app-sidebar--with-screenshot[data-v-066d163c] .app-sidebar-header__figure{background-size:cover}.app-sidebar__fallback-icon[data-v-066d163c]{width:100%;height:100%}.app-sidebar__description[data-v-066d163c]{display:flex;flex-direction:column;gap:12px}.app-sidebar__badges[data-v-066d163c]{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px}.app-sidebar__score[data-v-066d163c]{display:flex;align-items:center}.app-sidebar__version[data-v-066d163c]{color:var(--color-text-maxcontrast)}`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/views/AppStoreSidebar.vue\"],\"names\":[],\"mappings\":\"AAIE,2EACC,qBAAA,CAIF,6CAEC,UAAA,CACA,WAAA,CAGD,2CACC,YAAA,CACA,qBAAA,CACA,QAAA,CAGD,sCACC,YAAA,CACA,kBAAA,CACA,cAAA,CACA,QAAA,CAGD,qCACC,YAAA,CACA,kBAAA,CAGD,uCACC,mCAAA\",\"sourcesContent\":[\"\\n.app-sidebar {\\n\\t// If a screenshot is available it should cover the whole figure\\n\\t&--with-screenshot {\\n\\t\\t:deep(.app-sidebar-header__figure) {\\n\\t\\t\\tbackground-size: cover;\\n\\t\\t}\\n\\t}\\n\\n\\t&__fallback-icon {\\n\\t\\t// both 100% to center the icon\\n\\t\\twidth: 100%;\\n\\t\\theight: 100%;\\n\\t}\\n\\n\\t&__description {\\n\\t\\tdisplay: flex;\\n\\t\\tflex-direction: column;\\n\\t\\tgap: 12px;\\n\\t}\\n\\n\\t&__badges {\\n\\t\\tdisplay: flex;\\n\\t\\tflex-direction: row;\\n\\t\\tflex-wrap: wrap;\\n\\t\\tgap: 12px;\\n\\t}\\n\\n\\t&__score {\\n\\t\\tdisplay: flex;\\n\\t\\talign-items: center;\\n\\t}\\n\\n\\t&__version {\\n\\t\\tcolor: var(--color-text-maxcontrast);\\n\\t}\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `\n.app-score__wrapper[data-v-ab7c7026] {\n\tdisplay: inline-flex;\n\tcolor: var(--color-favorite, #a08b00);\n> *[data-v-ab7c7026] {\n\t\tvertical-align: text-bottom;\n}\n}\n`, \"\",{\"version\":3,\"sources\":[\"webpack://./apps/appstore/src/components/AppList/AppScore.vue\"],\"names\":[],\"mappings\":\";AA0EA;CACA,oBAAA;CACA,qCAAA;AAEA;EACA,2BAAA;AACA;AACA\",\"sourcesContent\":[\"\\n\\n\\n\\t\\n\\t\\t 0 || (configuredDeployOptions !== null && configuredDeployOptions.environment_variables.length > 0)\\\">\\n\\t\\t\\t\\t{{ t('settings', 'Environment variables') }}\\n\\t\\t\\t
\\n\\t\\t\\t\\n\\t\\t\\t\\t{{ t('settings', 'Mounts') }}
\\n\\t\\t\\t\\n\\t\\t\\t\\t\\n\\t\\t\\t\\t\\t\\t{{ t('settings', 'New mount') }}\\n\\t\\t\\t\\t\\t
\\n\\t\\t\\t\\t\\t 0\"\n\t\t\t:aria-label=\"t('settings', 'Registered Deploy daemons list')\">\n\t\t\t
\n\t\t\n\t\t
\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Icon') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Name') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Version') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Level') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Actions') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\n\t\t\t\t\t \n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Icon') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Name') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Version') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Level') }}\n\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t{{ t('appstore', 'Actions') }}\n\t\t\t\t\t \n\t\t\t\t\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t
\n\t\t 0\" class=\"apps-list__list-container\">\n\t\t\t\t\t
\n\t\t\t\n\t\t\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Icon') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Name') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Version') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Level') }}\n\t\t\t\t\t\t \n\t\t\t\t\t\t\n\t\t\t\t\t\t\t{{ t('appstore', 'Actions') }}\n\t\t\t\t\t\t \n\t\t\t\t\t{{ t('appstore', 'No apps found for your version') }}
\n\t\t\n\t\t\t\t
\n\n\t\t\t\n\t\t\t\t\t\t
\n\t\t\t\t\n\t\t\t\t\t{{ t('appstore', 'Latest updated') }}\n\t\t\t\t
\n\t\t\t\t\n\t\t\t\t\t{{ t('appstore', 'Author') }}\n\t\t\t\t
\n\t\t\t\t\n\t\t\t\t\t{{ t('appstore', 'Categories') }}\n\t\t\t\t
\n\t\t\t\t{{ t('appstore', 'Resources') }}
\n\t\t\t\t\n\t\t\t\t\t
\n\t\t\t{{ t('appstore', 'Interact') }}
\n\t\t\t\t 0 || (configuredDeployOptions !== null && configuredDeployOptions.environment_variables.length > 0)\">\n\t\t\t\t{{ t('settings', 'Environment variables') }}\n\t\t\t
\n\t\t\t\n\t\t\t\t{{ t('settings', 'Mounts') }}
\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t\t{{ t('settings', 'New mount') }}\n\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t\t\n\t\t\t
\n\t\t\t