Skip to content

Commit b229045

Browse files
committed
Initial Commit
0 parents  commit b229045

File tree

155 files changed

+10836
-0
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

155 files changed

+10836
-0
lines changed

.eslintrc.cjs

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
module.exports = {
2+
root: true,
3+
env: { browser: true, es2020: true },
4+
extends: [
5+
"eslint:recommended",
6+
"plugin:@typescript-eslint/recommended",
7+
"plugin:react-hooks/recommended",
8+
"prettier",
9+
],
10+
ignorePatterns: ["dist", ".eslintrc.cjs"],
11+
parser: "@typescript-eslint/parser",
12+
plugins: ["react-refresh", "import", "prettier"],
13+
rules: {
14+
"prettier/prettier": "warn",
15+
"react-refresh/only-export-components": [
16+
"warn",
17+
{ allowConstantExport: true },
18+
],
19+
"import/consistent-type-specifier-style": ["error", "prefer-top-level"],
20+
},
21+
};

.gitattributes

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
* text=auto eol=lf

.gitignore

+28
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
# Logs
2+
logs
3+
*.log
4+
npm-debug.log*
5+
yarn-debug.log*
6+
yarn-error.log*
7+
pnpm-debug.log*
8+
lerna-debug.log*
9+
10+
node_modules
11+
dist
12+
dist-ssr
13+
*.local
14+
15+
# Editor directories and files
16+
.vscode/*
17+
!.vscode/extensions.json
18+
!.vscode/settings.json
19+
.idea
20+
.DS_Store
21+
*.suo
22+
*.ntvs*
23+
*.njsproj
24+
*.sln
25+
*.sw?
26+
27+
# Optional stylelint cache
28+
.stylelintcache

.husky/pre-commit

+8
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
#!/usr/bin/env sh
2+
. "$(dirname -- "$0")/_/husky.sh"
3+
4+
pnpm install
5+
pnpm typecheck
6+
pnpm lint
7+
pnpm stylelint
8+
pnpm format

.prettierrc.cjs

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
/** @typedef {import("prettier").Config} PrettierConfig */
2+
/** @typedef {import("@ianvs/prettier-plugin-sort-imports").PluginConfig} SortImportsConfig */
3+
4+
/** @type { PrettierConfig | SortImportsConfig } */
5+
module.exports = {
6+
singleQuote: false,
7+
trailingComma: "all",
8+
plugins: ["@ianvs/prettier-plugin-sort-imports"],
9+
importOrder: [
10+
"^(react/(.*)$)|^(react$)",
11+
"<THIRD_PARTY_MODULES>",
12+
"",
13+
"^@/",
14+
"^[../]",
15+
"^[./]",
16+
],
17+
importOrderParserPlugins: ["typescript", "jsx", "decorators-legacy"],
18+
};

.stylelintrc.json

+35
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
{
2+
"extends": ["stylelint-config-recommended", "stylelint-config-standard-scss"],
3+
"plugins": ["stylelint-order"],
4+
"rules": {
5+
"at-rule-no-unknown": [
6+
true,
7+
{
8+
"ignoreAtRules": [
9+
"use",
10+
"extend",
11+
"at-root",
12+
"debug",
13+
"warn",
14+
"error",
15+
"if",
16+
"else",
17+
"for",
18+
"each",
19+
"while",
20+
"mixin",
21+
"include",
22+
"content",
23+
"return",
24+
"function"
25+
]
26+
}
27+
],
28+
"selector-pseudo-class-no-unknown": [
29+
true,
30+
{
31+
"ignorePseudoClasses": ["global"]
32+
}
33+
]
34+
}
35+
}

.vscode/extensions.json

+7
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
{
2+
"recommendations": [
3+
"dbaeumer.vscode-eslint",
4+
"esbenp.prettier-vscode",
5+
"stylelint.vscode-stylelint"
6+
]
7+
}

.vscode/settings.json

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
{
2+
"stylelint.validate": ["css", "scss"],
3+
"eslint.rules.customizations": [{ "rule": "*", "severity": "warn" }],
4+
"editor.codeActionsOnSave": {
5+
"source.fixAll.eslint": "explicit",
6+
"source.fixAll.stylelint": "explicit"
7+
},
8+
"editor.defaultFormatter": "esbenp.prettier-vscode",
9+
"editor.formatOnSave": true
10+
}

