-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #19 from suresh-gangumalla/feat/router-before-hook…
…-sample Router before hook sample
- Loading branch information
Showing
4 changed files
with
288 additions
and
1 deletion.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,278 @@ | ||
import Blits from '@lightningjs/blits' | ||
|
||
const hookPageTemplate = { | ||
template: ` | ||
<Element | ||
w="1920" | ||
h="1080" | ||
color="#fff" | ||
:effects="[$shader('radialGradient', {colors: ['#b43fcb', '#6150cb'], pivot: [0.5, 1.1], width: 2400, height: 800})]" | ||
> | ||
<Element :show="$up !== undefined"> | ||
<Element src="assets/arrow.png" w="100" h="44" x="960" y="40" mount="{x: 0.5}"/> | ||
<Text :content="$up && $up.toUpperCase()" x="960" y="100" size="76" mount="{x: 0.5}"/> | ||
</Element> | ||
<Element :show="$right !== undefined"> | ||
<Element src="assets/arrow.png" w="100" h="44" x="1900" y="540" mount="{x: 1, y: 0.5}" rotation="90"/> | ||
<Text :content="$right && $right.toUpperCase()" x="1760" y="540" size="76" rotation="90" mount="0.5"/> | ||
</Element> | ||
<Element :show="$down !== undefined"> | ||
<Element src="assets/arrow.png" w="100" h="44" x="960" y="1040" mount="{x: 0.5, y: 1}" rotation="180"/> | ||
<Text :content="$down && $down.toUpperCase()" x="960" y="980" size="76" mount="{x: 0.5, y: 1}"/> | ||
</Element> | ||
<Element :show="$left !== undefined"> | ||
<Element src="assets/arrow.png" w="100" h="44" x="40" y="540" mount="{ y: 0.5}" rotation="-90"/> | ||
<Text :content="$left && $left.toUpperCase()" x="180" y="540" size="76" mount="0.5" rotation="-90"/> | ||
</Element> | ||
<Text :content="$pageTitle" font="raleway" x="960" y="540" size="240" mount="0.5"/> | ||
</Element> | ||
`, | ||
props: [ | ||
{ | ||
key: 'page', | ||
cast: Object, | ||
}, | ||
], | ||
computed: { | ||
pageTitle() { | ||
//compute page title from page data, if there's no page data use default title | ||
return (this.page && this.page.title) || this.title | ||
}, | ||
}, | ||
state() { | ||
//default state template to indicate which directions will be available if they are defined when "extending" | ||
return { | ||
title: 'Start', | ||
up: 'up', | ||
right: 'right', | ||
down: 'down', | ||
left: 'left', | ||
} | ||
}, | ||
} | ||
|
||
//landing page of the router hook example, contains 2 flow examples | ||
export const RouterHookPage = Blits.Component('RouterHookPage', { | ||
...hookPageTemplate, | ||
state() { | ||
return { | ||
title: 'Start', | ||
down: 'episode flow', | ||
right: 'movie flow', | ||
} | ||
}, | ||
input: { | ||
right() { | ||
//trigger router to navigate to movie flow | ||
this.$router.to('/examples/router-hooks/movie') | ||
}, | ||
down() { | ||
//trigger router to navigate to episode flow | ||
this.$router.to('/examples/router-hooks/episode/1') | ||
}, | ||
}, | ||
}) | ||
|
||
//movie flow page, with 2 directions left: back, right: rating | ||
const Movie = Blits.Component('RouterHookMovie', { | ||
...hookPageTemplate, | ||
state() { | ||
return { | ||
title: 'Movie', | ||
left: 'Back', | ||
right: 'Rating', | ||
} | ||
}, | ||
input: { | ||
left() { | ||
//trigger router back navigation. Leads back to: /examples/router-hooks | ||
this.$router.back() | ||
}, | ||
right() { | ||
//trigger router to navigate to rating page | ||
this.$router.to('/examples/router-hooks/rating') | ||
}, | ||
}, | ||
}) | ||
|
||
//movie flow page, with 2 directions left: back, right: Router example page landing | ||
const Rating = Blits.Component('RouterHookRating', { | ||
...hookPageTemplate, | ||
state() { | ||
return { | ||
title: 'Rating', | ||
left: 'Back', | ||
right: 'TO START', | ||
} | ||
}, | ||
input: { | ||
left() { | ||
//trigger router back navigation. Leads back to: /examples/router-hooks/movie | ||
this.$router.back() | ||
}, | ||
right() { | ||
//trigger router to navigate to router hook example page landing | ||
this.$router.to('/examples/router-hooks/') | ||
}, | ||
}, | ||
}) | ||
|
||
//movie flow page, with 2 directions left: back, right: next episode | ||
const Episode = Blits.Component('RouterHookEpisode', { | ||
...hookPageTemplate, | ||
state() { | ||
return { | ||
title: 'Episode', | ||
left: 'Back', | ||
right: 'NEXT EPISODE', | ||
} | ||
}, | ||
input: { | ||
left() { | ||
//trigger router back navigation. Leads back to: /examples/router-hooks. Even when episode id > 1 | ||
this.$router.back() | ||
}, | ||
right() { | ||
//trigger router to navigate to the next episode, and NOT save current episode page in navigation history | ||
this.$router.to(`/examples/router-hooks/episode/${this.page.id + 1}`, undefined, { | ||
inHistory: false, | ||
}) | ||
}, | ||
}, | ||
}) | ||
|
||
//custom page transitions for when the router navigates to router example pages | ||
const PageTransitions = { | ||
slideInOutLeft: { | ||
before: { | ||
prop: 'x', | ||
value: '100%', | ||
}, | ||
in: { | ||
prop: 'x', | ||
value: 0, | ||
duration: 400, | ||
}, | ||
out: { | ||
prop: 'x', | ||
value: '-100%', | ||
duration: 400, | ||
}, | ||
}, | ||
slideInOutRight: { | ||
before: { | ||
prop: 'x', | ||
value: '-100%', | ||
}, | ||
in: { | ||
prop: 'x', | ||
value: 0, | ||
duration: 400, | ||
}, | ||
out: { | ||
prop: 'x', | ||
value: '100%', | ||
duration: 400, | ||
}, | ||
}, | ||
slideInOutUp: { | ||
before: { | ||
prop: 'y', | ||
value: '100%', | ||
}, | ||
in: { | ||
prop: 'y', | ||
value: 0, | ||
duration: 400, | ||
}, | ||
out: { | ||
prop: 'y', | ||
value: '-100%', | ||
duration: 400, | ||
}, | ||
}, | ||
slideInOutDown: { | ||
before: { | ||
prop: 'y', | ||
value: '-100%', | ||
}, | ||
in: { | ||
prop: 'y', | ||
value: 0, | ||
duration: 400, | ||
}, | ||
out: { | ||
prop: 'y', | ||
value: '100%', | ||
duration: 400, | ||
}, | ||
}, | ||
} | ||
|
||
export const RouterHookRoutes = [ | ||
{ | ||
path: '/examples/router-hooks', | ||
component: RouterHookPage, | ||
hooks: { | ||
async before(to, from) { | ||
//change transition based on 'from' route | ||
if (from && from.path === 'examples/router-hooks/movie') { | ||
to.transition = PageTransitions.slideInOutRight | ||
} | ||
if (from && from.path === 'examples/router-hooks/rating') { | ||
to.transition = PageTransitions.slideInOutLeft | ||
} | ||
if (from && from.path.indexOf('episode') > -1) { | ||
to.transition = PageTransitions.slideInOutDown | ||
} | ||
return to | ||
}, | ||
}, | ||
}, | ||
{ | ||
path: '/examples/router-hooks/episode/:id', | ||
component: Episode, | ||
hooks: { | ||
before(to, from) { | ||
//change transition based on 'from' route | ||
if (from && from.path.indexOf('episode') > -1) { | ||
to.transition = PageTransitions.slideInOutLeft | ||
} | ||
const { id } = to.params | ||
//if id > 5 lead route back to router example page landing | ||
if (id > 5) { | ||
return '/examples/router-hooks/' | ||
} | ||
//set page data based on episode ID | ||
to.data.page = { | ||
id: parseInt(id), | ||
title: `Episode ${id}`, | ||
} | ||
return to | ||
}, | ||
}, | ||
transition: PageTransitions.slideInOutUp, | ||
}, | ||
{ | ||
path: '/examples/router-hooks/movie', | ||
component: Movie, | ||
hooks: { | ||
before(to, from) { | ||
//change transition based on 'from' route | ||
if (from && from.path === 'examples/router-hooks') { | ||
to.transition = PageTransitions.slideInOutLeft | ||
} | ||
if (from && from.path === 'examples/router-hooks/rating') { | ||
to.transition = PageTransitions.slideInOutRight | ||
} | ||
return to | ||
}, | ||
}, | ||
}, | ||
{ | ||
path: '/examples/router-hooks/rating', | ||
component: Rating, | ||
transition: PageTransitions.slideInOutLeft, | ||
}, | ||
] |