-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript-v1.js
329 lines (307 loc) · 11.6 KB
/
script-v1.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
'use strict';
// Data
const title = { name: 'Joshua Llaneza', url: '' };
const navigation = [
{ name: 'About', url: './index.html' },
{ name: 'Landscape Architecture', url: './landscapearchitecture.html' },
{ name: 'Photography', url: './photography.html' },
{ name: 'Web Development', url: './webdevelopment.html' },
{ name: 'Email', url: 'mailto:[email protected]' },
];
const footer = 'Website and projects - copyright © Joshua Llaneza 2024';
const projects2 = [
'./content/img/screenshot_ml.jpg',
'./content/img/screenshot_magis1.jpg',
'./content/img/screenshot_magis2.jpg',
'./content/img/screenshot_magis3.jpg',
'./content/img/screenshot_themet.jpg',
'./content/img/screenshot_slide.jpg',
];
const projects = [
{
name: 'The MET Gallery',
year: '2023',
image: './content/img/screenshot_themet.png',
paragraphs: [
"As an art enthusiast, I wanted my first vanilla JavaScript project to showcase the MET Museum's European paintings collection by using their API to display some of their art on the web. This app fetches a list of artwork and then fetches to get the details and image. Users can enlarge the images to view more details and have the option to hide the information. The app displays high quality images if the user is on desktop but will fetch smaller images on mobile for faster load times.",
],
githubLink: 'https://github.com/JoshuaIsADev/The-MET-v3',
liveLink: 'https://the-met-gallery.netlify.app/',
liveUserNameGuest: '',
livePasswordGuest: '',
liveUserNameAdmin: '',
livePasswordAdmin: '',
technical: [
'Vanila Javascript',
'CSS',
'HTML',
'Responsive',
'The MET API(RESTful)',
'Figma',
],
client: 'n/a',
featuresUser: [
'View artwork from The MET API',
'Enlarge/minimize artwork',
'Hide/show information',
'Show next artwork',
'Small image in mobile',
],
featuresAdmin: [],
},
{
name: 'Slide',
year: '2023',
image: './content/img/screenshot_slide01.jpg',
paragraphs: [
'One of my friends asked me about the basics of financial budgeting. Instead of simply explaining it, I decided to build a user-friendly JavaScript app! This mobile-first app allows users to input their salary and receive recommendations on how much to spend on various categories such as housing, food, and transportation. Users can also adjust the values using sliders, and add or delete fields according to their preferences.',
],
githubLink: 'https://github.com/JoshuaIsADev/Slide',
liveLink: 'http://slide-budget.netlify.app',
liveUserNameGuest: '',
livePasswordGuest: '',
liveUserNameAdmin: '',
livePasswordAdmin: '',
technical: ['Vanila Javascript', 'CSS', 'HTML', 'Mobile-first', 'Figma'],
client: 'n/a',
featuresUser: [
'Input number',
'Adjust budget with sliders',
'Add category',
'Delete category',
],
featuresAdmin: [],
},
{
name: 'Maika Llaneza',
year: '2024',
image: './content/img/screenshot_ml.png',
paragraphs: [
'This was my first React project, which I built for a published author. Since she occasionally updates her bio and literary works, I decided to build a custom content manager in addition to her landing page. The challenge was to enable her to sign in, create, update, and delete her bio, photo, and literary works.',
'She also requested that her site be accessible, so I tested it extensively for accessibility. It achieved a perfect score of 100 from Google Lighthouse and was manually tested with Microsoft Narrator. The website has increased her online presence by allowing her to share it with her fans, prospective editors, and publishers.',
],
githubLink: 'https://github.com/JoshuaIsADev/Maika-Llaneza-v2',
liveLink: 'http://maikallaneza.com',
liveUserNameGuest: '',
livePasswordGuest: '',
liveUserNameAdmin: 'CMS demo available during interview',
livePasswordAdmin: '',
technical: [
'React',
'Javascript',
'CSS',
'Responsive',
'Vite',
'Styled components',
'React query',
'React hook forms',
'React router',
'Supabase(RESTful)',
'High accessibility score',
'Figma',
],
client: 'Maika Llaneza',
featuresUser: ['Read data from Supabase'],
featuresAdmin: [
'Add bio and projects',
'Edit bio projects, and photo',
'Delete projects',
'Sign in/out',
],
},
{
name: 'Magis',
year: '2024',
image: './content/img/screenshot_magis.png',
paragraphs: [
'As a design enthusiast, I was inspired to create a digital experience that reflects the artistic aesthetics of this company. After reviewing their current website, which caters to industry professionals, I decided to design a mock consumer website. This new site features e-commerce functionalities such as selecting colors, adding, editing, and deleting items in a shopping cart, as well as signing in and out to check previous orders.',
'To further challenge myself, I developed a content management application. This allows the business to sign in and out, and provides capabilities to add, edit, and delete products, images, and product variants.',
],
githubLink: 'https://github.com/JoshuaIsADev/magis',
liveLink: 'https://magis-portfolio-project.netlify.app/',
liveUserNameGuest: '[email protected]',
livePasswordGuest: 'GuestUser!1234',
liveUserNameAdmin: 'CMS demo available during interview',
livePasswordAdmin: '',
technical: [
'React',
'Javascript',
'CSS',
'Responsive',
'Vite',
'Styled components',
'React query',
'React hook forms',
'React router',
'Context Api',
'Supabase(RESTful)',
'Figma',
],
client:
'Disclaimer: The company is real, but this is a mock project for portfolio only. It is also NOT a clone.',
featuresUser: [
'Filter/sort products',
'Select variants',
'Add, edit, remove items in the cart',
'Place order',
'View previous orders',
'Sign in/out, and sign up',
],
featuresAdmin: [
'Filter/sort products',
'Add, edit, and remove products',
'Edit variant inventory',
'Add multiple gallery photos',
'Add variant photos',
'Sign in/out',
],
},
];
let find = document.querySelector('.projects-container');
const containerHeader = document.querySelector('.header-container');
const containerHeaderNav = document.querySelector('.header-nav');
const containerFooter = document.querySelector('.footer-container');
const containerProjects2 = document.querySelector('.projects-container');
const displayHeader = function (title) {
const html = `
<div class="text-row">
<h1 class="font-l">${title.name}</h1>
</div>
`;
containerHeader.insertAdjacentHTML('afterbegin', html);
};
const displayHeaderNav = function (navigation) {
navigation.forEach((nav, i) => {
const html = `
<li class="text-row">
<a href="${nav.url}" class="font-l">${nav.name}</a>
</li>
`;
containerHeaderNav.insertAdjacentHTML('beforebegin', html);
});
};
const displayFooter = function (footer) {
const html = `
<div class="text-row">
<p class="font-l">
${footer}
</p>
</div>
`;
containerFooter.insertAdjacentHTML('afterbegin', html);
};
const displayProjects2 = function (projects) {
projects.forEach((proj, i) => {
const html = `
<img alt="project screenshot ${i}" src=${proj} class="project-img"/>
`;
containerProjects2.insertAdjacentHTML('beforeend', html);
});
};
displayHeader(title);
displayHeaderNav(navigation);
displayFooter(footer);
displayProjects2(projects2);
// const containerProjects = document.querySelector('.projects-container');
// const displayProjects = function (projects) {
// projects.forEach((proj, i) => {
// // console.log(proj);
// const html = `
// <article class="project-wrapper">
// <div class="heading-container">
// <h2 class="font-l">${proj.name}</h2>
// </div>
// <div class="heading-container">
// <p class="font-xs">${proj.year}</p>
// </div>
// <img alt="${proj.name} project screenshot" src=${
// proj.image
// } class="project-img"/>
// <div class="about-container">
// <h3 class="font-s">About project</h3>
// <div class="about-wrapper">
// ${proj.paragraphs
// .map((paragraph) => `<p>${paragraph}</p>`)
// .join('')}
// </div>
// </div>
// <div class="details-container">
// <div class="links-container">
// <h3 class="font-s">Links</h3>
// <ul class="vertical-ul">
// <a href=${proj.githubLink} target="_blank">Github</a>
// </ul>
// <ul class="vertical-ul">
// <a href=${proj.liveLink} target="_blank">View live</a>
// </ul>
// ${
// proj.liveUserNameAdmin.length > 0
// ? `<ul class='vertical-ul'>
// <li><h4 class="font-xs">Admin login</h4></li>
// <li>Username: ${proj.liveUserNameAdmin}</li>
// ${
// proj.livePasswordAdmin.length > 0
// ? `<li>Password: ${proj.liveUserPasswordAdmin}`
// : ''
// }</li>
// </ul>`
// : ''
// }
// ${
// proj.liveUserNameGuest.length > 0
// ? `<ul class='vertical-ul'>
// <li><h4 class="font-xs">Consumer login</h4></li>
// <li>Username: ${proj.liveUserNameGuest}</li>
// <li>Password: ${proj.livePasswordGuest}</li>
// </ul>`
// : ''
// }
// </div>
// <div class="technical-container">
// <h3 class="font-s">Made with</h3>
// <ul class="technical-ul">
// ${proj.technical
// .map((technical) => `<li>${technical}</li>`)
// .join('')}
// </ul>
// </div>
// </div>
// <aside class="project-aside" aria-label="project client and features list">
// <div class="client-container">
// <h3 class="font-s">Client</h3>
// <ul class="technical">
// <li>
// ${proj.client}
// </li>
// </ul>
// </div>
// <div class="features-container">
// <h3 class="font-s">Features</h3>
// ${
// proj.featuresAdmin.length > 0
// ? `<h4 class="font-xs">Admin features</h4>
// <ul class="vertical-ul">
// ${proj.featuresAdmin
// .map((adminFeatures) => `<li>${adminFeatures}</li>`)
// .join('')}
// </ul>`
// : ''
// }
// ${
// proj.featuresUser.length > 0
// ? `<h4 class="font-xs">User features</h4>
// <ul class="vertical-ul">
// ${proj.featuresUser
// .map((userFeatures) => `<li>${userFeatures}</li>`)
// .join('')}
// </ul>`
// : ''
// }
// </div>
// </aside>
// </article>
// `;
// containerProjects.insertAdjacentHTML('afterbegin', html);
// });
// };
// displayProjects(projects);