CODE_OF_CONDUCT.md

+132
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,132 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
We as members, contributors, and leaders pledge to make participation in our
6+
community a harassment-free experience for everyone, regardless of age, body
7+
size, visible or invisible disability, ethnicity, sex characteristics, gender
8+
identity and expression, level of experience, education, socio-economic status,
9+
nationality, personal appearance, race, caste, color, religion, or sexual identity
10+
and orientation.
11+
12+
We pledge to act and interact in ways that contribute to an open, welcoming,
13+
diverse, inclusive, and healthy community.
14+
15+
## Our Standards
16+
17+
Examples of behavior that contributes to a positive environment for our
18+
community include:
19+
20+
- Demonstrating empathy and kindness toward other people
21+
- Being respectful of differing opinions, viewpoints, and experiences
22+
- Giving and gracefully accepting constructive feedback
23+
- Accepting responsibility and apologizing to those affected by our mistakes,
24+
and learning from the experience
25+
- Focusing on what is best not just for us as individuals, but for the
26+
overall community
27+
28+
Examples of unacceptable behavior include:
29+
30+
- The use of sexualized language or imagery, and sexual attention or
31+
advances of any kind
32+
- Trolling, insulting or derogatory comments, and personal or political attacks
33+
- Public or private harassment
34+
- Publishing others' private information, such as a physical or email
35+
address, without their explicit permission
36+
- Other conduct which could reasonably be considered inappropriate in a
37+
professional setting
38+
39+
## Enforcement Responsibilities
40+
41+
Community leaders are responsible for clarifying and enforcing our standards of
42+
acceptable behavior and will take appropriate and fair corrective action in
43+
response to any behavior that they deem inappropriate, threatening, offensive,
44+
or harmful.
45+
46+
Community leaders have the right and responsibility to remove, edit, or reject
47+
comments, commits, code, wiki edits, issues, and other contributions that are
48+
not aligned to this Code of Conduct, and will communicate reasons for moderation
49+
decisions when appropriate.
50+
51+
## Scope
52+
53+
This Code of Conduct applies within all community spaces, and also applies when
54+
an individual is officially representing the community in public spaces.
55+
Examples of representing our community include using an official e-mail address,
56+
posting via an official social media account, or acting as an appointed
57+
representative at an online or offline event.
58+
59+
## Enforcement
60+
61+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
62+
reported to the community leaders responsible for enforcement at
63+
64+
All complaints will be reviewed and investigated promptly and fairly.
65+
66+
All community leaders are obligated to respect the privacy and security of the
67+
reporter of any incident.
68+
69+
## Enforcement Guidelines
70+
71+
Community leaders will follow these Community Impact Guidelines in determining
72+
the consequences for any action they deem in violation of this Code of Conduct:
73+
74+
### 1. Correction
75+
76+
**Community Impact**: Use of inappropriate language or other behavior deemed
77+
unprofessional or unwelcome in the community.
78+
79+
**Consequence**: A private, written warning from community leaders, providing
80+
clarity around the nature of the violation and an explanation of why the
81+
behavior was inappropriate. A public apology may be requested.
82+
83+
### 2. Warning
84+
85+
**Community Impact**: A violation through a single incident or series
86+
of actions.
87+
88+
**Consequence**: A warning with consequences for continued behavior. No
89+
interaction with the people involved, including unsolicited interaction with
90+
those enforcing the Code of Conduct, for a specified period of time. This
91+
includes avoiding interactions in community spaces as well as external channels
92+
like social media. Violating these terms may lead to a temporary or
93+
permanent ban.
94+
95+
### 3. Temporary Ban
96+
97+
**Community Impact**: A serious violation of community standards, including
98+
sustained inappropriate behavior.
99+
100+
**Consequence**: A temporary ban from any sort of interaction or public
101+
communication with the community for a specified period of time. No public or
102+
private interaction with the people involved, including unsolicited interaction
103+
with those enforcing the Code of Conduct, is allowed during this period.
104+
Violating these terms may lead to a permanent ban.
105+
106+
### 4. Permanent Ban
107+
108+
**Community Impact**: Demonstrating a pattern of violation of community
109+
standards, including sustained inappropriate behavior, harassment of an
110+
individual, or aggression toward or disparagement of classes of individuals.
111+
112+
**Consequence**: A permanent ban from any sort of public interaction within
113+
the community.
114+
115+
## Attribution
116+
117+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118+
version 2.0, available at
119+
[https://www.contributor-covenant.org/version/2/0/code_of_conduct.html][v2.0].
120+
121+
Community Impact Guidelines were inspired by
122+
[Mozilla's code of conduct enforcement ladder][Mozilla CoC].
123+
124+
For answers to common questions about this code of conduct, see the FAQ at
125+
[https://www.contributor-covenant.org/faq][FAQ]. Translations are available
126+
at [https://www.contributor-covenant.org/translations][translations].
127+
128+
[homepage]: https://www.contributor-covenant.org
129+
[v2.0]: https://www.contributor-covenant.org/version/2/0/code_of_conduct.html
130+
[Mozilla CoC]: https://github.com/mozilla/diversity
131+
[FAQ]: https://www.contributor-covenant.org/faq
132+
[translations]: https://www.contributor-covenant.org/translations

CONTRIBUTING.md

+51
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,51 @@
1+
# ABC Virtual Background Maker Contributing Guide
2+
3+
Hi! We're really excited that you're interested in contributing to ABC Virtual Background Maker! Before submitting your contribution, please read through the following guide.
4+
5+
## Repo Setup
6+
7+
To develop locally, fork the repository and clone it in your local machine. The package manager used to install and link dependencies must be [pnpm](https://pnpm.io/).
8+
9+
To develop and test:
10+
11+
1. Run `pnpm i` in root folder.
12+
13+
2. (Optional. Run `pnpm run read-files` if you want to update app.config.json with new images)
14+
15+
3. Run `pnpm run dev` in root folder.
16+
17+
4. Dev server will be running at
18+
19+
```bash
20+
http://localhost:5173/
21+
```
22+
23+
## Pull Request Guidelines
24+
25+
- Checkout a topic branch from a base branch (e.g. `main`), and merge back against that branch.
26+
- Make sure husky pre-commit hook pass!
27+
- If adding a new feature:
28+
29+
- Provide a convincing reason to add this feature. Ideally, you should open a suggestion issue first, and have it approved before working on it.
30+
31+
- If fixing a bug:
32+
33+
- If you are resolving a special issue, add `fix #issueId` in your PR title.
34+
- Provide a detailed description of the bug and how you fix it in the PR.
35+
36+
## Maintenance Guidelines
37+
38+
> The following section is mostly for maintainers who have commit access, but it's helpful to go through if you intend to make non-trivial contributions to the codebase.
39+
40+
### Think Before Adding a Dependency
41+
42+
- Most deps should be added to `devDependencies`.
43+
- Avoid deps with large transitive dependencies that result in bloated size compared to the functionality it provides.
44+
45+
### Ensure Type Support
46+
47+
ABC Virtual Background Maker aims to be fully usable as a dependency in a TypeScript project.
48+
49+
## Deploy Demo
50+
51+
Once the PR merged into base branch (e.g. `main`), it will be deployed by automatically.

Dockerfile

+32
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
# Use the Nginx image from Docker Hub
2+
FROM nginx:1.25.3-alpine-slim
3+
4+
# Install Node.js and npm
5+
RUN apk add --no-cache nodejs npm
6+
7+
# Set the working directory for the build stage
8+
WORKDIR /app
9+
10+
# Copy application source code into the container
11+
COPY . .
12+
13+
# Install application's dependencies and build
14+
RUN npm install
15+
RUN npm run read-files
16+
RUN npm run build
17+
18+
# Set the working directory in the container
19+
WORKDIR /usr/share/nginx/html
20+
21+
# Remove default Nginx static assets
22+
RUN rm -rf ./*
23+
24+
# Copy the static content to the Nginx web root directory
25+
RUN cp -r /app/dist .
26+
RUN cp -r /app/backgrounds backgrounds
27+
28+
# Expose port 80 to the outside once the container has launched
29+
EXPOSE 80
30+
31+
# Start Nginx and keep it running in the foreground
32+
CMD ["nginx", "-g", "daemon off;"]

0 commit comments

Comments
 (0)