Explain the deal with calendars, files, and their names up here.
Points to cover:
OK, OK -- it looks like we've covered a lot of the ground about "current" in the new(ish) Section 2.3.6.4.
Also need firm definition of "current", to whit:
Zero or more calendars may be open at any time. Need to be clear about the distinction between an open calendar versus an open calendar file. I'm pretty sure it's pretty much the same distinction as a buffer and file in emacs, however it seems that with the requirments we've developed this far, a calendar doesn't get a name until it's stored to a file, i.e., the calendar's name is synonymous (and co-existent with) its file name. This may actually point to a problem we've not yet (I don't think) adequately addressed, viz., having more than one unsaved calendar open at the same time, i.e., as the result of executing `File New' more than once without executing any saves for the new calendars.
The name of the currently active file is listed in the banner of the command menubar. When no calendar file is open, the file name in the banner is listed as "none" (or perhaps, per musing above, something like "no name" is better). If the active calendar is that of another user, that user's name is displayed in place of the file name, in the form "OTHER USER: user name".
When exactly one calendar file is open, its name is listed only in the banner of the command menubar, not in any other display window. When two or more calendar files are open, the banner of every display window is augmented with the name of the file on which the displayed data are or will be stored.
The effect of multiple files on the windowing modes is as follows. Every window says what file it's associated with. The current file is defined as the file associated with the current window. Whenever a different window becomes active, the current file is changed to the file of that window. The banner of the menubar is changed as necessary dynamically. The default per-level windowing mode applies separately to each
22aug01 Note: The problem with every window having the file ID in the banner is that with the newish listing and filtering banner paraphenalia, the banners may get too crowded. So, let's leave the filename out of the individual window banners and have it just be in the menubar banner, updating as noted in the preceding paragraph.
This paragraph is now WRONG. Note that File Close and Window Close are different commands. The former closes a file and all windows containing views of that file's data. The latter closes only the current window and does not close the file (ever), even if the window is the last or only window open for (i.e., belonging to) a particular calendar.
Mention that the solid/grey type deal applies to options loading, but instead of calendar file types shown in solid type, calendar option files are shown in solid type.
Some `File Close' details:
6aug03 Notes:
Another 4aug03 Note. OK, I think I want to take back what I say in the next paragraph. I think it's appropriate to require that each user calendar be stored in a separate file in a known (settable) dir, with some reasonable convention for file name, such as the user's ID plus ".cal" extenstion.
4aug03 Note (if not mentioned elsewhere): Implementors can choose how they implement the central host repository, e.g., having a separate cal file for each user or having all user cals in the same file, or some other implementation. There is no requirement that a user be able to view the contents of a calendar in the central repository as a raw file in any form. Operatioally, the user has her own local calendar as a file with a known name. On the remote host, the publically-visible contents of that calendar are made available to other users through the calendar tool, via the operational effects of connecting and file saving described herein. Again, however, there is no requirement for the user to see a specific calendar file on the central host.
When the user saves and the current calendar is connected to one or more (active) hosts the calendar is written to those hosts.
Note that `Save' and `Save As' are disabled when the current window is that of another user's or group's calendar.
NOTE: Given the new unified view of options as just another type of "other data", there should not be a speific offer-to-save for options that is fundamentally different that offer to save other unsaved changes, such as categories or filters. Therefore, as noted somewhere abouts, we can mention, but not really make special cases for, the kinds of unsaved changes that exist when the offer-to-save dialog comes up.
If the user exectues `File Save' for a calendar with unapplied aux data, the file-save dialog contains the message and radio buttons:
If the user chooses the first radio option, the options are saved and the state of the otions for the saved calendar go from unsaved to saved, which will be reflected in the options dialog. If the user chooses the secon radio option,"There are X changes for this calendar." (x) Apply these changes before saving ( ) Do not apply these changes before saving
Some `Save As' Details:
It's more than just the window config since it includes what files are open. I think the easiest way to define exactly what save config does is as a script file. This way we can deal with the tricky issue of having the dispaly look the same, but having the displayed content all be relative to today's date. If for some reason the user would like to have a config that is absolute datewise, of relative some other date than today, then she can tweak the generated script from `Save Config', or of course write her own start-up script from scratch.
An issue we need to deal with is the relationship between the option setting of what we call "the standard default view" in the ui-overview. Here's what I think could work well: There is an option called `Start-Up View Level' that specifies the default viewing level from item to year. If there is no init file in the user's home dir (per OS-specific definition of "home dir" and as discussed further in Admin section), then the Cal Tool comes up a la described in the initial screen config in the ui-overview. Viz., there's a menubar and zero or one view window at the level specified by the setting of `Start-Up View Level', open on today's date. If there is an init file or the tool is invoked with an start-up file in the command line or from a start-up file icon, then we could do one of two things:
This works because of the rule that says the default window is put up before the init file is run, which means therefore that it's window 1 in the windows list, hence the arg of 1 to ViewWindows (assuming lists start from 1 like humans think, not from 0 like geeks think). But given this, here's an even simpler bit of code to do the same thing:ViewWindows(1); FileClose();
which works for hopefully obvious reasons.FileCloseAll();
This all seems pretty darn clean. To be consistent, it seems with this scheme that the first like of the init file saved with `Save Config' will in fact be the preceding chunk of code to close the default window, so that the config file starts with a blank slate.
Sketch of some ideas: The print dialog should include at least the following options:
So, here's the deal with printing. We'll keep it brutally simple by printing out in the plain text form of the current example-items file. In fact, we can use this file pretty much as is, except for the parenthetical remarks about edits made. We'll also need to add some kind of indication of individual instance changes to recurring items, which will be done in the same brutally simple form.
If the user exits or closes a calendar with unsaved options, then in addition to whatever offer-to-save file messages there may be, there are also offer-to- save options messages. Viz., there is one such message for each active calendar for which options have been applied but not saved. The text of these offer-to-save messages should most likely be integrated into the file offer-to- save dialogs, so two dialogs don't appear if both the file data and options need to be saved for a particular calendar.
If the user exits or closes a calendar with notifications that have not yet been responded to, the system displays a dialog of the form:
If the user chooses 'Review' and then grows tired of it before all notifications are processed (where processing means pressing one of the three buttons on the bottom, or explicitly closing the notification dialog (which is equivalent to Delay)), then she can select Exit of Close again (whichever of which started the whole thing, or either) and then hit Discard.There are meeting notifications you have not yet processed. Do you want to review or discard the unprocessed notiications? Review Discard
NOTE: Adjust the following fodder pulled from the options section to apply uniformly to all four types of aux data. What might be nice is to use this options-specific scenario as the concrete example for all five types of aux data. See also the semi-epiphany in Section 2.11.26.
The `Save As ...' button is used to save a copy of the current option
settings in a selected file. Saving options in different files allows the user
to create different option configurations that can be loaded using the options
`Load' command. When the user presses `Save As ...', the
system displays a dialog of the form shown in Figure 285.
Figure 285: Options save-as dialog.
To save options to a file, the user enters the filename in the save-as dialog
and presses `OK'. For example, Figure 286 shows the user having
entered the file name "PersonalOptions" as the location to which options
are saved.
Figure 286: Saving options to a PersonalOptions file.
The `Load ...' button is used to load a previously-saved options file.
When the user presses `Load ...', and there are no unapplied or unsaved
options, the system displays the dialog in
Figure 287.
Figure 287: Options load dialog.
To load options from a local file, the user selects or enters a filename in the
`File:' text field. The user can alternatively load the
administrator-defined options file from the Calendar Tool central host
computer, if the user is currently connected to an operational central host
(see
Section
).
If the user is not so connected, the `Load from central host' checkbox is
disabled. Figure 288 shows the user having selected to load from the
"Personal Options" file.
Figure 288: Loading from the Personal Options file.
Figure 289: Loading options from the Calendar Tool central host.
If there are unapplied or unsaved option changes when the user presses `Load
...', the system issues the warning shown in Figure 290,
Figure 290: .
The `Load' command does not perform `Apply' or `Save'. Once options are loaded, they are both unapplied and unsaved. Hence, loading has precisely the same effect as if the user had manually entered all of the loaded values in the options dialog.
Leaning towards fixing the following paragraph to allow load from (and maybe save to) two sources -- options files and (portions of) calendar files. If this happens, we need to fix above too. See Section 2.8.9 for an overview. So if we allow load from cal file but not save-as to cal file, here's how we accomplish save-into: open the cal file, load, save (as opposed to save-as).
Even though calendar-specific options are stored within calendar files, the `Save As' and `Load' option commands operate only on separate options files, not on the options portion of calendar files. The system considers calendar files and saved option files as two different file types (see Section 2.8.9 ). When an extant calendar file is selected in the `Save As' file-selection dialog, saving to that file replaces the previous file contents entirely, in just the same way as saving to any other extant file would do. The `Load' options command can only be used to load previously saved options files, not the options portion of a calendar file. Sections 2.8.1 and 2.8.2 describe how file dialogs display inapplicable file types and the details of overwriting extant files.
Since options are calendar-specific, the `Apply' and `Save' commands operate only on one calendar at a time, namely the current calendar. Switching to a different current calendar always makes the options for the newly current calendar become active, without applying or saving options for the previously current calendar. Given this behavior, there is no direct way to save or apply the same option settings to multiple calendars en masse. To apply or save the same option settings to more than one calendar, the user must save the options to a file, make a new calendar current, load the saved options, and then apply or save the loaded options to the newly current calendar.
Any applied but unsaved changes are not saved by `Cancel'. If the options dialog is subsequently opened on a calendar with unsaved option settings, the unsaved state of the options is reflected by the `Save' button being enabled. If user closes a calendar with unsaved options or exits the Calendar Tool when one or more calendars have unsaved options, the system warns the user of the condition, as described in Sections 2.3.6.1 and 2.8.5.
Local Files dialog now has two items: path for local file directory and name of default calendar file to open when the app is launched as an app as opposed to from a file. If the user specifies a value for the default start-up calendar and then invokes the cal tool from a file, the file from which the tool is invoked overrides the default start-up calendar.
NOT to all of the following paragraph; coverage of `File->Local Files' since it's been nuked to a command and moved to Admin options; the priv admin `File->Host Files' has been moved to the priv Admin menu. So, what this section covers is what's in the files (a review, most likely), but not these two commands, since they're not on a file menu anymore.
Need to cover `File->Local Files' command here or elsewhere, as well as the privileged admin `File->Host Files' command. With `File->Local Files' regular users should be able to set the path to where the local files are. When creating a config, admints can set the default value for the local files
There are four standard fixed-name files used by the CalendarTool:
Here's the order in which files are handled on start up:
Given the nixing of CommunityCalendar as the global calendar, the folloiwng paragraph is WRONG. If the CommunityCalendar file is deleted or corrupted, it's as if the user sets `Options.Meetings.When to Show Meeting Notifications' to `never', but otherwise things are as normal. Note that deleting (or renaming) CommunityCalendar on the user's local computer does not delete any of the user's community calendar information on any central host on which the user is registered. In order to do this, the user must contact the system adminstrator(s) on the host(s) from the user wants to be unsubscribed. There need not be any explicitly identifiable CommunityCalendar file on the central host. It is up to the user to be prudent about saving backup copies of calendar files, including the CommunityCalendar. There is no Calendar Tool command to download the contents of a CommunityCalendar file from a Calendar Tool central host.
Note that the value of the local files directory path, user settable via the `File->Local Files' command, is stored in the application program itself, not in a file. There's chicken-and-egg thing going on here [which I'll explan a bit more in due course].
The `Connect' command was described in
Section 2.6.6.1
on administrative commands. When the user selects the `Local Files'
command, the system displays the dialog shown in Figure 291.
Stick in the `Default Calendar Tool
Directory'
item from the Admin tab of the Options dialog.
Figure 291: Local files dialog.
Discuss the different file types and the ramifications thereof, including that filetypes are used to do the filename greying thing in open/load dialogs, and that file typing may vary in different operating environments.
OK, try this: (See the semi-epiphany in options.me.) Also, as a non- annoyiing emacs-like behavior, we'll list all file names greyed out in all save-as dialogs, but all the user to select them. This way in contexts like the options save-as dialog, we can let the user select the standard Options file in the chooser for overwriting. Given this behavior, we may well want to specialize the overwrite message into two cateogories: (1) overwriting an extant file of the correct type (e.g., overwriting Options from the options save-as dialog or an extant cal file from File->Save As) (2) overwriting an extant file of the wrong type (e.g., overwriting Categories the options save-as dialog or an extant file of some non- cal-tool type from the File->Save As dialog. It think is is all pretty farging sweet.