unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* A new filter-based customization interface
@ 2024-12-09  3:37 Moakt Temporary Email
  2024-12-10 19:56 ` Philip Kaludercic
  2024-12-24  4:51 ` Richard Stallman
  0 siblings, 2 replies; 22+ messages in thread
From: Moakt Temporary Email @ 2024-12-09  3:37 UTC (permalink / raw)
  To: emacs-devel

Hi everyone,

I am proposing a new beginner-friendly customization interface, which would make emacs more attractive for newcomers, be it actual developers, future developers to be, and even non-developers (writers, students, professors, teachers, etc.), and any lambda person having interest in using emacs.

I added a screenshot of what such an interface might look like (which is better than words).
https://justpaste.it/fdau4.

The main idea of this customization interface is to help users quickly and easily customize emacs for the actual task(s) they need, by providing familiar filters so they can quickly select and access the relevant customizations.

For example, they can select “irc”, “ide”, “agenda”, “completion”, “version control”, “c++”, etc, to filter the customizations relevant to use emacs as an IRC client, IDE, etc.

Today this not possible, and would require new users days and weeks to configure emacs, which would discourage and thus discard lot of them from using emacs.

Do you think this is something achievable in emacs ?
Do you think the actual customization interface can be enhanced to include these changes ? Or should it be a new separate interface ?

I have added all the details about this idea here:
https://lists.gnu.org/archive/html/emacs-devel/2024-12/msg00174.html
(It is too long to read, that is why I am sending this separate message).

Thank you




