.dotfiles/.local/share/gnome-shell/extensions/clipboard-indicator@tudmotu.../confirmDialog.js

73 lines
1.8 KiB
JavaScript

import St from 'gi://St';
import GObject from 'gi://GObject';
import Clutter from 'gi://Clutter';
import * as ModalDialog from 'resource:///org/gnome/shell/ui/modalDialog.js';
export class DialogManager {
#openDialog;
open (title, message, sub_message, ok_label, cancel_label, callback) {
if (this.#openDialog) return;
this.#openDialog = new ConfirmDialog(title, message + "\n" + sub_message, ok_label, cancel_label, callback);
this.#openDialog.onFinish = () => this.#openDialog = null;
this.#openDialog.open();
}
destroy () {
if (this.#openDialog) this.#openDialog.destroy();
this.#openDialog = null;
}
}
const ConfirmDialog = GObject.registerClass(
class ConfirmDialog extends ModalDialog.ModalDialog {
_init(title, desc, ok_label, cancel_label, callback) {
super._init();
let main_box = new St.BoxLayout({
vertical: false
});
this.contentLayout.add_child(main_box);
let message_box = new St.BoxLayout({
vertical: true
});
main_box.add_child(message_box);
let subject_label = new St.Label({
style: 'font-weight: bold',
x_align: Clutter.ActorAlign.CENTER,
text: title
});
message_box.add_child(subject_label);
let desc_label = new St.Label({
style: 'padding-top: 12px',
x_align: Clutter.ActorAlign.CENTER,
text: desc
});
message_box.add_child(desc_label);
this.setButtons([
{
label: cancel_label,
action: () => {
this.close();
this.onFinish();
},
key: Clutter.Escape
},
{
label: ok_label,
action: () => {
this.close();
this.onFinish();
callback();
}
}
]);
}
}
);