material-icon-theme 4.23.1 → 4.25.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (108) hide show
  1. package/.eslintrc.json +51 -51
  2. package/.github/PULL_REQUEST_TEMPLATE/pull_request_template.md +7 -0
  3. package/.github/workflows/build.yml +45 -45
  4. package/.github/workflows/color-check.yml +22 -22
  5. package/.github/workflows/release.yml +73 -73
  6. package/.vscodeignore +21 -21
  7. package/CHANGELOG.md +1325 -1292
  8. package/CONTRIBUTING.md +199 -29
  9. package/README.md +198 -199
  10. package/icons/bitbucket.svg +13 -1
  11. package/icons/bun.svg +2 -0
  12. package/icons/bun_light.svg +2 -0
  13. package/icons/craco.svg +45 -45
  14. package/icons/folder-changesets-open.svg +5 -5
  15. package/icons/folder-changesets.svg +2 -2
  16. package/icons/folder-decorators-open.svg +2 -2
  17. package/icons/folder-decorators.svg +5 -5
  18. package/icons/folder-gamemaker-open.svg +2 -0
  19. package/icons/folder-gamemaker.svg +2 -0
  20. package/icons/folder-supabase-open.svg +5 -5
  21. package/icons/folder-supabase.svg +2 -2
  22. package/icons/gamemaker.svg +4 -0
  23. package/icons/objective-c.svg +1 -0
  24. package/icons/objective-cpp.svg +1 -0
  25. package/icons/pascal.svg +6 -1
  26. package/icons/sonarcloud.svg +4 -4
  27. package/icons/stylable.svg +10 -10
  28. package/icons/supabase.svg +4 -4
  29. package/icons/tldraw.svg +4 -0
  30. package/icons/tldraw_light.svg +4 -0
  31. package/icons/vitest.svg +6 -6
  32. package/images/contributors.png +0 -0
  33. package/images/fileIcons.png +0 -0
  34. package/images/folderIcons.png +0 -0
  35. package/images/how-tos/folder-icon-parts.png +0 -0
  36. package/images/how-tos/pick-folder-colors.png +0 -0
  37. package/images/how-tos/pick-folder-colors.svg +301 -0
  38. package/images/how-tos/svg-folder-icon-with-correct-colors.png +0 -0
  39. package/images/how-tos/svg-folder-icon-with-wrong-colors.png +0 -0
  40. package/images/how-tos/svg-with-light-color.png +0 -0
  41. package/images/how-tos/svg-with-spacing.png +0 -0
  42. package/images/how-tos/svg-with-too-dark-color.png +0 -0
  43. package/images/how-tos/svg-with-wrong-color.png +0 -0
  44. package/images/how-tos/svg-without-spacing.png +0 -0
  45. package/package.json +252 -252
  46. package/package.nls.de.json +32 -32
  47. package/package.nls.es.json +29 -29
  48. package/package.nls.fr.json +29 -29
  49. package/package.nls.ja.json +32 -32
  50. package/package.nls.json +32 -32
  51. package/package.nls.nl.json +32 -32
  52. package/package.nls.pl.json +32 -32
  53. package/package.nls.pt-BR.json +29 -29
  54. package/package.nls.pt-PT.json +29 -29
  55. package/package.nls.ru.json +29 -29
  56. package/package.nls.zh-CN.json +29 -29
  57. package/package.nls.zh-TW.json +29 -29
  58. package/src/commands/activate.ts +28 -28
  59. package/src/commands/explorerArrows.ts +55 -55
  60. package/src/commands/folderColor.ts +96 -96
  61. package/src/commands/folders.ts +55 -55
  62. package/src/commands/grayscale.ts +55 -55
  63. package/src/commands/iconPacks.ts +64 -64
  64. package/src/commands/index.ts +30 -30
  65. package/src/commands/opacity.ts +46 -46
  66. package/src/commands/saturation.ts +46 -46
  67. package/src/extension.ts +37 -37
  68. package/src/helpers/customIcons.ts +8 -8
  69. package/src/helpers/index.ts +88 -88
  70. package/src/i18n/index.ts +78 -78
  71. package/src/i18n/lang-de.ts +43 -43
  72. package/src/i18n/lang-en.ts +43 -43
  73. package/src/i18n/lang-es.ts +43 -43
  74. package/src/i18n/lang-fr.ts +43 -43
  75. package/src/i18n/lang-ja.ts +43 -43
  76. package/src/i18n/lang-nl.ts +43 -43
  77. package/src/i18n/lang-pl.ts +43 -43
  78. package/src/i18n/lang-pt-br.ts +43 -43
  79. package/src/i18n/lang-pt-pt.ts +43 -43
  80. package/src/i18n/lang-ru.ts +43 -43
  81. package/src/i18n/lang-uk.ts +43 -43
  82. package/src/i18n/lang-zh-cn.ts +43 -43
  83. package/src/i18n/lang-zh-tw.ts +43 -43
  84. package/src/icons/fileIcons.ts +2240 -2197
  85. package/src/icons/folderIcons.ts +823 -806
  86. package/src/icons/generator/folderGenerator.ts +340 -340
  87. package/src/icons/generator/iconOpacity.ts +111 -111
  88. package/src/icons/generator/iconSaturation.ts +140 -140
  89. package/src/icons/generator/jsonGenerator.ts +191 -191
  90. package/src/icons/languageIcons.ts +144 -141
  91. package/src/models/i18n/translation.ts +41 -41
  92. package/src/models/iconConfiguration.ts +37 -37
  93. package/src/models/icons/iconJsonOptions.ts +21 -21
  94. package/src/models/index.ts +3 -3
  95. package/src/scripts/contributors/index.ts +138 -138
  96. package/src/scripts/helpers/screenshots.ts +32 -32
  97. package/src/scripts/icons/checks/checkIconAvailability.ts +215 -215
  98. package/src/scripts/icons/checks/checkIconConflicts.ts +152 -152
  99. package/src/scripts/icons/checks/checkIconUsage.ts +137 -137
  100. package/src/scripts/icons/checks/index.ts +7 -7
  101. package/src/scripts/preview/index.ts +40 -40
  102. package/src/scripts/preview/preview.ts +163 -163
  103. package/src/test/runTest.ts +26 -26
  104. package/src/test/spec/i18n/i18n.spec.ts +54 -54
  105. package/src/test/spec/icons/fileIcons.spec.ts +250 -250
  106. package/src/test/spec/icons/folderIcons.spec.ts +418 -418
  107. package/src/test/spec/icons/languageIcons.spec.ts +184 -184
  108. package/images/bloop.png +0 -0
