add Firebase integration and configuration
All checks were successful
Frontend Build and Deploy / build (push) Successful in 32s
All checks were successful
Frontend Build and Deploy / build (push) Successful in 32s
This commit is contained in:
parent
3084a8e27d
commit
8090fd13a3
@ -1,3 +1,11 @@
|
|||||||
# OpenCand API Configuration
|
# OpenCand API Configuration
|
||||||
# The base URL for the OpenCand API
|
# The base URL for the OpenCand API
|
||||||
VITE_API_BASE_URL=https://api.example.com
|
VITE_API_BASE_URL=https://api.example.com
|
||||||
|
|
||||||
|
VITE_FIREBASE_API_KEY="your_api_key"
|
||||||
|
VITE_FIREBASE_AUTH_DOMAIN="your_auth_domain"
|
||||||
|
VITE_FIREBASE_PROJECT_ID="your_project_id"
|
||||||
|
VITE_FIREBASE_STORAGE_BUCKET="your_storage_bucket"
|
||||||
|
VITE_FIREBASE_MESSAGING_SENDER_ID="your_messaging_sender_id"
|
||||||
|
VITE_FIREBASE_APP_ID="your_app_id"
|
||||||
|
VITE_FIREBASE_MEASUREMENT_ID="your_measurement_id"
|
||||||
|
@ -32,9 +32,15 @@ jobs:
|
|||||||
|
|
||||||
docker build \
|
docker build \
|
||||||
--build-arg VITE_API_BASE_URL="https://api.opencand.ivanch.me" \
|
--build-arg VITE_API_BASE_URL="https://api.opencand.ivanch.me" \
|
||||||
|
--build-arg VITE_FIREBASE_API_KEY="${{ secrets.VITE_FIREBASE_API_KEY }}" \
|
||||||
|
--build-arg VITE_FIREBASE_AUTH_DOMAIN="${{ secrets.VITE_FIREBASE_AUTH_DOMAIN }}" \
|
||||||
|
--build-arg VITE_FIREBASE_PROJECT_ID="${{ secrets.VITE_FIREBASE_PROJECT_ID }}" \
|
||||||
|
--build-arg VITE_FIREBASE_STORAGE_BUCKET="${{ secrets.VITE_FIREBASE_STORAGE_BUCKET }}" \
|
||||||
|
--build-arg VITE_FIREBASE_MESSAGING_SENDER_ID="${{ secrets.VITE_FIREBASE_MESSAGING_SENDER_ID }}" \
|
||||||
|
--build-arg VITE_FIREBASE_APP_ID="${{ secrets.VITE_FIREBASE_APP_ID }}" \
|
||||||
|
--build-arg VITE_FIREBASE_MEASUREMENT_ID="${{ secrets.VITE_FIREBASE_MEASUREMENT_ID }}" \
|
||||||
--file OpenCand.UI.dockerfile \
|
--file OpenCand.UI.dockerfile \
|
||||||
-t "${{ env.IMAGE_FRONTEND }}:${TAG}" \
|
-t "${{ env.IMAGE_FRONTEND }}:${TAG}" .
|
||||||
.
|
|
||||||
|
|
||||||
docker push "${{ env.IMAGE_FRONTEND }}:${TAG}"
|
docker push "${{ env.IMAGE_FRONTEND }}:${TAG}"
|
||||||
|
|
||||||
|
@ -11,6 +11,21 @@ COPY . .
|
|||||||
ARG VITE_API_BASE_URL
|
ARG VITE_API_BASE_URL
|
||||||
ENV VITE_API_BASE_URL=${VITE_API_BASE_URL}
|
ENV VITE_API_BASE_URL=${VITE_API_BASE_URL}
|
||||||
|
|
||||||
|
ARG VITE_FIREBASE_API_KEY
|
||||||
|
ENV VITE_FIREBASE_API_KEY=${VITE_FIREBASE_API_KEY}
|
||||||
|
ARG VITE_FIREBASE_AUTH_DOMAIN
|
||||||
|
ENV VITE_FIREBASE_AUTH_DOMAIN=${VITE_FIREBASE_AUTH_DOMAIN}
|
||||||
|
ARG VITE_FIREBASE_PROJECT_ID
|
||||||
|
ENV VITE_FIREBASE_PROJECT_ID=${VITE_FIREBASE_PROJECT_ID}
|
||||||
|
ARG VITE_FIREBASE_STORAGE_BUCKET
|
||||||
|
ENV VITE_FIREBASE_STORAGE_BUCKET=${VITE_FIREBASE_STORAGE_BUCKET}
|
||||||
|
ARG VITE_FIREBASE_MESSAGING_SENDER_ID
|
||||||
|
ENV VITE_FIREBASE_MESSAGING_SENDER_ID=${VITE_FIREBASE_MESSAGING_SENDER_ID}
|
||||||
|
ARG VITE_FIREBASE_APP_ID
|
||||||
|
ENV VITE_FIREBASE_APP_ID=${VITE_FIREBASE_APP_ID}
|
||||||
|
ARG VITE_FIREBASE_MEASUREMENT_ID
|
||||||
|
ENV VITE_FIREBASE_MEASUREMENT_ID=${VITE_FIREBASE_MEASUREMENT_ID}
|
||||||
|
|
||||||
RUN yarn build
|
RUN yarn build
|
||||||
|
|
||||||
# ─── Stage 2: Serve ────────────────────────────────────────────────────────
|
# ─── Stage 2: Serve ────────────────────────────────────────────────────────
|
||||||
|
996
package-lock.json
generated
996
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -12,6 +12,7 @@
|
|||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@tailwindcss/postcss": "^4.1.8",
|
"@tailwindcss/postcss": "^4.1.8",
|
||||||
"@tailwindcss/vite": "^4.1.8",
|
"@tailwindcss/vite": "^4.1.8",
|
||||||
|
"firebase": "^11.10.0",
|
||||||
"postcss": "^8.5.4",
|
"postcss": "^8.5.4",
|
||||||
"react": "^19.1.0",
|
"react": "^19.1.0",
|
||||||
"react-dom": "^19.1.0",
|
"react-dom": "^19.1.0",
|
||||||
|
18
src/config/firebase.ts
Normal file
18
src/config/firebase.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
|
||||||
|
import { initializeApp } from "firebase/app";
|
||||||
|
import { getAnalytics } from "firebase/analytics";
|
||||||
|
|
||||||
|
const firebaseConfig = {
|
||||||
|
apiKey: import.meta.env.VITE_FIREBASE_API_KEY,
|
||||||
|
authDomain: import.meta.env.VITE_FIREBASE_AUTH_DOMAIN,
|
||||||
|
projectId: import.meta.env.VITE_FIREBASE_PROJECT_ID,
|
||||||
|
storageBucket: import.meta.env.VITE_FIREBASE_STORAGE_BUCKET,
|
||||||
|
messagingSenderId: import.meta.env.VITE_FIREBASE_MESSAGING_SENDER_ID,
|
||||||
|
appId: import.meta.env.VITE_FIREBASE_APP_ID,
|
||||||
|
measurementId: import.meta.env.VITE_FIREBASE_MEASUREMENT_ID
|
||||||
|
};
|
||||||
|
|
||||||
|
const app = initializeApp(firebaseConfig);
|
||||||
|
const analytics = getAnalytics(app);
|
||||||
|
|
||||||
|
export { app, analytics };
|
@ -3,6 +3,7 @@ import { createRoot } from 'react-dom/client'
|
|||||||
import { BrowserRouter } from 'react-router-dom'
|
import { BrowserRouter } from 'react-router-dom'
|
||||||
import './index.css'
|
import './index.css'
|
||||||
import App from './App.tsx'
|
import App from './App.tsx'
|
||||||
|
import './config/firebase.ts'
|
||||||
|
|
||||||
createRoot(document.getElementById('root')!).render(
|
createRoot(document.getElementById('root')!).render(
|
||||||
<StrictMode>
|
<StrictMode>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user