-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
conf-schedule-short.tsx
305 lines (301 loc) · 15.5 KB
/
conf-schedule-short.tsx
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
interface ScheduleItem {
description: string;
speakers: Array<string>;
time: string;
title: string;
type: 'event' | 'break';
videoUrl?: string;
}
export function ConfScheduleShort(): JSX.Element {
const scheduleItemsForSunday16: ScheduleItem[] = [
{
type: 'event',
time: '9:00am - 5:00pm (UTC-07:00)',
title: 'Nx Workshop - Day 1',
description:
'Note, environment setup starts at 8am. This is the introductory part of the workshop which will give you all you need to get set up and running with your brand new Nx workspace. More details in the workshop section further down.',
speakers: ['Zack DeRose', 'Miroslav Jonas'],
videoUrl: '',
},
{
type: 'event',
time: '7:00pm (UTC-07:00)',
title: 'Speaker + VIP dinner (all attendees invited)',
description:
'All speakers as well as attendees are invited. Enjoy some food and good conversations!',
speakers: ['Speakers', 'Attendees'],
videoUrl: '',
},
];
const scheduleItemsForTuesday18: ScheduleItem[] = [
{
type: 'event',
time: '9:00am - 5:00pm (UTC-07:00)',
title: 'Nx Workshop - Day 2',
description:
'Note, environment setup starts at 8am. Join day 2 to take a deep dive into advanced Nx concepts that help you leverage Nx to its fullest. More details in the workshop section further down.',
speakers: ['Zack DeRose', 'Miroslav Jonas'],
videoUrl: '',
},
];
const scheduleItemsForMonday17: ScheduleItem[] = [
{
type: 'event',
time: '9:45 - 9:55am (UTC-07:00)',
title: 'Opening remarks',
description: '',
speakers: ['Jeff Cross'],
videoUrl: '',
},
{
type: 'event',
time: '10:00 - 10:25am (UTC-07:00)',
title: 'Keynote - Nx and Lerna: Integrated vs Package-Based Monorepos',
description:
'The JS community has two main styles of monorepos: the “package-based” approach (popularized by Lerna) and the “integrated” style (popularized by Nx, used by Google, Facebook etc.). While one is lightweight and easy to adopt, the other gives much more flexibility, scales better, and provides better dev ergonomics but requires a mind shift.\n' +
'In this talk, we’ll have a deeper look at how Lerna and Nx implement these approaches, the trade-offs, and the advantages; we will help you pick the right one and show how to migrate from one to the other.\n',
speakers: ['Victor Savkin'],
videoUrl: '',
},
{
type: 'event',
time: '10:30 - 10:55am (UTC-07:00)',
title: 'Re-thinking CI bottlenecks with Distributed Execution',
description:
'Nx’s powerful caching algorithms and dependency graph knowledge allow you to build simple CI pipelines that scale as your workspace grows. But caching and affected work best in the average case: when only some projects are changed in a PR, you can skip anything that can’t be affected by that change, and from the remaining ones the caching algorithms will help you replay all the work that has been done before. But after a certain point you have to start splitting the work across multiple agents if you want your workspace to scale. In this talk we’ll explore why your CI can slow down in big workspaces, and how you can unlock horizontal scaling by distributing your tasks across multiple machines. We’ll look at some of the issues with task distribution and how you can use NxCloud workflows to implement scalable CI configs that optimally splits the work across your matrix of agents.',
speakers: ['Rareş Matei', 'Altan Stalker'],
videoUrl: '',
},
{
type: 'event',
time: '11:00 - 11:25am (UTC-07:00)',
title: 'Lerna Reborn',
description:
"Lerna blazed the original trail in the open-source JavaScript monorepo space, and the whole ecosystem has benefitted immensely from that experience. It remains extremely popular for versioning/publishing and full monorepo workspace management, and now that the Nrwl Team has taken over stewardship of the project, we want to share some of the great updates we've made over the last few months as well as what we have planned for the near future.",
speakers: ['James Henry'],
videoUrl: '',
},
{
type: 'break',
time: '11:30 - 11:40am (UTC-07:00)',
title: 'Break',
description: '',
speakers: [],
videoUrl: '',
},
{
type: 'event',
time: '11:45 - 12:10pm (UTC-07:00)',
title: 'Nx + Cypress Like Peanut Butter & Jelly',
description:
"Name a more iconic duo than Nx & Cypress... I'll wait. In this talk I will highlight some of ways in which Nx integrates seamlessly with Cypress and how it can speed up both your development and overall developer experience. We will also take a look at Cypress Component Testing and how you can leverage Nx in your testing. By the end you will see why Nx and Cypress are the peanut butter and jelly of your developer toolbox.",
speakers: ['Jordan Powell'],
videoUrl: '',
},
{
type: 'event',
time: '12:15 - 12:25pm (UTC-07:00)',
title: 'CI/CD tricks with Nx',
description:
'⚡️ Lightning talk - Nx is great at telling us what changed and what needs to be rebuilt and/or deployed. How do we use this information to dynamically trigger CICD pipelines or workflows? In this talk we’ll review some tricks to generate dynamic configuration for both Azure DevOps and CircleCI that help to solve this problem. ',
speakers: ['Kennie Davis'],
videoUrl: '',
},
{
type: 'event',
time: '12:25 - 12:35pm (UTC-07:00)',
title: 'Exploring Library Boundaries for State Management Libraries',
description:
'⚡️ Lightning talk - State management libraries like Redux, Vuex, and NgRx give developers tools to introduce indirection between state management, side effects, and the view layer. Quickly learn about the ramifications indirection introduces for Nx libraries and explore ideas about creating module boundaries around your state management code.',
speakers: ['Mike Ryan'],
videoUrl: '',
},
{
type: 'event',
time: '12:35 - 12:45pm (UTC-07:00)',
title: 'Nx Workspace Guardrails',
description:
'⚡️ Lightning talk - Concept: in a Nx monorepo with lots of contributors, how do you help ensure engineers follow the desired patterns for development? You may have a roadmap for where you want to go, but how do you make sure folks don’t slide off the cliff along the way? You need some guardrails to help keep people on track. Thankfully, Nx has got you covered. We’ll show how built-in tools like workspace lint, ESLint, and workspace ESLint rules can help put checks in place to ensure the overall health of your workspace.',
speakers: ['Ryan Diehl'],
videoUrl: '',
},
{
type: 'break',
time: '12:45 - 2:00pm (UTC-07:00)',
title: 'Lunch',
description: '',
speakers: [],
videoUrl: '',
},
{
type: 'event',
time: '2:00 - 2:25pm (UTC-07:00)',
title: 'Extending Nx: Polyglot Superpowers',
description:
"Extensibility is in Nx's DNA, and having a tool that you can extend and customize to your monorepo setup is crucial. Sharing different languages in a monorepo is extremely common yet toolchains usually don't play well together. Fortunately, Nx allows you to extend its capabilities to integrate your whole stack. Use Nx's graph on your Go or Python code and see what is affected, or generate Go code via Nx. Make Nx polyglot to take advantage of affected tests and remote caching for all your tech stack.",
speakers: ['Jack Hsu', 'Benjamin Cabanes'],
videoUrl: '',
},
{
type: 'event',
time: '2:30 - 2:55pm (UTC-07:00)',
title: 'Nx, Ionic, Appflow: Navigating the Wild West of Hybrid Apps',
description:
'These days there are a lot of ways to build mobile apps. But what if you want to share your types across the frontend and backend, or share components and logic across your mobile and web app, and maybe an admin panel? At this point, your options get pretty limited, and things only get more complicated once you start thinking about how to automate building and deploying your native apps to the app store. In this talk, we’ll explore how to develop Ionic applications in an Nx workspace and how to configure Appflow for automated app store deployments.',
speakers: ['Devin Shoemaker'],
videoUrl: '',
},
{
type: 'event',
time: '3:00 - 3:25pm (UTC-07:00)',
title: 'Nx at Celonis',
description:
'Celonis adopted AngularJS in 2011, 5 years later in 2016 we had fewer applications to manage, and individual teams were responsible for each application, soon we found there are many issues with each team owning the code, we are duplicating some code, some teams dont have frontend developers and are sometimes dependent on each other is delaying the development workflow. Celonis decided to introduce the project "One Frontend" and we chose Nx and use Module Federation, join us to learn about the journey of Celonis migrating to Nx, why we chose Nx, and how CLI made our life easier, and what Nx\'s future is at Celonis.',
speakers: ['Santosh Yadav'],
videoUrl: '',
},
{
type: 'event',
time: '3:30 - 3:55pm (UTC-07:00)',
title: 'Make Nx Work for You with Custom Generators',
description:
'There is a lot the Nx can do for your application right out of the box, but did you know you can write custom workspace generators specific to YOUR application to help automate the various tasks your team performs on a daily basis? Why write yet another confluence page documenting all of the little things that have to be done after generating a library when you can write a workspace generator that handles all of the little details for you? In this talk we will cover everything you need to know to create your own workspace generator to help reduce manual tasks, enforce architectural patterns, and generate more consistent predictable code.',
speakers: ['Lara Newsom'],
videoUrl: '',
},
{
type: 'break',
time: '4:00 - 4:15pm (UTC-07:00)',
title: 'Break',
description: '',
speakers: [],
videoUrl: '',
},
{
type: 'event',
time: '4:15 - 4:40pm (UTC-07:00)',
title: 'The power of Nx Console',
description:
'Are you tired of searching the docs for the exact name of that Nx command flag? Or do you want to explore what’s possible but don’t know where to start? Nx isn’t just fast! We deeply care about the developer experience too! Every command, with all its options, running tasks, and the Nx graph. Just fingertips away so you can keep focused and remain in the flow. In this talk, we’re going deep into how to augment your Nx experience in VSCode! Not a VSCode user? Then be all ears: we might have a surprise.',
speakers: ['Jonathan Cammisuli'],
videoUrl: '',
},
{
type: 'event',
time: '4:45 - 5:00pm (UTC-07:00)',
title: 'Closing Remarks',
description: '',
speakers: ['Jeff Cross'],
videoUrl: '',
},
{
type: 'break',
time: '8:00pm - 12:00am (UTC-07:00)',
title: 'After Party',
description: '',
speakers: [],
videoUrl: '',
},
];
return (
<div className="border-t border-slate-200 dark:border-slate-700">
<div className="mx-auto max-w-screen-lg xl:max-w-screen-xl">
<div className="date-container-l font-input-mono mt-16 grid grid-cols-1 divide-x divide-slate-200 dark:divide-slate-700">
<div className="p-8 text-center">
<span className="rounded-md bg-slate-100 p-2 dark:bg-slate-800">
Sunday, October 16th
</span>
</div>
</div>
</div>
<section className="w-full divide-y divide-slate-200 border-t border-b dark:border-slate-700">
{scheduleItemsForSunday16.map((item) =>
item.type === 'event' ? scheduleRow(item) : breakRow(item)
)}
</section>
<div className="mx-auto max-w-screen-lg xl:max-w-screen-xl">
<div className="date-container-l font-input-mono mt-16 grid grid-cols-1 divide-x divide-slate-200 dark:divide-slate-700">
<div className="p-8 text-center">
<span className="rounded-md bg-slate-100 p-2 dark:bg-slate-800">
Monday, October 17th
</span>
</div>
</div>
</div>
<section className="w-full divide-y divide-slate-200 border-t border-b border-slate-200 dark:divide-slate-700 dark:border-slate-700">
{scheduleItemsForMonday17.map((item) =>
item.type === 'event' ? scheduleRow(item) : breakRow(item)
)}
</section>
<div className="mx-auto max-w-screen-lg xl:max-w-screen-xl">
<div className="date-container-l font-input-mono mt-16 grid grid-cols-1 divide-x divide-slate-200 dark:divide-slate-700">
<div className="p-8 text-center">
<span className="rounded-md bg-slate-100 p-2 dark:bg-slate-800">
Tuesday, October 18th
</span>
</div>
</div>
</div>
<section className="w-full divide-y divide-slate-200 border-t border-b dark:border-slate-700">
{scheduleItemsForTuesday18.map((item) =>
item.type === 'event' ? scheduleRow(item) : breakRow(item)
)}
</section>
</div>
);
}
const scheduleRow = (item: ScheduleItem): JSX.Element => (
<div key={item.title + item.time} className="w-full">
<div className="mx-auto max-w-screen-lg xl:max-w-screen-xl">
<article className="grid w-full grid-cols-1 md:grid-cols-5 md:divide-x md:divide-slate-200 md:dark:divide-slate-700">
<div className="font-input-mono px-5 pt-12 pb-8 md:py-12">
<span className="hidden md:block">{item.time}</span>
<span className="mb-4 rounded-md py-4 px-6 md:hidden">
{item.time}
</span>
</div>
<div className="font-input-mono col-span-2 px-5 md:py-12 md:px-8">
{item.videoUrl ? (
<h3 className="mb-4 underline">
<a href={item.videoUrl} target="_blank" rel="noreferrer">
{item.title}
</a>
</h3>
) : (
<h3 className="mb-4">{item.title}</h3>
)}
<div className="text-sm">{item.speakers.join(' & ')}</div>
</div>
<p className="col-span-2 px-5 pt-8 pb-12 md:py-12 md:px-8">
{item.description}
</p>
</article>
</div>
</div>
);
const breakRow = (item: ScheduleItem): JSX.Element => (
<div key={item.title + item.time} className="w-full">
<div className="mx-auto max-w-screen-lg xl:max-w-screen-xl">
<div className="grid w-full grid-cols-1 md:grid-cols-5">
<div className="font-input-mono px-5 pt-12 pb-8 md:py-12">
<span className="hidden md:block">{item.time}</span>
<span className="mb-4 rounded-md py-4 px-6 md:hidden">
{item.time}
</span>
</div>
<div className="px-5 pb-12 md:col-span-4 md:border-l md:border-slate-200 md:py-12 md:px-8 md:dark:border-slate-700">
{item.videoUrl ? (
<h3 className="font-input-mono underline">
<a href={item.videoUrl} target="_blank" rel="noreferrer">
{item.title}
</a>
</h3>
) : (
<h3 className="font-input-mono">{item.title}</h3>
)}
<div className="description">{item.description}</div>
</div>
</div>
</div>
</div>
);