Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Plugin support for adding action links to users and comments #6264

Open
kontrollanten opened this issue Mar 12, 2024 · 6 comments · May be fixed by #6692
Open

Plugin support for adding action links to users and comments #6264

kontrollanten opened this issue Mar 12, 2024 · 6 comments · May be fixed by #6692
Labels
Component: PeerTube Plugin 📦 Features that can be developed in a plugin, but require PeerTube plugin API development Type: Feature Request ✨

Comments

@kontrollanten
Copy link
Contributor

Describe the problem to be solved

Spam protection plugins, like the akismet plugin, should have the possibility to mark existing users and comments as spam.

Describe the solution you would like

Possibility to add actions in the following places:

  • user list
  • comments list
  • abuse list
  • video comments
  • account page
@Chocobozzz Chocobozzz added Type: Feature Request ✨ Component: PeerTube Plugin 📦 Features that can be developed in a plugin, but require PeerTube plugin API development labels Mar 12, 2024
@kontrollanten
Copy link
Contributor Author

I've started looking into this. It's pretty straight forward adding filters to be able to alter the dropdown action menus, but I got stuck onto two issues:

  • When running the handler we'd like to show some kind of loading indicator.
  • When the handler is done the view should be reloaded to see the result of the actions (when marking a comment as spam in the comments list, the comments list should be updated).

The first issue may not be a big deal, even though it will impair the UX. But the second issue must be handled in some way to solve this.

What about adding a trigger function to the plugin client API? The API could look like:

triggerAction('video-watch.comment-list.reload');
triggerAction('loading-indicator.load-start');
triggerAction('loading-indicator.load-end');

The triggerAction API may be useful in other cases as well. Any thoughts, @Chocobozzz ?

@kontrollanten
Copy link
Contributor Author

Ping @Chocobozzz

@Chocobozzz
Copy link
Owner

Sorry for the late feedback! Seems like a good idea. Do you have an example of other plugin systems that use such a method to ask for the core client to perform actions?

@kontrollanten
Copy link
Contributor Author

Unfortunately not

@kontrollanten
Copy link
Contributor Author

Wordpress has something similar.

function example_callback( $arg1, $arg2 ) {
    // (maybe) do something with the args.
}
add_action( 'example_action', 'example_callback', 10, 2 );

/*
 * Trigger the actions by calling the 'example_callback()' function
 * that's hooked onto `example_action` above.
 *
 * - 'example_action' is the action hook.
 * - $arg1 and $arg2 are the additional arguments passed to the callback.
do_action( 'example_action', $arg1, $arg2 )

https://developer.wordpress.org/reference/functions/do_action/

In our case it can be translated to:

video-comments.component.ts

  ngOnInit () {
    addAction('video-watch.comment-list.reload', this.resetVideo)
    ...
  }

  ngOnDestroy () {
    removeAction('video-watch.comment-list.reload')
    ...
  }

plugin.js

const onClickSpamButton = () => {
  deleteComment()
  doAction('video-watch.comment-list.reload')
}

@Chocobozzz
Copy link
Owner

Chocobozzz commented Sep 19, 2024

Seems interesting, plugins would also be able to add actions. I agree with the design!

@kontrollanten kontrollanten linked a pull request Oct 25, 2024 that will close this issue
1 task
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Component: PeerTube Plugin 📦 Features that can be developed in a plugin, but require PeerTube plugin API development Type: Feature Request ✨
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants