MOBILE-4527 compile: Fix JIT modules

More details about the fix: https://github.com/angular/angular/issues/44660#issuecomment-1976349160
main
Noel De Martin 2024-02-28 12:40:23 +01:00
parent 5ef95b611f
commit afb5ce3cde
4 changed files with 73 additions and 2 deletions

View File

@ -27,16 +27,19 @@ class mobile {
* @return array View data. * @return array View data.
*/ */
public static function view_index() { public static function view_index() {
global $OUTPUT;
$templates = [ $templates = [
[ [
'id' => 'main', 'id' => 'main',
'html' => '<h1 class="text-center">Hello<span id="username"></span>!</h1>', 'html' => $OUTPUT->render_from_template('local_moodleappbehat/mobile', []),
], ],
]; ];
$otherdata = ['answer' => null];
$javascript = file_get_contents(__DIR__ . '/../../js/mobile/index.js'); $javascript = file_get_contents(__DIR__ . '/../../js/mobile/index.js');
return compact('templates', 'javascript'); return compact('templates', 'otherdata', 'javascript');
} }
} }

View File

@ -0,0 +1,15 @@
{{=<% %>=}}
<h1 class="text-center">Hello<span id="username"></span>!</h1>
<ion-list>
<ion-item>
<ion-label position="floating">What is the answer to the Ultimate Question of Life, The Universe, and Everything?</ion-label>
<ion-input [(ngModel)]="CONTENT_OTHERDATA.answer"></ion-input>
</ion-item>
<ion-item *ngIf="CONTENT_OTHERDATA.answer === '42'">
<ion-label>That is correct!</ion-label>
</ion-item>
<ion-item *ngIf="CONTENT_OTHERDATA.answer && CONTENT_OTHERDATA.answer !== '42'">
<ion-label>That is not correct!</ion-label>
</ion-item>
</ion-list>

View File

@ -0,0 +1,46 @@
diff --git a/node_modules/@angular/compiler/fesm2022/compiler.mjs b/node_modules/@angular/compiler/fesm2022/compiler.mjs
index 5831cd3..c0ae072 100755
--- a/node_modules/@angular/compiler/fesm2022/compiler.mjs
+++ b/node_modules/@angular/compiler/fesm2022/compiler.mjs
@@ -6072,13 +6072,41 @@ var R3NgModuleMetadataKind;
R3NgModuleMetadataKind[R3NgModuleMetadataKind["Global"] = 0] = "Global";
R3NgModuleMetadataKind[R3NgModuleMetadataKind["Local"] = 1] = "Local";
})(R3NgModuleMetadataKind || (R3NgModuleMetadataKind = {}));
+
+/**
+ * These are the only modules we're using to compile dynamic templates, we don't need to force JIT anywhere else.
+ *
+ * In particular, they are imported like this:
+ * - CommonModule
+ * - FormsModule -> ɵInternalFormsSharedModule -> RadioControlRegistryModule
+ * - IonicModule -> CommonModule
+ * - ReactiveFormsModule -> ɵInternalFormsSharedModule -> RadioControlRegistryModule
+ * - TranslateModule
+ */
+const jitModules = [
+ 'CommonModule',
+ 'FormsModule',
+ 'IonicModule',
+ 'ɵInternalFormsSharedModule',
+ 'RadioControlRegistryModule',
+ 'ReactiveFormsModule',
+ 'TranslateModule',
+];
+
/**
* Construct an `R3NgModuleDef` for the given `R3NgModuleMetadata`.
*/
function compileNgModule(meta) {
const statements = [];
const definitionMap = new DefinitionMap();
+ const moduleName = meta.type.value?.node.loc?.identifierName;
definitionMap.set('type', meta.type.value);
+
+ if (moduleName && jitModules.includes(moduleName)) {
+ // Force JIT compilation.
+ meta.selectorScopeMode = R3SelectorScopeMode.Inline;
+ }
+
// Assign bootstrap definition. In local compilation mode (i.e., for
// `R3NgModuleMetadataKind.LOCAL`) we assign the bootstrap field using the runtime
// `ɵɵsetNgModuleScope`.

View File

@ -19,3 +19,10 @@ Feature: Plugins work properly.
When I press the more menu button in the app When I press the more menu button in the app
And I press "Moodle App Behat (auto-generated)" in the app And I press "Moodle App Behat (auto-generated)" in the app
Then I should find "Lifecycle hook called" in the app Then I should find "Lifecycle hook called" in the app
Scenario: Use Angular directives
Given I entered the app as "studentusername"
When I press the more menu button in the app
And I press "Moodle App Behat (auto-generated)" in the app
And I set the field "the Ultimate Question" to "42" in the app
Then I should find "That is correct!" in the app