My Curriculum Vitae in an App
This time I wanted to make an experiment in order to increase my skills in react-native, because is a new technology for me, and I think that only practice makes perfect.
I don't know if there is another similar project. I guess, but I don't really mind about it, because my target is to learn, not to make the best application in the world.
So, I thought that it could be fun take my CV, and turn it into an App, not just a pretty PDF.
I decided to make a little project, but using almost the same tools that I use to handle in my regular projects.
According to this target, I need first of all, what I want, and then I draw the next sketch:
I decided to put the basics: A little profile, some education, my favorite skills, and of course, my experience.
Then, I made a piece of conceptual application architecture (I'm not an architect, but I like pretending to be one) to have a clearer panorama about the final result, so, I got this:
So, at this point, I got enough information to make some mockups for every interface.
5 mockups, each one for every module that I defined at the beginning of this article.
Now I need to create some of the activities that I'm going to do.
This part is a little complex, so, I'm going to simplify the process. I'm gonna make a basic baseline (without dates) with some activities per interface, and I'm gonna put them on Trello, which is a pretty good tool for get a Kanban board.
I made an structure to define the project better. I know, is a small project, maybe doesn't require so much, but, I'd rather this way to avoid noise in my execution.
Through the above list, I am trying to define every stage of my project. Some of them are done, another are on the way, and the rest is waiting.
In less than 140 characters, is just a little document that explains that I'm making an application with client side, and server side.
I hope to publish it at least on Play store.
Now, is time to write the EDT (not an strict one, ofcourse), in order to make all the activities that Trello requires.
This is the final version for this project. I tried to be concise, but, at the same time, pragmatic (very) in order to get the final goal in a realistic way. Although, I tried to involve almost all the stages considered in a more complex project.
Now, I'm ready to put the activities on my board (I mean, Trello).
Meanwhile, I've been working on the code, and at the time of write this lines, I already got the layout of the Splash, and the Profile Interface, at least in their first version each one.
I've been working on the code, as said before, so, I got some material in their firsts versions, such as Splash, Profile, and Skill interfaces.
My Trello Board right looks like below:
If you want, you can see the original board on Trello using this link: https://trello.com/b/j1knHu14/cv
Right now, I got the next interfaces:
Splash, Profile, and some scratch for Skills
And yes, the lasts two ones are the same, but, with a little difference that I've been considering now. It was an advice from a designer friend: Remove the border!, so, probably I will do that :)
I've had some problems with the charts plugin. Initially, I tried to use react-native-charts-wrapper, and, in spite of it, it looks beautiful, I couldn't use it, because it requires a different version of Xcode that I can't get, and the reason (in less than 140 characters) is because I changed by myself the SSD of my laptop, and macOS High Sierra is not compatible, so, I need to go back to Sierra, and that's why I can't install Xcode 9.3, or highest. Yea, is a really sad love story, but, that's how life is, so, we need to keep going and working with what we have.
So, I tried another library, simpler than the previous one, but effective: Victory.
It works like a charm from the beginning, and I don't needed to make an special setup on Xcode, just react-native coding.
I'll try to apply a technic or artesanal methodology in the execution of every interface, not only because I like it, but, it was very useful for me in many projects with agile methodologies, and has allowed us to make faster prototypes.
I don't even remember where and when I learned it (I don't even know if it's ok to do that), but it consists in 3 stages:
Do it
Consists in making things work, that's all. No matter how, but, usually the client requieres to see results, without concern what's behind the scene.
Do it well
Normally, we got here after a milestone, or an owner review, I mean, when the storm has passed, and we have enough time (not always) to make things in a better way. Usually, is not necessary to make big changes, just correct details.
Optimize
Here is when we can take code, and turn it into a real master piece, a piece of art that deserves a place in a museum :) ...ok, maybe not, and it only can be the second part of the "Do it well" stage.
At this time I have been working in many details of the project, so, I can show you my status. I almost finish the front-end according to the baseline plan.
I already have all the interfaces, and there is only one thing left: The tab controller, but I'm going to do that tomorrow.
Right now, the project looks like below:
I'm thinking about changing a few details before publishing the app, but that doesn't mean that I'm going to publish it soon. Maybe some details in the Skills interface, and, as you can see, I removed the circle border, or, in other words, I turned white the black border.
Next step on the list is the Footer menu, and after two days trying different plugins that allow me a clean, fast, and customizable handle, not only with the installation, but the configuration and implementation, I got a good one with the FooterTab from native-base framework.
It was funny, because Native Base was my second framework and I've used it in a lot of experiments 2, or 4 months ago, but, suddenly, I forgot it, and I started to work with pure react components.
Using FooterTab is pretty easy, and is easier if we can combine it with the rest of the NativeBase basic structure to make a responsive design.
So, finally, I used FooterTab with Content components to put my stuff where it's supposed to be.
Next image is the preliminary view of the Tab menu in action with a charged interface.
And well, at this moment, I have already done the first part of this project, I mean, the Do it stage, like I show in the next video show:
Now, I'm going to make a better version (Do it well stage) of this application, using separate files for the whole CSS, improving the container for the tabs, maybe customizing the icons, and achieve some details in order to make a good user experience.
After struggling a little with my forgotten memories, I made the Splash screen in pure Xcode. I think this will be temporary for two reasons:
- I need to recover my old memories about the layout in pure Xcode. I was really good on this the last year, but, without practice, nowadays I'm an amateur again.
- I would like to figure out the way to use my react-native version of the Splash screen. Right now I think is not possible, but maybe I don't know some tool/framework/toy to make it.
- Between the Splash screen, and the Profile screen, there is a time gap that has to be removed.
- To be honest, is not as pretty as I want, and definitely, I need to change it soon.
Meanwhile, at this moment, the app looks like below when I open it.
Well, after spending a time searching any solution to the Splash screen, I realized that effectively, there's no chance to integrate pure Xcode Splash with any react-native interface.
So, I started to create a way to tidy up my idea: I'm going to emulate an integration in a "simple" form.
To do that, I need make some changes. Now, the avatar is alone in the middle of the screen. That's the Xcode Splash screen.
Then, my name and title appear with a fade-in effect. At this part, we are now in the react-native Splash. I mean, I put them together creating the illusion that there is only one screen, but, when the Xcode Splash go out, we get the react-native Splash exactly in the same position.
After that last point, is a matter of the Animated component to do the rest.
As the video shows, is not totally finished at the end, but, I think that the main idea is 90% completed.
Sometimes, this story could sound weird, because I haven't been writing the text like one and unique piece. Is the work of many days. Every day I've been trying to put some of my time on this. Ok, no more cheesy moments.
After the last version of the first idea to the Splash, I get a new version. It could be the final, maybe.
Now, the Splash match with the profile in the same position, and I added some bars...don't know why exactly, but I like it :).
After that, I decided to break away every button in the footer in order to add some intro animation for every one. The result is below:
At the moment of writing down this lines, I made a centralized header, because until 10 minutes ago, every interface got his own header. Now, there is only an unique header, and every interface is loaded like always, but they don't have a header anymore.
Above is the structure hierarchy extracted from the View debugging option on Xcode.
And, after a suggestion from a friend of mine, I decided to follow up her instruction about the header design.
So, this is the preview of the new header. I uploaded the code, but is not responsive yet, but soon :)
while writing these lines, and after making the header component, it becomes responsive.
It was easy because I made it in an isolate way, and works like a charm.
Visually is still the same, so, there is not a new Image.
Now is time to change the charts, because I didn't like it after receiving a few feedback from people who work on design.
So, I thought about using some library, because there are a lot of nice libraries, and the one that I like the most (at least in Bars style) was the used in NBA App.
But, I wanted something different, and I wanted to learn a little more, so, I scratched something with basic react-native components, and I found out that it's not only easy, but fun to make graphs, and of course, I know that the more spectacular is the graphic, the more complex is the process to make it.
After an hour of playing with this, I got the first version of the component:
Now is time to animate them. For that, I'm using the same Animated component for a very easy implementation, and the result is below:
And the Skills interface was reduced (well, before this change it was as long as now, but now is better) too :
<Bars name='ActionScript' startAt={0} percentaje={90} primaryColor='#db4e4e' />
<Bars name='Ionic' startAt={90} percentaje={70} primaryColor='#2f9cfc' />
<Bars name='PHP' startAt={180} percentaje={75} primaryColor='#627dbc' />
<Bars name='Laravel' startAt={270} percentaje={50} primaryColor='#f0514b' />
<Bars name='React Native' startAt={360} percentaje={30} primaryColor='#1ca6cd' />
Well, a last detail about my new Bar component. I wanted to add an animation for the number as well, but, this time, I rather use a existing component: AnimateNumber.
At the beginning I had my doubts, because is not as recent as I wished, but is still working, and it gave to my Bar component a nice extra detail animating the number, so, at least by now, I'll keep it.
The implementation was not traumatic, it just took a simple line in the same place where I had the value:
<Text style={{position: 'absolute', color: '#000', fontFamily: 'CenturyGothic-Bold'}}>
<AnimateNumber value={this.props.percentaje} countBy={1} timing="linear" />%
</Text>