Programming Tips πŸ’‘
51.5K subscribers
67 photos
10 videos
30 files
354 links
Programming & AI:
Tips πŸ’‘
Articles πŸ“•
Resources πŸ‘Ύ
Design Patterns πŸ’Ž
Software Principles βœ…

πŸ‡³πŸ‡± Contact: @MoienTajik

🎯 Buy ads: https://telega.io/c/ProgrammingTip
Download Telegram
Principle of Least Surprise 😳

Principle Statement :

In interface design, always do the least surprising thing. 😨

Description :

Never surprise the user. ❌

An interface should behave exactly as the user thinks it behaves. βœ…

What surprises the user depends on the kind of interface and the type of user. πŸ–₯

The central idea of PLS is to think about how the user would want to use the interface. 🀳🏻

Principle of least astonishment is when you, as an API designer, prevent your users from saying WAT. 😱

πŸ”ΈπŸ”ΉπŸ”ΈπŸ”Ή

Examples :

1️⃣ Consider an elevator with a button next to it that says "call". ☎️

When you press the button, the payphone phone rings (rather than calling the elevator to that floor). ❌

The correct design would be to put the call button next to the phone rather than the elevator. β›“


2️⃣ Think of a web page that has popup window that shows a windows style error with an 'ok' button on it. πŸ†—

People click the 'ok' button thinking it is for the operating system and instead go to another web page. 🌐

This astonishes the user. 😦


3️⃣ The name of a function should reflect what it does. Otherwise, a user of the function will be unpleasantly surprised❗️

Bad :
int multiply(int a, int b)
{
return a + b;
}


Better :
int multiply(int a, int b)
{
return a * b;
}


πŸ”ΉπŸ”ΈπŸ”ΉπŸ”Έ

When it comes to an API ... πŸ‘Ύ

β€’ Think about a toString() method that instead of printing out the fields returns back "to be implemented". πŸ€₯

β€’ An equals() method that works on hidden information. πŸ‘

β€’ Sometimes people try to implement a sorted list class by changing the add method to call sort() on the array afterwards. πŸ—‚

This astonishing because the add method is supposed to append to the list. πŸ—³

This is especially astonishing when one gets back a List object with no knowledge that somewhere deep inside, someone violated the interface contract. πŸ€”

Having a method that does one distinct thing contributes to reduction of astonishment. βœ…

https://t.me/pgimg/115

γ€°γ€°γ€°γ€°γ€°γ€°
#Principle #PLS
@ProgrammingTip
Nivo ✨

Provides supercharged React components to easily build dataviz apps, it's built on top of d3. βš›οΈ

Several libraries already exist for React d3 integration, but just a few provide server side rendering ability and fully declarative charts. πŸ’Ž

Features :
πŸ”Έ Highly customizable
πŸ”Ή Motion/transitions
πŸ”Έ Component playground
πŸ”Ή Exhaustive documentation
πŸ”Έ Isomorphic rendering
πŸ”Ή SVG charts
πŸ”Έ HTML charts
πŸ”Ή Canvas charts
πŸ”Έ Server side rendering API
πŸ”Ή Gradients
πŸ”Έ Responsive charts

https://t.me/pgimg/116

[ Source ] : github.com/plouc/nivo

[ Document & Website ] : nivo.rocks

γ€°γ€°γ€°γ€°γ€°γ€°
#React #Chart #Calendar
#Treemap #JavaScript

@ProgrammingTip
Use DbContextPooling to Improve the Performance : .NET Core 2.1 Feature πŸ’Ž

If you are familiar with .NET Core, then you might be knowing AddDbContext method. 🧐

This method is used to inject dependency of DbContext into your controller and it should be written in the Startup.cs class. πŸ’‰

So in case of AddDbContext, a new instance will be created for each request and would get disposed once the work is done. ♻️

New contexts are getting created for each request. ⏳

That is still fine but if there are more than 1k requests – 1k times object will be created and disposed, unless you have made it a Singleton. ☝🏻

Creating and disposing of so many objects may impact the performance. ❌

How DbContextPooling can help❓

https://t.me/pgimg/117

[ Article ] : http://bit.do/dbpol

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core
@ProgrammingTip
Using MariaDB with ASP.NET Core 2.0 🌊

What is MariaDB❓

MariaDB is a community-developed fork of the MySQL relational database management system intended to remain free under the GNU GPL. 🐧

Development is led by some of the original developers of MySQL, who forked it due to concerns over its acquisition by Oracle Corporation. πŸ’Ž