@@ -1,250 +1,250 @@
1
- import { deepStrictEqual } from 'assert';
2
- import merge from 'lodash.merge';
3
- import {
4
- getDefaultIconOptions,
5
- loadFileIconDefinitions,
6
- } from '../../../icons/index';
7
- import { FileIcons, IconConfiguration, IconPack } from '../../../models/index';
8
-
9
- describe('file icons', () => {
10
- let expectedConfig: IconConfiguration;
11
-
12
- beforeEach(() => {
13
- expectedConfig = merge({}, new IconConfiguration(), {
14
- options: getDefaultIconOptions(),
15
- });
16
- });
17
-
18
- it('should configure icon definitions', () => {
19
- const fileIcons: FileIcons = {
20
- defaultIcon: { name: 'file' },
21
- icons: [
22
- {
23
- name: 'angular',
24
- fileNames: ['.angular-cli.json', 'angular-cli.json'],
25
- enabledFor: [IconPack.Angular, IconPack.Ngrx],
26
- },
27
- {
28
- name: 'javascript',
29
- fileNames: ['filename.js'],
30
- fileExtensions: ['js'],
31
- },
32
- ],
33
- };
34
- const options = getDefaultIconOptions();
35
- const iconConfig = merge({}, new IconConfiguration(), { options });
36
- const iconDefinitions = loadFileIconDefinitions(
37
- fileIcons,
38
- iconConfig,
39
- options
40
- );
41
-
42
- expectedConfig.iconDefinitions = {
43
- angular: {
44
- iconPath: './../icons/angular.svg',
45
- },
46
- javascript: {
47
- iconPath: './../icons/javascript.svg',
48
- },
49
- file: {
50
- iconPath: './../icons/file.svg',
51
- },
52
- };
53
- expectedConfig.file = 'file';
54
- expectedConfig.fileExtensions = {
55
- js: 'javascript',
56
- };
57
- expectedConfig.fileNames = {
58
- '.angular-cli.json': 'angular',
59
- 'angular-cli.json': 'angular',
60
- 'filename.js': 'javascript',
61
- };
62
-
63
- deepStrictEqual(iconDefinitions, expectedConfig);
64
- });
65
-
66
- it('should disable icon packs', () => {
67
- const fileIcons: FileIcons = {
68
- defaultIcon: { name: 'file' },
69
- icons: [
70
- {
71
- name: 'angular',
72
- fileNames: ['.angular-cli.json', 'angular-cli.json'],
73
- enabledFor: [IconPack.Ngrx],
74
- },
75
- {
76
- name: 'javascript',
77
- fileNames: ['filename.js'],
78
- fileExtensions: ['js'],
79
- },
80
- ],
81
- };
82
-
83
- const options = getDefaultIconOptions();
84
- options.activeIconPack = '';
85
- const iconConfig = merge({}, new IconConfiguration(), { options });
86
- const iconDefinitions = loadFileIconDefinitions(
87
- fileIcons,
88
- iconConfig,
89
- options
90
- );
91
-
92
- expectedConfig.iconDefinitions = {
93
- file: {
94
- iconPath: './../icons/file.svg',
95
- },
96
- javascript: {
97
- iconPath: './../icons/javascript.svg',
98
- },
99
- };
100
- expectedConfig.file = 'file';
101
- expectedConfig.fileExtensions = {
102
- js: 'javascript',
103
- };
104
- expectedConfig.fileNames = {
105
- 'filename.js': 'javascript',
106
- };
107
-
108
- // disable default icon pack by using empty string
109
- expectedConfig.options!.activeIconPack = '';
110
-
111
- deepStrictEqual(iconDefinitions, expectedConfig);
112
- });
113
-
114
- it('should configure custom icon associations', () => {
115
- const fileIcons: FileIcons = {
116
- defaultIcon: { name: 'file' },
117
- icons: [
118
- {
119
- name: 'angular',
120
- fileNames: ['.angular-cli.json', 'angular-cli.json'],
121
- },
122
- {
123
- name: 'javascript',
124
- fileNames: ['filename.js'],
125
- fileExtensions: ['js'],
126
- },
127
- ],
128
- };
129
- const options = getDefaultIconOptions();
130
- options.files.associations = {
131
- '*.sample.ts': 'angular',
132
- 'sample.js': 'javascript',
133
- };
134
- const iconConfig = merge({}, new IconConfiguration(), { options });
135
- const iconDefinitions = loadFileIconDefinitions(
136
- fileIcons,
137
- iconConfig,
138
- options
139
- );
140
-
141
- expectedConfig.iconDefinitions = {
142
- file: {
143
- iconPath: './../icons/file.svg',
144
- },
145
- javascript: {
146
- iconPath: './../icons/javascript.svg',
147
- },
148
- angular: {
149
- iconPath: './../icons/angular.svg',
150
- },
151
- };
152
- expectedConfig.file = 'file';
153
- expectedConfig.fileExtensions = {
154
- js: 'javascript',
155
- 'sample.ts': 'angular',
156
- };
157
- expectedConfig.fileNames = {
158
- '.angular-cli.json': 'angular',
159
- 'angular-cli.json': 'angular',
160
- 'sample.js': 'javascript',
161
- 'filename.js': 'javascript',
162
- };
163
- expectedConfig.options!.files!.associations = {
164
- '*.sample.ts': 'angular',
165
- 'sample.js': 'javascript',
166
- };
167
-
168
- deepStrictEqual(iconDefinitions, expectedConfig);
169
- });
170
-
171
- it('should configure language icons for light and high contrast', () => {
172
- const fileIcons: FileIcons = {
173
- defaultIcon: { name: 'file', light: true, highContrast: true },
174
- icons: [
175
- {
176
- name: 'angular',
177
- fileNames: ['.angular-cli.json', 'angular-cli.json'],
178
- enabledFor: [IconPack.Angular, IconPack.Ngrx],
179
- },
180
- {
181
- name: 'javascript',
182
- fileNames: ['filename.js'],
183
- fileExtensions: ['js'],
184
- light: true,
185
- highContrast: true,
186
- },
187
- ],
188
- };
189
- const options = getDefaultIconOptions();
190
- const iconConfig = merge({}, new IconConfiguration(), { options });
191
- const iconDefinitions = loadFileIconDefinitions(
192
- fileIcons,
193
- iconConfig,
194
- options
195
- );
196
- /* eslint-disable camelcase */
197
- expectedConfig.iconDefinitions = {
198
- file: {
199
- iconPath: './../icons/file.svg',
200
- },
201
- file_light: {
202
- iconPath: './../icons/file_light.svg',
203
- },
204
- file_highContrast: {
205
- iconPath: './../icons/file_highContrast.svg',
206
- },
207
- javascript: {
208
- iconPath: './../icons/javascript.svg',
209
- },
210
- javascript_light: {
211
- iconPath: './../icons/javascript_light.svg',
212
- },
213
- javascript_highContrast: {
214
- iconPath: './../icons/javascript_highContrast.svg',
215
- },
216
- angular: {
217
- iconPath: './../icons/angular.svg',
218
- },
219
- };
220
- expectedConfig.file = 'file';
221
- expectedConfig.fileExtensions = {
222
- js: 'javascript',
223
- };
224
- expectedConfig.light = {
225
- file: 'file_light',
226
- fileExtensions: {
227
- js: 'javascript_light',
228
- },
229
- fileNames: {
230
- 'filename.js': 'javascript_light',
231
- },
232
- };
233
- expectedConfig.highContrast = {
234
- file: 'file_highContrast',
235
- fileExtensions: {
236
- js: 'javascript_highContrast',
237
- },
238
- fileNames: {
239
- 'filename.js': 'javascript_highContrast',
240
- },
241
- };
242
- expectedConfig.fileNames = {
243
- '.angular-cli.json': 'angular',
244
- 'angular-cli.json': 'angular',
245
- 'filename.js': 'javascript',
246
- };
247
- /* eslint-enable camelcase */
248
- deepStrictEqual(iconDefinitions, expectedConfig);
249
- });
250
- });
1
+ import { deepStrictEqual } from 'assert';
2
+ import merge from 'lodash.merge';
3
+ import {
4
+ getDefaultIconOptions,
5
+ loadFileIconDefinitions,
6
+ } from '../../../icons/index';
7
+ import { FileIcons, IconConfiguration, IconPack } from '../../../models/index';
8
+
9
+ describe('file icons', () => {
10
+ let expectedConfig: IconConfiguration;
11
+
12
+ beforeEach(() => {
13
+ expectedConfig = merge({}, new IconConfiguration(), {
14
+ options: getDefaultIconOptions(),
15
+ });
16
+ });
17
+
18
+ it('should configure icon definitions', () => {
19
+ const fileIcons: FileIcons = {
20
+ defaultIcon: { name: 'file' },
21
+ icons: [
22
+ {
23
+ name: 'angular',
24
+ fileNames: ['.angular-cli.json', 'angular-cli.json'],
25
+ enabledFor: [IconPack.Angular, IconPack.Ngrx],
26
+ },
27
+ {
28
+ name: 'javascript',
29
+ fileNames: ['filename.js'],
30
+ fileExtensions: ['js'],
31
+ },
32
+ ],
33
+ };
34
+ const options = getDefaultIconOptions();
35
+ const iconConfig = merge({}, new IconConfiguration(), { options });
36
+ const iconDefinitions = loadFileIconDefinitions(
37
+ fileIcons,
38
+ iconConfig,
39
+ options
40
+ );
41
+
42
+ expectedConfig.iconDefinitions = {
43
+ angular: {
44
+ iconPath: './../icons/angular.svg',
45
+ },
46
+ javascript: {
47
+ iconPath: './../icons/javascript.svg',
48
+ },
49
+ file: {
50
+ iconPath: './../icons/file.svg',
51
+ },
52
+ };
53
+ expectedConfig.file = 'file';
54
+ expectedConfig.fileExtensions = {
55
+ js: 'javascript',
56
+ };
57
+ expectedConfig.fileNames = {
58
+ '.angular-cli.json': 'angular',
59
+ 'angular-cli.json': 'angular',
60
+ 'filename.js': 'javascript',
61
+ };
62
+
63
+ deepStrictEqual(iconDefinitions, expectedConfig);
64
+ });
65
+
66
+ it('should disable icon packs', () => {
67
+ const fileIcons: FileIcons = {
68
+ defaultIcon: { name: 'file' },
69
+ icons: [
70
+ {
71
+ name: 'angular',
72
+ fileNames: ['.angular-cli.json', 'angular-cli.json'],
73
+ enabledFor: [IconPack.Ngrx],
74
+ },
75
+ {
76
+ name: 'javascript',
77
+ fileNames: ['filename.js'],
78
+ fileExtensions: ['js'],
79
+ },
80
+ ],
81
+ };
82
+
83
+ const options = getDefaultIconOptions();
84
+ options.activeIconPack = '';
85
+ const iconConfig = merge({}, new IconConfiguration(), { options });
86
+ const iconDefinitions = loadFileIconDefinitions(
87
+ fileIcons,
88
+ iconConfig,
89
+ options
90
+ );
91
+
92
+ expectedConfig.iconDefinitions = {
93
+ file: {
94
+ iconPath: './../icons/file.svg',
95
+ },
96
+ javascript: {
97
+ iconPath: './../icons/javascript.svg',
98
+ },
99
+ };
100
+ expectedConfig.file = 'file';
101
+ expectedConfig.fileExtensions = {
102
+ js: 'javascript',
103
+ };
104
+ expectedConfig.fileNames = {
105
+ 'filename.js': 'javascript',
106
+ };
107
+
108
+ // disable default icon pack by using empty string
109
+ expectedConfig.options!.activeIconPack = '';
110
+
111
+ deepStrictEqual(iconDefinitions, expectedConfig);
112
+ });
113
+
114
+ it('should configure custom icon associations', () => {
115
+ const fileIcons: FileIcons = {
116
+ defaultIcon: { name: 'file' },
117
+ icons: [
118
+ {
119
+ name: 'angular',
120
+ fileNames: ['.angular-cli.json', 'angular-cli.json'],
121
+ },
122
+ {
123
+ name: 'javascript',
124
+ fileNames: ['filename.js'],
125
+ fileExtensions: ['js'],
126
+ },
127
+ ],
128
+ };
129
+ const options = getDefaultIconOptions();
130
+ options.files.associations = {
131
+ '*.sample.ts': 'angular',
132
+ 'sample.js': 'javascript',
133
+ };
134
+ const iconConfig = merge({}, new IconConfiguration(), { options });
135
+ const iconDefinitions = loadFileIconDefinitions(
136
+ fileIcons,
137
+ iconConfig,
138
+ options
139
+ );
140
+
141
+ expectedConfig.iconDefinitions = {
142
+ file: {
143
+ iconPath: './../icons/file.svg',
144
+ },
145
+ javascript: {
146
+ iconPath: './../icons/javascript.svg',
147
+ },
148
+ angular: {
149
+ iconPath: './../icons/angular.svg',
150
+ },
151
+ };
152
+ expectedConfig.file = 'file';
153
+ expectedConfig.fileExtensions = {
154
+ js: 'javascript',
155
+ 'sample.ts': 'angular',
156
+ };
157
+ expectedConfig.fileNames = {
158
+ '.angular-cli.json': 'angular',
159
+ 'angular-cli.json': 'angular',
160
+ 'sample.js': 'javascript',
161
+ 'filename.js': 'javascript',
162
+ };
163
+ expectedConfig.options!.files!.associations = {
164
+ '*.sample.ts': 'angular',
165
+ 'sample.js': 'javascript',
166
+ };
167
+
168
+ deepStrictEqual(iconDefinitions, expectedConfig);
169
+ });
170
+
171
+ it('should configure language icons for light and high contrast', () => {
172
+ const fileIcons: FileIcons = {
173
+ defaultIcon: { name: 'file', light: true, highContrast: true },
174
+ icons: [
175
+ {
176
+ name: 'angular',
177
+ fileNames: ['.angular-cli.json', 'angular-cli.json'],
178
+ enabledFor: [IconPack.Angular, IconPack.Ngrx],
179
+ },
180
+ {
181
+ name: 'javascript',
182
+ fileNames: ['filename.js'],
183
+ fileExtensions: ['js'],
184
+ light: true,
185
+ highContrast: true,
186
+ },
187
+ ],
188
+ };
189
+ const options = getDefaultIconOptions();
190
+ const iconConfig = merge({}, new IconConfiguration(), { options });
191
+ const iconDefinitions = loadFileIconDefinitions(
192
+ fileIcons,
193
+ iconConfig,
194
+ options
195
+ );
196
+ /* eslint-disable camelcase */
197
+ expectedConfig.iconDefinitions = {
198
+ file: {
199
+ iconPath: './../icons/file.svg',
200
+ },
201
+ file_light: {
202
+ iconPath: './../icons/file_light.svg',
203
+ },
204
+ file_highContrast: {
205
+ iconPath: './../icons/file_highContrast.svg',
206
+ },
207
+ javascript: {
208
+ iconPath: './../icons/javascript.svg',
209
+ },
210
+ javascript_light: {
211
+ iconPath: './../icons/javascript_light.svg',
212
+ },
213
+ javascript_highContrast: {
214
+ iconPath: './../icons/javascript_highContrast.svg',
215
+ },
216
+ angular: {
217
+ iconPath: './../icons/angular.svg',
218
+ },
219
+ };
220
+ expectedConfig.file = 'file';
221
+ expectedConfig.fileExtensions = {
222
+ js: 'javascript',
223
+ };
224
+ expectedConfig.light = {
225
+ file: 'file_light',
226
+ fileExtensions: {
227
+ js: 'javascript_light',
228
+ },
229
+ fileNames: {
230
+ 'filename.js': 'javascript_light',
231
+ },
232
+ };
233
+ expectedConfig.highContrast = {
234
+ file: 'file_highContrast',
235
+ fileExtensions: {
236
+ js: 'javascript_highContrast',
237
+ },
238
+ fileNames: {
239
+ 'filename.js': 'javascript_highContrast',
240
+ },
241
+ };
242
+ expectedConfig.fileNames = {
243
+ '.angular-cli.json': 'angular',
244
+ 'angular-cli.json': 'angular',
245
+ 'filename.js': 'javascript',
246
+ };
247
+ /* eslint-enable camelcase */
248
+ deepStrictEqual(iconDefinitions, expectedConfig);
249
+ });
250
+ });