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
|
||||
# The base URL for the OpenCand API
|
||||
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 \
|
||||
--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 \
|
||||
-t "${{ env.IMAGE_FRONTEND }}:${TAG}" \
|
||||
.
|
||||
-t "${{ env.IMAGE_FRONTEND }}:${TAG}" .
|
||||
|
||||
docker push "${{ env.IMAGE_FRONTEND }}:${TAG}"
|
||||
|
||||
|
@ -11,6 +11,21 @@ COPY . .
|
||||
ARG 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
|
||||
|
||||
# ─── 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": {
|
||||
"@tailwindcss/postcss": "^4.1.8",
|
||||
"@tailwindcss/vite": "^4.1.8",
|
||||
"firebase": "^11.10.0",
|
||||
"postcss": "^8.5.4",
|
||||
"react": "^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 './index.css'
|
||||
import App from './App.tsx'
|
||||
import './config/firebase.ts'
|
||||
|
||||
createRoot(document.getElementById('root')!).render(
|
||||
<StrictMode>
|
||||
|
Loading…
x
Reference in New Issue
Block a user