lisk-sdk
lisk-sdk copied to clipboard
Replace Interfaces with `type` , `type alias` & `intersection`
Description
Currently we have interface
s with similar elements. We can replace them using type
, type alias
& intersection
feature.
Motivation
Elements are duplicated. We can simply use type alias
for an existing type & merge similar types using intersection
Additional Information
- https://www.typescriptlang.org/docs/handbook/2/everyday-types.html#type-aliases
- https://www.typescriptlang.org/docs/handbook/2/everyday-types.html#differences-between-type-aliases-and-interfaces
data:image/s3,"s3://crabby-images/973fa/973faec51db10e56e86d4837af4c116350c40504" alt="Screenshot 2022-08-09 at 03 17 20 PM"
Do you mean replace all interfaces with types or only in applicable scenarios?
For the above issue, you can solve it by extending the Keys
interface e.g.
data:image/s3,"s3://crabby-images/6a564/6a56451140c5a8d3586251f519cd3304daa14fac" alt="image"
By extending an interface, we can reduce the duplication. In my humble opinion, this is not an interface issue but more of a design issue as you can still have duplication with type/type aliases as well.
-
Only in current file
-
Yes, code duplication could be avoided using
extend
ing interface also. Not sure, if AuthAccount reallyextend
sKeys
from OOP perspective. Since they are not directly parent/child, hencetype
seems a better alternative. -
Using type alias (there is no duplication)
type RegisterMultisignatureParams = Keys
Also here framework/src/modules/reward/types.ts
Closing this issue for no activity