From 6ed1c5db0fe1af121ac9698d58ab0ca880643435 Mon Sep 17 00:00:00 2001 From: Kyle McCormick Date: Fri, 6 Jan 2023 16:37:10 -0500 Subject: [PATCH] refactor: go back to using upstream process_npm_assets --- .../openedx/settings/partials/common_all.py | 13 +++++ .../build/openedx/bin/openedx-assets | 52 +------------------ .../build/openedx/settings/partials/assets.py | 13 +++++ 3 files changed, 27 insertions(+), 51 deletions(-) diff --git a/tutor/templates/apps/openedx/settings/partials/common_all.py b/tutor/templates/apps/openedx/settings/partials/common_all.py index b22519922c7..26a37538e0d 100644 --- a/tutor/templates/apps/openedx/settings/partials/common_all.py +++ b/tutor/templates/apps/openedx/settings/partials/common_all.py @@ -177,5 +177,18 @@ "user": None, } +# Upstream expects node_modules to be within edx-platform, but we put +# node_modules under /openedx/node_modules, so we must adjust any settings +# that hold a node_modules path. +NODE_MODULES_ROOT = "/openedx/node_modules/@edx" +STATICFILES_DIRS = [ + *[ + staticfiles_dir for staticfiles_dir in STATICFILES_DIRS + if "node_modules/@edx" not in staticfiles_dir + ], + NODE_MODULES_ROOT, +] +PIPELINE["UGLIFYJS_BINARY"] = "/openedx/node_modules/.bin/uglifyjs" + {{ patch("openedx-common-settings") }} ######## End of settings common to LMS and CMS diff --git a/tutor/templates/build/openedx/bin/openedx-assets b/tutor/templates/build/openedx/bin/openedx-assets index 0610e8a671b..aadf2c1371f 100755 --- a/tutor/templates/build/openedx/bin/openedx-assets +++ b/tutor/templates/build/openedx/bin/openedx-assets @@ -141,58 +141,8 @@ def run_xmodule(_args): def run_npm(_args): """ Post-process npm assets. - - Reimplementation of edx-platform's pavelib/assets.py:process_npm_assets() """ - - print(f"{sys.argv[0]}: Post-processing npm assets.") - print(f"{sys.argv[0]}: {NODE_MODULES_PATH=}") - - # Create JS and CSS vendor directories. - sh( - "mkdir", - "-p", - "common/static/common/js/vendor", - "common/static/common/css/vendor", - ) - - # Copy studio-frontend CSS and JS into vendor directory. - copy_css = f"""\ -find {NODE_MODULES_PATH}/@edx/studio-frontend/dist \ --type f \( -name \*.css -o -name \*.css.map \) | \ -xargs cp --target-directory=common/static/common/css/vendor\ -""" - copy_js = f"""\ -find {NODE_MODULES_PATH}/@edx/studio-frontend/dist \ --type f \! -name \*.css \! -name \*.css.map | \ -xargs cp --target-directory=common/static/common/js/vendor\ -""" - sh("sh", "-c", copy_css) - sh("sh", "-c", copy_js) - - # Copy certain node_modules into vendor directory. - sh( - "cp", - "-f", - "--target-directory=common/static/common/js/vendor", - f"{NODE_MODULES_PATH}/backbone.paginator/lib/backbone.paginator.js", - f"{NODE_MODULES_PATH}/backbone/backbone.js", - f"{NODE_MODULES_PATH}/bootstrap/dist/js/bootstrap.bundle.js", - f"{NODE_MODULES_PATH}/hls.js/dist/hls.js", - f"{NODE_MODULES_PATH}/jquery-migrate/dist/jquery-migrate.js", - f"{NODE_MODULES_PATH}/jquery.scrollto/jquery.scrollTo.js", - f"{NODE_MODULES_PATH}/jquery/dist/jquery.js", - f"{NODE_MODULES_PATH}/moment-timezone/builds/moment-timezone-with-data.js", - f"{NODE_MODULES_PATH}/moment/min/moment-with-locales.js", - f"{NODE_MODULES_PATH}/picturefill/dist/picturefill.js", - f"{NODE_MODULES_PATH}/requirejs/require.js", - f"{NODE_MODULES_PATH}/underscore.string/dist/underscore.string.js", - f"{NODE_MODULES_PATH}/underscore/underscore.js", - f"{NODE_MODULES_PATH}/which-country/index.js", - f"{NODE_MODULES_PATH}/sinon/pkg/sinon.js", - f"{NODE_MODULES_PATH}/squirejs/src/Squire.js", - ) - + sh("/bin/sh", "scripts/process-npm-assets.sh", "--node-modules", "/openedx/node_modules") def run_webpack(args): print(f"{sys.argv[0]}: Executing webpack") diff --git a/tutor/templates/build/openedx/settings/partials/assets.py b/tutor/templates/build/openedx/settings/partials/assets.py index fce97cdb857..bbd4e7f0369 100644 --- a/tutor/templates/build/openedx/settings/partials/assets.py +++ b/tutor/templates/build/openedx/settings/partials/assets.py @@ -18,4 +18,17 @@ "default": {}, } +# Upstream expects node_modules to be within edx-platform, but we put +# node_modules under /openedx/node_modules, so we must adjust any settings +# that hold a node_modules path. +NODE_MODULES_ROOT = "/openedx/node_modules/@edx" +STATICFILES_DIRS = [ + *[ + staticfiles_dir for staticfiles_dir in STATICFILES_DIRS + if "node_modules/@edx" not in staticfiles_dir + ], + NODE_MODULES_ROOT, +] +PIPELINE["UGLIFYJS_BINARY"] = "/openedx/node_modules/.bin/uglifyjs" + {{ patch("openedx-common-assets-settings") }}