diff --git a/package.json b/package.json index ac3330bda3..77722fb276 100644 --- a/package.json +++ b/package.json @@ -42,7 +42,7 @@ "remix-analyzer": "0.3.1", "remix-debug": "0.3.1", "remix-lib": "0.4.1", - "remix-plugin": "0.0.1-alpha.8", + "remix-plugin": "latest", "remix-solidity": "0.3.1", "remix-tests": "0.1.1", "remixd": "0.1.8-alpha.6", diff --git a/src/app/components/plugin-manager-component.js b/src/app/components/plugin-manager-component.js index d2431a56bc..32ab9d2907 100644 --- a/src/app/components/plugin-manager-component.js +++ b/src/app/components/plugin-manager-component.js @@ -18,7 +18,8 @@ class PluginManagerComponent { profile () { return { - name: 'plugin manager', + displayName: 'plugin manager', + name: 'pluginManager', methods: [], events: [], icon: '', @@ -45,7 +46,7 @@ class PluginManagerComponent { ` let inactiveMods = yo` -
+

Inactive Modules

` @@ -63,21 +64,22 @@ class PluginManagerComponent { searchbox.addEventListener('keyup', (event) => { this.filterPlugins(event) }) - var modulesActive = this.store.getActives() - modulesActive.sort(function (a, b) { - var textA = a.profile.name.toUpperCase() - var textB = b.profile.name.toUpperCase() - return (textA < textB) ? -1 : (textA > textB) ? 1 : 0 - }) + var modulesActiveNotReq = this.store.getActives().filter(({profile}) => !profile.required) + this.sortObject(modulesActiveNotReq) - modulesActive.forEach((mod) => { - activeMods.appendChild(this.renderItem(mod.profile.name)) - }) + if (modulesActiveNotReq.length > 0) { + modulesActiveNotReq.forEach((mod) => { + activeMods.appendChild(this.renderItem(mod.profile.name)) + }) + activeMods.style.display = 'block' + } else { + activeMods.style.display = 'none' + } - var modulesAll = this.store.getAll() - modulesAll.sort() - modulesAll.forEach((mod) => { - if (!modulesActive.includes(mod)) { + var modulesAllNotReq = this.store.getAll().filter(({profile}) => !profile.required) + this.sortObject(modulesAllNotReq) + modulesAllNotReq.forEach((mod) => { + if (!modulesActiveNotReq.includes(mod)) { inactiveMods.appendChild(this.renderItem(mod.profile.name)) } }) @@ -87,11 +89,20 @@ class PluginManagerComponent { return rootView } + sortObject (obj) { + obj.sort((a, b) => { + var textA = a.profile.name.toUpperCase() + var textB = b.profile.name.toUpperCase() + return (textA < textB) ? -1 : (textA > textB) ? 1 : 0 + }) + } + renderItem (item) { let ctrBtns const mod = this.store.getOne(item) if (!mod) return + let displayName = (mod.profile.displayName) ? mod.profile.displayName : mod.profile.name let action = () => { if (this.store.isActive(item)) { this.appManager.deactivateOne(item) @@ -100,13 +111,13 @@ class PluginManagerComponent { } } - ctrBtns = yo`
+ ctrBtns = yo`
` return yo` -
-

${mod.profile.name}

+
+

${displayName}

${mod.profile.description} ${ctrBtns}
@@ -174,4 +185,7 @@ const css = csjs` .plugins_settings input { margin: 10px; } + .hideIt { + display: none; + } `