generated from ntoll/codespaces-project-template-pyscript
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 284ccc9
Showing
9 changed files
with
301 additions
and
0 deletions.
There are no files selected for viewing
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,36 @@ | ||
// For format details, see https://aka.ms/devcontainer.json. For config options, see the README at: | ||
// https://github.com/devcontainers/images/tree/main/src/javascript-node | ||
{ | ||
"name": "PyScript Site with GitHub Codespaces", | ||
"image": "mcr.microsoft.com/devcontainers/universal:2", | ||
"hostRequirements": { | ||
"cpus": 4 | ||
}, | ||
"waitFor": "onCreateCommand", | ||
"updateContentCommand": "", | ||
"postCreateCommand": "", | ||
"postAttachCommand": "", | ||
|
||
// Configure tool-specific properties. | ||
"customizations": { | ||
// Configure properties specific to VS Code. | ||
"vscode": { | ||
// Add the IDs of extensions you want installed when the container is created. | ||
"extensions": [ | ||
"ritwickdey.LiveServer", | ||
"ms-python.python", | ||
"GitHub.copilot" | ||
], | ||
"settings": { | ||
"emmet.includeLanguages": { | ||
"razor": "html" | ||
}, | ||
"emmet.triggerExpansionOnTab": true | ||
} | ||
} | ||
}, | ||
|
||
"features": { | ||
"ghcr.io/devcontainers/features/github-cli:1": {}, | ||
} | ||
} |
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,15 @@ | ||
<!-- | ||
This repository does not accept pull requests through the normal process. | ||
PRs without the 'pre-approved' label will be automatically closed. If you are learning about this repository | ||
and are following the steps, then you need to make changes in your own account. | ||
If you need this PR to be merged, you have two options: | ||
1. Label this PR with the 'pre-approved' label if you have admin or enough privileges | ||
or | ||
2. Tag alfredodeza to take a look | ||
Thank you for your understanding! | ||
--> |
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,19 @@ | ||
name: Auto close pull requests | ||
on: | ||
pull_request_target: | ||
types: [opened, labeled, unlabeled, reopened] | ||
|
||
jobs: | ||
auto_close: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v2 | ||
|
||
- name: Close PR if not pre-approved | ||
if: ${{ !(contains(github.event.pull_request.labels.*.name, 'pre-approved')) && !(contains(github.event.pull_request.body, '@alfredodeza')) }} | ||
run: | | ||
MESSAGE="This repository doesn't accept pull requests. Please fork the repository and make changes there. If you really need this PR to be merged you must be an admin and label this pr with the 'pre-approved' label *or* tag Alfredo Deza (\`@alfredodeza\`) to take a look." | ||
gh pr close ${{ github.event.pull_request.number }} --repo education/codespaces-project-template-js --comment "$MESSAGE" | ||
env: | ||
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |
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,24 @@ | ||
# Logs | ||
logs | ||
*.log | ||
|
||
# Build files generated from Parcel | ||
dist | ||
|
||
# Dependency directories | ||
node_modules/ | ||
|
||
# Optional npm cache directory | ||
.npm | ||
|
||
# Optional eslint cache | ||
.eslintcache | ||
|
||
# dotenv environment variables file | ||
.env | ||
.env.test | ||
|
||
# parcel-bundler cache (https://parceljs.org/) | ||
.parcel-cache | ||
|
||
.DS_Store |
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,157 @@ | ||
[data:image/s3,"s3://crabby-images/87f81/87f81b2237bddd5ddb22caa11d7a2a943c7f0d98" alt="Open in GitHub Codespaces"](https://github.com/codespaces/new?hide_repo_select=true&ref=main&repo=816765904) | ||
|
||
# 🐍📜 PyScript with GitHub Codespaces and Copilot | ||
|
||
_Create, customize and deploy your own [PyScript](https://pyscript.net) | ||
website in minutes._ ✨ | ||
|
||
In this template repository we have the development environment and base set | ||
and ready to go. So that you can immediately launch your | ||
[Codespace](https://github.com/features/codespaces/) environment and start | ||
customizing your site using [Copilot](https://copilot.github.com) to help you | ||
write code faster. | ||
|
||
* **Who is this for?** __Anyone__ looking to create a | ||
[PyScript](https://pyscript.net/) site, learn web development, or test out | ||
Codespaces. | ||
* **How much experience do you need?** __Zero__. You decide how much you want | ||
to customize based on your experience, and time available. | ||
* **Tools needed:** _None_. No need to install anything! All you need is a web | ||
browser. | ||
* **Prerequisites:** _None_. This template includes your development | ||
environment and deployable web app for you to create your own site. | ||
|
||
## About this PyScript template | ||
|
||
This template includes the minimal viable PyScript application, from which you | ||
can build. | ||
|
||
### Quick Start | ||
|
||
1. Click the **Use this Template** button and then **Create a new repository** as can be seen in the image below. | ||
Note: Make sure you've signed in to GitHub otherwise, you wouldn't see the **Use this Template** button. | ||
data:image/s3,"s3://crabby-images/76c82/76c82f3d350b929d1f7becfc4a5c18106d0e8a13" alt="PyScript web application" | ||
1. Select the repository owner (e.g. your GitHub account) | ||
1. Enter a unique name for your new repository | ||
1. Click the **Code** button | ||
1. Click **Create Codespace on main** button | ||
1. Customize your PyScript site with Copilot | ||
1. [Deploy your site](#-deploy-your-web-application) | ||
|
||
<details> | ||
<summary><b>🎥 To learn more about Codespaces, watch our video tutorial series</b></summary> | ||
|
||
[data:image/s3,"s3://crabby-images/b00b8/b00b89ea28f0767f15c7156e2131f9f75f6f0192" alt="Codespaces Tutorial"](https://aka.ms/CodespacesVideoTutorial "Codespaces Tutorial") | ||
</details> | ||
|
||
## 🗃️ PyScript template | ||
|
||
This repo is a GitHub template to build a PyScript web application. The goal is | ||
to give you a template that you can immediately utilize to create your own | ||
PyScript website through Codespaces. | ||
|
||
The repo contains the following: | ||
|
||
* `.devcontainer/devcontainer.json`: Configuration file used by Codespaces to | ||
configure Visual Studio Code settings, such as the enabling of additional | ||
extensions. | ||
* `config.json`: the | ||
[PyScript configuration](https://docs.pyscript.net/2024.6.1/user-guide/configuration/) | ||
used by your application. | ||
* `index.html`: the | ||
[HTML page](https://docs.pyscript.net/2024.6.1/user-guide/first-steps/) | ||
used to load your PyScript application. | ||
* `main.py`: the [Python script](https://pyscript.net/) to run. | ||
* `mini-coi.js`: a | ||
[utility](https://docs.pyscript.net/2024.6.1/user-guide/workers/#http-headers) | ||
to ensure all PyScript's features are available. | ||
* `README.md`: this file (that you're reading right now). | ||
|
||
## 🚀 Getting started | ||
|
||
This PyScript project contains everything you need so that you can immediately | ||
open Codespaces, see it running, and deploy at any point. | ||
|
||
Your development environment is all set for you to start. | ||
|
||
* Visual Studio Code with the [Python plugin](https://code.visualstudio.com/docs/languages/python) enabled. | ||
* The [LiveServer](https://marketplace.visualstudio.com/items?itemName=ritwickdey.LiveServer) plugin (so you can view your site). | ||
* GitHub [copilot support](https://github.com/features/copilot) (if you have it enabled for your account). | ||
|
||
### Create your PyScript app | ||
|
||
1. Create a repository from this template. Use this | ||
[create repo link](https://github.com/ntoll/codespaces-project-template-pyscript/generate). | ||
Select the repository owner, provide a name, a description if you'd like and | ||
if you'd like the new repository to be public or private. | ||
1. Before creating the Codespace, enable GitHub Copilot for your account. | ||
1. Navigate to the main page of the newly created repository. | ||
3. Under the repository name, use the Code drop-down menu, and in the | ||
Codespaces tab, select "Create codespace on main". | ||
4. Wait as GitHub initializes the Codespace. | ||
5. When complete you will see your Codespace load with a terminal section at | ||
the bottom. Codespaces will install all the required extensions in your | ||
container. Once the package installs are completed, you'll be able to start | ||
editing and start a LiveServer to see your site. | ||
|
||
## 🏃 Deploy your web application | ||
|
||
Project includes the setup needed for you to deploy **FREE** to either | ||
[Azure Static Web Apps](https://azure.microsoft.com/products/app-service/static/?WT.mc_id=academic-79839-sagibbon) | ||
_**or**_ [GitHub Pages](https://pages.github.com/)</a>. Instructions are | ||
included below for Azure. The following YouTube video demonstrates how to get | ||
your Codespace up and running, then deployed to GitHub Pages in under two | ||
minutes: | ||
|
||
[data:image/s3,"s3://crabby-images/d5bb2/d5bb27371b29ebd6465fe79d2ac9906bc79f9a86" alt="PyScript to Github pages in 2 minutes."](https://www.youtube.com/watch?v=dmIWFcJ2UTI) | ||
|
||
### Azure Static Web Apps | ||
|
||
[Azure Static Web Apps](https://azure.microsoft.com/products/app-service/static/?WT.mc_id=academic-79839-sagibbon) | ||
is Microsoft's hosting solution for static sites (or sites that are rendered in | ||
the user's browser, not on a server) through Azure. This service provides | ||
additional opportunities to expand your site through Azure Functions, | ||
authentication, staging versions and more. | ||
|
||
You'll need both Azure and GitHub accounts to deploy your web application. If | ||
you don't yet have an Azure account you can create it from within during the | ||
deploy process, or from below links: | ||
|
||
* [Create a (no Credit Card required) Azure For Students account](https://azure.microsoft.com/free/students/?WT.mc_id=academic-79839-sagibbon) | ||
* [Create a new Azure account](https://azure.microsoft.com/?WT.mc_id=academic-79839-sagibbon) | ||
|
||
With your project open in Codespaces: | ||
|
||
1. Click Azure icon in the left sidebar. Log in if you are not already, and if | ||
new to Azure, follow the prompts to create your account. | ||
1. From Azure menu click “+” sign and then “Create Static Web App”. | ||
1. If you are not logged into GitHub you will be prompted to log in. If you | ||
have any pending file changes you will then be prompted to commit those | ||
changes. | ||
1. Set your application information when prompted: | ||
1. **Region**: pick the one closest to you | ||
1. **Project structure**: select "React" | ||
1. **Location of application code**: `/` | ||
1. **Build location**: `dist` | ||
1. When complete you will see a notification at the bottom of your screen, and | ||
a new GitHub Action workflow will be added to your project. If you click | ||
“Open Action in GitHub” you will see the action that was created for you, | ||
and it is currently running. | ||
data:image/s3,"s3://crabby-images/8e3d4/8e3d4a92ad04a75de2c2b4439c92780479299f5e" alt="Azure Static Web App deploy" | ||
1. To view the status of your deployment, find your Static Web App resource in | ||
the Azure tab in the VS Code left side bar. | ||
1. Once deployment is complete, you can view your brand new new publicly | ||
accessible application by right clicking on your Static Web App resource and | ||
selecting "Browse Site". | ||
|
||
> **Issues?** When creating your Static Web app, if you are prompted to select | ||
> an Azure subscription and are not able to select a subscription, check the | ||
> "Accounts" tab in VS Code. Make sure to choose the "Grant access to ..." | ||
> options if those options appear. Should you receive the error-message | ||
> "RepositoryToken is invalid. ..." switch to Visual Studio Code for the Web | ||
> (vscode.dev) and repeat the steps there. | ||
> 🤩 **Bonus**: [Setup a custom domain for your Azure Static Web App](https://learn.microsoft.com/en-us/shows/azure-tips-and-tricks-static-web-apps/how-to-set-up-a-custom-domain-name-in-azure-static-web-apps-10-of-16--azure-tips-and-tricks-static-w/?WT.mc_id=academic-79839-sagibbon) | ||
## 🔎 Found an issue or have an idea for improvement? | ||
Help us make this template repository better by [letting us know and opening an issue!](/../../issues/new). |
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 @@ | ||
{} |
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,20 @@ | ||
<!DOCTYPE html> | ||
<html lang="en"> | ||
<head> | ||
<script src="/mini-coi.js" scope="./"></script> | ||
<title>PyScript Application Template</title> | ||
|
||
<!-- Recommended meta tags --> | ||
<meta charset="UTF-8"> | ||
<meta name="viewport" content="width=device-width,initial-scale=1.0"> | ||
|
||
<!-- PyScript CSS --> | ||
<link rel="stylesheet" href="https://pyscript.net/releases/2024.6.1/core.css"> | ||
|
||
<!-- This script tag bootstraps PyScript --> | ||
<script type="module" src="https://pyscript.net/releases/2024.6.1/core.js"></script> | ||
</head> | ||
<body> | ||
<script type="mpy" src="./main.py" config="./config.json" terminal></script> | ||
</body> | ||
</html> |
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 @@ | ||
print("Hello, world!") |
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,28 @@ | ||
/*! coi-serviceworker v0.1.7 - Guido Zuidhof and contributors, licensed under MIT */ | ||
/*! mini-coi - Andrea Giammarchi and contributors, licensed under MIT */ | ||
(({ document: d, navigator: { serviceWorker: s } }) => { | ||
if (d) { | ||
const { currentScript: c } = d; | ||
s.register(c.src, { scope: c.getAttribute('scope') || '.' }).then(r => { | ||
r.addEventListener('updatefound', () => location.reload()); | ||
if (r.active && !s.controller) location.reload(); | ||
}); | ||
} | ||
else { | ||
addEventListener('install', () => skipWaiting()); | ||
addEventListener('activate', e => e.waitUntil(clients.claim())); | ||
addEventListener('fetch', e => { | ||
const { request: r } = e; | ||
if (r.cache === 'only-if-cached' && r.mode !== 'same-origin') return; | ||
e.respondWith(fetch(r).then(r => { | ||
const { body, status, statusText } = r; | ||
if (!status || status > 399) return r; | ||
const h = new Headers(r.headers); | ||
h.set('Cross-Origin-Opener-Policy', 'same-origin'); | ||
h.set('Cross-Origin-Embedder-Policy', 'require-corp'); | ||
h.set('Cross-Origin-Resource-Policy', 'cross-origin'); | ||
return new Response(body, { status, statusText, headers: h }); | ||
})); | ||
}); | ||
} | ||
})(self); |