/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef __com_sun_star_document_Settings_idl__ #define __com_sun_star_document_Settings_idl__ #ifndef __com_sun_star_beans_XPropertySet_idl__ #include #endif #ifndef __com_sun_star_i18n_XForbiddenCharacters_idl__ #include #endif //============================================================================= module com { module sun { module star { module document { //============================================================================= /** describes properties that apply to the whole document of any application.

For application specific settings, please refer to the individual services.

@see com::sun::star::text::DocumentSettings @see com::sun::star::sheet::DocumentSettings @see com::sun::star::drawing::DocumentSettings @see com::sun::star::presentation::DocumentSettings */ published service Settings { /** gives access to the properties implemented by this service. */ interface com::sun::star::beans::XPropertySet; //------------------------------------------------------------------------- // Note: These settings are global. However there is a note at // every property that shows which application currently makes use // of it. // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** gives access to the set of forbidden characters. @return the XForbiddenCharacters interface to allow retreival and modification of the forbidden characters set. */ [optional, property] com::sun::star::i18n::XForbiddenCharacters ForbiddenCharacters; // Writer and Calc //------------------------------------------------------------------------- /** specifies the update mode for links when loading text documents.

For supported values see the constants group LinkUpdateModes.

*/ [optional, property] short LinkUpdateMode; // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** printer used by the document. */ [property] string PrinterName; // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** platform and driver dependent printer setup data.

This property serves to capture the current printer setup settings, such as paper tray, printer options, etc. The data can typically be interpreted only by the system that generated it. The PrinterSetup property may be used to save and restore the user's printer settings.

*/ [property] sequence< byte > PrinterSetup; // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** specifies if kerning is applied to Asian punctuation.

Applies only if kerning is enabled.

*/ [optional, property] boolean IsKernAsianPunctuation; // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** specifies the compression (character spacing) type used for Asian characters. @see com::sun::star::text::CharacterCompressionType */ [optional, property] short CharacterCompressionType; // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** specifies if the user-specific settings saved within a document should be loaded with the document. */ [optional, property] boolean ApplyUserData; // Writer and Calc //------------------------------------------------------------------------- /** specifies if a new version is created if a document has been modified and you want to close it. */ [optional, property] boolean SaveVersionOnClose; // Writer and Draw/Impress and Calc //------------------------------------------------------------------------- /** specifies if the document should be updated when the template it was created from changes.

Applies only for documents that were created from a template.

*/ [optional, property] boolean UpdateFromTemplate; // Writer //------------------------------------------------------------------------- /** specifies if fields in text documents are updated automatically. */ [optional, property] boolean FieldAutoUpdate; // Writer //------------------------------------------------------------------------- /** The name of the globally registered DataSource from which the current data is taken.

The data source can e.g. be used for feeding a form letter.

*/ [optional, property] string CurrentDatabaseDataSource; // Writer //------------------------------------------------------------------------- /** a string value, specifying the name of the object displayed currently (or the SQL statement used). */ [optional, property] string CurrentDatabaseCommand; // Writer //------------------------------------------------------------------------- // Note: What is the property DataTableName? Is this Writer-specific? /** determines the interpretation of the property DataTableName. @see com::sun::star::sdb::CommandType */ [optional, property] long CurrentDatabaseCommandType; // Draw and Impress //------------------------------------------------------------------------- /** */ [optional, property] long DefaultTabStop; // Draw and Impress //------------------------------------------------------------------------- /** determines if the document will be printed as a booklet (brochure), i.e., two document pages are put together on one physical page, such that you can fold the print result and get a booklet.

Note, that you have to print in duplex mode, if both, IsPrintBookletFront and IsPrintBookletBack are set to .

*/ [optional, property] boolean IsPrintBooklet; // Draw and Impress //------------------------------------------------------------------------- /** is only effective, if IsPrintBooklet is . If this property is also , only the fronts of the pages of your booklet are printed.

This is especially useful, if your printer does not supply duplex printing.

*/ [optional, property] boolean IsPrintBookletFront; // Draw and Impress //------------------------------------------------------------------------- /** is only effective, if IsPrintBooklet is . If this property is also , only the backs of the pages of your booklet are printed.

This is especially useful, if your printer does not supply duplex printing.

*/ [optional, property] boolean IsPrintBookletBack; // Draw and Impress //------------------------------------------------------------------------- // Note: Define a constant group for that? /** */ [optional, property] long PrintQuality; // Draw and Impress //------------------------------------------------------------------------- /** contains the URL that points to a color table (file extension .soc) that will be used for showing a palette in dialogs using colors. */ [optional, property] string ColorTableURL; // Draw and Impress //------------------------------------------------------------------------- /** */ [optional, property] string DashTableURL; // Draw and Impress //------------------------------------------------------------------------- /** */ [optional, property] string LineEndTableURL; // Draw and Impress //------------------------------------------------------------------------- /** */ [optional, property] string HatchTableURL; // Draw and Impress //------------------------------------------------------------------------- /** */ [optional, property] string GradientTableURL; // Draw and Impress //------------------------------------------------------------------------- /** */ [optional, property] string BitmapTableURL; // Calc //------------------------------------------------------------------------- /** */ [optional, property] boolean AutoCalculate; // Writer, later others //------------------------------------------------------------------------- /** forbid use of printer metrics for layout

For supported values see the constants group PrinterIndependentLayout.

*/ [optional, property] short PrinterIndependentLayout; // Writer, maybe later other applications, too //------------------------------------------------------------------------- /** layout engine should add value of a Font's 'external leading' * attribute to the line spacing. */ [optional, property] boolean AddExternalLeading; }; //============================================================================= }; }; }; }; #endif