From 93fe3bc7f7c3e0c5d1de9e9aaf3b18f8f3b90b26 Mon Sep 17 00:00:00 2001 From: Shuhei Kadowaki Date: Thu, 16 Apr 2020 01:38:37 +0900 Subject: [PATCH 1/2] follow #722: - fix error on module selection - fix styling - fix errors on item filtering when items are Object --- lib/runtime/modules.coffee | 4 ++-- lib/ui/selector.js | 12 +++++------- styles/julia-client.less | 15 +++++++++------ 3 files changed, 16 insertions(+), 15 deletions(-) diff --git a/lib/runtime/modules.coffee b/lib/runtime/modules.coffee index 8befac90..58b6cc75 100644 --- a/lib/runtime/modules.coffee +++ b/lib/runtime/modules.coffee @@ -4,7 +4,7 @@ {debounce} = require 'underscore-plus' {client} = require '../connection' -{selector} = require '../ui' +{show} = require '../ui/selector' {module: getmodule, allmodules, ismodule} = client.import ['module', 'allmodules', 'ismodule'] @@ -66,7 +66,7 @@ module.exports = modules modules.catch (err) => console.log err - selector.show(modules, { active, infoMessage: 'Select module to evaluate in' }).then (mod) => + show(modules, { active }).then (mod) => return unless mod? if mod is @autodetect delete item.juliaModule diff --git a/lib/ui/selector.js b/lib/ui/selector.js index 42d758a9..b3335424 100644 --- a/lib/ui/selector.js +++ b/lib/ui/selector.js @@ -14,7 +14,7 @@ export function activate (_ink) { items: [], elementForItem }) - selector.element.classList.add('command-palette', 'julia-clientselector') + selector.element.classList.add('command-palette', 'julia-client-selector') panel = atom.workspace.addModalPanel({ item: selector.element }) } @@ -46,6 +46,8 @@ export function show (items, { active, emptyMessage, errorMessage, infoMessage, selector.focus() let confirmed = false return new Promise((resolve, reject) => { + // HACK: + // we can't pass those callback functions to `update` while atom-select-list's document says they can be ... selector.props.didConfirmSelection = (item) => { confirmed = true selector.cancelSelection() @@ -73,13 +75,12 @@ export function show (items, { active, emptyMessage, errorMessage, infoMessage, } } } + selector.props.filterKeyForItem = (items.length > 0 && items[0] instanceof Object) ? + item => item.primary : item => item if (items.constructor == Promise) { items.then(items => { - const filterKeyForItem = (items.length > 0 && items[0] instanceof Object) ? - item => item.primary : item => item selector.update({ items, - filterKeyForItem, emptyMessage, errorMessage, infoMessage, @@ -96,11 +97,8 @@ export function show (items, { active, emptyMessage, errorMessage, infoMessage, selector.cancelSelection() }) } else { - const filterKeyForItem = (items.length > 0 && items[0] instanceof Object) ? - item => item.primary : item => item selector.update({ items, - filterKeyForItem, emptyMessage, errorMessage, infoMessage, diff --git a/styles/julia-client.less b/styles/julia-client.less index 17af5ab7..e89a4098 100644 --- a/styles/julia-client.less +++ b/styles/julia-client.less @@ -5,12 +5,6 @@ @import "ui-variables"; @import "syntax-variables"; -.julia-client-selector { - .character-match { - font-weight: bold; - } -} - .julia { table { td { @@ -91,6 +85,15 @@ atom-text-editor.editor { } } +.julia-client-selector { + .character-match { + font-weight: bold; + } + .two-lines { + padding: 0.50em 1.0em !important + } +} + .julia-syntax-color-selector { color: @syntax-text-color; background-color: @syntax-background-color; From 25418168364daadd89735830fd554e7f7779ce6c Mon Sep 17 00:00:00 2001 From: Shuhei Kadowaki Date: Thu, 16 Apr 2020 01:56:33 +0900 Subject: [PATCH 2/2] more respect old ink's style --- styles/julia-client.less | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/styles/julia-client.less b/styles/julia-client.less index e89a4098..ab739671 100644 --- a/styles/julia-client.less +++ b/styles/julia-client.less @@ -86,12 +86,18 @@ atom-text-editor.editor { } .julia-client-selector { + .two-lines { + padding: 0.5em 1em !important; + .primary-line, .secondary-line { + line-height: 2em; + } + } + .error-message { + color: @text-color-error; + } .character-match { font-weight: bold; } - .two-lines { - padding: 0.50em 1.0em !important - } } .julia-syntax-color-selector {