- colors for Panel icons

- border for status updates for panel icons
- Display name uppercase
pull/1/head
LianaHus 6 years ago
parent 4ec234cac6
commit db61fbcd10
  1. 2
      src/app/components/plugin-manager-component.js
  2. 2
      src/app/components/swap-panel-component.js
  3. 95
      src/app/components/vertical-icons-component.js
  4. 4
      src/app/files/fileManager.js
  5. 2
      src/app/panels/file-panel.js
  6. 1
      src/app/panels/styles/terminal-styles.js
  7. 4
      src/app/tabs/analysis-tab.js
  8. 6
      src/app/tabs/compile-tab.js
  9. 6
      src/app/tabs/debugger-tab.js
  10. 4
      src/app/tabs/settings-tab.js
  11. 4
      src/app/tabs/test-tab.js
  12. 1
      src/app/tabs/theme-module.js
  13. 2
      src/app/ui/landing-page/landing-page.js
  14. 2
      src/remixAppManager.js

@ -35,8 +35,8 @@ const css = csjs`
`
const profile = {
displayName: 'plugin manager',
name: 'pluginManager',
displayName: 'Plugin manager',
methods: [],
events: [],
icon: '',

@ -73,7 +73,7 @@ module.exports = SwapPanelComponent
const css = csjs`
.plugins {
height : 100%;
height : 95%;
}
.plugItIn {
display : none;

@ -33,11 +33,6 @@ class VerticalIconComponent {
})
this.store.event.on('add', (api) => { })
this.store.event.on('remove', (api) => { })
let themeModule = globalRegistry.get('themeModule').api
themeModule.events.on('themeChanged', (type) => {
this.updateIcons(type)
})
}
stopListenOnStatus (api) {
@ -63,27 +58,13 @@ class VerticalIconComponent {
* @param {ModuleProfile} profile The profile of the module
*/
addIcon ({kind, name, icon, displayName}) {
this.icons[name] = yo`<div class="${css.icon}" onclick="${(e) => { this._iconClick(name) }}" plugin="${name}" title="${displayName || name}" ><img src="${icon}" alt="${name}" /></div>`
this.icons[name] = yo`
<div class="${css.icon}" onclick="${(e) => { this._iconClick(name) }}" plugin="${name}" title="${displayName || name}" >
<img class="image" src="${icon}" alt="${name}" />
</div>`
this.iconKind[kind || 'other'].appendChild(this.icons[name])
}
updateIcons(type)
{
if (!type) {
type = globalRegistry.get("themeModule").api.currentTheme().quality === 'dark'
}
let icon
for (icon in this.icons) {
if (type === 'dark') {
this.icons[icon].classList.remove(`${css.light}`)
this.icons[icon].classList.add(`${css.dark}`)
} else {
this.icons[icon].classList.remove(`${css.dark}`)
this.icons[icon].classList.add(`${css.light}`)
}
}
}
/**
* Set a new status for the @arg name
* @param {String} name
@ -92,7 +73,7 @@ class VerticalIconComponent {
setIconStatus (name, status) {
const el = this.icons[name]
if (!el) return
let statusEl = el.querySelector('i')
let statusEl = el.querySelector('span')
if (statusEl) {
el.removeChild(statusEl)
}
@ -100,7 +81,7 @@ class VerticalIconComponent {
let key = helper.checkSpecialChars(status.key) ? '' : status.key
let type = helper.checkSpecialChars(status.type) ? '' : status.type
let title = helper.checkSpecialChars(status.title) ? '' : status.title
el.appendChild(yo`<i title="${title}" class="fa fa-${key} ${css.status} text-${type}" aria-hidden="true"></i>`)
el.appendChild(yo`<span title="${title}" class="fa fa-${key} ${css.status} text-${type}" aria-hidden="true"></span>`)
// el.classList = "" doesn't work on all browser use instead
var classList = el.classList;
@ -123,20 +104,28 @@ class VerticalIconComponent {
if (this.icons[name]) this.iconKind[kind || 'other'].removeChild(this.icons[name])
}
/**
* Set an icon as active
* @param {string} name Name of profile of the module to activate
*/
select (name) {
this.updateIcons()
let currentActive = this.view.querySelector(`.${css.active}`)
const themeType = globalRegistry.get("themeModule").api.currentTheme().quality
const invert = themeType === 'dark' ? 1 : 0
// Remove active for the current activated icons
const currentActive = this.view.querySelector(`.${css.active}`)
if (currentActive) {
let currentTitle = currentActive.getAttribute('title')
currentActive.classList.toggle(`${css.active}`)
if (currentTitle !== name) {
let activate = this.view.querySelector(`[plugin="${name}"]`)
if (activate) activate.classList.toggle(`${css.active}`)
}
} else {
let activate = this.view.querySelector(`[plugin="${name}"]`)
if (activate) activate.classList.toggle(`${css.active}`)
currentActive.classList.remove(css.active)
let image = currentActive.querySelector('.image')
image.style.setProperty('filter', 'invert(0.5)')
}
// Add active for the new activated icon
const nextActive = this.view.querySelector(`[plugin="${name}"]`)
if (nextActive) {
let image = nextActive.querySelector('.image')
nextActive.classList.add(css.active)
image.style.setProperty('filter', `invert(${invert})`)
}
this.events.emit('showContent', name)
}
@ -216,36 +205,21 @@ const css = csjs`
padding: 3px;
position: relative;
border-radius: 8px;
filter: invert(0.5);
}
.dark{
filter: invert(0.5);
}
.light{
filter: invert(0.5);
}
.icon img {
width: 28px;
height: 28px;
padding: 4px;
filter: invert(0.5);
}
.image {
filter: invert(0.5);
}
.icon svg {
width: 28px;
height: 28px;
padding: 4px;
}
.light.active {
border-radius: 8px;
padding-top: 1px;
padding-left: 1px;
filter: invert(0);
}
.dark.active {
border-radius: 8px;
padding-top: 1px;
padding-left: 1px;
filter: invert(1);
}
.icon[title='settings'] {
position: absolute;
bottom: 0;
@ -255,4 +229,15 @@ const css = csjs`
bottom: 0;
right: 0;
}
.statusWithBG
border-radius: 8px;
background-color: var(--danger);
color: var(--light);
font-size: 12px;
height: 15px;
text-align: center;
font-weight: bold;
padding-left: 5px;
padding-right: 5px;
}
`

@ -13,9 +13,9 @@ import { FileSystemApi } from 'remix-plugin'
*/
const profile = {
displayName: 'file manager',
name: 'fileManager',
description: 'service - read/write to any files or folders, require giving permissions',
displayName: 'File manager',
description: 'Service - read/write to any files or folders, require giving permissions',
permission: true
}

@ -29,7 +29,7 @@ var canUpload = window.File || window.FileReader || window.FileList || window.Bl
const profile = {
name: 'fileExplorers',
displayName: 'file explorers',
displayName: 'File explorers',
methods: [],
events: [],
icon: '',

@ -12,7 +12,6 @@ var css = csjs`
}
.bar {
display : flex;
min-height : 3em;
z-index : 3;
}
.menu {

@ -8,11 +8,11 @@ import { EventEmitter } from 'events'
const profile = {
name: 'solidityStaticAnalysis',
displayName: 'solidity static analysis',
displayName: 'Solidity static analysis',
methods: [],
events: [],
icon: '',
description: ' - ',
description: 'Checks the contract code for security vulnerabilities and bad practices.',
kind: 'analysis',
location: 'swapPanel'
}

@ -20,10 +20,10 @@ const CompilerContainer = require('./compileTab/compilerContainer.js')
import { CompilerApi } from 'remix-plugin'
const profile = {
displayName: 'solidity compiler',
name: 'solidity',
icon: '',
description: 'compile solidity contracts',
displayName: 'Solidity compiler',
icon: '',
description: 'Compile solidity contracts',
kind: 'compile',
permission: true,
location: 'swapPanel'

@ -5,13 +5,13 @@ var DebuggerUI = require('../debugger/debuggerUI')
import { BaseApi } from 'remix-plugin'
const profile = {
displayName: 'debugger',
const profile = { displayName: 'Debugger',
name: 'debugger',
displayName: 'Solidity compiler',
methods: [],
events: [],
icon: '',
description: 'debug transactions',
description: 'Debug transactions',
kind: 'debugging',
location: 'swapPanel'
}

@ -7,12 +7,12 @@ var css = require('./styles/settings-tab-styles')
import { BaseApi } from 'remix-plugin'
const profile = {
displayName: 'settings',
name: 'settings',
displayName: 'Settings',
methods: [],
events: [],
icon: '',
description: ' - ',
description: 'Remix-IDE settings',
kind: 'settings',
location: 'swapPanel'
}

@ -9,11 +9,11 @@ const TestTabLogic = require('./testTab/testTab')
const profile = {
name: 'solidityUnitTesting',
displayName: 'solidity unit testing',
displayName: 'Solidity unit testing',
methods: [],
events: [],
icon: '',
description: ' - ',
description: 'Fast tool to generate unit tests for your contracts',
location: 'swapPanel'
}

@ -56,6 +56,7 @@ export class ThemeModule extends BaseApi {
this.storage.set('theme', next)
document.getElementById('theme-link').setAttribute('href', nextTheme.url)
document.documentElement.style.setProperty('--theme', nextTheme.quality)
this.active = themeName ? themeName : this.active
this.events.emit('themeChanged', nextTheme.quality)
}
}

@ -60,8 +60,8 @@ import { BaseApi } from 'remix-plugin'
import Section from './section'
const profile = {
displayName: 'Home',
name: 'home',
displayName: 'Home',
methods: [],
events: [],
description: ' - ',

@ -58,7 +58,7 @@ export class RemixAppManager extends AppManagerApi {
plugins () {
let vyper = {
displayName: 'vyper',
displayName: 'Vyper',
name: 'vyper',
events: ['compilationFinished'],
methods: [],

Loading…
Cancel
Save