Skip to content

Commit

Permalink
Added custom components
Browse files Browse the repository at this point in the history
  • Loading branch information
legopitstop committed Jun 8, 2024
1 parent b8f45e6 commit 68275b0
Show file tree
Hide file tree
Showing 31 changed files with 1,803 additions and 1,729 deletions.
1 change: 1 addition & 0 deletions docs/.vitepress/bandage.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"links":[{"namespace":"bandage","pattern":"/bandage/recipes#:ref"}],"items":[{"id":"bandage:bandage","name":"Bandage","texture":""},{"id":"bandage:nether_bandage","name":"Nether Bandage","texture":""},{"id":"bandage:end_bandage","name":"End Bandage","texture":""},{"id":"bandage:water_bandage","name":"Water Bandage","texture":""}]}
1 change: 1 addition & 0 deletions docs/.vitepress/breaker.json

Large diffs are not rendered by default.

42 changes: 42 additions & 0 deletions docs/.vitepress/classes/BedrockGeoLoader.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
import * as THREE from "three";

export class BedrockGeoLoader extends THREE.Loader {
constructor(manager) {
super(manager);
}

load(url) {
const onError = () => {};
const onProgress = () => {};
const scope = this;
const loader = new THREE.FileLoader(scope.manager);
loader.setPath(scope.path);
loader.setRequestHeader(scope.requestHeader);
loader.setWithCredentials(scope.withCredentials);
loader.load(
url,
function (text) {
try {
console.log(text);
scope.parse(JSON.parse(text));
} catch (e) {
if (onError) {
onError(e);
} else {
console.error(e);
}

scope.manager.itemError(url);
}
},
onError,
onProgress
);
}

parse(json) {
console.log(json);

return undefined;
}
}
31 changes: 31 additions & 0 deletions docs/.vitepress/classes/Identifier.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@

export class Identifier {
constructor(namespace, path) {
this.namespace = namespace;
this.path = path;
}

static fromString(namespace, path) {
if (path == undefined) {
if (namespace instanceof Identifier) {return namespace}
var namespace2, path2;
[namespace2, path2] = namespace.toString().split(":");
if (!path2) {
return new Identifier("minecraft", namespace);
}
return new Identifier(namespace2, path2);
}
return new Identifier(namespace, path2);
}

match(other) {
if (other instanceof Identifier) {
return this.namespace === other.namespace && this.path === other.path;
}
return this.match(Identifier.fromString(other));
}

toString() {
return this.namespace + ":" + this.path;
}
}
90 changes: 90 additions & 0 deletions docs/.vitepress/classes/Item.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
import { Identifier } from "./Identifier";
import { renderFormatting, getLink } from "../theme/mcui";

export class Item {
constructor(id, name, texture, link, lore = []) {
this.id = id;
this.name = name;
this.link = link;
this.texture = texture
? texture
: "";
this.lore = lore;
}
static unknown() {
return new Item(
Identifier.fromString("unknown"),
"Unknown",
""
);
}

// parse item
static fromJson(data) {
return new Item(
Identifier.fromString(data.id),
data.name,
data.texture,
data.link,
data.lore
);
}

match(other) {
if (other instanceof Item) {
return this.id.match(other.id);
}
return false;
}

toString() {
return this.id.toString();
}

cleanName() {
if (!this._cleanName) {
this._cleanName = this.name.replace(/§./g, '');
}
return this._cleanName;
}

getDisplayName() {
if (!this.displayName) {
this.displayName = renderFormatting(this.name);
}
return this.displayName;
}

getMinetip() {
if (!this.minetip) {
// Name
this.minetip = this.getDisplayName() + "<br>";
// Lore
var htmlLore = [];
if (this.lore) {
for (const ln of this.lore) {
htmlLore.push(renderFormatting(ln));
}
}
// Advanced Tooltips
htmlLore.push('<span class="format-8">' + this.id.toString() + "</span>");
this.minetip += htmlLore.join("<br>");
}
return this.minetip;
}

getLink() {
if (!this.link) {
var link = getLink(this);
this.link = link ? link : "#" + this.id.path;
}
return this.link;
}

getLinkTarget() {
if (!this.linkTarget) {
this.linkTarget = this.getLink().startsWith("http") ? "_blank" : "_self";
}
return this.linkTarget;
}
}
148 changes: 148 additions & 0 deletions docs/.vitepress/components/ArmorStandGenerator.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,148 @@
<!-- WARN: Not ready for production!! -->

<template>
<div id="renderer"></div>
</template>

