Skip to content

Latest commit

 

History

History
73 lines (55 loc) · 2.03 KB

readme.md

File metadata and controls

73 lines (55 loc) · 2.03 KB

Playcanvas typescript example

Project - https://playcanvas.com/project/913369/overview/typescript-example

Build - https://playcanv.as/p/KRxr5lon/

Forum post - https://forum.playcanvas.com/t/example-template-project-with-typescript/25272

Setup

  • Install dependencies npm i
  • Copy .pcconfig to your home directory e.g.
    • windows - C:/Users/<username>
    • macos - /Users/<username>
  • Copy pcconfig.example.json and rename to pcconfig.json. This file is needed to configure playcanvas-sync to sync script files to correct playcanvas project.
  • In pcconfig.json using playcanvas-sync guide fill this environment variables
    • PLAYCANVAS_API_KEY
    • PLAYCANVAS_BRANCH_ID
    • PLAYCANVAS_PROJECT_ID
  • now you ready to go - npm run dev

npm scripts

Command Description
npm run dev Compiles tsc files and push to playcanvas.com project
npm run build Performs build and push to playcanvas.com project

Conventions

Scripts preferable structure

// typings and libs goes first, split by empty line
import { ScriptTypeBase } from "../../types/ScriptTypeBase";

// components second
import { falledCheckEvents } from "./falledCheck";

// utils third
import { createScript, attrib } from "../../utils/createScriptDecorator";
import { ebEvents, events } from "../../utils/events";

// consts here
const defaultAmmoCount = 30;

@createScript("shooting")
class Shooting extends ScriptTypeBase {
  // attributes
  @attrib({ type: "boolean", default: true })
  autoReload: boolean;
  @attrib({
    type: "number",
    default: 1,
    min: 0.01,
    description: "Reload time in seconds",
  })
  reloadTime: number;

  // local properties
  shotTimer: TInterval;
  reloadingTimer: TTimeout;
  isReloading: boolean = false;

  // methods
  initialize() {}

  onDestroy() {}
}

// default export at the end
export default Shooting;