elk/examples/xm/message-dialog.scm

50 lines
1.5 KiB
Scheme

;;; -*-Scheme-*-
;;;
;;; Message box dialog demo
(require 'motif)
(load-widgets shell message-box row-column toggle-button push-button)
(load 'radio-stuff.scm)
(define top (application-initialize 'message-box))
(define rc (create-managed-widget (find-class 'row-column) top))
(define box (create-radio-box 'push-button rc))
(define buttons
(map (lambda (label)
(radio-box-add-button! box 'label-string label
'alignment "alignment_center"))
'(error information message question warning working)))
(for-each
(lambda (button)
(add-callback button 'activate-callback
(lambda _
(post-dialog (car (get-values button 'label-string))))))
buttons)
(define box2 (create-radio-box 'toggle-button rc 'radio-behavior #f))
(define ok (radio-box-add-button! box2 'label-string 'OK-button 'set #t))
(define cancel (radio-box-add-button! box2 'label-string 'Cancel-button
'set #t))
(define help (radio-box-add-button! box2 'label-string 'Help-button 'set #t))
(define (post-dialog type)
(let* ((shell (create-popup-shell (find-class 'dialog-shell) rc))
(box (create-widget
(find-class 'message-box) shell
'dialog-type (string->symbol (string-append "dialog-" type)))))
(unless (car (get-values ok 'set))
(unmanage-child (name->widget box 'OK)))
(unless (car (get-values cancel 'set))
(unmanage-child (name->widget box 'Cancel)))
(unless (car (get-values help 'set))
(unmanage-child (name->widget box 'Help)))
(manage-child box)))
(realize-widget top)
(context-main-loop (widget-context top))