Un projet web en utilisant Symfony 3 et Angular 2

Un projet web en utilisant Symfony 3 et Angular 2

Prérequis: Vous devez avoir le munimun en Angular 2 si non veuillez consulter les tutoriels en Angular 2

Etape 1 :

Après l’installation du Symfony 3, vous devez avoir npm installer sur votre machine si non voici la doc pour l’installation du nodeJS.

Etape 2 :

L’installation du notre projet Angular2 dans le répertoire web/

// Vous devez exécuter ses lignes

git clone https://github.com/angular/quickstart
mv -f quickstart/* .
mv -f quickstart/.* .

 

L’étape suivante et de supprimer le dossier quickstart , et les deux fichiers index.html et styles.css en utilisant la commande suivante

rm -rf app index.html styles.css quickstart/

Remarque : Nous avons supprimé le dossier app car nous allons utiliser le dossier bundles de Symfony où nous conservons tous les assets.

 

Etape 3 :

La mise à jour du fichier package.json situé dans le dossier web/ par ce code :

{
  "name": "angular-quickstart",
  "version": "1.0.0",
  "description": "QuickStart package.json from the documentation, supplemented with testing support",
  "scripts": {
    "e2e": "tsc && concurrently \"protractor protractor.config.js\" --kill-others --success first",
    "lint": "tslint ./app/**/*.ts -t verbose",
    "pree2e": "webdriver-manager update",
    "test": "tsc && concurrently \"tsc -w\" \"karma start karma.conf.js\"",
    "test-once": "tsc && karma start karma.conf.js --single-run",
    "tsc": "tsc",
    "tsc:w": "tsc -w"
  },
  "keywords": [],
  "author": "",
  "license": "MIT",
  "dependencies": {
    "@angular/common": "~2.2.0",
    "@angular/compiler": "~2.2.0",
    "@angular/core": "~2.2.0",
    "@angular/forms": "~2.2.0",
    "@angular/http": "~2.2.0",
    "@angular/platform-browser": "~2.2.0",
    "@angular/platform-browser-dynamic": "~2.2.0",
    "@angular/router": "~3.2.0",

    "angular-in-memory-web-api": "~0.1.15",
    "systemjs": "0.19.40",
    "core-js": "^2.4.1",
    "reflect-metadata": "^0.1.8",
    "rxjs": "5.0.0-beta.12",
    "zone.js": "^0.6.26"
  },
  "devDependencies": {
    "concurrently": "^3.1.0",
    "typescript": "^2.0.10",

    "canonical-path": "0.0.2",
    "http-server": "^0.9.0",
    "tslint": "^3.15.1",
    "lodash": "^4.16.4",
    "jasmine-core": "~2.4.1",
    "karma": "^1.3.0",
    "karma-chrome-launcher": "^2.0.0",
    "karma-cli": "^1.0.1",
    "karma-htmlfile-reporter": "^0.3.4",
    "karma-jasmine": "^1.0.2",
    "karma-jasmine-html-reporter": "^0.2.2",
    "protractor": "4.0.9",
    "webdriver-manager": "10.2.5",
    "rimraf": "^2.5.4",

    "@types/node": "^6.0.46",
    "@types/jasmine": "^2.5.36",
    "@types/selenium-webdriver": "^2.53.33"
  },
  "repository": {}
}

 

La modification aussi du fichier systemjs.config.js situé dans web/src/ par ce code :

/**
 * System configuration for Angular samples
 * Adjust as necessary for your application needs.
 */
