Skip to content

Commit 63fdf92

Browse files
authoredSep 7, 2017
Using the localized texts in UI (#979)
* Making the constants used in views and also the commands and settings localizable
1 parent d786cbe commit 63fdf92

23 files changed

+594
-90
lines changed
 

‎.gitignore

+2-1
Original file line numberDiff line numberDiff line change
@@ -17,4 +17,5 @@ coverage
1717
test-reports
1818
.vscode-test
1919
localization/i18n/
20-
src/constants/localizedConstants.ts
20+
src/constants/localizedConstants.ts
21+
package.nls.*.json

‎gulpfile.js

+1-1
Original file line numberDiff line numberDiff line change
@@ -120,7 +120,7 @@ gulp.task('ext:copy-appinsights', () => {
120120

121121
gulp.task('ext:copy', gulp.series('ext:copy-tests', 'ext:copy-js', 'ext:copy-config'));
122122

123-
gulp.task('ext:localization', gulp.series('ext:localization:xliff-to-ts', 'ext:localization:xliff-to-json'));
123+
gulp.task('ext:localization', gulp.series('ext:localization:xliff-to-ts', 'ext:localization:xliff-to-json', 'ext:localization:xliff-to-package.nls'));
124124

125125
gulp.task('ext:build', gulp.series('ext:localization', 'ext:lint', 'ext:compile', 'ext:copy'));
126126

Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="zh-Hans">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="zh-Hant">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="de">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>

‎localization/xliff/enu/constants/localizedConstants.enu.xlf

+42
Original file line numberDiff line numberDiff line change
@@ -293,6 +293,48 @@
293293
<trans-unit id="noActiveEditorMsg">
294294
<source xml:lang="en">A SQL editor must have focus before executing this command</source>
295295
</trans-unit>
296+
<trans-unit id="maximizeLabel">
297+
<source xml:lang="en">Maximize</source>
298+
</trans-unit>
299+
<trans-unit id="restoreLabel">
300+
<source xml:lang="en">Restore</source>
301+
</trans-unit>
302+
<trans-unit id="saveCSVLabel">
303+
<source xml:lang="en">Save as CSV</source>
304+
</trans-unit>
305+
<trans-unit id="saveJSONLabel">
306+
<source xml:lang="en">Save as JSON</source>
307+
</trans-unit>
308+
<trans-unit id="saveExcelLabel">
309+
<source xml:lang="en">Save as Excel</source>
310+
</trans-unit>
311+
<trans-unit id="resultPaneLabel">
312+
<source xml:lang="en">Results</source>
313+
</trans-unit>
314+
<trans-unit id="selectAll">
315+
<source xml:lang="en">Select all</source>
316+
</trans-unit>
317+
<trans-unit id="copyLabel">
318+
<source xml:lang="en">Copy</source>
319+
</trans-unit>
320+
<trans-unit id="copyWithHeadersLabel">
321+
<source xml:lang="en">Copy with Headers</source>
322+
</trans-unit>
323+
<trans-unit id="executeQueryLabel">
324+
<source xml:lang="en">Executing query...</source>
325+
</trans-unit>
326+
<trans-unit id="messagePaneLabel">
327+
<source xml:lang="en">Messages</source>
328+
</trans-unit>
329+
<trans-unit id="lineSelectorFormatted">
330+
<source xml:lang="en">Line {0}</source>
331+
</trans-unit>
332+
<trans-unit id="elapsedTimeLabel">
333+
<source xml:lang="en">Total execution time: {0}</source>
334+
</trans-unit>
335+
<trans-unit id="msgCannotSaveMultipleSelections">
336+
<source xml:lang="en">Save results command cannot be used with multiple selections.</source>
337+
</trans-unit>
296338
</body>
297339
</file>
298340
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,199 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en">
4+
<body>
5+
<trans-unit id="extension.runQuery">
6+
<source xml:lang="en">Execute Query</source>
7+
</trans-unit>
8+
<trans-unit id="extension.runCurrentStatement">
9+
<source xml:lang="en">Execute Current Statement</source>
10+
</trans-unit>
11+
<trans-unit id="extension.cancelQuery">
12+
<source xml:lang="en">Cancel Query</source>
13+
</trans-unit>
14+
<trans-unit id="extension.connect">
15+
<source xml:lang="en">Connect</source>
16+
</trans-unit>
17+
<trans-unit id="extension.disconnect">
18+
<source xml:lang="en">Disconnect</source>
19+
</trans-unit>
20+
<trans-unit id="extension.manageProfiles">
21+
<source xml:lang="en">Manage Connection Profiles</source>
22+
</trans-unit>
23+
<trans-unit id="extension.chooseDatabase">
24+
<source xml:lang="en">Use Database</source>
25+
</trans-unit>
26+
<trans-unit id="extension.showGettingStarted">
27+
<source xml:lang="en">Getting Started Guide</source>
28+
</trans-unit>
29+
<trans-unit id="extension.newQuery">
30+
<source xml:lang="en">New Query</source>
31+
</trans-unit>
32+
<trans-unit id="extension.rebuildIntelliSenseCache">
33+
<source xml:lang="en">Refresh IntelliSense Cache</source>
34+
</trans-unit>
35+
<trans-unit id="mssql.logDebugInfo">
36+
<source xml:lang="en">[Optional] Log debug output to the VS Code console (Help -> Toggle Developer Tools)</source>
37+
</trans-unit>
38+
<trans-unit id="mssql.maxRecentConnections">
39+
<source xml:lang="en">The maximum number of recently used connections to store in the connection list.</source>
40+
</trans-unit>
41+
<trans-unit id="mssql.connections">
42+
<source xml:lang="en">Connection profiles defined in 'User Settings' are shown under 'MS SQL: Connect' command in the command palette.</source>
43+
</trans-unit>
44+
<trans-unit id="mssql.connection.server">
45+
<source xml:lang="en"><![CDATA[[Required] Specify the server name to connect to. Use 'hostname\\instance' or '<server>.database.windows.net' for Azure SQL Database.]]></source>
46+
</trans-unit>
47+
<trans-unit id="mssql.connection.database">
48+
<source xml:lang="en">[Optional] Specify the database name to connect to. If database is not specified, the default user database setting is used, typically 'master'.</source>
49+
</trans-unit>
50+
<trans-unit id="mssql.connection.user">
51+
<source xml:lang="en">[Optional] Specify the user name for SQL Server authentication. If user name is not specified, when you connect, you will be asked again.</source>
52+
</trans-unit>
53+
<trans-unit id="mssql.connection.password">
54+
<source xml:lang="en">[Optional] Specify the password for SQL Server authentication. If password is not specified or already saved, when you connect, you will be asked again.</source>
55+
</trans-unit>
56+
<trans-unit id="mssql.connection.authenticationType">
57+
<source xml:lang="en">[Optional] Specify the SQL Server authentication type.</source>
58+
</trans-unit>
59+
<trans-unit id="mssql.connection.port">
60+
<source xml:lang="en">[Optional] Specify the port number to connect to.</source>
61+
</trans-unit>
62+
<trans-unit id="mssql.connection.encrypt">
63+
<source xml:lang="en">[Optional] When set to 'true', SQL Server uses SSL encryption for data sent between the client and the server if the server has a certificate installed. Set 'true' for Azure SQL Database connection.</source>
64+
</trans-unit>
65+
<trans-unit id="mssql.connection.trustServerCertificate">
66+
<source xml:lang="en">[Optional] When set to 'true', the SQL Server SSL certificate is automatically trusted when the communication layer is encrypted using SSL. Set 'false' for Azure SQL Database connection.</source>
67+
</trans-unit>
68+
<trans-unit id="mssql.connection.persistSecurityInfo">
69+
<source xml:lang="en">[Optional] When set to false, security-sensitive information, such as the password, is not returned as part of the connection if the connection is open or has ever been in an open state.</source>
70+
</trans-unit>
71+
<trans-unit id="mssql.connection.connectTimeout">
72+
<source xml:lang="en">[Optional] Specify the length of time in seconds to wait for a connection to the server before it times out. The default timeout value for Azure SQL Database is 30.</source>
73+
</trans-unit>
74+
<trans-unit id="mssql.connection.connectRetryCount">
75+
<source xml:lang="en">[Optional] Specify the number of attempts to restore connection.</source>
76+
</trans-unit>
77+
<trans-unit id="mssql.connection.connectRetryInterval">
78+
<source xml:lang="en">[Optional] Specify the delay between attempts to restore connection.</source>
79+
</trans-unit>
80+
<trans-unit id="mssql.connection.workstationId">
81+
<source xml:lang="en">[Optional] Specify the name of the workstation connecting to SQL Server.</source>
82+
</trans-unit>
83+
<trans-unit id="mssql.connection.applicationIntent">
84+
<source xml:lang="en">[Optional] Declares the application workload type when connecting to SQL Server such as ReadWrite or ReadOnly. Refer to SQL Server AlwaysOn for more detail.</source>
85+
</trans-unit>
86+
<trans-unit id="mssql.connection.currentLanguage">
87+
<source xml:lang="en">[Optional] Indicates the SQL Server language settings.</source>
88+
</trans-unit>
89+
<trans-unit id="mssql.connection.pooling">
90+
<source xml:lang="en">[Optional] When set to 'true', the connection object is drawn from the appropriate pool, or if necessary, is created and added to the appropriate pool.</source>
91+
</trans-unit>
92+
<trans-unit id="mssql.connection.maxPoolSize">
93+
<source xml:lang="en">[Optional] Specify the maximum number of connections allowed in the pool.</source>
94+
</trans-unit>
95+
<trans-unit id="mssql.connection.minPoolSize">
96+
<source xml:lang="en">[Optional] Specify the minimum number of connections allowed in the pool.</source>
97+
</trans-unit>
98+
<trans-unit id="mssql.connection.loadBalanceTimeout">
99+
<source xml:lang="en">[Optional] Specify the minimum amount of time in seconds for this connection to live in the pool before being removed/deleted.</source>
100+
</trans-unit>
101+
<trans-unit id="mssql.connection.replication">
102+
<source xml:lang="en">[Optional] Used by SQL Server in replication.</source>
103+
</trans-unit>
104+
<trans-unit id="mssql.connection.attachDbFilename">
105+
<source xml:lang="en">[Optional] Specify the name of the primary file, including the full path name, of an attachable database.</source>
106+
</trans-unit>
107+
<trans-unit id="mssql.connection.failoverPartner">
108+
<source xml:lang="en">[Optional] Specify the name or network address of the instance of SQL Server that acts as a failover partner.</source>
109+
</trans-unit>
110+
<trans-unit id="mssql.connection.multiSubnetFailover">
111+
<source xml:lang="en">[Optional] When set to 'true', the detection and connection to the active server is faster if AlwaysOn Availability Group is configured on different subnets.</source>
112+
</trans-unit>
113+
<trans-unit id="mssql.connection.multipleActiveResultSets">
114+
<source xml:lang="en">[Optional] When set to 'true', multiple result sets can be returned and read from on connection.</source>
115+
</trans-unit>
116+
<trans-unit id="mssql.connection.packetSize">
117+
<source xml:lang="en">[Optional] Specify the size in bytes of the network packets to communicate with SQL Server.</source>
118+
</trans-unit>
119+
<trans-unit id="mssql.connection.typeSystemVersion">
120+
<source xml:lang="en">[Optional] Indicates which server type the provider will expose through the DataReader.</source>
121+
</trans-unit>
122+
<trans-unit id="mssql.connection.connectionString">
123+
<source xml:lang="en">[Optional] The ADO.NET connection string to use for the connection. Overrides any other options given in this connection.</source>
124+
</trans-unit>
125+
<trans-unit id="mssql.connection.profileName">
126+
<source xml:lang="en">[Optional] Specify a custom name for this connection profile to easily browse and search in the command palette of Visual Studio Code.</source>
127+
</trans-unit>
128+
<trans-unit id="mssql.connection.savePassword">
129+
<source xml:lang="en">[Optional] When set to 'true', the password for SQL Server authentication is saved in the secure store of your operating system such as KeyChain in MacOS or Secure Store in Windows.</source>
130+
</trans-unit>
131+
<trans-unit id="mssql.connection.emptyPasswordInput">
132+
<source xml:lang="en">[Optional] Indicates whether this profile has an empty password explicitly set</source>
133+
</trans-unit>
134+
<trans-unit id="mssql.shortcuts">
135+
<source xml:lang="en">Shortcuts related to the results window</source>
136+
</trans-unit>
137+
<trans-unit id="mssql.messagesDefaultOpen">
138+
<source xml:lang="en">True for the messages pane to be open by default; false for closed</source>
139+
</trans-unit>
140+
<trans-unit id="mssql.resultsFontFamily">
141+
<source xml:lang="en">Set the font family for the results grid; set to blank to use the editor font</source>
142+
</trans-unit>
143+
<trans-unit id="mssql.resultsFontSize">
144+
<source xml:lang="en">Set the font size for the results grid; set to blank to use the editor size</source>
145+
</trans-unit>
146+
<trans-unit id="mssql.saveAsCsv.includeHeaders">
147+
<source xml:lang="en">[Optional] When true, column headers are included when saving results as CSV</source>
148+
</trans-unit>
149+
<trans-unit id="mssql.copyIncludeHeaders">
150+
<source xml:lang="en">[Optional] Configuration options for copying results from the Results View</source>
151+
</trans-unit>
152+
<trans-unit id="mssql.copyRemoveNewLine">
153+
<source xml:lang="en">[Optional] Configuration options for copying multi-line results from the Results View</source>
154+
</trans-unit>
155+
<trans-unit id="mssql.showBatchTime">
156+
<source xml:lang="en">[Optional] Should execution time be shown for individual batches</source>
157+
</trans-unit>
158+
<trans-unit id="mssql.splitPaneSelection">
159+
<source xml:lang="en">[Optional] Configuration options for which column new result panes should open in</source>
160+
</trans-unit>
161+
<trans-unit id="mssql.format.alignColumnDefinitionsInColumns">
162+
<source xml:lang="en">Should column definitions be aligned?</source>
163+
</trans-unit>
164+
<trans-unit id="mssql.format.datatypeCasing">
165+
<source xml:lang="en">Should data types be formatted as UPPERCASE, lowercase, or none (not formatted)</source>
166+
</trans-unit>
167+
<trans-unit id="mssql.format.keywordCasing">
168+
<source xml:lang="en">Should keywords be formatted as UPPERCASE, lowercase, or none (not formatted)</source>
169+
</trans-unit>
170+
<trans-unit id="mssql.format.placeCommasBeforeNextStatement">
171+
<source xml:lang="en">should commas be placed at the beginning of each statement in a list e.g. ', mycolumn2' instead of at the end e.g. 'mycolumn1,'</source>
172+
</trans-unit>
173+
<trans-unit id="mssql.format.placeSelectStatementReferencesOnNewLine">
174+
<source xml:lang="en">Should references to objects in a select statements be split into separate lines? E.g. for 'SELECT C1, C2 FROM T1' both C1 and C2 will be on separate lines</source>
175+
</trans-unit>
176+
<trans-unit id="mssql.applyLocalization">
177+
<source xml:lang="en">[Optional] Configuration options for localizing into VSCode's configured locale (must restart VSCode for settings to take effect)</source>
178+
</trans-unit>
179+
<trans-unit id="mssql.query.displayBitAsNumber">
180+
<source xml:lang="en">Should BIT columns be displayed as numbers (1 or 0)? If false, BIT columns will be displayed as 'true' or 'false'</source>
181+
</trans-unit>
182+
<trans-unit id="mssql.intelliSense.enableIntelliSense">
183+
<source xml:lang="en">Should IntelliSense be enabled</source>
184+
</trans-unit>
185+
<trans-unit id="mssql.intelliSense.enableErrorChecking">
186+
<source xml:lang="en">Should IntelliSense error checking be enabled</source>
187+
</trans-unit>
188+
<trans-unit id="mssql.intelliSense.enableSuggestions">
189+
<source xml:lang="en">Should IntelliSense suggestions be enabled</source>
190+
</trans-unit>
191+
<trans-unit id="mssql.intelliSense.enableQuickInfo">
192+
<source xml:lang="en">Should IntelliSense quick info be enabled</source>
193+
</trans-unit>
194+
<trans-unit id="mssql.intelliSense.lowerCaseSuggestions">
195+
<source xml:lang="en">Should IntelliSense suggestions be lowercase</source>
196+
</trans-unit>
197+
</body>
198+
</file>
199+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="es">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="fr">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="it">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="ja">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="ko">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="pt-BR">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?xml version="1.0" ?>
2+
<xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:oasis:names:tc:xliff:document:1.2 xliff-core-1.2-transitional.xsd">
3+
<file datatype="xml" original="extension.i18ntest.JSON" source-language="en" target-language="ru">
4+
<body>
5+
</body>
6+
</file>
7+
</xliff>

‎package.json

+65-65
Large diffs are not rendered by default.

‎package.nls.json

+66
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
{
2+
"extension.runQuery":"Execute Query",
3+
"extension.runCurrentStatement":"Execute Current Statement",
4+
"extension.cancelQuery":"Cancel Query",
5+
"extension.connect":"Connect",
6+
"extension.disconnect":"Disconnect",
7+
"extension.manageProfiles":"Manage Connection Profiles",
8+
"extension.chooseDatabase":"Use Database",
9+
"extension.showGettingStarted":"Getting Started Guide",
10+
"extension.newQuery":"New Query",
11+
"extension.rebuildIntelliSenseCache":"Refresh IntelliSense Cache",
12+
"mssql.logDebugInfo":"[Optional] Log debug output to the VS Code console (Help -> Toggle Developer Tools)",
13+
"mssql.maxRecentConnections":"The maximum number of recently used connections to store in the connection list.",
14+
"mssql.connections":"Connection profiles defined in 'User Settings' are shown under 'MS SQL: Connect' command in the command palette.",
15+
"mssql.connection.server":"[Required] Specify the server name to connect to. Use 'hostname instance' or '<server>.database.windows.net' for Azure SQL Database.",
16+
"mssql.connection.database":"[Optional] Specify the database name to connect to. If database is not specified, the default user database setting is used, typically 'master'.",
17+
"mssql.connection.user":"[Optional] Specify the user name for SQL Server authentication. If user name is not specified, when you connect, you will be asked again.",
18+
"mssql.connection.password":"[Optional] Specify the password for SQL Server authentication. If password is not specified or already saved, when you connect, you will be asked again.",
19+
"mssql.connection.authenticationType":"[Optional] Specify the SQL Server authentication type.",
20+
"mssql.connection.port":"[Optional] Specify the port number to connect to.",
21+
"mssql.connection.encrypt":"[Optional] When set to 'true', SQL Server uses SSL encryption for data sent between the client and the server if the server has a certificate installed. Set 'true' for Azure SQL Database connection.",
22+
"mssql.connection.trustServerCertificate":"[Optional] When set to 'true', the SQL Server SSL certificate is automatically trusted when the communication layer is encrypted using SSL. Set 'false' for Azure SQL Database connection.",
23+
"mssql.connection.persistSecurityInfo":"[Optional] When set to false, security-sensitive information, such as the password, is not returned as part of the connection if the connection is open or has ever been in an open state.",
24+
"mssql.connection.connectTimeout":"[Optional] Specify the length of time in seconds to wait for a connection to the server before it times out. The default timeout value for Azure SQL Database is 30.",
25+
"mssql.connection.connectRetryCount":"[Optional] Specify the number of attempts to restore connection.",
26+
"mssql.connection.connectRetryInterval":"[Optional] Specify the delay between attempts to restore connection.",
27+
"mssql.connection.workstationId":"[Optional] Specify the name of the workstation connecting to SQL Server.",
28+
"mssql.connection.applicationIntent":"[Optional] Declares the application workload type when connecting to SQL Server such as ReadWrite or ReadOnly. Refer to SQL Server AlwaysOn for more detail.",
29+
"mssql.connection.currentLanguage":"[Optional] Indicates the SQL Server language settings.",
30+
"mssql.connection.pooling":"[Optional] When set to 'true', the connection object is drawn from the appropriate pool, or if necessary, is created and added to the appropriate pool.",
31+
"mssql.connection.maxPoolSize":"[Optional] Specify the maximum number of connections allowed in the pool.",
32+
"mssql.connection.minPoolSize":"[Optional] Specify the minimum number of connections allowed in the pool.",
33+
"mssql.connection.loadBalanceTimeout":"[Optional] Specify the minimum amount of time in seconds for this connection to live in the pool before being removed/deleted.",
34+
"mssql.connection.replication":"[Optional] Used by SQL Server in replication.",
35+
"mssql.connection.attachDbFilename":"[Optional] Specify the name of the primary file, including the full path name, of an attachable database.",
36+
"mssql.connection.failoverPartner":"[Optional] Specify the name or network address of the instance of SQL Server that acts as a failover partner.",
37+
"mssql.connection.multiSubnetFailover":"[Optional] When set to 'true', the detection and connection to the active server is faster if AlwaysOn Availability Group is configured on different subnets.",
38+
"mssql.connection.multipleActiveResultSets":"[Optional] When set to 'true', multiple result sets can be returned and read from on connection.",
39+
"mssql.connection.packetSize":"[Optional] Specify the size in bytes of the network packets to communicate with SQL Server.",
40+
"mssql.connection.typeSystemVersion":"[Optional] Indicates which server type the provider will expose through the DataReader.",
41+
"mssql.connection.connectionString":"[Optional] The ADO.NET connection string to use for the connection. Overrides any other options given in this connection.",
42+
"mssql.connection.profileName":"[Optional] Specify a custom name for this connection profile to easily browse and search in the command palette of Visual Studio Code.",
43+
"mssql.connection.savePassword":"[Optional] When set to 'true', the password for SQL Server authentication is saved in the secure store of your operating system such as KeyChain in MacOS or Secure Store in Windows.",
44+
"mssql.connection.emptyPasswordInput":"[Optional] Indicates whether this profile has an empty password explicitly set",
45+
"mssql.shortcuts":"Shortcuts related to the results window",
46+
"mssql.messagesDefaultOpen":"True for the messages pane to be open by default; false for closed",
47+
"mssql.resultsFontFamily":"Set the font family for the results grid; set to blank to use the editor font",
48+
"mssql.resultsFontSize":"Set the font size for the results grid; set to blank to use the editor size",
49+
"mssql.saveAsCsv.includeHeaders":"[Optional] When true, column headers are included when saving results as CSV",
50+
"mssql.copyIncludeHeaders":"[Optional] Configuration options for copying results from the Results View",
51+
"mssql.copyRemoveNewLine":"[Optional] Configuration options for copying multi-line results from the Results View",
52+
"mssql.showBatchTime":"[Optional] Should execution time be shown for individual batches",
53+
"mssql.splitPaneSelection":"[Optional] Configuration options for which column new result panes should open in",
54+
"mssql.format.alignColumnDefinitionsInColumns":"Should column definitions be aligned?",
55+
"mssql.format.datatypeCasing":"Should data types be formatted as UPPERCASE, lowercase, or none (not formatted)",
56+
"mssql.format.keywordCasing":"Should keywords be formatted as UPPERCASE, lowercase, or none (not formatted)",
57+
"mssql.format.placeCommasBeforeNextStatement":"should commas be placed at the beginning of each statement in a list e.g. ', mycolumn2' instead of at the end e.g. 'mycolumn1,'",
58+
"mssql.format.placeSelectStatementReferencesOnNewLine":"Should references to objects in a select statements be split into separate lines? E.g. for 'SELECT C1, C2 FROM T1' both C1 and C2 will be on separate lines",
59+
"mssql.applyLocalization":"[Optional] Configuration options for localizing into VSCode's configured locale (must restart VSCode for settings to take effect)",
60+
"mssql.query.displayBitAsNumber":"Should BIT columns be displayed as numbers (1 or 0)? If false, BIT columns will be displayed as 'true' or 'false'",
61+
"mssql.intelliSense.enableIntelliSense":"Should IntelliSense be enabled",
62+
"mssql.intelliSense.enableErrorChecking":"Should IntelliSense error checking be enabled",
63+
"mssql.intelliSense.enableSuggestions":"Should IntelliSense suggestions be enabled",
64+
"mssql.intelliSense.enableQuickInfo":"Should IntelliSense quick info be enabled",
65+
"mssql.intelliSense.lowerCaseSuggestions":"Should IntelliSense suggestions be lowercase"
66+
}

‎src/constants/constants.ts

+2
Original file line numberDiff line numberDiff line change
@@ -52,6 +52,8 @@ export const changelogLink = 'https://aka.ms/vscode-mssql-changelog';
5252
export const integratedAuthHelpLink = 'https://aka.ms/vscode-mssql-integratedauth';
5353
export const sqlToolsServiceCrashLink = 'https://github.com/Microsoft/vscode-mssql/wiki/SqlToolsService-Known-Issues';
5454

55+
export const localizedTexts = 'localizedTexts';
56+
5557
// Configuration Constants
5658
export const copyIncludeHeaders = 'copyIncludeHeaders';
5759
export const configLogDebugInfo = 'logDebugInfo';

‎src/models/interfaces.ts

+4-2
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,8 @@ export enum ContentType {
1515
OpenLink = 8,
1616
ShowError = 9,
1717
ShowWarning = 10,
18-
Config = 11
18+
Config = 11,
19+
LocalizedTexts = 12
1920
};
2021

2122
export interface ISlickRange {
@@ -43,7 +44,8 @@ export const ContentTypes = [
4344
Constants.outputContentTypeOpenLink,
4445
Constants.outputContentTypeShowError,
4546
Constants.outputContentTypeShowWarning,
46-
Constants.outputContentTypeConfig
47+
Constants.outputContentTypeConfig,
48+
Constants.localizedTexts
4749
];
4850

4951
/**

‎src/models/sqlOutputContentProvider.ts

+6
Original file line numberDiff line numberDiff line change
@@ -66,6 +66,12 @@ export class SqlOutputContentProvider implements vscode.TextDocumentContentProvi
6666
this._service.addPostHandler(Interfaces.ContentType.ShowError, (req, res) => this.showErrorRequestHandler(req, res));
6767
// add http post handler for showing warning to user
6868
this._service.addPostHandler(Interfaces.ContentType.ShowWarning, (req, res) => this.showWarningRequestHandler(req, res));
69+
// add http get handler for getting all localized texts
70+
this._service.addHandler(Interfaces.ContentType.LocalizedTexts, (req, res) => {
71+
let localizedText = LocalizedConstants;
72+
res.send(localizedText);
73+
});
74+
6975

7076
// start express server on localhost and listen on a random port
7177
try {
+22-14
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,27 @@
1+
/** Note: The new constants in this file should be added to localization\xliff\constants\localizedConstants.enu.xlf so the localized texts get loaded here */
2+
13
/** Results Pane Labels */
2-
export const maximizeLabel = 'Maximize';
3-
export const restoreLabel = 'Restore';
4-
export const saveCSVLabel = 'Save as CSV';
5-
export const saveJSONLabel = 'Save as JSON';
6-
export const saveExcelLabel = 'Save as Excel';
7-
export const resultPaneLabel = 'Results';
8-
export const selectAll = 'Select all';
9-
export const copyLabel = 'Copy';
10-
export const copyWithHeadersLabel = 'Copy with Headers';
4+
export let maximizeLabel = 'Maximize';
5+
export let restoreLabel = 'Restore';
6+
export let saveCSVLabel = 'Save as CSV';
7+
export let saveJSONLabel = 'Save as JSON';
8+
export let saveExcelLabel = 'Save as Excel';
9+
export let resultPaneLabel = 'Results';
10+
export let selectAll = 'Select all';
11+
export let copyLabel = 'Copy';
12+
export let copyWithHeadersLabel = 'Copy with Headers';
1113

1214
/** Messages Pane Labels */
13-
export const executeQueryLabel = 'Executing query...';
14-
export const messagePaneLabel = 'Messages';
15-
export const lineSelectorFormatted = 'Line {0}';
16-
export const elapsedTimeLabel = 'Total execution time: {0}';
15+
export let executeQueryLabel = 'Executing query...';
16+
export let messagePaneLabel = 'Messages';
17+
export let lineSelectorFormatted = 'Line {0}';
18+
export let elapsedTimeLabel = 'Total execution time: {0}';
1719

1820
/** Warning message for save icons */
19-
export const msgCannotSaveMultipleSelections = 'Save results command cannot be used with multiple selections.';
21+
export let msgCannotSaveMultipleSelections = 'Save results command cannot be used with multiple selections.';
22+
23+
export let loadLocalizedConstant = (key: string, value: string) => {
24+
// Update the value of the property with the name equal to key in this file
25+
this[key] = value;
26+
};
27+

‎src/views/htmlcontent/src/js/services/data.service.ts

+23
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@ import * as Utils from './../utils';
1313
import { ResultSetSubset, ISelectionData,
1414
IResultsConfig, WebSocketEvent } from './../interfaces';
1515

16+
import * as Constants from './../constants';
17+
1618
const WS_URL = 'ws://localhost:' + window.location.port + '/';
1719

1820
/**
@@ -59,6 +61,12 @@ export class DataService {
5961
let data = JSON.parse(response.data);
6062
return data;
6163
});
64+
65+
this.getLocalizedTextsRequest().then(result => {
66+
Object.keys(result).forEach(key => {
67+
Constants.loadLocalizedConstant(key, result[key]);
68+
});
69+
});
6270
}
6371

6472
/**
@@ -100,6 +108,21 @@ export class DataService {
100108
});
101109
}
102110

111+
/**
112+
* send request to get all the localized texts
113+
*/
114+
getLocalizedTextsRequest(): Promise<{ [key: string]: any }> {
115+
const self = this;
116+
let headers = new Headers();
117+
let url = '/localizedTexts';
118+
119+
return new Promise<{ [key: string]: any }>((resolve, reject) => {
120+
self.http.get(url, { headers: headers }).subscribe(result => {
121+
resolve(result.json());
122+
});
123+
});
124+
}
125+
103126
/**
104127
* send request to open content in new editor
105128
* @param content The content to be opened

‎src/views/htmlcontent/test/app.component.spec.ts

+3
Original file line numberDiff line numberDiff line change
@@ -110,6 +110,9 @@ class MockDataService {
110110
public copyResults(selection: ISlickRange[], batchId: number, resultId: number): void {
111111
// no op
112112
}
113+
public getLocalizedTextsRequest(): Promise<{ [key: string]: any }> {
114+
return Promise.resolve({});
115+
}
113116
}
114117

115118
class MockShortcutService {

‎tasks/localizationtasks.js

+89-7
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,28 @@ var gulp = require('gulp')
44
var config = require('./config')
55
var through = require('through2')
66
var path = require('path')
7-
7+
var packageAllKeys = require('./../package.nls.json')
8+
9+
const iso639_3_to_2 = {
10+
chs: 'zh-cn',
11+
cht: 'zh-tw',
12+
csy: 'cs-cz',
13+
deu: 'de',
14+
enu: 'en',
15+
esn: 'es',
16+
fra: 'fr',
17+
hun: 'hu',
18+
ita: 'it',
19+
jpn: 'ja',
20+
kor: 'ko',
21+
nld: 'nl',
22+
plk: 'pl',
23+
ptb: 'pt-br',
24+
ptg: 'pt',
25+
rus: 'ru',
26+
sve: 'sv-se',
27+
trk: 'tr'
28+
};
829

930
// converts a json object into xml
1031
function convertDictionaryToXml(dict) {
@@ -17,7 +38,7 @@ function convertDictionaryToJson(dict) {
1738
}
1839

1940
// converts an xml file into a json object
20-
function convertXmlToDictionary(xmlInput) {
41+
function convertXmlToDictionary(xmlInput, escapeChar = true) {
2142
let xmlDom = new dom().parseFromString(xmlInput);
2243
let transUnits = xmlDom.getElementsByTagName('trans-unit');
2344
let dict = {};
@@ -31,14 +52,14 @@ function convertXmlToDictionary(xmlInput) {
3152
let sourceElement = unit.getElementsByTagName('source');
3253
let source = '';
3354
if (sourceElement.length >= 1) {
34-
source = escapeChars(sourceElement[0].textContent);
55+
source = escapeChars(sourceElement[0].textContent, escapeChar);
3556
}
3657

3758
// Extract target element if possible
3859
let targetElement = unit.getElementsByTagName('target');
3960
let target = '';
4061
if(targetElement.length >= 1){
41-
target = escapeChars(targetElement[0].textContent);
62+
target = escapeChars(targetElement[0].textContent, escapeChar);
4263
}
4364

4465
// Return json with {id:{target,source}} format
@@ -49,8 +70,12 @@ function convertXmlToDictionary(xmlInput) {
4970
}
5071

5172
// Escapes all characters which need to be escaped (')
52-
function escapeChars(input) {
53-
return input.replace(/'/g, "\\'");
73+
function escapeChars(input, escapeChar = true) {
74+
if (escapeChar) {
75+
return input.replace(/'/g, "\\'");
76+
} else {
77+
return input;
78+
}
5479
}
5580

5681
// converts plain text json into a json object
@@ -61,7 +86,8 @@ function convertJsonToDictionary(jsonInput) {
6186
// export json files from *.xlf
6287
// mirrors the file paths and names
6388
gulp.task('ext:localization:xliff-to-json', function () {
64-
return gulp.src([config.paths.project.localization + '/xliff/**/*.xlf', '!' + config.paths.project.localization + '/xliff/enu/**/*.xlf'])
89+
return gulp.src([config.paths.project.localization + '/xliff/**/*.xlf', '!' + config.paths.project.localization + '/xliff/enu/**/*.xlf', '!' +
90+
config.paths.project.localization + '/xliff/**/*localizedPackage.json.*.xlf'])
6591
.pipe(through.obj(function (file, enc, callback) {
6692

6793
// convert xliff into json document
@@ -122,3 +148,59 @@ gulp.task('ext:localization:xliff-to-ts', function () {
122148
}))
123149
.pipe(gulp.dest(config.paths.project.root + '/src/constants/'));
124150
});
151+
152+
// Generates a localized package.nls.*.json
153+
gulp.task('ext:localization:xliff-to-package.nls', function () {
154+
return gulp.src([config.paths.project.localization + '/xliff/**/localizedPackage.json.*.xlf', '!' + config.paths.project.localization + '/xliff/en/localizedPackage.json.*.xlf'], { base: '' })
155+
.pipe(through.obj(function (file, enc, callback) {
156+
// convert xliff into json document
157+
let dict = convertXmlToDictionary(String(file.contents), false);
158+
159+
var contents = ['{'];
160+
161+
// Get all the keys from package.nls.json which is the English version and get the localized value from xlf
162+
// Use the English value if not translated, right now there's no fall back to English if the text is not localized.
163+
// So all the keys have to exist in all package.nls.*.json
164+
Object.keys(packageAllKeys).forEach(key => {
165+
let value = packageAllKeys[key];
166+
if (contents.length >= 2) {
167+
contents[contents.length - 1] += ',';
168+
}
169+
if (dict.hasOwnProperty(key)) {
170+
171+
value = dict[key]['target'];
172+
}
173+
if (value === '') {
174+
value = packageAllKeys[key];
175+
}
176+
let instantiation = '"' + key + '":"' + value + '"';
177+
contents.push(instantiation);
178+
179+
});
180+
181+
// end the function
182+
contents.push('}');
183+
184+
// Join with new lines in between
185+
let fullFileContents = contents.join('\r\n') + '\r\n';
186+
file.contents = new Buffer(fullFileContents);
187+
188+
let indexToStart = 'localizedPackage.json.'.length + 1;
189+
let languageIndex = file.basename.indexOf('.', indexToStart);
190+
let language = file.basename.substr(indexToStart - 1, (languageIndex - indexToStart) + 1);
191+
192+
// Name our file
193+
if (language === 'enu') {
194+
file.basename = 'package.nls.json';
195+
} else {
196+
file.basename = 'package.nls.' + iso639_3_to_2[language] +'.json';
197+
}
198+
199+
// Make the new file create on root
200+
file.dirname = file.dirname.replace(language , '');
201+
202+
// callback to notify we have completed the current file
203+
callback(null, file);
204+
}))
205+
.pipe(gulp.dest(config.paths.project.root));
206+
});

0 commit comments

Comments
 (0)
Please sign in to comment.