<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: TDP17</title>
    <description>The latest articles on DEV Community by TDP17 (@tdp17).</description>
    <link>https://dev.to/tdp17</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F736898%2F6baa8b41-ba93-495b-b726-b128ddb1f5ca.png</url>
      <title>DEV Community: TDP17</title>
      <link>https://dev.to/tdp17</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/tdp17"/>
    <language>en</language>
    <item>
      <title>Flexi project - Blog Report</title>
      <dc:creator>TDP17</dc:creator>
      <pubDate>Fri, 28 Apr 2023 07:55:18 +0000</pubDate>
      <link>https://dev.to/tdp17/flexi-project-blog-report-gkg</link>
      <guid>https://dev.to/tdp17/flexi-project-blog-report-gkg</guid>
      <description>&lt;p&gt;For our 6th semester of college, my friends and I decided to work on a document management &lt;code&gt;progressive web app (pwa)&lt;/code&gt; called 'DocIt'.&lt;br&gt;
In this blog, I will dive into the latest tools and techniques used to create the Frontend of this application. I will also talk about why this set of technologies was our choice.&lt;/p&gt;

&lt;h2&gt;
  
  
  Which technologies were used by an individual in the project
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;a href="https://vuejs.org/"&gt;&lt;strong&gt;Vue.js&lt;/strong&gt;&lt;/a&gt; - a JavaScript framework for building web user interfaces.&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://sass-lang.com/"&gt;&lt;strong&gt;SASS&lt;/strong&gt;&lt;/a&gt; - a CSS extension language for styling&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://fontawesome.com/"&gt;&lt;strong&gt;FontAwesome&lt;/strong&gt;&lt;/a&gt; - icon library and toolkit&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Linting &amp;amp; Code Quality&lt;/strong&gt; - a &lt;strong&gt;Husky, ESLint, Staged-Lint&lt;/strong&gt; and &lt;strong&gt;Prettier&lt;/strong&gt; setup&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Why only these technologies
&lt;/h2&gt;

&lt;h3&gt;
  
  
  Vue
&lt;/h3&gt;

&lt;blockquote&gt;
&lt;p&gt;Vue2 is awesome because it combines simplicity, flexibility, performance, and a supportive community, making it a powerful tool for building modern user interfaces for web applications.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Being used to React/Next environments, I was a bit hesitant when it came to migrating to Vue for this project. All of it changed when I started working on the project and the migration was made seamless by the extensive and comprehensive documentation that they provide. &lt;/p&gt;

&lt;h4&gt;
  
  
  Some features I personally enjoyed of Vue.js
&lt;/h4&gt;

&lt;ul&gt;
&lt;li&gt;In built state management library &lt;code&gt;Vuex&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Out of the box scoped styling support options with sass/scss&lt;/li&gt;
&lt;li&gt;Shorthands for many common workflows like &lt;code&gt;v-model&lt;/code&gt; reduces developer time by a lot&lt;/li&gt;
&lt;li&gt;The opinionated suggestions for routing, state management solutions like &lt;code&gt;vue-router&lt;/code&gt;, &lt;code&gt;vuex&lt;/code&gt; and their documentation. This is while keeping it flexible to mix-n-match &lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Sass + FontAwesome
&lt;/h3&gt;

&lt;p&gt;These libraries are just amazing at reducing development time and for the short timeframe of this project, proved to be a godsend&lt;/p&gt;

&lt;h3&gt;
  
  
  Linting &amp;amp; Code Quality
&lt;/h3&gt;

&lt;h4&gt;
  
  
  Husky
&lt;/h4&gt;

&lt;p&gt;Allows you to manage your client-side &lt;code&gt;githooks&lt;/code&gt; and is a pretty cool open-source solution to most of the hassles that come up while setting up hooks&lt;/p&gt;

&lt;h4&gt;
  
  
  Staged-lint
&lt;/h4&gt;

&lt;p&gt;A tool to run your linting (husky pre-commit hook in this case) only for the changed (staged) files&lt;/p&gt;

&lt;h4&gt;
  
  
  Prettier + ESLint
&lt;/h4&gt;

&lt;p&gt;Industry standards for maintaining code formatting, quality and static checking for problems (linting)&lt;/p&gt;

&lt;h2&gt;
  
  
  How you applied the learned knowledge to your project
&lt;/h2&gt;

&lt;p&gt;During this semester, we also learned about Vue in class, which helped me get a head-start in developing the project. The workflows and correct practices taught to us were very helpful in quickly getting me used to Vue development. &lt;br&gt;
We were also taught to create PWAs and the ecosystem surrounding them (service workers, manifests, etc.)&lt;/p&gt;

&lt;h2&gt;
  
  
  How differently you have applied the technologies in use
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Vue.js - Frontend development library - SFCs
Ecosystem of Vuex, Vue-router

CSS + SCSS - Styling - Scoped

PWA - Creating a PWA

FontAwesome - Icons
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  How others have used which technologies for similar work / project
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://vuejs.org/partners/"&gt;Vue Partners&lt;/a&gt;&lt;br&gt;
Vue is used by the likes of Facebook, Netflix, Adobe, Apple, Google, Gitlab for the development of their products' user interfaces. It is only rising in popularity according to Stack overflow surveys due to it's friendly learning curve and DX.&lt;/p&gt;

&lt;h2&gt;
  
  
  About your technical contribution and learning via this blog
&lt;/h2&gt;

&lt;p&gt;I worked primarily on the Frontend development.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Receive the designs in Figma&lt;/li&gt;
&lt;li&gt;Code up the user interface, fix it's responsivity and styling&lt;/li&gt;
&lt;li&gt;Add the reactive (js) part&lt;/li&gt;
&lt;li&gt;Connect to the backend using &lt;code&gt;fetch&lt;/code&gt; requests&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;I also deployed the project using &lt;code&gt;Firebase&lt;/code&gt;, transformed it into a PWA and further tested if it fit the requirements&lt;/p&gt;

&lt;p&gt;As a part of the project, my team and I worked in sprints which also introduced me to the world of documentation and Agile. I took on the role of Scrum Master and planned out the execution of the project&lt;/p&gt;

&lt;p&gt;Essentially, I learnt a new JavaScript framework Vue.js, its development environment, how to create PWAs and much more.&lt;/p&gt;

</description>
      <category>vue</category>
      <category>firebase</category>
      <category>pwa</category>
    </item>
  </channel>
</rss>