(function (global) {
  System.config({
    paths: {
      // paths serve as alias
      'npm:': 'node_modules/'
    },
    // map tells the System loader where to look for things
    map: {
      // our app is within the app folder
      app: 'bundles',

      // angular bundles
      '@angular/core': 'npm:@angular/core/bundles/core.umd.js',
      '@angular/common': 'npm:@angular/common/bundles/common.umd.js',
      '@angular/compiler': 'npm:@angular/compiler/bundles/compiler.umd.js',
      '@angular/platform-browser': 'npm:@angular/platform-browser/bundles/platform-browser.umd.js',
      '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic/bundles/platform-browser-dynamic.umd.js',
      '@angular/http': 'npm:@angular/http/bundles/http.umd.js',
      '@angular/router': 'npm:@angular/router/bundles/router.umd.js',
      '@angular/router/upgrade': 'npm:@angular/router/bundles/router-upgrade.umd.js',
      '@angular/forms': 'npm:@angular/forms/bundles/forms.umd.js',
      '@angular/upgrade': 'npm:@angular/upgrade/bundles/upgrade.umd.js',
      '@angular/upgrade/static': 'npm:@angular/upgrade/bundles/upgrade-static.umd.js',

      // other libraries
      'rxjs':                      'npm:rxjs',
      'angular-in-memory-web-api': 'npm:angular-in-memory-web-api/bundles/in-memory-web-api.umd.js'
    },
    // packages tells the System loader how to load when no filename and/or no extension
    packages: {
      app: {
        main: './app/ts/main.js',
        defaultExtension: 'js'
      },
      rxjs: {
        defaultExtension: 'js'
      }
    }
  });
})(this);
// Se qu on a fait : 
// C est changé app: bundles,
// changé le path du fichier main.js

 

Etape 4 :

L’installation des dépendances de NodeJS

Rendez vous sur le dossier web et exécuter cette commande

npm install

 

Etape 5 :

Maintenant on va créer notre première Component

Rendez vous sur le dossier web/bundles/ , on va créer un dossier app/ et dans ce dossier app on va créer un dossier ts/

Donc le chemin qu’on va avoir est web/bundles/app/ts/

Ensuite on va créer 3 fichiers comme suit :

// fichier 1 web/bundles/app/ts/app.component.ts

import { Component } from '@angular/core';

@Component({
    selector: 'sf-angular',
    template: 'Message à afficher'
})

export class AppComponent { }

// fichier 2 web/bundles/app/ts/app.module.ts

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent }   from './app.component';

@NgModule({
    imports:      [ BrowserModule ],
    declarations: [ AppComponent ],
    bootstrap:    [ AppComponent ]
})

export class AppModule { }

// fichier 3 web/bundles/app/ts/main.ts

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app.module';

const platform = platformBrowserDynamic();
platform.bootstrapModule(AppModule);

 

Retournez nous un peut sur Symfony, on va modifier le fichier par defaut base.html.twig situé dans \app\Resources\views

<html>
    <head>
        <meta charset="UTF-8" />
        <title>{% block title %}Welcome!{% endblock %}</title>
        {% block stylesheets %}{% endblock %}
        <link rel="icon" type="image/x-icon" href="{{ asset('favicon.ico') }}" />
 
        <!-- 1. Load libraries -->
        <!-- Polyfill(s) for older browsers -->
        <script src="{{ asset('node_modules/core-js/client/shim.min.js') }}"></script>
        <script src="{{ asset('node_modules/zone.js/dist/zone.js') }}"></script>
        <script src="{{ asset('node_modules/reflect-metadata/Reflect.js') }}"></script>
        <script src="{{ asset('node_modules/systemjs/dist/system.src.js') }}"></script>
        <!-- 2. Configure SystemJS -->
        <script src="{{ asset('src/systemjs.config.js') }}"></script>
        <script>
            System.import('app').catch(function(err){ console.error(err); });
        </script>
    </head>
    <body>
        {% block body %}
        {% endblock %}
        {% block javascripts %}{% endblock %}
    </body>
</html>

 

La modification d’un autre fichier view est nécessaire pour l’affichage correcte du code.

Suite au dernier tutoriel on a crée un bundle ArticlesBundle, on va modifier notre fichier view par defaut

{% extends '::base.html.twig' %}

{% block body %}
    Bonjour,
    <sf-angular>Patientez svp...</sf-angular>
{% endblock %}

 

La dernière chose à faire est de compiler les fichiers ts. Dans le dossier Web.

Rendez vous sur le dossier web/

npm run tsc /bundles/app/ts/*

 

Etape 6 :

Ouvrir une autre invite de commande dans la répertoire principale de Symfony et exécuter cette ligne

./bin/console server:start

Et puis naviguer sur et voilà. 🙂