<table><tr><td style="">hein added a comment.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D12069">View Revision</a></tr></table><br /><div><div><blockquote style="border-left: 3px solid #8C98B8;
          color: #6B748C;
          font-style: italic;
          margin: 4px 0 12px 0;
          padding: 8px 12px;
          background-color: #F8F9FC;">
<div style="font-style: normal;
          padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D12069#243315" style="background-color: #e7e7e7;
          border-color: #e7e7e7;
          border-radius: 3px;
          padding: 0 4px;
          font-weight: bold;
          color: black;text-decoration: none;">D12069#243315</a>, <a href="https://phabricator.kde.org/p/davidedmundson/" style="
              border-color: #f1f7ff;
              color: #19558d;
              background-color: #f1f7ff;
                border: 1px solid transparent;
                border-radius: 3px;
                font-weight: bold;
                padding: 0 4px;">@davidedmundson</a> wrote:</div>
<div style="margin: 0;
          padding: 0;
          border: 0;
          color: rgb(107, 116, 140);"><p>Is that something that can happen now?</p></div>
</blockquote>

<p>We have a GSoC project in the Ideas list this year that's aimed at it, and there are other Linux desktops that prove it's possible (e.g. Gnome has this).</p>

<p>The goal is to evolve the keyboard settings in System Settings towards managing input languages, the way it's done in the products of most of our competitors (both free and proprietary). The general workflow is to add an input language, then select the keyboard layout for it. This is incidentally exactly how the config UI for something like ibus/fcitx works. In Plasma, currently you need to reach this via the panel widget. Via the GSoC project, we want to bring it to System Settings instead. kimpanel can then run kcmshell. Life will be good.</p>

<p>Since not all systems have an IM daemon running (although increasingly Linux systems run one by default, e.g. Gnome does for globally available emoji input), the KCM will need to have modes where it either backchannels to the IM daemon for configuration or uses xkb as before. On Wayland the situation is a little bit different since the compositor is always in charge of the layout, so it will need to talk both to KWin and the IM daemon. The details of this are still up on the air: That's why it's a multi-month project.</p>

<p>Just like the KCM will fall back to xkb on IM daemon-less systems, it makes sense to pursue this architecture as far as the panel indicators are concerned. It's long been known that the redundancy/conflict between kimpanel and the keyboard layout indicator will eventually need to be resolved/collapsed. The problems we're having:</p>

<ul class="remarkup-list">
<li class="remarkup-list-item">We have support for automagically adding the keyboard layout indicator when needed, but we lack this for kimpanel. We currently add kimpanel to the default panel on first logon based on a locale white list. But if you do first logon on an English-language system and later add, say, Chinese input (which in lieu of the GSoC project you currently need to do painfully in a manual sysadmin fashion), you need to manually add the widget. It's a TODO to make this automatic.</li>
</ul>

<ul class="remarkup-list">
<li class="remarkup-list-item">When an IM daemon is in use, the keyboard layout indicator currently becomes useless on X11 (because the IM daemon takes over keyboard layout management). But when the IM daemon goes away, it becomes useful again. Currently the user needs to do lots of manual steps to switch between them. Add/remove/hide one or the other, etc.</li>
</ul>

<p>It therefore IMHO makes sense to put the layout indicator into kimpanel as a fallback codepath (and on Wayland we'd currently always use this fallback until we figure out IM there properly). If the reaction to this is "eww, I don't understand kimpanel and I don't want to touch it", then that's exactly the problem: We need more core devs to review and improve kimpanel and integrate it properly into the core offering. It does things we need (our users rely on it), but it's currently developed largely in isolation and poorly integrated. That this is one of the few areas where we still ship two redundant/overlapping UI solutions is telling.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R120 Plasma Workspace</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D12069">https://phabricator.kde.org/D12069</a></div></div><br /><div><strong>To: </strong>apol, Plasma<br /><strong>Cc: </strong>hein, graesslin, broulik, davidedmundson, plasma-devel, ragreen, Pitel, ZrenBot, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas, apol, mart<br /></div>