The goal is to create a simple web application that makes a request to an API, parses the response, and displays the result in the UI. The app will consist of two major components - one search component and one results component.
This component should contain two elements:
- 'Login' Text input for entering a String value
- 'Submit' Button for initiating a request to
https://api.github.com/search/users?q={login} in:login
, where {login} is the input value
# Example curl GET request to search for login `foo`
curl --request GET '[https://api.github.com/search/users?q=foo in:login](https://api.github.com/search/users?q=foo%20in:login)'
This component should contain a single element:
- Results Table for displaying the results of the User search
The results table has the following requirements:
- Display three columns from the response:
avatar_url
login
type
- Use Pagination, with 9 items displayed Per_Page
The UI should appear modern and simple while following best practices around HTML + CSS/SCSS.
- After the app is launched, the Search component is displayed
- The user enters a random String value into the 'Login' field and clicks the 'Submit' button
- The app sends an HTTP request to
https://api.github.com/search/users?q={login} in:login
, where {login} is the String value entered by the user - The app then parses the response from the server. If data is returned, the Results component should display the fetched values. If there is an issue with the request, then an error message should be displayed.
- The app should be written using TypeScript, with proper static typings applied wherever possible
- The app has to compile and run without issue. It should be stable and reasonably fool-proof, handling all obvious test cases.
- The overall code quality should be excellent, with the assumption the application would be deployed to a production environment.
- The app should contain basic tests, with >50% code coverage.
- Production: https://wondrous-kitsune-c7984a.netlify.app
- Development: https://dev--wondrous-kitsune-c7984a.netlify.app
This project was generated with: Angular CLI version 14.
- Node: v16
- Package Manager: npm v8.5
Run npm run start
for a dev server. Navigate to http://localhost:4200/
. The application will automatically reload if you change any of the source files.
Run npm run build
to build the project. The build artifacts will be stored in the dist/isidro-moreno-web
directory.
Run npm run test
to execute the unit tests and generate reports via Jest.
Run
npm run test
Every time tests are run a text report is printed in the console and an Istanbul HTML report is stored under:
<project_root>/coverage/lcov-report/isidro-moreno-web/index.html
Features released as of September 26th:
- Search input component that triggers API query given a
login
string input. - Results component:
- Display paginated results in a table if input
string
matches alogin
field. More info here - Provide page navigation through custom pagination component (navigation information is retrieved from API response headers
- Client side sorting by
login
column. (Client side sorting for current page data displayed in the table). Github doensn't providelogin
as a sort parameter for server-side sorting. More info here.
- Display paginated results in a table if input
- Loading indicators for:
- New search
- Page navigation
- Welcome screen with instructions
- Responsive design
- Error screens for server and client side errors (Unhandled JS exceptions, Network outage, others)
The following items describe the main guidelines I took in order to share skills and get feedback. I've performed tasks I'm used to performing on a daily basis. For that purpose I followed some steps like:
- setting up an Angular project from scratch
- research and analyze about tools that help accelerate development:
- ng-zorro for UI/UX development
- http-link-header parser lib for GitHub API pagination metadata provided in response headers)
- develop custom components that adjust to API features/restrictions
- The solution needs a component that prevents the user from navigating to a specific page (not included among ng-zorro components) and at the same time yet simple to cover usual navigation requirements: besides the fact ng-zorro provides several components for navigating through pages, GitHub's Pagination documentation suggests to use navigation links provided in response headers for building a URL on client side in order to get pagination data instead of building URLs dynamically. For that purpose:
- I developed a custom navigation component that fits page navigation metadata provided by GitHub's API response headers
- make commits following a unified and simple syntax (check repo history)
- include common code quality tools as part of development life cycle and CI like Prettier, ESLint and integration of pre-commit hook (
lint-staged
node package) - use pull requests and provide relevant information
- Follow rebase/linear history
- Enable GitHub Actions for build checks (Code coverage, Unit Tests, Code formatting checks, other Node CI GitHub Actions)
- Integrate
dev
andmain
branches with Netlify Deploys - Automatic "Netlify Deploy Previews" for each PR
- Netlify Deployment details integration to PRs as comments:
Example:
- Angular: v14
- ng-zorro: v13
- http-link-header v1.0.5
- Angular CLI: v14
- rxjs v7.5
- typescript v4.6
- ESLint
- Prettier
- Jasmine
- lint-staged