@rws-framework/client 2.13.1 → 2.13.3
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.
- package/.bin/add-v.sh +9 -9
- package/.bin/emerge.sh +15 -15
- package/.emerge-fast.yaml +46 -46
- package/.emerge-typescript-template.yaml +23 -23
- package/.emerge-vis-output/fast-element/emerge-file_result_dependency_graph.graphml +693 -693
- package/.emerge-vis-output/fast-element/emerge-filesystem_graph.graphml +705 -705
- package/.emerge-vis-output/fast-element/emerge-statistics-metrics.txt +440 -440
- package/.emerge-vis-output/fast-element/html/emerge.html +500 -500
- package/.emerge-vis-output/fast-element/html/jsconfig.json +8 -8
- package/.emerge-vis-output/fast-element/html/resources/css/custom.css +211 -211
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_common.js +44 -44
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_data.js +13 -13
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_git.js +1413 -1413
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_graph.js +539 -539
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_heatmap.js +219 -219
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_hull.js +179 -179
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_main.js +1002 -1002
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_search.js +71 -71
- package/.emerge-vis-output/fast-element/html/resources/js/emerge_ui.js +199 -199
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-grid.css +4123 -4123
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-grid.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-grid.rtl.css +4122 -4122
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-grid.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-reboot.css +487 -487
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-reboot.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-reboot.rtl.css +484 -484
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-reboot.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-utilities.css +4265 -4265
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-utilities.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-utilities.rtl.css +4256 -4256
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap-utilities.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap.css +10877 -10877
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap.rtl.css +10841 -10841
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/css/bootstrap.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/js/bootstrap.bundle.js +7075 -7075
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/js/bootstrap.bundle.min.js +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/js/bootstrap.esm.js +5202 -5202
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/js/bootstrap.esm.min.js +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/js/bootstrap.js +5249 -5249
- package/.emerge-vis-output/fast-element/html/vendors/bootstrap/js/bootstrap.min.js +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/d3/d3.v7.8.4.min.js +2 -2
- package/.emerge-vis-output/fast-element/html/vendors/d3/d3.v7.min.js +2 -2
- package/.emerge-vis-output/fast-element/html/vendors/dark-mode-switch/css/dark-mode.css +148 -148
- package/.emerge-vis-output/fast-element/html/vendors/daterangepicker/daterangepicker.min.js +7 -7
- package/.emerge-vis-output/fast-element/html/vendors/daterangepicker/moment.min.js +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/hull/hull.js +373 -373
- package/.emerge-vis-output/fast-element/html/vendors/jquery/jquery-3.6.0.min.js +2 -2
- package/.emerge-vis-output/fast-element/html/vendors/popper/popper.min.js +6 -6
- package/.emerge-vis-output/fast-element/html/vendors/simpleheat/simpleheat.js +141 -141
- package/.emerge-vis-output/fast-foundation/emerge-file_result_dependency_graph.graphml +4043 -4043
- package/.emerge-vis-output/fast-foundation/emerge-filesystem_graph.graphml +4538 -4538
- package/.emerge-vis-output/fast-foundation/emerge-statistics-metrics.txt +2510 -2510
- package/.emerge-vis-output/fast-foundation/html/emerge.html +500 -500
- package/.emerge-vis-output/fast-foundation/html/jsconfig.json +8 -8
- package/.emerge-vis-output/fast-foundation/html/resources/css/custom.css +211 -211
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_common.js +44 -44
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_data.js +13 -13
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_git.js +1413 -1413
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_graph.js +539 -539
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_heatmap.js +219 -219
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_hull.js +179 -179
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_main.js +1002 -1002
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_search.js +71 -71
- package/.emerge-vis-output/fast-foundation/html/resources/js/emerge_ui.js +199 -199
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-grid.css +4123 -4123
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-grid.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-grid.rtl.css +4122 -4122
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-grid.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-reboot.css +487 -487
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-reboot.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-reboot.rtl.css +484 -484
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-reboot.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-utilities.css +4265 -4265
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-utilities.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-utilities.rtl.css +4256 -4256
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap-utilities.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap.css +10877 -10877
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap.rtl.css +10841 -10841
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/css/bootstrap.rtl.min.css +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/js/bootstrap.bundle.js +7075 -7075
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/js/bootstrap.bundle.min.js +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/js/bootstrap.esm.js +5202 -5202
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/js/bootstrap.esm.min.js +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/js/bootstrap.js +5249 -5249
- package/.emerge-vis-output/fast-foundation/html/vendors/bootstrap/js/bootstrap.min.js +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/d3/d3.v7.8.4.min.js +2 -2
- package/.emerge-vis-output/fast-foundation/html/vendors/d3/d3.v7.min.js +2 -2
- package/.emerge-vis-output/fast-foundation/html/vendors/dark-mode-switch/css/dark-mode.css +148 -148
- package/.emerge-vis-output/fast-foundation/html/vendors/daterangepicker/daterangepicker.min.js +7 -7
- package/.emerge-vis-output/fast-foundation/html/vendors/daterangepicker/moment.min.js +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/hull/hull.js +373 -373
- package/.emerge-vis-output/fast-foundation/html/vendors/jquery/jquery-3.6.0.min.js +2 -2
- package/.emerge-vis-output/fast-foundation/html/vendors/popper/popper.min.js +6 -6
- package/.emerge-vis-output/fast-foundation/html/vendors/simpleheat/simpleheat.js +141 -141
- package/.emerge-vis-output/rws-client/emerge-file_result_dependency_graph.graphml +1143 -1143
- package/.emerge-vis-output/rws-client/emerge-filesystem_graph.graphml +1003 -1003
- package/.emerge-vis-output/rws-client/emerge-statistics-metrics.txt +655 -655
- package/.emerge-vis-output/rws-client/html/emerge.html +500 -500
- package/.emerge-vis-output/rws-client/html/jsconfig.json +8 -8
- package/.emerge-vis-output/rws-client/html/resources/css/custom.css +211 -211
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_common.js +44 -44
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_data.js +13 -13
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_git.js +1413 -1413
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_graph.js +539 -539
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_heatmap.js +219 -219
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_hull.js +179 -179
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_main.js +1002 -1002
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_search.js +71 -71
- package/.emerge-vis-output/rws-client/html/resources/js/emerge_ui.js +199 -199
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-grid.css +4123 -4123
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-grid.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-grid.rtl.css +4122 -4122
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-grid.rtl.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-reboot.css +487 -487
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-reboot.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-reboot.rtl.css +484 -484
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-reboot.rtl.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-utilities.css +4265 -4265
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-utilities.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-utilities.rtl.css +4256 -4256
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap-utilities.rtl.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap.css +10877 -10877
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap.rtl.css +10841 -10841
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/css/bootstrap.rtl.min.css +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/js/bootstrap.bundle.js +7075 -7075
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/js/bootstrap.bundle.min.js +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/js/bootstrap.esm.js +5202 -5202
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/js/bootstrap.esm.min.js +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/js/bootstrap.js +5249 -5249
- package/.emerge-vis-output/rws-client/html/vendors/bootstrap/js/bootstrap.min.js +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/d3/d3.v7.8.4.min.js +2 -2
- package/.emerge-vis-output/rws-client/html/vendors/d3/d3.v7.min.js +2 -2
- package/.emerge-vis-output/rws-client/html/vendors/dark-mode-switch/css/dark-mode.css +148 -148
- package/.emerge-vis-output/rws-client/html/vendors/daterangepicker/daterangepicker.min.js +7 -7
- package/.emerge-vis-output/rws-client/html/vendors/daterangepicker/moment.min.js +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/hull/hull.js +373 -373
- package/.emerge-vis-output/rws-client/html/vendors/jquery/jquery-3.6.0.min.js +2 -2
- package/.emerge-vis-output/rws-client/html/vendors/popper/popper.min.js +6 -6
- package/.emerge-vis-output/rws-client/html/vendors/simpleheat/simpleheat.js +141 -141
- package/.eslintrc.json +51 -51
- package/.gitmodules +2 -2
- package/.setup/.eslintrc.json +11 -11
- package/.setup/_base.eslintrc.json +48 -48
- package/.setup/tsconfig.json +28 -28
- package/PLUGINS.MD +188 -188
- package/README.md +1023 -1023
- package/_tools.js +396 -396
- package/builder/vite/index.ts +4 -4
- package/{cfg/build_steps → builder}/vite/loaders/html.ts +11 -11
- package/{cfg/build_steps → builder}/vite/loaders/index.ts +8 -8
- package/{cfg/build_steps → builder}/vite/loaders/loader.type.ts +27 -27
- package/{cfg/build_steps → builder}/vite/loaders/scss.ts +32 -32
- package/{cfg/build_steps → builder}/vite/loaders/ts.ts +309 -312
- package/builder/vite/rws.vite.config.ts +56 -49
- package/{cfg/build_steps → builder}/vite/rws_scss_plugin.ts +61 -60
- package/{cfg/build_steps → builder}/vite/scss/_compiler.ts +95 -94
- package/{cfg/build_steps → builder}/vite/scss/_fonts.ts +80 -80
- package/{cfg/build_steps → builder}/vite/scss/_fs.ts +83 -81
- package/{cfg/build_steps → builder}/vite/scss/_import.ts +191 -184
- package/builder/webpack/after/copy.js +78 -78
- package/builder/webpack/after/sw.js +13 -13
- package/builder/webpack/index.js +10 -10
- package/builder/webpack/loaders/rws_fast_html_loader.js +17 -17
- package/builder/webpack/loaders/rws_fast_scss_loader.js +43 -43
- package/builder/webpack/loaders/rws_fast_ts_loader.js +96 -96
- package/builder/webpack/loaders/ts/html_error.js +19 -19
- package/builder/webpack/rws.webpack.config.js +169 -169
- package/builder/webpack/rws_scss_plugin.js +62 -62
- package/builder/webpack/rws_webpack_plugin.js +137 -137
- package/builder/webpack/scss/_compiler.js +97 -97
- package/builder/webpack/scss/_fonts.js +80 -80
- package/builder/webpack/scss/_fs.js +84 -84
- package/builder/webpack/scss/_import.js +186 -186
- package/cfg/_default.cfg.js +26 -26
- package/cfg/_storage.d.ts +22 -22
- package/cfg/_storage.js +42 -42
- package/cfg/build_steps/vite/_build_config.ts +105 -105
- package/cfg/build_steps/vite/_env_defines.ts +17 -17
- package/cfg/build_steps/vite/_loaders.ts +187 -184
- package/cfg/build_steps/vite/index.ts +2 -2
- package/cfg/build_steps/vite/types.ts +7 -7
- package/cfg/build_steps/webpack/_actions.js +85 -85
- package/cfg/build_steps/webpack/_aliases.js +9 -9
- package/cfg/build_steps/webpack/_build_config.js +76 -76
- package/cfg/build_steps/webpack/_cache.js +98 -98
- package/cfg/build_steps/webpack/_component_handling.js +60 -60
- package/cfg/build_steps/webpack/_dev_servers.js +14 -14
- package/cfg/build_steps/webpack/_env_defines.js +18 -18
- package/cfg/build_steps/webpack/_info.js +18 -18
- package/cfg/build_steps/webpack/_loaders.js +223 -223
- package/cfg/build_steps/webpack/_plugins.js +102 -102
- package/cfg/build_steps/webpack/_production.js +37 -37
- package/cfg/build_steps/webpack/_rws_externals.js +68 -68
- package/cfg/build_steps/webpack/_timing.js +52 -52
- package/cfg/build_steps/webpack/_webpack_config.js +58 -58
- package/cfg/tsconfigSetup.js +150 -150
- package/console.js +86 -86
- package/docs/assets/26e93147f10415a0ed4a.svg +6 -6
- package/docs/assets/75c9471662e97ee24f29.svg +7 -7
- package/docs/assets/db90e4df2373980c497d.svg +9 -9
- package/docs/assets/highlight.css +127 -127
- package/docs/assets/main.js +59 -59
- package/docs/assets/style.css +1414 -1414
- package/docs/classes/ApiServiceInstance.html +25 -25
- package/docs/classes/ConfigServiceInstance.html +21 -21
- package/docs/classes/DOMServiceInstance.html +17 -17
- package/docs/classes/NotifyServiceInstance.html +15 -15
- package/docs/classes/RWSClientInstance.html +45 -45
- package/docs/classes/RWSPlugin.html +13 -13
- package/docs/classes/RWSService.html +10 -10
- package/docs/classes/RWSViewComponent.html +1022 -1022
- package/docs/classes/ServiceWorkerServiceInstance.html +13 -13
- package/docs/classes/UtilsServiceInstance.html +13 -13
- package/docs/functions/attr.html +5 -5
- package/docs/functions/observable.html +3 -3
- package/docs/index.html +179 -179
- package/docs/interfaces/HTMLTag.html +3 -3
- package/docs/interfaces/IRWSConfig.html +20 -20
- package/docs/interfaces/IRWSDecoratorOptions.html +5 -5
- package/docs/interfaces/IRWSHttpRoute.html +2 -2
- package/docs/interfaces/IRWSPrefixedHTTProutes.html +2 -2
- package/docs/interfaces/IRWSUser.html +5 -5
- package/docs/modules.html +45 -45
- package/foundation/index.js +1 -1
- package/foundation/rws-foundation.d.ts +7 -7
- package/foundation/rws-foundation.js +7 -7
- package/package.json +108 -108
- package/service_worker/src/_service_worker.ts +83 -83
- package/service_worker/tsconfig.json +20 -20
- package/service_worker/webpack.config.js +66 -66
- package/src/client/components.ts +67 -67
- package/src/client/config.ts +165 -165
- package/src/client/services.ts +27 -27
- package/src/client.ts +212 -212
- package/src/components/_attrs/_default_observable_accessor.ts +8 -8
- package/src/components/_attrs/_extended_accessor.ts +40 -40
- package/src/components/_attrs/_external_handler.ts +7 -7
- package/src/components/_attrs/_external_observable_accessor.ts +8 -8
- package/src/components/_attrs/angular-attr.ts +34 -34
- package/src/components/_attrs/external-attr.ts +59 -59
- package/src/components/_attrs/external-observable.ts +52 -52
- package/src/components/_attrs/sanitize-html.ts +80 -80
- package/src/components/_component.ts +245 -245
- package/src/components/_container.ts +15 -15
- package/src/components/_decorator.ts +122 -122
- package/src/components/_decorators/RWSFillBuild.ts +54 -54
- package/src/components/_decorators/RWSInject.ts +49 -49
- package/src/components/_decorators/RWSService.ts +11 -11
- package/src/components/_decorators/_di.ts +15 -15
- package/src/components/_definitions.ts +64 -64
- package/src/components/_event_handling.ts +40 -40
- package/src/components/index.ts +14 -14
- package/src/components/loader/component.ts +12 -12
- package/src/components/loader/styles/layout.scss +13 -13
- package/src/components/progress/component.ts +54 -54
- package/src/components/progress/styles/layout.scss +90 -90
- package/src/components/progress/template.html +24 -24
- package/src/components/uploader/component.ts +83 -83
- package/src/components/uploader/styles/layout.scss +130 -130
- package/src/components/uploader/template.html +16 -16
- package/src/index.ts +93 -93
- package/src/plugins/_builder.js +31 -31
- package/src/plugins/_plugin.ts +63 -63
- package/src/services/ApiService.ts +242 -242
- package/src/services/ConfigService.ts +134 -134
- package/src/services/DOMService.ts +100 -100
- package/src/services/NotifyService.ts +47 -47
- package/src/services/ServiceWorkerService.ts +60 -60
- package/src/services/UtilsService.ts +60 -60
- package/src/services/_service.ts +64 -64
- package/src/styles/_darkreader.scss +30 -30
- package/src/styles/_grid.scss +75 -75
- package/src/styles/_misc.scss +8 -8
- package/src/styles/_scrollbars.scss +40 -40
- package/src/styles/includes.scss +4 -4
- package/src/types/IRWSConfig.ts +30 -30
- package/src/types/IRWSPlugin.ts +18 -18
- package/src/types/IRWSUser.ts +6 -6
- package/src/types/IRWSViewComponent.ts +36 -36
- package/src/types/RWSNotify.ts +6 -6
- package/src/types/RWSWindow.ts +41 -41
- package/tsconfig.json +30 -30
- package/typedoc.json +13 -13
- package/types/declarations.d.ts +8 -8
- package/types/docs-typings.d.ts +15 -15
|
@@ -1,50 +1,57 @@
|
|
|
1
|
-
import path from 'path';
|
|
2
|
-
import { fileURLToPath } from 'url';
|
|
3
|
-
import { processEnvDefines } from '../../cfg/build_steps/vite/_env_defines';
|
|
4
|
-
import { getRWSVitePlugins } from '../../cfg/build_steps/vite/_loaders';
|
|
5
|
-
import { rwsPath } from '@rws-framework/console';
|
|
6
|
-
import type { RWSViteConfig } from '../../cfg/build_steps/vite/types';
|
|
7
|
-
import type { UserConfig } from 'vite'; // Add this import
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import { fileURLToPath } from 'url';
|
|
3
|
+
import { processEnvDefines } from '../../cfg/build_steps/vite/_env_defines';
|
|
4
|
+
import { getRWSVitePlugins } from '../../cfg/build_steps/vite/_loaders';
|
|
5
|
+
import { rwsPath } from '@rws-framework/console';
|
|
6
|
+
import type { RWSViteConfig } from '../../cfg/build_steps/vite/types';
|
|
7
|
+
import type { UserConfig } from 'vite'; // Add this import
|
|
8
|
+
import { RWSScssPlugin } from './rws_scss_plugin';
|
|
9
|
+
|
|
10
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
11
|
+
const __dirname = path.dirname(__filename);
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
export const _DEFAULT_CFG: RWSViteConfig = {
|
|
16
|
+
dev: true,
|
|
17
|
+
tsConfigPath: path.resolve(rwsPath.findPackageDir(process.cwd()), 'tsconfig.json'),
|
|
18
|
+
cssOutputPath: path.resolve(rwsPath.findPackageDir(process.cwd()), 'public', 'css'),
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export function rwsViteBuilder(config: Partial<RWSViteConfig> = _DEFAULT_CFG, devDebug = false): UserConfig {
|
|
22
|
+
if(!config.tsConfigPath){
|
|
23
|
+
config.tsConfigPath = _DEFAULT_CFG.tsConfigPath;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
if(!config.cssOutputPath){
|
|
27
|
+
config.cssOutputPath = _DEFAULT_CFG.cssOutputPath;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const scssPlugin = new RWSScssPlugin({ autoCompile: [], dev: config.dev as boolean });
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
const theConfig: RWSViteConfig = {..._DEFAULT_CFG, ...config};
|
|
34
|
+
|
|
35
|
+
// Return a plain configuration object
|
|
36
|
+
return {
|
|
37
|
+
define: processEnvDefines(theConfig, _DEFAULT_CFG, devDebug),
|
|
38
|
+
plugins: getRWSVitePlugins({
|
|
39
|
+
scssPlugin,
|
|
40
|
+
packageDir: rwsPath.findPackageDir(process.cwd()),
|
|
41
|
+
nodeModulesPath: `${rwsPath.findRootWorkspacePath(process.cwd())}/node_modules`,
|
|
42
|
+
tsConfigPath: theConfig.tsConfigPath,
|
|
43
|
+
cssOutputPath: theConfig.cssOutputPath as string,
|
|
44
|
+
dev: config.dev as boolean
|
|
45
|
+
}),
|
|
46
|
+
build: {
|
|
47
|
+
minify: !config.dev,
|
|
48
|
+
sourcemap: config.dev,
|
|
49
|
+
outDir: 'dist',
|
|
50
|
+
rollupOptions: {
|
|
51
|
+
input: {
|
|
52
|
+
main: path.resolve(process.cwd(), 'index.html')
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
};
|
|
50
57
|
}
|
|
@@ -1,60 +1,61 @@
|
|
|
1
|
-
import path from 'path';
|
|
2
|
-
import { rwsPath } from '@rws-framework/console';
|
|
3
|
-
|
|
4
|
-
import _scss_compiler_builder from './scss/_compiler';
|
|
5
|
-
import _scss_import_builder from './scss/_import';
|
|
6
|
-
|
|
7
|
-
import _scss_fs_builder from './scss/_fs';
|
|
8
|
-
|
|
9
|
-
type PluginParams = { autoCompile: string[] };
|
|
10
|
-
|
|
11
|
-
class RWSScssPlugin {
|
|
12
|
-
protected autoCompile: string[] = [];
|
|
13
|
-
protected node_modules_dir: (fileDir: string) => void;
|
|
14
|
-
|
|
15
|
-
private _scss_import: any;
|
|
16
|
-
private _scss_fs: any;
|
|
17
|
-
private _scss_compiler: any;
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
{
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
{
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import { rwsPath } from '@rws-framework/console';
|
|
3
|
+
|
|
4
|
+
import _scss_compiler_builder from './scss/_compiler';
|
|
5
|
+
import _scss_import_builder from './scss/_import';
|
|
6
|
+
|
|
7
|
+
import _scss_fs_builder from './scss/_fs';
|
|
8
|
+
|
|
9
|
+
type PluginParams = { autoCompile: string[], dev: boolean };
|
|
10
|
+
|
|
11
|
+
class RWSScssPlugin {
|
|
12
|
+
protected autoCompile: string[] = [];
|
|
13
|
+
protected node_modules_dir: (fileDir: string) => void;
|
|
14
|
+
|
|
15
|
+
private _scss_import: any;
|
|
16
|
+
private _scss_fs: any;
|
|
17
|
+
private _scss_compiler: any;
|
|
18
|
+
private dev
|
|
19
|
+
|
|
20
|
+
constructor(params: PluginParams = { autoCompile: [], dev: true }) {
|
|
21
|
+
this.node_modules_dir = (fileDir) => path.relative(fileDir, rwsPath.findRootWorkspacePath(process.cwd())) + '/node_modules/'
|
|
22
|
+
this._scss_import = _scss_import_builder(this);
|
|
23
|
+
this._scss_fs = _scss_fs_builder(this);
|
|
24
|
+
this._scss_compiler = _scss_compiler_builder(this);
|
|
25
|
+
|
|
26
|
+
if (!!params.autoCompile && params.autoCompile.length > 0) {
|
|
27
|
+
this.autoCompile = params.autoCompile;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
for (let index in this.autoCompile) {
|
|
31
|
+
const sassFile = this.autoCompile[index];
|
|
32
|
+
this.compileFile(sassFile);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
apply(compiler) {
|
|
38
|
+
const _self = this;
|
|
39
|
+
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
async compileFile(scssPath): Promise<{ code: string, dependencies: string[]}>
|
|
44
|
+
{
|
|
45
|
+
scssPath = this._scss_import.processImportPath(scssPath, path.dirname(scssPath))
|
|
46
|
+
let scssCode = this._scss_fs.getCodeFromFile(scssPath);
|
|
47
|
+
return await this._scss_compiler.compileScssCode(scssCode, path.dirname(scssPath), null, scssPath);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async compileScssCode(scssCode: string, scssPath: string): Promise<{ code: string, dependencies: string[]}>
|
|
51
|
+
{
|
|
52
|
+
return await this._scss_compiler.compileScssCode(scssCode, scssPath, this.dev);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
writeCssFile(scssFilePath: string, cssContent: string): string
|
|
56
|
+
{
|
|
57
|
+
return this._scss_fs.writeCssFile(scssFilePath, cssContent);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export {RWSScssPlugin};
|
|
@@ -1,95 +1,96 @@
|
|
|
1
|
-
import sass from 'sass-embedded';
|
|
2
|
-
import path from 'path';
|
|
3
|
-
import chalk from 'chalk';
|
|
4
|
-
import emojiRegex from 'emoji-regex';
|
|
5
|
-
|
|
6
|
-
import _scss_fonts_builder from './_fonts';
|
|
7
|
-
let _scss_fonts: any = null;
|
|
8
|
-
import _scss_import_builder from './_import';
|
|
9
|
-
let _scss_import: any = null;
|
|
10
|
-
|
|
11
|
-
async function compileScssCode(scssCode: string, fileRootDir: string,
|
|
12
|
-
code: string,
|
|
13
|
-
dependencies: string[]
|
|
14
|
-
}> {
|
|
15
|
-
_scss_fonts = _scss_fonts_builder(this);
|
|
16
|
-
_scss_import = _scss_import_builder(this);
|
|
17
|
-
|
|
18
|
-
const [scssImports] = _scss_import.extractScssImports(scssCode, fileRootDir);
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
compiledCode =
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
console.error(
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
code = code.replace(
|
|
86
|
-
code = code.replace(
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
1
|
+
import sass from 'sass-embedded';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import chalk from 'chalk';
|
|
4
|
+
import emojiRegex from 'emoji-regex';
|
|
5
|
+
|
|
6
|
+
import _scss_fonts_builder from './_fonts';
|
|
7
|
+
let _scss_fonts: any = null;
|
|
8
|
+
import _scss_import_builder from './_import';
|
|
9
|
+
let _scss_import: any = null;
|
|
10
|
+
|
|
11
|
+
async function compileScssCode(scssCode: string, fileRootDir: string, minify: boolean = false): Promise<{
|
|
12
|
+
code: string,
|
|
13
|
+
dependencies: string[]
|
|
14
|
+
}> {
|
|
15
|
+
_scss_fonts = _scss_fonts_builder(this);
|
|
16
|
+
_scss_import = _scss_import_builder(this);
|
|
17
|
+
|
|
18
|
+
const [scssImports] = _scss_import.extractScssImports(scssCode, fileRootDir);
|
|
19
|
+
|
|
20
|
+
const dependencies = scssImports.map((item) => item[2]);
|
|
21
|
+
|
|
22
|
+
if (scssImports && scssImports.length) {
|
|
23
|
+
scssCode = _scss_import.replaceImports(_scss_import.processImports(scssImports, fileRootDir), scssCode);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const uses = _scss_import.extractScssUses(scssCode)[0];
|
|
27
|
+
let scssUses = '';
|
|
28
|
+
uses.forEach(scssUse => {
|
|
29
|
+
const useLine = scssUse[1];
|
|
30
|
+
if(scssCode.indexOf(useLine) === -1){
|
|
31
|
+
scssUses += useLine + '\n';
|
|
32
|
+
scssCode = scssCode.replace(useLine + '\n', '');
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
scssCode = removeComments(scssUses + scssCode);
|
|
37
|
+
|
|
38
|
+
try {
|
|
39
|
+
|
|
40
|
+
const result: sass.CompileResult = await sass.compileStringAsync(scssCode, {
|
|
41
|
+
loadPaths: [fileRootDir],
|
|
42
|
+
style: minify ? "compressed" : "expanded",
|
|
43
|
+
sourceMap: false
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
let compiledCode = result.css.toString();
|
|
47
|
+
|
|
48
|
+
compiledCode = _scss_fonts.replaceFontUrlWithBase64(compiledCode);
|
|
49
|
+
compiledCode = replaceEmojisWithQuestionMark(compiledCode, fileRootDir);
|
|
50
|
+
return { code: compiledCode, dependencies };
|
|
51
|
+
} catch (err) {
|
|
52
|
+
console.error('SASS Error in', fileRootDir);
|
|
53
|
+
console.error(err);
|
|
54
|
+
throw err;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function checkForImporterType(_module, checkTypeExt) {
|
|
59
|
+
let importingFileExtension = '';
|
|
60
|
+
if (_module && _module.issuer && _module.issuer.resource) {
|
|
61
|
+
importingFileExtension = path.extname(_module.issuer.resource);
|
|
62
|
+
if (importingFileExtension === ('.' + checkTypeExt)) {
|
|
63
|
+
return true;
|
|
64
|
+
}
|
|
65
|
+
} else {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
return false
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function replaceEmojisWithQuestionMark(code, componentDir) {
|
|
72
|
+
const regex = emojiRegex();
|
|
73
|
+
let hasEmoji = false;
|
|
74
|
+
const result = code.replace(regex, (match) => {
|
|
75
|
+
hasEmoji = true;
|
|
76
|
+
return '?';
|
|
77
|
+
});
|
|
78
|
+
if (hasEmoji) {
|
|
79
|
+
console.log(chalk.yellow(`Emojis in css detected and replaced with "?" in "${path.dirname(componentDir)}" component`));
|
|
80
|
+
}
|
|
81
|
+
return result;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function removeComments(code) {
|
|
85
|
+
code = code.replace(/\/\/.*$/gm, '');
|
|
86
|
+
code = code.replace(/\/\*[\s\S]*?\*\//g, '');
|
|
87
|
+
code = code.replace(/^\s*$(?:\r\n?|\n)/gm, '');
|
|
88
|
+
return code;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
export default function(element) {
|
|
92
|
+
return {
|
|
93
|
+
checkForImporterType: checkForImporterType.bind(element),
|
|
94
|
+
compileScssCode: compileScssCode.bind(element)
|
|
95
|
+
};
|
|
95
96
|
};
|
|
@@ -1,81 +1,81 @@
|
|
|
1
|
-
const fs = require('fs');
|
|
2
|
-
const path = require('path');
|
|
3
|
-
const FONT_REGEX = /url\(['"]?(.+?\.(woff|woff2|eot|ttf|otf))['"]?\)/gm;
|
|
4
|
-
|
|
5
|
-
import _scss_import_builder from './_import';
|
|
6
|
-
let _scss_import: any = null;
|
|
7
|
-
|
|
8
|
-
function hasFontEmbeds(css) {
|
|
9
|
-
return FONT_REGEX.test(css);
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
function embedFontsInCss(css, cssFilePath) {
|
|
13
|
-
let match;
|
|
14
|
-
|
|
15
|
-
while ((match = FONT_REGEX.exec(css)) !== null) {
|
|
16
|
-
const fontPath = match[1];
|
|
17
|
-
const absoluteFontPath = path.resolve(path.dirname(cssFilePath), fontPath);
|
|
18
|
-
|
|
19
|
-
if (fs.existsSync(absoluteFontPath)) {
|
|
20
|
-
const fontData = fs.readFileSync(absoluteFontPath);
|
|
21
|
-
const base64Font = fontData.toString('base64');
|
|
22
|
-
const fontMimeType = getFontMimeType(path.extname(absoluteFontPath));
|
|
23
|
-
const fontDataURL = `data:${fontMimeType};base64,${base64Font}`;
|
|
24
|
-
|
|
25
|
-
css = css.replace(new RegExp(match[0], 'g'), `url(${fontDataURL})`);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
return css;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
function getFontMimeType(extension) {
|
|
33
|
-
switch (extension) {
|
|
34
|
-
case '.woff': return 'font/woff';
|
|
35
|
-
case '.woff2': return 'font/woff2';
|
|
36
|
-
case '.eot': return 'application/vnd.ms-fontobject';
|
|
37
|
-
case '.ttf': return 'font/ttf';
|
|
38
|
-
case '.otf': return 'font/otf';
|
|
39
|
-
default: return 'application/octet-stream';
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
function convertFontToBase64(fontPath) {
|
|
44
|
-
return fs.readFileSync(fontPath, { encoding: 'base64' });
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
function replaceFontUrlWithBase64(cssContent) {
|
|
48
|
-
const fontFaceRegex = /@font-face\s*\{[^}]*\}/g;
|
|
49
|
-
let fontFaces = [...cssContent.matchAll(fontFaceRegex)];
|
|
50
|
-
_scss_import = _scss_import_builder(this);
|
|
51
|
-
|
|
52
|
-
for (const fontFace of fontFaces) {
|
|
53
|
-
const fontFaceContent = fontFace[0];
|
|
54
|
-
const urlRegex = /url\((['"]?)([^)'"]+)(\1)\)/g;
|
|
55
|
-
let match;
|
|
56
|
-
|
|
57
|
-
let modifiedFontFaceContent = fontFaceContent;
|
|
58
|
-
|
|
59
|
-
while ((match = urlRegex.exec(fontFaceContent)) !== null) {
|
|
60
|
-
// Create a promise to convert each font to Base64 and replace in CSS
|
|
61
|
-
const base64 = convertFontToBase64(_scss_import.processImportPath(match[2], null, true));
|
|
62
|
-
const base64Font = `data:font/woff2;base64,${base64}`;
|
|
63
|
-
|
|
64
|
-
modifiedFontFaceContent = modifiedFontFaceContent.replace(match[2], base64Font);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
cssContent = cssContent.replace(fontFaceContent, modifiedFontFaceContent)
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
return cssContent;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
export default function(element) {
|
|
74
|
-
return {
|
|
75
|
-
hasFontEmbeds: hasFontEmbeds.bind(element),
|
|
76
|
-
embedFontsInCss: embedFontsInCss.bind(element),
|
|
77
|
-
getFontMimeType: getFontMimeType.bind(element),
|
|
78
|
-
convertFontToBase64: convertFontToBase64.bind(element),
|
|
79
|
-
replaceFontUrlWithBase64: replaceFontUrlWithBase64.bind(element)
|
|
80
|
-
};
|
|
1
|
+
const fs = require('fs');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const FONT_REGEX = /url\(['"]?(.+?\.(woff|woff2|eot|ttf|otf))['"]?\)/gm;
|
|
4
|
+
|
|
5
|
+
import _scss_import_builder from './_import';
|
|
6
|
+
let _scss_import: any = null;
|
|
7
|
+
|
|
8
|
+
function hasFontEmbeds(css) {
|
|
9
|
+
return FONT_REGEX.test(css);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
function embedFontsInCss(css, cssFilePath) {
|
|
13
|
+
let match;
|
|
14
|
+
|
|
15
|
+
while ((match = FONT_REGEX.exec(css)) !== null) {
|
|
16
|
+
const fontPath = match[1];
|
|
17
|
+
const absoluteFontPath = path.resolve(path.dirname(cssFilePath), fontPath);
|
|
18
|
+
|
|
19
|
+
if (fs.existsSync(absoluteFontPath)) {
|
|
20
|
+
const fontData = fs.readFileSync(absoluteFontPath);
|
|
21
|
+
const base64Font = fontData.toString('base64');
|
|
22
|
+
const fontMimeType = getFontMimeType(path.extname(absoluteFontPath));
|
|
23
|
+
const fontDataURL = `data:${fontMimeType};base64,${base64Font}`;
|
|
24
|
+
|
|
25
|
+
css = css.replace(new RegExp(match[0], 'g'), `url(${fontDataURL})`);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return css;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
function getFontMimeType(extension) {
|
|
33
|
+
switch (extension) {
|
|
34
|
+
case '.woff': return 'font/woff';
|
|
35
|
+
case '.woff2': return 'font/woff2';
|
|
36
|
+
case '.eot': return 'application/vnd.ms-fontobject';
|
|
37
|
+
case '.ttf': return 'font/ttf';
|
|
38
|
+
case '.otf': return 'font/otf';
|
|
39
|
+
default: return 'application/octet-stream';
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function convertFontToBase64(fontPath) {
|
|
44
|
+
return fs.readFileSync(fontPath, { encoding: 'base64' });
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function replaceFontUrlWithBase64(cssContent) {
|
|
48
|
+
const fontFaceRegex = /@font-face\s*\{[^}]*\}/g;
|
|
49
|
+
let fontFaces = [...cssContent.matchAll(fontFaceRegex)];
|
|
50
|
+
_scss_import = _scss_import_builder(this);
|
|
51
|
+
|
|
52
|
+
for (const fontFace of fontFaces) {
|
|
53
|
+
const fontFaceContent = fontFace[0];
|
|
54
|
+
const urlRegex = /url\((['"]?)([^)'"]+)(\1)\)/g;
|
|
55
|
+
let match;
|
|
56
|
+
|
|
57
|
+
let modifiedFontFaceContent = fontFaceContent;
|
|
58
|
+
|
|
59
|
+
while ((match = urlRegex.exec(fontFaceContent)) !== null) {
|
|
60
|
+
// Create a promise to convert each font to Base64 and replace in CSS
|
|
61
|
+
const base64 = convertFontToBase64(_scss_import.processImportPath(match[2], null, true));
|
|
62
|
+
const base64Font = `data:font/woff2;base64,${base64}`;
|
|
63
|
+
|
|
64
|
+
modifiedFontFaceContent = modifiedFontFaceContent.replace(match[2], base64Font);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
cssContent = cssContent.replace(fontFaceContent, modifiedFontFaceContent)
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
return cssContent;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export default function(element) {
|
|
74
|
+
return {
|
|
75
|
+
hasFontEmbeds: hasFontEmbeds.bind(element),
|
|
76
|
+
embedFontsInCss: embedFontsInCss.bind(element),
|
|
77
|
+
getFontMimeType: getFontMimeType.bind(element),
|
|
78
|
+
convertFontToBase64: convertFontToBase64.bind(element),
|
|
79
|
+
replaceFontUrlWithBase64: replaceFontUrlWithBase64.bind(element)
|
|
80
|
+
};
|
|
81
81
|
};
|