@turnipxenon/pineapple 2.4.23 → 2.4.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.idea/workspace.xml +63 -58
- package/.svelte-kit/__package__/index.d.ts +1 -1
- package/.svelte-kit/__package__/index.js +1 -1
- package/.svelte-kit/__package__/template/Seaweed/GameSection.svelte +207 -0
- package/.svelte-kit/__package__/template/Seaweed/GameSection.svelte.d.ts +17 -0
- package/.svelte-kit/__package__/template/Seaweed/ProjectSection.svelte +289 -0
- package/.svelte-kit/__package__/template/Seaweed/ProjectSection.svelte.d.ts +17 -0
- package/.svelte-kit/__package__/template/Seaweed/SeaweedTemplate.svelte +246 -0
- package/.svelte-kit/__package__/template/{SeaweedTemplate.svelte.d.ts → Seaweed/SeaweedTemplate.svelte.d.ts} +1 -0
- package/.svelte-kit/__package__/template/Seaweed/seaweed.postcss +133 -0
- package/.svelte-kit/ambient.d.ts +2 -0
- package/.svelte-kit/generated/server/internal.js +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/template/Seaweed/GameSection.svelte +207 -0
- package/dist/template/Seaweed/GameSection.svelte.d.ts +17 -0
- package/dist/template/Seaweed/ProjectSection.svelte +289 -0
- package/dist/template/Seaweed/ProjectSection.svelte.d.ts +17 -0
- package/dist/template/Seaweed/SeaweedTemplate.svelte +246 -0
- package/dist/template/{SeaweedTemplate.svelte.d.ts → Seaweed/SeaweedTemplate.svelte.d.ts} +1 -0
- package/dist/template/Seaweed/seaweed.postcss +133 -0
- package/package.json +1 -1
- package/src/lib/index.ts +1 -1
- package/src/lib/template/Seaweed/GameSection.svelte +213 -0
- package/src/lib/template/Seaweed/ProjectSection.svelte +298 -0
- package/src/lib/template/Seaweed/SeaweedTemplate.svelte +275 -0
- package/src/lib/template/Seaweed/seaweed.postcss +133 -0
- package/src/routes/(seaweed)/portfolio/+page.svelte +1 -1
- package/src/routes/(seaweed)/portfolio/actual/+page.svelte +4 -4
- package/.svelte-kit/__package__/template/SeaweedTemplate.svelte +0 -910
- package/dist/template/SeaweedTemplate.svelte +0 -910
- package/src/lib/template/SeaweedTemplate.svelte +0 -877
package/.idea/workspace.xml
CHANGED
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
<option name="autoReloadType" value="SELECTIVE" />
|
|
5
5
|
</component>
|
|
6
6
|
<component name="ChangeListManager">
|
|
7
|
-
<list default="true" id="accb6ba2-c343-4f84-ad30-6e2d71eceee5" name="Changes" comment="
|
|
8
|
-
<change beforePath="$PROJECT_DIR$/src/lib/
|
|
7
|
+
<list default="true" id="accb6ba2-c343-4f84-ad30-6e2d71eceee5" name="Changes" comment="Refactor GameSection out of SeaweedTemplate">
|
|
8
|
+
<change beforePath="$PROJECT_DIR$/src/lib/template/Seaweed/SeaweedTemplate.svelte" beforeDir="false" afterPath="$PROJECT_DIR$/src/lib/template/Seaweed/SeaweedTemplate.svelte" afterDir="false" />
|
|
9
9
|
</list>
|
|
10
10
|
<option name="SHOW_DIALOG" value="false" />
|
|
11
11
|
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
|
@@ -36,6 +36,8 @@
|
|
|
36
36
|
<option value="Toast" />
|
|
37
37
|
<option value="TestCard" />
|
|
38
38
|
<option value="TypeScript File" />
|
|
39
|
+
<option value="GameSection" />
|
|
40
|
+
<option value="ProjectSection" />
|
|
39
41
|
</list>
|
|
40
42
|
</option>
|
|
41
43
|
</component>
|
|
@@ -76,32 +78,32 @@
|
|
|
76
78
|
<option name="hideEmptyMiddlePackages" value="true" />
|
|
77
79
|
<option name="showLibraryContents" value="true" />
|
|
78
80
|
</component>
|
|
79
|
-
<component name="PropertiesComponent"
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
81
|
+
<component name="PropertiesComponent"><![CDATA[{
|
|
82
|
+
"keyToString": {
|
|
83
|
+
"DefaultHtmlFileTemplate": "HTML File",
|
|
84
|
+
"RunOnceActivity.OpenProjectViewOnStart": "true",
|
|
85
|
+
"RunOnceActivity.ShowReadmeOnStart": "true",
|
|
86
|
+
"WebServerToolWindowFactoryState": "false",
|
|
87
|
+
"git-widget-placeholder": "turnip/dev",
|
|
88
|
+
"ignore.virus.scanning.warn.message": "true",
|
|
89
|
+
"last_opened_file_path": "C:/Users/Pumpkin/Projects/Web/pineapple/src/lib/assets/placeholder",
|
|
90
|
+
"node.js.detected.package.eslint": "true",
|
|
91
|
+
"node.js.detected.package.tslint": "true",
|
|
92
|
+
"node.js.selected.package.eslint": "(autodetect)",
|
|
93
|
+
"node.js.selected.package.tslint": "(autodetect)",
|
|
94
|
+
"nodejs_interpreter_path": "node",
|
|
95
|
+
"nodejs_package_manager_path": "yarn",
|
|
96
|
+
"npm.build.executor": "Run",
|
|
97
|
+
"npm.dev (1).executor": "Run",
|
|
98
|
+
"npm.dev --open.executor": "Run",
|
|
99
|
+
"npm.dev offline.executor": "Run",
|
|
100
|
+
"npm.dev-offline.executor": "Run",
|
|
101
|
+
"npm.dev.executor": "Run",
|
|
102
|
+
"settings.editor.selected.configurable": "inlay.hints",
|
|
103
|
+
"ts.external.directory.path": "C:\\Users\\Pumpkin\\Projects\\Web\\pineapple\\node_modules\\typescript\\lib",
|
|
104
|
+
"vue.rearranger.settings.migration": "true"
|
|
103
105
|
}
|
|
104
|
-
}
|
|
106
|
+
}]]></component>
|
|
105
107
|
<component name="RecentsManager">
|
|
106
108
|
<key name="CopyFile.RECENT_KEYS">
|
|
107
109
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\assets\placeholder" />
|
|
@@ -111,11 +113,11 @@
|
|
|
111
113
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\components\pineapple\toast\custom-toast" />
|
|
112
114
|
</key>
|
|
113
115
|
<key name="MoveFile.RECENT_KEYS">
|
|
116
|
+
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\template\Seaweed" />
|
|
114
117
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\routes\(pineapple)\about" />
|
|
115
118
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\routes\(pineapple)" />
|
|
116
119
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\components\pineapple\toast\custom-toast" />
|
|
117
120
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\components\pineapple\toast" />
|
|
118
|
-
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\components\pineapple" />
|
|
119
121
|
</key>
|
|
120
122
|
<key name="es6.move.members.recent.items">
|
|
121
123
|
<recent name="C:\Users\Pumpkin\Projects\Web\pineapple\src\lib\util\util.ts" />
|
|
@@ -149,8 +151,8 @@
|
|
|
149
151
|
</list>
|
|
150
152
|
<recent_temporary>
|
|
151
153
|
<list>
|
|
152
|
-
<item itemvalue="npm.dev-offline" />
|
|
153
154
|
<item itemvalue="npm.dev --open" />
|
|
155
|
+
<item itemvalue="npm.dev-offline" />
|
|
154
156
|
<item itemvalue="npm.dev --open" />
|
|
155
157
|
<item itemvalue="npm.dev-offline" />
|
|
156
158
|
<item itemvalue="npm.dev --open" />
|
|
@@ -216,31 +218,10 @@
|
|
|
216
218
|
<workItem from="1711052377810" duration="128000" />
|
|
217
219
|
<workItem from="1711090540281" duration="11162000" />
|
|
218
220
|
<workItem from="1711104214619" duration="25000" />
|
|
219
|
-
<workItem from="1711108187279" duration="
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
<
|
|
223
|
-
<created>1710094498499</created>
|
|
224
|
-
<option name="number" value="00036" />
|
|
225
|
-
<option name="presentableId" value="LOCAL-00036" />
|
|
226
|
-
<option name="project" value="LOCAL" />
|
|
227
|
-
<updated>1710094498499</updated>
|
|
228
|
-
</task>
|
|
229
|
-
<task id="LOCAL-00037" summary="Fix accordion styling and cropped object positioning">
|
|
230
|
-
<option name="closed" value="true" />
|
|
231
|
-
<created>1710097868234</created>
|
|
232
|
-
<option name="number" value="00037" />
|
|
233
|
-
<option name="presentableId" value="LOCAL-00037" />
|
|
234
|
-
<option name="project" value="LOCAL" />
|
|
235
|
-
<updated>1710097868234</updated>
|
|
236
|
-
</task>
|
|
237
|
-
<task id="LOCAL-00038" summary="Adjust css for mobile">
|
|
238
|
-
<option name="closed" value="true" />
|
|
239
|
-
<created>1710113276818</created>
|
|
240
|
-
<option name="number" value="00038" />
|
|
241
|
-
<option name="presentableId" value="LOCAL-00038" />
|
|
242
|
-
<option name="project" value="LOCAL" />
|
|
243
|
-
<updated>1710113276818</updated>
|
|
221
|
+
<workItem from="1711108187279" duration="1163000" />
|
|
222
|
+
<workItem from="1711115902471" duration="148000" />
|
|
223
|
+
<workItem from="1711116299202" duration="1291000" />
|
|
224
|
+
<workItem from="1711179012668" duration="1717000" />
|
|
244
225
|
</task>
|
|
245
226
|
<task id="LOCAL-00039" summary="Add chips and query">
|
|
246
227
|
<option name="closed" value="true" />
|
|
@@ -610,7 +591,31 @@
|
|
|
610
591
|
<option name="project" value="LOCAL" />
|
|
611
592
|
<updated>1711101645201</updated>
|
|
612
593
|
</task>
|
|
613
|
-
<
|
|
594
|
+
<task id="LOCAL-00085" summary="Add external link warning stub">
|
|
595
|
+
<option name="closed" value="true" />
|
|
596
|
+
<created>1711108553537</created>
|
|
597
|
+
<option name="number" value="00085" />
|
|
598
|
+
<option name="presentableId" value="LOCAL-00085" />
|
|
599
|
+
<option name="project" value="LOCAL" />
|
|
600
|
+
<updated>1711108553537</updated>
|
|
601
|
+
</task>
|
|
602
|
+
<task id="LOCAL-00086" summary="Refactor Game Section to separate component">
|
|
603
|
+
<option name="closed" value="true" />
|
|
604
|
+
<created>1711180090086</created>
|
|
605
|
+
<option name="number" value="00086" />
|
|
606
|
+
<option name="presentableId" value="LOCAL-00086" />
|
|
607
|
+
<option name="project" value="LOCAL" />
|
|
608
|
+
<updated>1711180090086</updated>
|
|
609
|
+
</task>
|
|
610
|
+
<task id="LOCAL-00087" summary="Refactor GameSection out of SeaweedTemplate">
|
|
611
|
+
<option name="closed" value="true" />
|
|
612
|
+
<created>1711180642880</created>
|
|
613
|
+
<option name="number" value="00087" />
|
|
614
|
+
<option name="presentableId" value="LOCAL-00087" />
|
|
615
|
+
<option name="project" value="LOCAL" />
|
|
616
|
+
<updated>1711180642880</updated>
|
|
617
|
+
</task>
|
|
618
|
+
<option name="localTasksCounter" value="88" />
|
|
614
619
|
<servers />
|
|
615
620
|
</component>
|
|
616
621
|
<component name="TypeScriptGeneratedFilesManager">
|
|
@@ -668,8 +673,6 @@
|
|
|
668
673
|
</option>
|
|
669
674
|
</component>
|
|
670
675
|
<component name="VcsManagerConfiguration">
|
|
671
|
-
<MESSAGE value="Improve text contrast" />
|
|
672
|
-
<MESSAGE value="Improve text contrast in dark mode" />
|
|
673
676
|
<MESSAGE value="Add animation to dynamically added button in social section" />
|
|
674
677
|
<MESSAGE value="Implement normal state for PineappleBaseLayout" />
|
|
675
678
|
<MESSAGE value="Add custom toast" />
|
|
@@ -693,6 +696,8 @@
|
|
|
693
696
|
<MESSAGE value="Adjust turnip fab button color" />
|
|
694
697
|
<MESSAGE value="Replace btn-group postcss class with turnip-menu There is postcss defined class called btn-group which has styles that have !important, which I accidentally used not knowing it exists, and it overrides whatever styles I apply on my class" />
|
|
695
698
|
<MESSAGE value="Add external link warning stub" />
|
|
696
|
-
<
|
|
699
|
+
<MESSAGE value="Refactor Game Section to separate component" />
|
|
700
|
+
<MESSAGE value="Refactor GameSection out of SeaweedTemplate" />
|
|
701
|
+
<option name="LAST_COMMIT_MESSAGE" value="Refactor GameSection out of SeaweedTemplate" />
|
|
697
702
|
</component>
|
|
698
703
|
</project>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { default as PineappleLayoutBase } from "./components/pineapple/PineappleBaseLayout.svelte";
|
|
2
|
-
export { default as SeaweedTemplate } from "./template/SeaweedTemplate.svelte";
|
|
2
|
+
export { default as SeaweedTemplate } from "./template/Seaweed/SeaweedTemplate.svelte";
|
|
3
3
|
export { default as LazyAsset } from "./components/LazyAsset.svelte";
|
|
4
4
|
export { default as Card } from "./components/Card.svelte";
|
|
5
5
|
export * from "./components/dialog_manager/DialogManagerStore";
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { default as PineappleLayoutBase } from "./components/pineapple/PineappleBaseLayout.svelte";
|
|
2
|
-
export { default as SeaweedTemplate } from "./template/SeaweedTemplate.svelte";
|
|
2
|
+
export { default as SeaweedTemplate } from "./template/Seaweed/SeaweedTemplate.svelte";
|
|
3
3
|
export { default as LazyAsset } from "./components/LazyAsset.svelte";
|
|
4
4
|
export { default as Card } from "./components/Card.svelte";
|
|
5
5
|
export * from "./components/dialog_manager/DialogManagerStore";
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
<script>export let email = "turnipxenon@gmail.com";
|
|
2
|
+
import "./seaweed.postcss";
|
|
3
|
+
import HeaderPengi from "../../assets/temp/header-pengi.mp4";
|
|
4
|
+
import GithubIcon from "../../assets/icons/github-mark.svg";
|
|
5
|
+
import { ItchLogoHotLink } from "../../consts";
|
|
6
|
+
import HeaderHepCat from "../../assets/temp/header-hep-cat.mp4";
|
|
7
|
+
import BitbucketIcon from "../../assets/icons/bitbucket-icon.svg";
|
|
8
|
+
import HeaderChefWings from "../../assets/game_dev/footage-chef-wings.gif";
|
|
9
|
+
import LinkIcon from "../../assets/icons/link-icon.svg";
|
|
10
|
+
import HeaderSoulwork from "../../assets/temp/header-soulwork.mp4";
|
|
11
|
+
import Card from "../../components/Card.svelte";
|
|
12
|
+
import { getModalStore } from "@skeletonlabs/skeleton";
|
|
13
|
+
const modalStore = getModalStore();
|
|
14
|
+
const chefWingsWarning = {
|
|
15
|
+
type: "confirm",
|
|
16
|
+
title: "Warning: please confirm",
|
|
17
|
+
body: `This will directly link to the game itself, since this game does not have any game page or any publicly viewable source code. The game is only playable on desktop. Are you sure you wish to proceed? If there are any bugs, please report at <a href='mailto:${email}' target='_blank'>${email}</a>.`,
|
|
18
|
+
response: (r) => {
|
|
19
|
+
if (r) {
|
|
20
|
+
window.open("https://selk.io/birb-project/trunk/");
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
</script>
|
|
25
|
+
|
|
26
|
+
<Card>
|
|
27
|
+
<div class="section-card title-card" slot="content">
|
|
28
|
+
<h1 class="text-center">Games</h1>
|
|
29
|
+
</div>
|
|
30
|
+
</Card>
|
|
31
|
+
|
|
32
|
+
<section class="games-section">
|
|
33
|
+
|
|
34
|
+
<Card>
|
|
35
|
+
<section class="game-card" slot="content">
|
|
36
|
+
<video playsinline autoplay muted loop preload="none">
|
|
37
|
+
video unavailable. original video contains pengi gameplay showing the dynamic dialog
|
|
38
|
+
layout and character animation.
|
|
39
|
+
<source src={HeaderPengi} type="video/mp4">
|
|
40
|
+
</video>
|
|
41
|
+
|
|
42
|
+
<section class="game-card-body">
|
|
43
|
+
|
|
44
|
+
<h1>Pengi</h1>
|
|
45
|
+
|
|
46
|
+
<blockquote>
|
|
47
|
+
Well well, quite the dreamer, aren’t you? Might be hard to get in... costs a lot of
|
|
48
|
+
money...
|
|
49
|
+
</blockquote>
|
|
50
|
+
|
|
51
|
+
<p>
|
|
52
|
+
Pengi is a text-based adventure made in <span class="qt-unity">Unity</span>. I acted as the sole
|
|
53
|
+
programmer for the team. Most of the work revolves around UI and creating <a
|
|
54
|
+
href="https://yarnspinner.dev/" target="_blank">YarnSpinner</a> commands for writers
|
|
55
|
+
to use to create expressive stage directions in the script.
|
|
56
|
+
</p>
|
|
57
|
+
|
|
58
|
+
<section class="game-link-section">
|
|
59
|
+
<button type="button" class="game-button turnip-button"
|
|
60
|
+
role="link"
|
|
61
|
+
title="https://github.com/GreenTea-M/ProjectPengi"
|
|
62
|
+
on:click={()=> window.open("https://github.com/GreenTea-M/ProjectPengi")}>
|
|
63
|
+
<img alt="github icon" src={GithubIcon}>
|
|
64
|
+
</button>
|
|
65
|
+
<button type="button" class="game-button turnip-button"
|
|
66
|
+
role="link"
|
|
67
|
+
title="https://turnipxenon.itch.io/pengi"
|
|
68
|
+
on:click={()=> window.open("https://turnipxenon.itch.io/pengi")}>
|
|
69
|
+
<img alt="itch.io icon" src={ItchLogoHotLink}>
|
|
70
|
+
</button>
|
|
71
|
+
</section>
|
|
72
|
+
</section>
|
|
73
|
+
</section>
|
|
74
|
+
</Card>
|
|
75
|
+
|
|
76
|
+
<Card>
|
|
77
|
+
<section class="game-card" slot="content">
|
|
78
|
+
<!-- todo: move the image crop a bit lower -->
|
|
79
|
+
<video playsinline autoplay muted loop preload="none" id="hepcat-video">
|
|
80
|
+
<source src={HeaderHepCat} type="video/mp4">
|
|
81
|
+
</video>
|
|
82
|
+
|
|
83
|
+
<section class="game-card-body">
|
|
84
|
+
|
|
85
|
+
<h1>Hepcat</h1>
|
|
86
|
+
|
|
87
|
+
<blockquote>
|
|
88
|
+
"Cats, Jazz, and a little bit of Death. What more could anyone ask for?"
|
|
89
|
+
</blockquote>
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
<p>This is a course project made by a team of six for <a
|
|
93
|
+
href="https://sites.google.com/ualberta.ca/cmput250/">CMPUT 250</a>, and it won <a
|
|
94
|
+
href="https://webdocs.cs.ualberta.ca/~nathanst/certificate/">Game of the year.</a>
|
|
95
|
+
</p>
|
|
96
|
+
|
|
97
|
+
<p>
|
|
98
|
+
Hep Cat is a rhythm game made in <a
|
|
99
|
+
href="https://www.rpgmakerweb.com/products/programs/rpg-maker-mv" target="_blank" class="qt-rpgmaker">
|
|
100
|
+
RPG Maker MV</a> with the help of additional custom-made <span class="qt-js">Javascript</span> plugins. I
|
|
101
|
+
wrote the rhythm game plugin's framework. For this plugin to work, I
|
|
102
|
+
had to write a <span class="qt-python">Python</span> script that parses osu! files into readable JSON
|
|
103
|
+
files.
|
|
104
|
+
</p>
|
|
105
|
+
|
|
106
|
+
|
|
107
|
+
<section class="game-link-section">
|
|
108
|
+
<button type="button" class="game-button turnip-button"
|
|
109
|
+
role="link"
|
|
110
|
+
title="https://bitbucket.org/egginchicken/hep-cat/src/master/"
|
|
111
|
+
on:click={()=> window.open("https://bitbucket.org/egginchicken/hep-cat/src/master/")}>
|
|
112
|
+
<img alt="bitbucket icon" src={BitbucketIcon}>
|
|
113
|
+
</button>
|
|
114
|
+
<button type="button" class="game-button turnip-button"
|
|
115
|
+
role="link"
|
|
116
|
+
title="https://just-a-phantom.itch.io/hep-cat"
|
|
117
|
+
on:click={()=> window.open("https://just-a-phantom.itch.io/hep-cat")}>
|
|
118
|
+
<img alt="itch.io icon" src={ItchLogoHotLink}>
|
|
119
|
+
</button>
|
|
120
|
+
</section>
|
|
121
|
+
</section>
|
|
122
|
+
</section>
|
|
123
|
+
</Card>
|
|
124
|
+
|
|
125
|
+
<Card>
|
|
126
|
+
<section class="game-card" slot="content">
|
|
127
|
+
<img src={HeaderChefWings} alt="todo" loading="lazy">
|
|
128
|
+
<section class="game-card-body">
|
|
129
|
+
|
|
130
|
+
<h1>Chef Wings</h1>
|
|
131
|
+
<p>
|
|
132
|
+
A “roguelite-lite” where you gather ingredients in a procedurally-generated dungeon and use
|
|
133
|
+
them to cook for customers and then critics!
|
|
134
|
+
</p>
|
|
135
|
+
<p>
|
|
136
|
+
I built and documented several of the game’s systems including the game state management
|
|
137
|
+
system that extends <span class="qt-unity">Unity’s</span> existing Monobehavior lifecycle with new events,
|
|
138
|
+
and the dialogue, event, and level systems that coordinate the game flow using the interactive
|
|
139
|
+
dialogue tool YarnSpinner
|
|
140
|
+
</p>
|
|
141
|
+
|
|
142
|
+
<section class="game-link-section">
|
|
143
|
+
<button type="button" class="game-button turnip-button"
|
|
144
|
+
title="https://selk.io/birb-project/trunk/"
|
|
145
|
+
on:click={()=>modalStore.trigger(chefWingsWarning)}>
|
|
146
|
+
<img alt="itch.io icon" src={LinkIcon}>
|
|
147
|
+
<span>selk.io/birb-project/trunk/</span>
|
|
148
|
+
</button>
|
|
149
|
+
</section>
|
|
150
|
+
</section>
|
|
151
|
+
</section>
|
|
152
|
+
</Card>
|
|
153
|
+
<Card>
|
|
154
|
+
<section class="game-card" slot="content">
|
|
155
|
+
<video playsinline autoplay muted loop preload="none">
|
|
156
|
+
<source src={HeaderSoulwork} type="video/mp4">
|
|
157
|
+
</video>
|
|
158
|
+
<section class="game-card-body">
|
|
159
|
+
|
|
160
|
+
<h1>Soulwork</h1>
|
|
161
|
+
|
|
162
|
+
<p>
|
|
163
|
+
Soulwork is a 2D platforming game that uses unique physics to solve puzzle-based levels.
|
|
164
|
+
This project is a Time to Game Jam entry, restricting game development to be under 48
|
|
165
|
+
hours.
|
|
166
|
+
</p>
|
|
167
|
+
<p>
|
|
168
|
+
I helped make the level designing tools used by the designers to drag-and-drop objects
|
|
169
|
+
on the stage. I also helped program the unique physics-based gameplay mechanic. This was
|
|
170
|
+
was made in <span class="qt-unity">Unity</span> written using <span class="qt-cs">C#</span>.
|
|
171
|
+
</p>
|
|
172
|
+
|
|
173
|
+
|
|
174
|
+
<section class="game-link-section">
|
|
175
|
+
<button type="button" class="game-button turnip-button"
|
|
176
|
+
role="link"
|
|
177
|
+
title="https://github.com/Zeyu-Li/Clockwork"
|
|
178
|
+
on:click={()=> window.open("https://github.com/Zeyu-Li/Clockwork")}>
|
|
179
|
+
<img alt="github icon" src={GithubIcon}>
|
|
180
|
+
</button>
|
|
181
|
+
<button type="button" class="game-button turnip-button"
|
|
182
|
+
role="link"
|
|
183
|
+
title="https://itch.io/jam/time-to-game-jam-gadec-fall-game-jam/rate/514331"
|
|
184
|
+
on:click={()=> window.open("https://itch.io/jam/time-to-game-jam-gadec-fall-game-jam/rate/514331")}>
|
|
185
|
+
<img alt="itch.io icon" src={ItchLogoHotLink}>
|
|
186
|
+
</button>
|
|
187
|
+
</section>
|
|
188
|
+
</section>
|
|
189
|
+
</section>
|
|
190
|
+
</Card>
|
|
191
|
+
<Card overrideStyle="align-self: flex-start;">
|
|
192
|
+
<section class="game-card itch-promo" slot="content">
|
|
193
|
+
<h1 class="mb-12 text-center">Check out my itch.io page for more games</h1>
|
|
194
|
+
|
|
195
|
+
<section class="game-link-section">
|
|
196
|
+
<button type="button" class="btn variant-filled-primary turnip-button"
|
|
197
|
+
role="link"
|
|
198
|
+
title="https://turnipxenon.itch.io/"
|
|
199
|
+
on:click={() => window.open("https://turnipxenon.itch.io/")}>
|
|
200
|
+
<img src={ItchLogoHotLink} class="long-btn-image" alt="itch icon">
|
|
201
|
+
<span>TurnipXenon</span>
|
|
202
|
+
</button>
|
|
203
|
+
</section>
|
|
204
|
+
|
|
205
|
+
</section>
|
|
206
|
+
</Card>
|
|
207
|
+
</section>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SvelteComponent } from "svelte";
|
|
2
|
+
import "./seaweed.postcss";
|
|
3
|
+
declare const __propDef: {
|
|
4
|
+
props: {
|
|
5
|
+
email?: string | undefined;
|
|
6
|
+
};
|
|
7
|
+
events: {
|
|
8
|
+
[evt: string]: CustomEvent<any>;
|
|
9
|
+
};
|
|
10
|
+
slots: {};
|
|
11
|
+
};
|
|
12
|
+
export type GameSectionProps = typeof __propDef.props;
|
|
13
|
+
export type GameSectionEvents = typeof __propDef.events;
|
|
14
|
+
export type GameSectionSlots = typeof __propDef.slots;
|
|
15
|
+
export default class GameSection extends SvelteComponent<GameSectionProps, GameSectionEvents, GameSectionSlots> {
|
|
16
|
+
}
|
|
17
|
+
export {};
|