Basically it is a fork of MySQL which is guaranteed to stay open source, and as noted it is supposed to be a drop-in replacement for MySQL. ✨

So let’s put this to the test with a simple ASP.NET Core application. πŸ”₯

https://t.me/pgimg/118

[ Article ] : bit.do/mariad

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core #MariaDB #MySql
@ProgrammingTip
18 Interesting Things from jQuery ✨

jQuery is one of the most popular JavaScript libraries in use today. πŸ’Ž

It is the library that is beloved by most of the web developers for scripting. πŸ‘Ύ

In this article I'm going to share you some of the interesting things from that library. πŸ”₯

https://t.me/pgimg/119

[ Article ] : bit.do/jqint

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #jQuery
@ProgrammingTip
Blazor πŸ”₯

An experimental .NET web framework using C#/Razor and HTML that runs in the browser via WebAssembly that is supported by Microsoft. πŸ’Ž

Blazor is a .NET web framework that runs in any browser. 🌐

Blazor uses only the latest web standards. No plugins or transpilation needed. βœ…

It runs in the browser on a real .NET runtime (Mono) implemented in WebAssembly that executes normal .NET assemblies. ⚑️

It works in older browsers too by falling back to an asm.js based .NET runtime. πŸ‘΄πŸΏ

Blazor will have all the features of a modern web framework, including ✨ :
β€’ Components
β€’ Routing
β€’ Layouts
β€’ Forms and validation
β€’ Dependency injection
β€’ JavaScript interop
β€’ Live reloading
β€’ Server-side rendering
β€’ Full .NET debugging


https://t.me/pgimg/120

[ Github ] : bit.do/blazor
[ Learn ] : learn-blazor.com
[ Flight Finder ] : bit.do/ffinder
[ Sample CRUD ] : bit.do/bzcrud

γ€°γ€°γ€°γ€°γ€°γ€°
#Blazor #AspMvc #Core
@ProgammingTip
Avoid Lazy Loading Entities in ASP.NET Applications πŸ™…πŸ»β€β™‚οΈ

Lazy Loading is an Entity Framework feature that lets you worry less about the specific amount of data you need to fetch with a given query. 😌

Instead, you write simple queries, and Entity Framework will load the minimal amount of data (which is a good thing), and then will only fetch additional data on an as-needed basis. βœ…

That is, rather than eager loading all of the related data a given entity might have, lazy loading is a technique that has EF perform the minimal amount of work needed up front, and then only performs additional work if it turns out to be necessary. ⚠️

This sounds like a great feature, but you should turn it off in your ASP.NET web apps. 🚫

This article explains why you should do this. 🧐


https://t.me/pgimg/121

[ Article ] : bit.do/lazyy

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #LazyLoading
@ProgrammingTip
Ngrok πŸ”₯

Ngrok allows you to expose a web server running on your local machine to the internet. 🌐

Just tell ngrok what port your web server is listening on :πŸ‘‚πŸ»

ngrok http [port] -host-header="localhost:[port]"


Result βœ… :

Tunnel Status : online
Version : 2.0/2.0
Web Interface : 127.0.0.1:4040
Forwarding : http://92832de0.ngrok.io
Forwarding : https://92832de0.ngrok.io


You can now access your website from ✨ :
http://92832de0.ngrok.io

When you start ngrok, it will display a UI in your terminal with the public URL of your tunnel and other status and metrics information about connections made over your tunnel πŸ› .


Inspecting Your Traffic πŸ“Š

Ngrok provides a real-time web UI where you can introspect all of the HTTP traffic running over your tunnels. πŸ‘€

After you've started ngrok, just open http://localhost:4040 in a web browser to inspect request details. πŸŒ€


https://t.me/pgimg/122

[ Docs ] : ngrok.com/docs

γ€°γ€°γ€°γ€°γ€°γ€°
#Ngrok #Testing
@ProgrammingTip
A shorter and URL friendly GUID ✨

This a small helper class in C#. πŸ‘Ύ

The class encodes a GUID into a 22 character long string and decodes the string back to the original GUID again. βœ…

It takes a standard GUID like this πŸ”¬ :
c9a646d3-9c61-4cb7-bfcd-ee2522c8f633


And converts it into this smaller string πŸ’Ž :
00amyWGct0y_ze4lIsj2Mw


It basically just converts a GUID into a base64 string and shortens it a bit. ⚑️


https://t.me/pgimg/123

