Book Image

Full Stack Development with Angular and GraphQL

By : Ahmed Bouchefra
Book Image

Full Stack Development with Angular and GraphQL

By: Ahmed Bouchefra

Overview of this book

GraphQL is an alternative to traditional REST technology for querying Web APIs. Together with Angular and TypeScript, it provides a tech stack option for building future-proof web applications that are robust and maintainable at any scale. This book leverages the potential of cutting-edge technologies like GraphQL and Apollo and helps Angular developers add it to their stack. Starting with introducing full-stack development, you will learn to create a monorepo project with Lerna and NPM Workspaces. You will then learn to configure Node.js-based backend using GraphQL, Express, and Apollo Server. The book will demonstrate how to build professional-looking UIs with Angular Material. It will then show you how to create Web APIs for your frontend with GraphQL. All this in a step-by-step manner. The book covers advanced topics such as local state management, reactive variables, and generating TypeScript types using the GraphQL scheme to develop a scalable codebase. By the end of this book, you'll have the skills you need to be able to build your full-stack application.
Table of Contents (16 chapters)
1
Part 1: Setting Up the Development Environment, GraphQL Server, and Database
7
Part 2: Building the Angular Frontend with Realtime Support
13
Part 3: Adding Realtime Support

Implementing the profile component

In this section, we'll implement the profile component by extending the base component:

  1. To begin, open the core/index.ts file and export the profile service using the following syntax:
    export { ProfileService }
        from '../users/services/profile/profile.service';
  2. Open the users/components/profile/profile.component.ts file and add the imports as follows:
    import {
      Component,
      ElementRef,
      Injector,
      ViewChild
    } from '@angular/core';
    import {
      ActivatedRoute,
      ParamMap
    } from '@angular/router';
    import { User }
      from '@ngsocial/graphql/types';
    import {
      User
        as UserModel
    } from 'src/app/shared';
    import { Maybe } from 'graphql/jsutils/Maybe';
    import { Subject } from 'rxjs';
    import {
      take,
      takeUntil,
      switchMap...