kdeconnect-kde/plugins
Christoph Wolk 9f34092aa9 plugins/runcommand: make config dialog HIG-compliant
The HIG recommend that buttons with an action label that require further
user input end in an ellipsis, and that dialog buttons should clearly
indicate what they do. Button labels typically do not match the given
exceptions that license sentence case. Currently, the main "Add command"
button in the configuration button does not end in an ellipsis even
though it opens a dialog, is sentence case, and the dialog has a "Save"
rather than the customary "Add" that is used for these kinds of actions,
in particular in kcms. The dialog title is also not translatable.

This change adds the ellipsis, converts the button to title case, makes
the dialog title translatable, and adds an "Add" button as an action to
the dialog.
2024-09-08 13:19:44 +00:00
..
battery SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
bigscreen SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
clipboard SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
connectivity-report SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
contacts SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
findmyphone SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
findthisdevice SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
lockdevice SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
mmtelephony SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
mousepad SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
mpriscontrol SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
mprisremote SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
notifications SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
pausemusic SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
ping SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
presenter SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
remotecommands SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
remotecontrol SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
remotekeyboard SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
remotesystemvolume SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
runcommand plugins/runcommand: make config dialog HIG-compliant 2024-09-08 13:19:44 +00:00
screensaver-inhibit SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
sendnotifications SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
sftp SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
share SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
sms Fix clang-format 14 being confused about comment before access modifier 2024-09-08 08:46:53 +00:00
systemvolume plugins/systemvolume: Work around remaining clang-format differences between different versions 2024-09-08 08:46:53 +00:00
telephony SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
virtualmonitor SVN_SILENT made messages (.desktop file) - always resolve ours 2024-08-28 01:25:08 +00:00
CMakeLists.txt Cleanup all occurences of QT_MAJOR_VERSION in cmake 2023-12-28 17:49:07 +01:00
kdeconnect.notifyrc SVN_SILENT made messages (.desktop file) - always resolve ours 2024-07-30 01:23:49 +00:00
kdeconnect.schema.json Add custom JSON schema, extending KPluginMetaData and enforcing KDE-Connect specific keys 2024-08-12 11:01:22 +00:00
Messages.sh Figure out Messages.sh after code refactoring 2014-06-17 18:45:47 +02:00
README.txt Fix file name on plugin's readme. 2022-11-27 01:40:51 +00:00

Writing a plugin for KDE Connect
=================================

For the desktop client (this project):
--------------------------------------

1. Enter the "plugins" directory.
2. Copy the "ping" under a different name ("findmyphone" in this example).
3. Add "add_subdirectory(findmyphone)" to CMakeLists.txt after the others "add_subdirectory".
4. Enter the new "findmyphone" directory.
5. Edit CMakeLists.txt by replacing "ping" with "findmyphone".
6. Rename other files in this directory by replacing "ping" with "findmyphone"
7. Write a description of your plugin into "README"
8. Edit findmyphoneplugin.cpp and findmyphoneplugin.h.
  A. Change license header.
  B. Replace (case sensitive) "ping" with "findmyphone", "PingPlugin" with "FindMyPhonePlugin" and "PING" with "FINDMYPHONE".
9. Edit kdeconnect_findmyphone.json file:
  A. Replace "ping" with "findmyphone".
  B. Change name, description, icon, author, email, version, website, license info.
  C. Remove all the translations
  D. Set X-KDEConnect-SupportedPacketType and X-KDEConnect-OutgoingPacketType to the packet type your plugin will receive
     and send, respectively. In this example this is "kdeconnect.findmyphone". Make sure that this matches what is defined in
     the findmyphoneplugin.h file (in the line "#define PACKET_TYPE_..."), and also in Android.
10. Now you have an empty skeleton to implement your new plugin logic.

For Android (project kdeconnect-android):
-----------------------------------------

1. Change directory to src/org/kde/kdeconnect/Plugins.
2. Copy "PingPlugin" under a different name ("FindMyPhonePlugin" in this example).
3. Enter the new "FindMyPhonePlugin" directory.
4. Rename "PingPlugin.java" to "FindMyPhonePlugin.java"
5. Edit it. Replace (case sensitive) "Ping" with "FindMyPhone", "ping" with "findmyphone", "PING" with "FINDMYPHONE"
   and "plugin_ping" with "plugin_findmyphone".
6. Open res/values/strings.xml. Find and copy the lines "pref_plugin_ping_desc" and "pref_plugin_ping" replacing "ping"
   with "findmyphone" and edit the plugin name and description between <string> </string>).
7. Now you have an empty skeleton to implement your new plugin logic.