[ Article ] : bit.do/guids

γ€°γ€°γ€°γ€°γ€°γ€°
#CSharp #GUID
@ProgrammingTip
Programming Tips πŸ’‘
Photo
ASP.NET Core.2 & Angular 5.pdf
7.3 MB
ASP.NET Core 2 & Angular 5 - Full Stack Web Development with .NET Core & Angular πŸ“•

Author : Valerio De Sanctis πŸ–Š

Publisher : Packt πŸ’Ž

γ€°γ€°γ€°γ€°γ€°γ€°
#Book #AspMvc #Core #Angular
@ProgrammingTip
API Feature Folders ⚑️

In ASP.NET Core (and unlike ASP.NET 5 / Web API 2), Web API controllers are just controllers. πŸ—‚

You don’t need to inherit from a different base type or anything like that. ❌

What’s more, your API controllers should be returning DTOs that are separate from your underlying domain or data model. ↔️

What I’ve found to be a better organization is to do away with the Controllers folder (or keep it around if you’re using view-based controllers) and instead use feature folders for your APIs. πŸ’Ž

I’m partial to having a root level API folder but if you’d prefer to put your features in the root of the project that would work, too. πŸ‘πŸ»

Within each feature folder, you include the controller along with any model types it needs to work with, like this πŸ‘Ύ :

https://t.me/pgimg/124

Obviously one benefit of this approach is that it’s more cohesive. βœ…

Things that change together are located physically next to one another, and the friction involved in moving between different folders with too many files in them is greatly reduced. βœ‚οΈ

Another nice thing about this approach is that it just works. Unlike view-based controllers, you don’t need to change anything about how ASP.NET Core is configured to have this organization structure work for you. ✨


[ Article ] : bit.do/apif

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core #API
@ProgrammingTip
A Mini-Course on React Native Flexbox ✨

Flexbox solves design issues that are particularly challenging on mobile, and it does so strikingly well β€” without requiring hacky CSS or Javascript tricks. πŸ—‚

But there’s a learning curve.
The property names all sound incredibly similar and do nothing to indicate what sets them apart. ↔️

On top of that, each property has a set of values that are mostly similar, yet slightly different, from each other. And to compound the confusion, not all properties of the Flexbox standard are included in React Native. πŸŒ€

This can cause surprises when you try to follow regular CSS documentation, only to discover that React Native doesn’t implement a particular feature, such as reverse flex❗️

To help make it easier to internalize the rules of Flexbox, I’ve decided to write the guide that I would have liked to read β€” with the underlying concepts explained and simple examples along the way. πŸ‘Ύ

Doodle along with me and get comfortable solving design scenarios with Flexbox. πŸ’Ž


https://t.me/pgimg/125

[ Article ] : bit.do/rnat

γ€°γ€°γ€°γ€°γ€°γ€°
#ReactNative #Design
@ProgrammingTip
InversifyJS ⚑️

A powerful and lightweight inversion of control container for JavaScript & Node.js apps powered by TypeScript. πŸ’Ž


About πŸ‘€

InversifyJS is a lightweight (4KB) inversion of control (IoC) container for TypeScript and JavaScript apps. πŸ’‰

An IoC container uses a class constructor to identify and inject its dependencies. πŸ—‚

InversifyJS has a friendly API and encourages the usage of the best OOP and IoC practices. βœ…


Motivation πŸ’œ

JavaScript now supports object oriented (OO) programming with class based inheritance. These features are great but the truth is that they are also dangerous. ☠️

We need a good OO design (SOLID, Composite Reuse, etc.) to protect ourselves from these threats. The problem is that OO design is difficult and that is exactly why we created InversifyJS. ✨

InversifyJS is a tool that helps JavaScript developers write code with good OO design. πŸ’―


Philosophy πŸŒ€

InversifyJS has been developed with 4 main goals πŸ” :

β€’ Allow JavaScript developers to write code that adheres to the SOLID principles. ☝🏻

β€’ Facilitate and encourage the adherence to the best OOP and IoC practices. πŸ”₯

β€’ Add as little runtime overhead as possible. ⏰

β€’ Provide a state of the art development experience. 🌈


https://t.me/pgimg/126

[ Github ] : bit.do/inversify

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #DI #Inversify
@ProgrammingTip
Favor Privileges over Role Checks ⛔️

A very common practice in web applications, especially those written using the ASP.NET built-in Role provider, is to perform role checks throughout the code to determine whether a user should have access to a particular page or control or command. πŸ”

