Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 1 | # base class for tk common dialogues |
| 2 | # |
| 3 | # this module provides a base class for accessing the common |
Georg Brandl | 14fc427 | 2008-05-17 18:39:55 +0000 | [diff] [blame] | 4 | # dialogues available in Tk 4.2 and newer. use filedialog, |
| 5 | # colorchooser, and messagebox to access the individual |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 6 | # dialogs. |
| 7 | # |
| 8 | # written by Fredrik Lundh, May 1997 |
| 9 | # |
| 10 | |
Flavian Hautbois | 76b6451 | 2019-07-26 03:30:33 +0200 | [diff] [blame] | 11 | __all__ = ["Dialog"] |
| 12 | |
Serhiy Storchaka | 675c97e | 2020-12-25 20:19:20 +0200 | [diff] [blame] | 13 | from tkinter import Frame, _get_temp_root, _destroy_temp_root |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 14 | |
Serhiy Storchaka | dc0d571 | 2018-10-12 19:01:00 +0300 | [diff] [blame] | 15 | |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 16 | class Dialog: |
| 17 | |
Flavian Hautbois | 76b6451 | 2019-07-26 03:30:33 +0200 | [diff] [blame] | 18 | command = None |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 19 | |
| 20 | def __init__(self, master=None, **options): |
Serhiy Storchaka | bb70b2a | 2020-12-25 17:04:26 +0200 | [diff] [blame] | 21 | if master is None: |
Serhiy Storchaka | 3d569fd | 2020-12-19 12:17:08 +0200 | [diff] [blame] | 22 | master = options.get('parent') |
Flavian Hautbois | 76b6451 | 2019-07-26 03:30:33 +0200 | [diff] [blame] | 23 | self.master = master |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 24 | self.options = options |
| 25 | |
| 26 | def _fixoptions(self): |
| 27 | pass # hook |
| 28 | |
| 29 | def _fixresult(self, widget, result): |
| 30 | return result # hook |
| 31 | |
| 32 | def show(self, **options): |
| 33 | |
| 34 | # update instance options |
Guido van Rossum | c457048 | 1998-03-20 20:45:49 +0000 | [diff] [blame] | 35 | for k, v in options.items(): |
| 36 | self.options[k] = v |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 37 | |
| 38 | self._fixoptions() |
| 39 | |
Serhiy Storchaka | 675c97e | 2020-12-25 20:19:20 +0200 | [diff] [blame] | 40 | master = self.master |
| 41 | if master is None: |
| 42 | master = _get_temp_root() |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 43 | try: |
Serhiy Storchaka | 675c97e | 2020-12-25 20:19:20 +0200 | [diff] [blame] | 44 | self._test_callback(master) # The function below is replaced for some tests. |
| 45 | s = master.tk.call(self.command, *master._options(self.options)) |
| 46 | s = self._fixresult(master, s) |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 47 | finally: |
Serhiy Storchaka | 675c97e | 2020-12-25 20:19:20 +0200 | [diff] [blame] | 48 | _destroy_temp_root(master) |
Guido van Rossum | 1e8c8a2 | 1997-07-19 20:02:36 +0000 | [diff] [blame] | 49 | |
| 50 | return s |
Serhiy Storchaka | 675c97e | 2020-12-25 20:19:20 +0200 | [diff] [blame] | 51 | |
| 52 | def _test_callback(self, master): |
| 53 | pass |