<script>
import * as THREE from "three";
import { OrbitControls } from "three/addons/controls/OrbitControls.js";
import { GUI } from "three/addons/libs/lil-gui.module.min.js";
import { BedrockGeoLoader } from "../classes/BedrockGeoLoader.js";
// https://threejs.org/docs/#manual/en/introduction/Installation
export default {
name: "ArmorStandGenerator",
data() {
return {};
},
methods: {
init: function () {
const armorStand = new BedrockGeoLoader().load(
"../theme/models/armor_stand.geo.json",
"geometry.armor_stand"
);
let container = document.getElementById("renderer");
this.scene = new THREE.Scene();
this.camera = new THREE.PerspectiveCamera(
75,
container.clientWidth / container.clientHeight,
0.1,
1000
);
this.renderer = new THREE.WebGLRenderer();
this.renderer.setSize(container.clientWidth, container.clientHeight);
container.appendChild(this.renderer.domElement);
// Cube
const geometry = new THREE.BoxGeometry(1, 1, 1);
const material = new THREE.MeshLambertMaterial({ color: 0xff0000 });
this.cube = new THREE.Mesh(geometry, material);
this.scene.add(this.cube);
// Light
const ambientLight = new THREE.AmbientLight(0xffffff, 0.5);
const light = new THREE.SpotLight(0xffffff, 200);
light.position.set(0, 0, 1);
this.scene.add(ambientLight, light);
this.lightHolder = new THREE.Group();
this.lightHolder.add(light);
this.scene.add(this.lightHolder);
// Controls
this.camera.position.set(0, 0, 5);
const controls = new OrbitControls(this.camera, this.renderer.domElement);
controls.enablePan = false;
controls.enableZoom = false;
this.createPanel();
},
createPanel() {
const gui = new GUI({ container: document.getElementById("renderer") });
const head = {
x: 0,
y: 0,
z: 0,
};
const body = {
x: 0,
y: 0,
z: 0,
};
const leftArm = {
x: 0,
y: 0,
z: 0,
};
const rightArm = {
x: 0,
y: 0,
z: 0,
};
const leftLeg = {
x: 0,
y: 0,
z: 0,
};
const rightLeg = {
x: 0,
y: 0,
z: 0,
};
const headFolder = gui.addFolder("Head");
headFolder.add(head, "x", 0, 360, 1);
headFolder.add(head, "y", 0, 360, 1);
headFolder.add(head, "z", 0, 360, 1);
const bodyFolder = gui.addFolder("Body");
bodyFolder.add(body, "x", 0, 360, 1);
bodyFolder.add(body, "y", 0, 360, 1);
bodyFolder.add(body, "z", 0, 360, 1);
const leftArmFolder = gui.addFolder("Left Arm");
leftArmFolder.add(leftArm, "x", 0, 360, 1);
leftArmFolder.add(leftArm, "y", 0, 360, 1);
leftArmFolder.add(leftArm, "z", 0, 360, 1);
const rightArmFolder = gui.addFolder("Right Arm");
rightArmFolder.add(rightArm, "x", 0, 360, 1);
rightArmFolder.add(rightArm, "y", 0, 360, 1);
rightArmFolder.add(rightArm, "z", 0, 360, 1);
const leftLegFolder = gui.addFolder("Left Leg");
leftLegFolder.add(leftLeg, "x", 0, 360, 1);
leftLegFolder.add(leftLeg, "y", 0, 360, 1);
leftLegFolder.add(leftLeg, "z", 0, 360, 1);
const rightLegFolder = gui.addFolder("Right Leg");
rightLegFolder.add(rightLeg, "x", 0, 360, 1);
rightLegFolder.add(rightLeg, "y", 0, 360, 1);
rightLegFolder.add(rightLeg, "z", 0, 360, 1);
gui.onChange((event) => {
console.log(event.property);
});
gui.open();
},
animate: function () {
requestAnimationFrame(this.animate);
// this.cube.rotation.x += 0.01;
// this.cube.rotation.y += 0.01;
this.lightHolder.quaternion.copy(this.camera.quaternion);
this.renderer.render(this.scene, this.camera);
},
},
mounted() {
this.init();
this.animate();
},
};
</script>

<style scoped>
#renderer {
display: block;
width: 500px;
height: 500px;
cursor: move;
}
</style>
25 changes: 25 additions & 0 deletions docs/.vitepress/components/BisectHostingAds.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<template>
<div class="BisectHostingAds">ADVERT</div>
</template>

<script>
export default {
name: "BisectHostingAds",
};
</script>

<style scoped>
.BisectHostingAds {
display: flex;
justify-content: center;
align-items: center;
padding: 24px;
border-radius: 12px;
min-height: 256px;
text-align: center;
line-height: 18px;
font-size: 12px;
font-weight: 500;
background-color: var(--vp-carbon-ads-bg-color);
}
</style>
26 changes: 26 additions & 0 deletions docs/.vitepress/components/BrewingRecipe.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<template>
<div>
<span class="mcui mcui-Brewing pixel-image">
<span class="mcui-input">
<InvSlot :id="input" />
</span>
<span class="mcui-output">
<InvSlot />
<InvSlot :id="output" />
<InvSlot />
</span>
</span>
</div>
</template>

<script>
export default {
name: "BrewingRecipe",
props: {
input: String,
output: String,
},
};
</script>

<style scoped></style>
Loading

0 comments on commit 68275b0

Please sign in to comment.