^ permalink raw reply	[flat|nested] 22+ messages in thread
* Re: A new filter-based customization interface
@ 2024-12-16 22:02 Moakt Temporary Email
  2024-12-31  4:43 ` Richard Stallman
  0 siblings, 1 reply; 22+ messages in thread
From: Moakt Temporary Email @ 2024-12-16 22:02 UTC (permalink / raw)
  To: emacs-devel

Hi Richard,


> I looked at the image you sent.  I supposed it is supposed to be
> self-explanatory, but as often happens for graphical interfaces, I
> can't tell the meaning of what I see.
> 
> 
> In order for a graphica interface to be natural and self-evident,
> it should to be clear just by looking what each visual item means.
> Is it an alternative you can select?
> Is it a heading which describes the role of whatever follows?
> Is it a command you can click on to control the interface?
> These things are not clear to me.
> 
> Here are some of the visuak aspects for which the meaning is not clear to me.
> 
> * There is a bunch of lines at the top which start with
>     Filter by
>     1. categoryL 
>     interfaceL modeline tookbar,..
>     general: startup quit backup...
> 
> What do tese names mean?  Are they related to custom group names?
> Some of them sare names of custom groups, but some are not.
> What does each of these names mean?


Each name is a filter that user can select to filter on the corresponding user options. I tried to classify them using the most beginner-friendly terms, just to show the main idea I want yo communicate.

When the user sees such an interface, he will also have a quick idea of what he can do with emacs, he can also immediately start discovering/trying different options.


> * Is that an exhaustive list of all "categories"?


I added only some, just to show the main idea.

I can also think about other non-”by category” filters, for example:
1. by state: [customized] [non-customized (default)]
2. by version: .. [27] [28] [29] [to be removed in future versions (deprecated)]


> * If so, are you supposed to click on one to select it?
> * Or are some categories someho selexted now, and this is a list of the
> ones that are selected right now?


Yes, user can select a single filter, or combine (AND) multiple filters.
For example user can select “completion”+”auto-save”.

Each time the user select an additional filter, the list of filters should decrease, leaving only the ones that are meaningful to additionally select.

And maybe also making other sub-filters (sub-categories) appear to help further narrowing the list of customizations (under “Selected Customizations:”).
For example “auto-completion” filter can appear if “completion” filter is selected.

With this, user can precisely find what he is exactly looking for, with few easy and understandable clicks, even with a huge number of options.


> * How does the fact that a category is selected
> affect what happens in the rest of this display?


Each time the user select an additional filter, the list of customizations under “Selected Customizations:” will also decrease. The purpose is to quickly find the customizations relevant to a given task/behavior.


> The next thing it says is
> 
>   Sort by: package
> 
> What does that mean?  Is "package" one of several psople choices?  If
> so, what are the other possible choices and how do you specify another choice?


This should sort the list of customizations (under “Selected Customizations:”) by certain criteria. One example is “package”, another can be to list the already customized (non-default) first, etc.

I added it only to keep it in mind when implementing the interface, in case it turned out to be useful to the user later on. But I can’t see it is real added value for the moment.


> Then it says
> 
>   Selected Customizations:
> 
> What does that expression "selected customizations" mean?  What
> determines which customizations are selected?  How do you control
> which ones are selected?  And what do you achieve by controlling that?


The list under "Selected Customizations", are the customizations user selected by applying one or more filter(s) from the above.

Their is no filter selected in this image, but we can image that when user selects the “modeline” filter for example, we can either:
- replace it in-place by a “modeline[X]”.
- or remove it, and add a “modeline” or “modeline[X]” to a separate list of “selected filters” for example.
- or keep it in place, but change its appearance (color, etc…)
- etc.

With this, user can know what filters he already selected, and can unselected them one by one by clicking on them again.

Maybe it can also be implemented it differently.


> How does this relate to M-x customize...?
> It looks like the names of these things do NOT match names of user options.
> 
> Each item and value seem to be followed by some sort of classification,
> but what do they mean?  They do not seem to be custom groups.
> Where are they defined?  For instance, two say :modeline:,  What does
> that indicate?


Each item is a customization/option to show to the user.

The value is only a single choice (I added it for demonstration), but it can be replaced by its corresponding UI element (checkbox, dropdown menu, ...)

The classifications to the right are not part of the interface. I may have hidden them. I used them to “tag”/relate each entry to its corresponding filters/categories. These classifications are also not exhaustive (only some for demonstration).

All the options that are related to the modeline, would be tagged as “modeline”, and will be selected/filtered when user select the “modeline” filter.

Some classifications might (not) match with the actual custom groups, I tried to list them from another POV. they can be modified/adapted as needed.

This interface will require each option to have multiple groups/tags.

And maybe the user could be given the possibility to add his own tags (to each option, and to the interface), so he can categories, and quickly access his favorite options.

> What does [X] mean?  Does it mean "this is enabled"?

Yes, it represents a “checked” checkbox.


> If so, what indicates "this is not enabled"?
An “unchecked” checkbox would be represented by [ ].
But this is not how it might look like in the final interface, it is only for demonstration.
I also explained everything in details in this message https://lists.gnu.org/archive/html/emacs-devel/2024-12/msg00174.html.

I also proposed a quick “Get Started” introduction to emacs (frame, window, modeline, command, etc.), so user can directly use this interface.
This introduction can be added to emacs independently from the interface, because it already enhances user first experience with emacs, I post it under a different thread https://lists.gnu.org/archive/html/emacs-devel/2024-12/msg00064.html.

Thank you




^ permalink raw reply	[flat|nested] 22+ messages in thread
* Re: A new filter-based customization interface
@ 2024-12-31 11:49 Moakt Temporary Email
  2025-01-02  4:36 ` Richard Stallman
                   ` (4 more replies)
  0 siblings, 5 replies; 22+ messages in thread
From: Moakt Temporary Email @ 2024-12-31 11:49 UTC (permalink / raw)
  To: emacs-devel

Hi Richard,


Thank you for taking my proposition into consideration.


> Would you like to familiarize yourself with M-x configure and related
> commands, see what it does and what it doesn't do, and describe
> your idea in terms of how it differs from what we already have?
>
> Do the differences concern manner of display, or the semantics
> of the customization methods?

I listed below some of the differences that come to my mind first:


- make better choices:
many things can be done in emacs, in different ways, filtering on a specific topic, can show user that he has alternatives to what he is trying to accomplish.



- discover-ability:
emacs has many options/features (even little ones), that are of big help/change for users, in their daily use of emacs, and they often discover them (very) late.



- self-descriptive:
The interface by itself, before even using it, describes what emacs can do.
(Yet emacs can do many other things that should be added to the interface)



- navigation
I find it difficult to navigate back and forth in the actual interface.

Most softwares have a fixed menu to the left, that is always there, to which you can always refer.  And also sometimes tabs to the right (for each entry in the left menu), for which also you can always refer.

With the actual interface sometimes you also loose the sense of where you are.  You can only see the direct parent group, and also sometimes you need to scroll to see it, other times you find multiple direct parent groups which can be confusing.

With the new interface, we can avoid this.
we can display all the filter section in a buffer, and all the resulting options in another buffer, which gives the user a more pleasant navigation (although we are comparing two different concept for finding the options).



- beginner-friendly
Using terms that users may be already familiar with.  Users can be coming from different backgrounds.



- gradually introduce users to emacs vocabulary
While most of the filters would use familiar terms, there are some that are emacs-specific.  This makes users realize that these words are important/special in emacs.
For example: face, overlay, minibuffer, keybinding, keymap, font-lock, narrowing, mark, region, kill ring, mark ring, etc.

User should have been already introduced to the other more important ones (modeline, frame, window, echo area, buffer, command, etc.), which are _really_ needed to start using emacs. (check the side note below)



- intuitive
emacs has a huge number of options, for which some are candidate to more than one group, and can have also some side effects on other things happening in emacs or on the user system, etc.  So the most intuitive way I can think of is to use tags.



- visually
I did not add anything special to the interface, yet it already looks nicer.
With little modifications it can be even better, we can for example use some colors, icons, etc.



- important options when starting with emacs:
There are somehow “known” options that user would normally add/change first when starting with emacs, we can put them forward, when the user opens the interface for the first time, or group them together under a specific filter.



- extensible/flexible
The interface can be extended to include any sort of filters.
For example, we can let user filter on options depending on emacs versions [...] [27] [28] [29] [30] [deprecated], or if option is safe or not, etc.



- help/learn:
I can see the same questions are being asked from emacs users, on platforms, (how can I do this ?, etc.), while in there very question, you can find the necessary keywords, that if they use in this interface, they would easily find what they are looking for.



- help/troubleshoot:
many questions are also related to problems, (having this behavior when doing this action, or emacs became very slow, etc.). These keywords can also be used to find the corresponding responsible option(s).



- attractive
Users are often attracted by what they see first, if an image of the new interface (yet to be enhanced/modified) is posted on emacs website, or on some platforms, will be more appealing to users, than an image of the actual interface.


- more informative
We can instead of displaying filters like this:
 [modeline]  [window]  [frame]  [tab]

we can add a counter of the underlying options like this:
 [modeline(30)]  [window(25)]  [frame(10)]  [tab(15)]



- user’s tags/filters:
We can give user the possibility to tag the options himself. (by workflow, project, task, work, home, friend, favorite, check later, laptop, etc.)
These tags would automatically appear in the interface.



- accurate results
doing a text search might not find the option user is looking for, maybe because the keyword is not included, or the keyword is wrongly written, or written differently, for example “modeline”/“mode line”, or maybe a synonym of the keyword was used.

Sometimes, user may get options he was not looking for, because it happened that the keyword is present in the text.



- possible search keyword(s)
new users often don’t really know what to search for.  For example, user should search for “auto-completion” or “auto-fill”, “cut” or “kill”, “paste” or “yank”, “region” or “selection”, “cursor” or “point”, “color” or “font” or “face” or “theme” or “appearance” or “visual”, etc.

while trying different keywords in the actual interface, user will get some results (and mostly different each time), which bring more confusion.

And even though, it happens that user chose the correct keyword(s) from the first time, and as the results are not guaranteed to be accurate (check previous section), this might bring even more confusion.



- excluding tags:
This interface would normally filter on intersection ([a] AND [b]) between selected filters.
But sometimes user would need to select [a] AND [b] AND ![c].
I don’t see the usefulness of doing a union [a] OR [b], but it can also be implemented using this interface, if needed.



- task-oriented
When users choose emacs (or any other software), it is to accomplish a given task first (agenda, spellcheck, irc, etc.), this interface (a) will enable users to quickly find the options related to the given task.

If someone may find that these tags should be represented in another way (b), or someone else prefers (c).

We can give the user an option to choose between interface (a), (b) or (c), with one of them being the default.



-package integration: [^1]
we can also integrate packages, so user can easily find the needed package(s), and install them (their corresponding options would be then added).
It would be somehow similar to what “M-x finder-by-keyword RET” does.

This will also be a nice and straight-forward way to gradually introduce user to package ecosystem in emacs.



- user’s commands integration: [^2]
We can also tag the commands in the same go, so user can easily find the command(s) he needs to accomplish a certain task, the same advantages above would apply here.



- other symbols integration: [^3]
Also tagging the other api functions, variables, hooks, macros, etc, which will be a great help for users/developers trying to learn and/or write their own: (the same advantages above would apply here too)
+ to see if it already exists, before doing so.
+ to search which api they can use, for a certain task, in their own functions.
+ to find some similar functions, as an example/inspiration to what they are trying to accomplish (if the “exact” functionality is not already implemented).
+ to “discover” the available api gradually.



- other
tagging the options might have other usefulness than for using them for this interface.  Some tags can be more internally oriented, and not intended to be used/shown to user.




[^1], [^2], [^3]:
For these, they can be in a separate interface, or we can add them to the same interface, for example as below:
- filter by type: [option] [command] [variable] [function] [macro] [hook] [package]




Side Note:
----------
I wrote a “Get Started” introduction to emacs, and showed how it can be nicely integrated in the current Startup buffer, to guide the user when opening emacs for the first time (or even referring to it later as needed), and I would like to know your opinion on it.  It is the HTML code at the very end of the following message: https://lists.gnu.org/archive/html/emacs-devel/2024-10/msg00245.html.



I am proposing a global idea to make starting with emacs much easier and intuitive for newcomers and deferring any (long) reading material to later on. (this will also be useful for everyone)



Thank you




^ permalink raw reply	[flat|nested] 22+ messages in thread

end of thread, other threads:[~2025-01-02  4:37 UTC | newest]

Thread overview: 22+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-12-09  3:37 A new filter-based customization interface Moakt Temporary Email
2024-12-10 19:56 ` Philip Kaludercic
2024-12-12  4:48   ` Richard Stallman
2024-12-24  4:51 ` Richard Stallman
2024-12-24 21:10   ` Björn Bidar
     [not found]   ` <87bjx0oki1.fsf@>
2024-12-26  4:30     ` Richard Stallman
2024-12-29 15:29       ` Björn Bidar
     [not found]       ` <87o70ucxt5.fsf@>
2024-12-29 18:23         ` [External] : " Drew Adams
2024-12-29 23:39           ` Björn Bidar
2024-12-31  4:43         ` Richard Stallman
2025-01-01 20:00           ` Björn Bidar
2024-12-26  4:30     ` Richard Stallman
2024-12-29 20:02       ` Björn Bidar
     [not found]       ` <87a5ce1clq.fsf@>
2024-12-31  4:43         ` Richard Stallman
  -- strict thread matches above, loose matches on Subject: below --
2024-12-16 22:02 Moakt Temporary Email
2024-12-31  4:43 ` Richard Stallman
2024-12-31 11:49 Moakt Temporary Email
2025-01-02  4:36 ` Richard Stallman
2025-01-02  4:36 ` Richard Stallman
2025-01-02  4:36 ` Richard Stallman
2025-01-02  4:36 ` Richard Stallman
2025-01-02  4:37 ` Richard Stallman

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).