xref: /AOO41X/main/sw/source/ui/dialog/ascfldlg.cxx (revision 8809db7a87f97847b57a57f4cd2b0104b2b83182)
1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_sw.hxx"
26 #ifdef SW_DLLIMPLEMENTATION
27 #undef SW_DLLIMPLEMENTATION
28 #endif
29 #include <hintids.hxx>
30 #include <rtl/textenc.h>
31 #include <i18npool/mslangid.hxx>
32 #include <com/sun/star/i18n/ScriptType.hpp>
33 #include <unotools/lingucfg.hxx>
34 #include <fontcfg.hxx>
35 #include <swmodule.hxx>
36 #include <editeng/unolingu.hxx>
37 #include <sfx2/printer.hxx>
38 #include <editeng/flstitem.hxx>
39 #include <svx/dlgutil.hxx>
40 #include <editeng/fontitem.hxx>
41 #include <editeng/langitem.hxx>
42 #include <editeng/scripttypeitem.hxx>
43 #include <swtypes.hxx>
44 #include <ascfldlg.hxx>
45 #include <shellio.hxx>
46 #include <docsh.hxx>
47 #include <doc.hxx>
48 #include <errhdl.hxx>
49 
50 #ifndef _DIALOG_HRC
51 #include <dialog.hrc>
52 #endif
53 #ifndef _ASCFLDLG_HRC
54 #include <ascfldlg.hrc>
55 #endif
56 
57 #include "vcl/metric.hxx"
58 
59 
60 using namespace ::com::sun::star;
61 
62 const sal_Unicode cDialogExtraDataClose = '}';
63 const char __FAR_DATA sDialogImpExtraData[] = "EncImpDlg:{";
64 const char __FAR_DATA sDialogExpExtraData[] = "EncExpDlg:{";
65 const sal_uInt16 nDialogExtraDataLen = 11;      // 12345678901
66 
67 SwAsciiFilterDlg::SwAsciiFilterDlg( Window* pParent, SwDocShell& rDocSh,
68                                     SvStream* pStream )
69     : SfxModalDialog( pParent, SW_RES( DLG_ASCII_FILTER )),
70     aFL( this, SW_RES( FL_1 )),
71     aCharSetFT( this, SW_RES( FT_CHARSET )),
72     aCharSetLB( this, SW_RES( LB_CHARSET )),
73     aFontFT( this, SW_RES( FT_FONT )),
74     aFontLB( this, SW_RES( LB_FONT )),
75     aLanguageFT( this, SW_RES( FT_LANGUAGE )),
76     aLanguageLB( this, SW_RES( LB_LANGUAGE )),
77     aCRLF_FT( this, SW_RES( FT_CRLF )),
78     aCRLF_RB( this, SW_RES( RB_CRLF )),
79     aCR_RB( this, SW_RES( RB_CR )),
80     aLF_RB( this, SW_RES( RB_LF )),
81     aOkPB( this, SW_RES( PB_OK )),
82     aCancelPB( this, SW_RES( PB_CANCEL )),
83     aHelpPB( this, SW_RES( PB_HELP )),
84     sSystemCharSet( SW_RES( STR_SYS_CHARSET )),
85     bSaveLineStatus( sal_True )
86 {
87     FreeResource();
88 
89     SwAsciiOptions aOpt;
90     {
91         const String& rFindNm = String::CreateFromAscii(
92                                     pStream ? sDialogImpExtraData
93                                             : sDialogExpExtraData);
94         sal_uInt16 nEnd, nStt = GetExtraData().Search( rFindNm );
95         if( STRING_NOTFOUND != nStt )
96         {
97             nStt += nDialogExtraDataLen;
98             nEnd = GetExtraData().Search( cDialogExtraDataClose, nStt );
99             if( STRING_NOTFOUND != nEnd )
100             {
101                 aOpt.ReadUserData( GetExtraData().Copy( nStt, nEnd - nStt ));
102                 nStt -= nDialogExtraDataLen;
103                 GetExtraData().Erase( nStt, nEnd - nStt + 1 );
104             }
105         }
106     }
107 
108     // read the first chars and check the charset, (language - with L&H)
109     if( pStream )
110     {
111         char aBuffer[ 4098 ];
112         sal_uLong nOldPos = pStream->Tell();
113         sal_uLong nBytesRead = pStream->Read( aBuffer, 4096 );
114         pStream->Seek( nOldPos );
115 
116         if( nBytesRead <= 4096 )
117         {
118             aBuffer[ nBytesRead ] = '0';
119             aBuffer[ nBytesRead+1 ] = '0';
120             if( 0 != ( nBytesRead & 0x00000001 ) )
121                 aBuffer[ nBytesRead + 2 ] = '0';
122         }
123 
124         sal_Bool bCR = sal_False, bLF = sal_False, bNoNormalChar = sal_False,
125             bNullChar = sal_False;
126         for( sal_uInt16 nCnt = 0; nCnt < nBytesRead; ++nCnt )
127             switch( aBuffer[ nCnt ] )
128             {
129                 case 0x0:   bNullChar = sal_True; break;
130                 case 0xA:   bLF = sal_True; break;
131                 case 0xD:   bCR = sal_True; break;
132                 case 0xC:
133                 case 0x1A:
134                 case 0x9:   break;
135                 default:
136                     if( 0x20 > aBuffer[ nCnt ] )
137                         bNoNormalChar = sal_True;
138             }
139 
140         if( !bNullChar )
141         {
142             if( bCR )
143             {
144                 if( bLF )
145                 {
146                     aOpt.SetParaFlags( LINEEND_CRLF );
147 // have to check if of CharSet is type of ANSI
148 //                  aOpt.SetCharSet( CHARSET_ANSI );
149                 }
150                 else
151                 {
152                     aOpt.SetParaFlags( LINEEND_CR );
153 // have to check if CharSet is type of MAC
154 //                  aOpt.SetCharSet( CHARSET_MAC );
155                 }
156             }
157             else if( bLF )
158             {
159                 aOpt.SetParaFlags( LINEEND_LF );
160 // have to check if of CharSet is type of ANSI
161 //              aOpt.SetCharSet( CHARSET_ANSI );
162             }
163         }
164 
165         SwDoc* pDoc = rDocSh.GetDoc();
166 
167         sal_uInt16 nAppScriptType = GetI18NScriptTypeOfLanguage( (sal_uInt16)GetAppLanguage() );
168         {
169             sal_Bool bDelPrinter = sal_False;
170             SfxPrinter* pPrt = pDoc ? pDoc->getPrinter(false) : 0;
171             if( !pPrt )
172             {
173                 SfxItemSet* pSet = new SfxItemSet( rDocSh.GetPool(),
174                             SID_PRINTER_NOTFOUND_WARN, SID_PRINTER_NOTFOUND_WARN,
175                             SID_PRINTER_CHANGESTODOC, SID_PRINTER_CHANGESTODOC,
176                             0 );
177                 pPrt = new SfxPrinter( pSet );
178                 bDelPrinter = sal_True;
179             }
180 
181 
182             // get the set of disctinct available family names
183             std::set< String > aFontNames;
184             int nFontNames = pPrt->GetDevFontCount();
185             for( int i = 0; i < nFontNames; i++ )
186             {
187                 FontInfo aInf( pPrt->GetDevFont( i ) );
188                 aFontNames.insert( aInf.GetName() );
189             }
190 
191             // insert to listbox
192             for( std::set< String >::const_iterator it = aFontNames.begin();
193                  it != aFontNames.end(); ++it )
194             {
195                 aFontLB.InsertEntry( *it );
196             }
197 
198             if( !aOpt.GetFontName().Len() )
199             {
200                 if(pDoc)
201                 {
202                     sal_uInt16 nFontRes = RES_CHRATR_FONT;
203                     if(SCRIPTTYPE_ASIAN == nAppScriptType)
204                         nFontRes = RES_CHRATR_CJK_FONT;
205                     else if(SCRIPTTYPE_COMPLEX == nAppScriptType)
206                         nFontRes = RES_CHRATR_CTL_FONT;
207 
208                     aOpt.SetFontName( ((SvxFontItem&)pDoc->GetDefault(
209                                     nFontRes )).GetFamilyName() );
210                 }
211                 else
212                 {
213                     sal_uInt16 nFontType = FONT_STANDARD;
214                     if(SCRIPTTYPE_ASIAN == nAppScriptType)
215                         nFontType = FONT_STANDARD_CJK;
216                     else if(SCRIPTTYPE_COMPLEX == nAppScriptType)
217                         nFontType = FONT_STANDARD_CTL;
218                     aOpt.SetFontName(SW_MOD()->GetStdFontConfig()->GetFontFor(nFontType));
219                 }
220             }
221             aFontLB.SelectEntry( aOpt.GetFontName() );
222 
223             if( bDelPrinter )
224                 delete pPrt;
225         }
226 
227         // initialisiere Sprache
228         {
229             if( !aOpt.GetLanguage() )
230             {
231                 if(pDoc)
232                 {
233                     sal_uInt16 nWhich = GetWhichOfScript( RES_CHRATR_LANGUAGE, nAppScriptType);
234                     aOpt.SetLanguage( ((SvxLanguageItem&)pDoc->
235                                 GetDefault( nWhich )).GetLanguage());
236                 }
237                 else
238                 {
239                     SvtLinguOptions aLinguOpt;
240                     SvtLinguConfig().GetOptions( aLinguOpt );
241                     switch(nAppScriptType)
242                     {
243                         case SCRIPTTYPE_ASIAN:
244                             aOpt.SetLanguage(MsLangId::resolveSystemLanguageByScriptType(aLinguOpt.nDefaultLanguage_CJK, SCRIPTTYPE_ASIAN));
245                         break;
246                         case SCRIPTTYPE_COMPLEX:
247                             aOpt.SetLanguage(MsLangId::resolveSystemLanguageByScriptType(aLinguOpt.nDefaultLanguage_CTL, SCRIPTTYPE_COMPLEX));
248                         break;
249                         //SCRIPTTYPE_LATIN:
250                         default:
251                             aOpt.SetLanguage(MsLangId::resolveSystemLanguageByScriptType(aLinguOpt.nDefaultLanguage, SCRIPTTYPE_LATIN));
252                     }
253                 }
254             }
255 
256             aLanguageLB.SetLanguageList( LANG_LIST_ALL, sal_True, sal_False );
257             aLanguageLB.SelectLanguage( aOpt.GetLanguage() );
258         }
259     }
260     else
261     {
262         // hide the used Control for the Export and move the
263         // other behind the charset controls
264         aFontFT.Hide();
265         aFontLB.Hide();
266         aLanguageFT.Hide();
267         aLanguageLB.Hide();
268 
269         long nY = aFontFT.GetPosPixel().Y() + 1;
270         Point aPos( aCRLF_FT.GetPosPixel() );   aPos.Y() = nY;
271         aCRLF_FT.SetPosPixel( aPos );
272 
273         aPos = aCRLF_RB.GetPosPixel();  aPos.Y() = nY;
274         aCRLF_RB.SetPosPixel( aPos );
275 
276         aPos = aCR_RB.GetPosPixel();    aPos.Y() = nY;
277         aCR_RB.SetPosPixel( aPos );
278 
279         aPos = aLF_RB.GetPosPixel();    aPos.Y() = nY;
280         aLF_RB.SetPosPixel( aPos );
281 
282         Size aSize = GetSizePixel();
283         Size aTmpSz( 6, 6 );
284         aTmpSz = LogicToPixel(aTmpSz, MAP_APPFONT);
285         aSize.Height() = aHelpPB.GetPosPixel().Y() +
286                          aHelpPB.GetSizePixel().Height() + aTmpSz.Height();
287         SetSizePixel( aSize );
288     }
289 
290     // initialisiere Zeichensatz
291     aCharSetLB.FillFromTextEncodingTable( pStream != NULL );
292     aCharSetLB.SelectTextEncoding( aOpt.GetCharSet()  );
293 
294     aCharSetLB.SetSelectHdl( LINK( this, SwAsciiFilterDlg, CharSetSelHdl ));
295     aCRLF_RB.SetToggleHdl( LINK( this, SwAsciiFilterDlg, LineEndHdl ));
296     aLF_RB.SetToggleHdl( LINK( this, SwAsciiFilterDlg, LineEndHdl ));
297     aCR_RB.SetToggleHdl( LINK( this, SwAsciiFilterDlg, LineEndHdl ));
298 
299     SetCRLF( aOpt.GetParaFlags() );
300 
301     aCRLF_RB.SaveValue();
302     aLF_RB.SaveValue();
303     aCR_RB.SaveValue();
304 }
305 
306 
307 SwAsciiFilterDlg::~SwAsciiFilterDlg()
308 {
309 }
310 
311 
312 void SwAsciiFilterDlg::FillOptions( SwAsciiOptions& rOptions )
313 {
314     sal_uLong nCCode = aCharSetLB.GetSelectTextEncoding();
315     String sFont;
316     sal_uLong nLng = 0;
317     if( aFontLB.IsVisible() )
318     {
319         sFont = aFontLB.GetSelectEntry();
320         nLng = (sal_uLong)aLanguageLB.GetSelectLanguage();
321     }
322 
323     rOptions.SetFontName( sFont );
324     rOptions.SetCharSet( rtl_TextEncoding( nCCode ) );
325     rOptions.SetLanguage( sal_uInt16( nLng ) );
326     rOptions.SetParaFlags( GetCRLF() );
327 
328     // JP: Task #71802# save the user settings
329     String sData;
330     rOptions.WriteUserData( sData );
331     if( sData.Len() )
332     {
333         const String& rFindNm = String::CreateFromAscii(
334                                     aFontLB.IsVisible() ? sDialogImpExtraData
335                                             : sDialogExpExtraData);
336         sal_uInt16 nEnd, nStt = GetExtraData().Search( rFindNm );
337         if( STRING_NOTFOUND != nStt )
338         {
339             // called twice, so remove "old" settings
340             nEnd = GetExtraData().Search( cDialogExtraDataClose,
341                                             nStt + nDialogExtraDataLen );
342             if( STRING_NOTFOUND != nEnd )
343                 GetExtraData().Erase( nStt, nEnd - nStt + 1 );
344         }
345         String sTmp(GetExtraData());
346         sTmp += rFindNm;
347         sTmp += sData;
348         sTmp += cDialogExtraDataClose;
349         GetExtraData() = sTmp;
350     }
351 }
352 
353 void SwAsciiFilterDlg::SetCRLF( LineEnd eEnd )
354 {
355     switch( eEnd )
356     {
357     case LINEEND_CR:    aCR_RB.Check();     break;
358     case LINEEND_CRLF:  aCRLF_RB.Check();   break;
359     case LINEEND_LF:    aLF_RB.Check();     break;
360     }
361 }
362 
363 LineEnd SwAsciiFilterDlg::GetCRLF() const
364 {
365     LineEnd eEnd;
366     if( aCR_RB.IsChecked() )
367         eEnd = LINEEND_CR;
368     else if( aLF_RB.IsChecked() )
369         eEnd = LINEEND_LF;
370     else
371         eEnd = LINEEND_CRLF;
372     return eEnd;
373 }
374 
375 IMPL_LINK( SwAsciiFilterDlg, CharSetSelHdl, SvxTextEncodingBox*, pBox )
376 {
377     LineEnd eOldEnd = GetCRLF(), eEnd = (LineEnd)-1;
378     LanguageType nLng = aFontLB.IsVisible()
379                     ? aLanguageLB.GetSelectLanguage()
380                     : LANGUAGE_SYSTEM,
381                 nOldLng = nLng;
382 
383     rtl_TextEncoding nChrSet = pBox->GetSelectTextEncoding();
384     if( nChrSet == gsl_getSystemTextEncoding() )
385         eEnd = GetSystemLineEnd();
386     else
387     {
388         switch( nChrSet )
389         {
390         case RTL_TEXTENCODING_MS_1252:
391 #ifdef UNX
392             eEnd = LINEEND_LF;
393 #else
394             eEnd = LINEEND_CRLF;                // ANSI
395 #endif
396             break;
397 
398         case RTL_TEXTENCODING_APPLE_ROMAN:      // MAC
399             eEnd = LINEEND_CR;
400             break;
401 
402         case RTL_TEXTENCODING_IBM_850:          // DOS
403             eEnd = LINEEND_CRLF;
404             break;
405 
406         case RTL_TEXTENCODING_APPLE_ARABIC:
407         case RTL_TEXTENCODING_APPLE_CENTEURO:
408         case RTL_TEXTENCODING_APPLE_CROATIAN:
409         case RTL_TEXTENCODING_APPLE_CYRILLIC:
410         case RTL_TEXTENCODING_APPLE_DEVANAGARI:
411         case RTL_TEXTENCODING_APPLE_FARSI:
412         case RTL_TEXTENCODING_APPLE_GREEK:
413         case RTL_TEXTENCODING_APPLE_GUJARATI:
414         case RTL_TEXTENCODING_APPLE_GURMUKHI:
415         case RTL_TEXTENCODING_APPLE_HEBREW:
416         case RTL_TEXTENCODING_APPLE_ICELAND:
417         case RTL_TEXTENCODING_APPLE_ROMANIAN:
418         case RTL_TEXTENCODING_APPLE_THAI:
419         case RTL_TEXTENCODING_APPLE_TURKISH:
420         case RTL_TEXTENCODING_APPLE_UKRAINIAN:
421         case RTL_TEXTENCODING_APPLE_CHINSIMP:
422         case RTL_TEXTENCODING_APPLE_CHINTRAD:
423         case RTL_TEXTENCODING_APPLE_JAPANESE:
424         case RTL_TEXTENCODING_APPLE_KOREAN:
425             eEnd = LINEEND_CR;
426             break;
427         }
428     }
429 
430     bSaveLineStatus = sal_False;
431     if( eEnd != (LineEnd)-1 )       // changed?
432     {
433         if( eOldEnd != eEnd )
434             SetCRLF( eEnd );
435     }
436     else
437     {
438         // restore old user choise (not the automatic!)
439         aCRLF_RB.Check( aCRLF_RB.GetSavedValue() );
440         aCR_RB.Check( aCR_RB.GetSavedValue() );
441         aLF_RB.Check( aLF_RB.GetSavedValue() );
442     }
443     bSaveLineStatus = sal_True;
444 
445     if( nOldLng != nLng && aFontLB.IsVisible() )
446         aLanguageLB.SelectLanguage( nLng );
447 
448     return 0;
449 }
450 
451 IMPL_LINK( SwAsciiFilterDlg, LineEndHdl, RadioButton*, pBtn )
452 {
453     if( bSaveLineStatus )
454         pBtn->SaveValue();
455     return 0;
456 }
457 
458 
459