For instance, you might see something like this ♻️ :

if (User.IsInRole(Roles.Administrators))
{
SomeSpecialControl.Visible = true;
}


The problems with the maintainability of this approach become apparent after a short while.❗️

For one, any buttons or other controls on the SomeSpecialControl above that post back to the page should also do a role check to ensure the user submitting the postback is in an acceptable role, otherwise a security hole may be present and users outside of these roles may be able to perform privileged actions. ☠️

πŸ”ΈπŸ”ΉπŸ”ΈπŸ”Ή

Introducing Privileges βœ…

Wouldn't it be better to act like this❓

EditorPanel.Visibility = CurrentUser.CanEdit(CurrentArticle);


This is very clear and is at the appropriate level of abstraction. πŸ’Ž

CanEdit isn’t itself a privilege; we can look at it as a sort of helper method in this case that lets us write clear and concise code. ✨


https://t.me/pgimg/127

[ Full Article ] : bit.do/prauth

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Authorization
@ProgrammingTip
Real World - Conduit 🌏

"The mother of all demo apps." πŸ”₯


While most "todo" demos provide an excellent cursory glance at a framework's capabilities, they typically don't convey the knowledge & perspective required to actually build real applications with it. βœ…

Real World solves this by allowing you to choose any front-end like 🌈 :
β€’ React / Redux / Mobx
β€’ Angular
β€’ Vue
β€’ Elm
β€’ Aurelia
β€’ Clojure

And any back-end like πŸŒ€ :
β€’ ASP.NET Core
β€’ Node / Express
β€’ F#
β€’ Laravel
β€’ Django
β€’ Rails
β€’ Go + Gin
β€’ Rust
β€’ Scala & Play Framework
β€’ Hapi.js

And see how they power a real world, beautifully designed fullstack app called "Conduit". ✨


https://t.me/pgimg/128

[ Projects ] : bit.do/reworld

γ€°γ€°γ€°γ€°γ€°γ€°
#Template #RealWorld
@ProgrammingTip
Carbon✨

Create and share beautiful images of your source code. 🌈

You know all of those code screenshots you see on Twitter❓

Although the code's usually impressive, we saw room for improvement in the aesthetic department. βœ…

Carbon is the easiest way to create beautiful images of your source code. 🌌

So what are you waiting for❓
Go impress all of your followers with your newfound design prowess. 🎨

https://t.me/pgimg/129

[ Website ] : carbon.now.sh

γ€°γ€°γ€°γ€°γ€°γ€°
#Code #Scheme
@ProgrammingTip
Apress - Real-Time Web Application Development.pdf
21.3 MB
Real-Time Web Application Development : With ASP.NET Core, SignalR, Docker, and Azure πŸ“•

Author : Rami Vemula πŸ–Š

Publisher : Apress ✨

γ€°γ€°γ€°γ€°γ€°
#Book #AspMvc #Core #SignalR #Docker #Azure
@ProgrammingTip
Flexbox Froggy 🐸

Flexbox Froggy is a game for learning CSS flexbox. πŸ‘Ύ

Flexbox Froggy takes inspiration from the classic arcade game Frogger, and web literacy games like the brilliant CSS Diner and Erase All Kittens, where you learn about CSS selectors and HTML markup respectively. πŸ”₯


https://t.me/pgimg/130

[ Learn ] : flexboxfroggy.com

γ€°γ€°γ€°γ€°γ€°γ€°
#FlexBox #CSS
@ProgrammingTip
Using Redis Cache in .NET Core πŸ—‚

Redis is a high performance distributed cache. It’s great for storing data that you are going to need again and again in a short period of time when you don’t want to use processing power to β€œcreate” that data again. ♻️

Think number crunching or heavy SQL queries for data that doesn’t change often. 🚫


Roll Your Own πŸ‘€

First off. You can absolutely roll your own Redis Cache services abstracted by your own interfaces etc. βœ…

You may find it a little difficult to find libraries that target .NET Core, but this will change over time. ⏳

In saying that, there is a β€œ.NET Core” way of doing things that is a little different. It does tie you into the framework a little, but it abstracts away the caching completely and let’s Microsoft handle it and that’s what we are going to go over today. πŸ’Ž


https://t.me/pgimg/131

[ Article ] : bit.do/rcache

γ€°γ€°γ€°γ€°γ€°γ€°
#Redis #AspMvc #Core #Cache
@ProgrammingTip