diff --git a/pages/_meta.json b/pages/_meta.json
index 7f4cf53..82f11d5 100644
--- a/pages/_meta.json
+++ b/pages/_meta.json
@@ -84,6 +84,10 @@
"corporate-dashboard": {
"title": "Corporate Dashboard",
"href": "/special-projects/corporate-dashboard"
+ },
+ "centralized-calendar": {
+ "title": "Centralized Calendar",
+ "href": "/special-projects/centralized-calendar"
}
}
}
diff --git a/pages/special-projects/_meta.json b/pages/special-projects/_meta.json
index 50a22e4..0ad1031 100644
--- a/pages/special-projects/_meta.json
+++ b/pages/special-projects/_meta.json
@@ -3,5 +3,10 @@
"title": "Corporate Dashboard",
"type": "page",
"display": "hidden"
+ },
+ "centralized-calendar": {
+ "title": "Centralized Calendar",
+ "type": "page",
+ "display": "hidden"
}
}
diff --git a/pages/special-projects/centralized-calendar/_meta.json b/pages/special-projects/centralized-calendar/_meta.json
new file mode 100644
index 0000000..0dcdbd3
--- /dev/null
+++ b/pages/special-projects/centralized-calendar/_meta.json
@@ -0,0 +1,24 @@
+{
+ "index": {
+ "title": "Overview"
+ },
+ "end-user": {
+ "title": "End User Guide"
+ },
+ "---": {
+ "type": "separator"
+ },
+ "-- Technical Documentation": {
+ "type": "separator",
+ "title": "Technical Documentation"
+ },
+ "getting-started": {
+ "title": "Getting Started"
+ },
+ "api-reference": {
+ "title": "API Reference"
+ },
+ "architecture": {
+ "title": "Architecture"
+ }
+}
diff --git a/pages/special-projects/centralized-calendar/api-reference.mdx b/pages/special-projects/centralized-calendar/api-reference.mdx
new file mode 100644
index 0000000..a24360d
--- /dev/null
+++ b/pages/special-projects/centralized-calendar/api-reference.mdx
@@ -0,0 +1,3 @@
+import { Steps, Callout } from "nextra/components";
+
+# API Reference
diff --git a/pages/special-projects/centralized-calendar/architecture.mdx b/pages/special-projects/centralized-calendar/architecture.mdx
new file mode 100644
index 0000000..f4f0f77
--- /dev/null
+++ b/pages/special-projects/centralized-calendar/architecture.mdx
@@ -0,0 +1,5 @@
+import { Steps, Callout } from "nextra/components";
+
+# Architecture
+
+{/* Include details on application architecture and decisions such as only updating future events. */}
diff --git a/pages/special-projects/centralized-calendar/end-user.mdx b/pages/special-projects/centralized-calendar/end-user.mdx
new file mode 100644
index 0000000..efc3ddf
--- /dev/null
+++ b/pages/special-projects/centralized-calendar/end-user.mdx
@@ -0,0 +1,75 @@
+import { Callout } from "nextra/components";
+
+# End User Guide
+
+
+ This page is intended for members of other ICS organization to provide information on how to
+ participate in the ics-centralized-calendar project.
+
+
+{/* Include a breif introduction of what is Centralized Calendar Project is and steps to get a the required Google Calendar URL. */}
+
+## Introduction
+
+The `ics-centralized-calendar` project is an easy to use API meant to provide centralized access to all ICS calendars, offering options for selecting specific clubs and output formats (ICS or JSON).
+
+## Steps to Add Your Google Calendar URL
+
+To participate in the ics-centralized-calendar project, follow these steps to share your Google Calendar URL:
+
+1. **Open Google Calendar:**
+
+ - Go to [Google Calendar](https://calendar.google.com).
+
+2. **Access Calendar Settings:**
+
+ - On the left sidebar, hover over the calendar you want to share.
+ - Click on the three vertical dots that appear and select "Settings and sharing."
+
+3. **Get the Shareable Link:**
+
+ - Scroll down to the "Access permissions for events" section.
+ - Check the box that says "Make available to public."
+ - Scroll further down to the "Integrate calendar" section.
+ - Copy the "Public address in iCal format" link.
+
+4. **Submit Your Calendar Link:**
+ - Send the copied calendar link to our project team leads ([Alex](https://github.com/alexanderl19), [Eddy](https://github.com/ecxyzzy)).
+
+
+ Remember to make sure your calendar is set to public so that we can access and integrate your
+ events.
+
+
+{/* Include a breif FAQ with information on how event updates work. */}
+
+## FAQ
+
+### How do event updates work?
+
+Once your calendar link is submitted and integrated into the ics-centralized-calendar, your events will be automatically updated every 6 hours. This ensures that any new events or changes to existing events that have not happened yet are reflected in the ics-centralized-calendar quickly.
+
+### What event information is required?
+
+Every event should have the following fields for best clarity and organization, these fields are usually required by default when creating an event in Google Calendar:
+
+- **Title:** A clear description of the event.
+- **Date and Time:** A start and end time that is input through the google calendar GUI.
+- **Description:** Include details such as location, agenda, and contact information.
+
+### How can I make changes to my events?
+
+Simply update your events in your Google Calendar. The changes will be reflected in the ics-centralized-calendar during the next update cycle.
+
+### How do I change or remove my club's calendar from the centralized calendar?
+
+Contact our project leads([Alex](https://github.com/alexanderl19), [Eddy](https://github.com/ecxyzzy)) to change or remove your calendar URL from the ics-centralized-calendar.
+
+### Who do I contact for support?
+
+If you have any questions or need assistance, contact our project leads ([Alex](https://github.com/alexanderl19), [Eddy](https://github.com/ecxyzzy)).
+
+
+ By participating in the ics-centralized-calendar project, you help create a more organized and
+ informed ICS community. Thank you for your contribution!
+
diff --git a/pages/special-projects/centralized-calendar/getting-started.mdx b/pages/special-projects/centralized-calendar/getting-started.mdx
new file mode 100644
index 0000000..0c723c1
--- /dev/null
+++ b/pages/special-projects/centralized-calendar/getting-started.mdx
@@ -0,0 +1,69 @@
+import { Steps, Callout } from "nextra/components";
+
+# Getting Started
+
+
+ This project is currently private, and only available to ICSSC Projects internal members.
+
+
+## Setup
+
+
+### Clone Repository
+
+```bash
+git clone https://github.com/icssc/ics-centralized-calendar.git
+cd corporate-dashboard
+```
+
+### Install Dependencies
+
+
+ This project uses pnpm. Use pnpm to install dependencies to avoid mismatching lockfiles.
+
+
+```bash
+pnpm install
+```
+
+### Setup IAM Credentials _Optional_
+
+This is an optional step only available for ICSSC Projects internal members. If this is your first time setting up an ICSSC project using SST, request credentials from your project lead. If you've already set up IAM Credentials for another ICSSC project, this step is not necessary.
+
+```
+[default]
+aws_access_key_id =
+aws_secret_access_key =
+```
+
+### Setup postgres environment variable
+
+You can request database credentials from you project lead or you can just create your own database server on your local machine for local development purposes. Whichever you choose, you will need to set the `DATABASE_URL` environment variable in a `.env` file in the root of the project. The `.env` file should look like this:
+
+```
+DATABASE_URL=postgres://yourusername:yourpassword@localhost:5432/calendar
+```
+
+
+
+## Commands
+
+### Dev
+
+#### With SST
+
+```bash
+pnpm dev
+```
+
+#### Without SST
+
+```bash
+pnpm exec next dev
+```
+
+### Build
+
+```bash
+pnpm build
+```
diff --git a/pages/special-projects/centralized-calendar/index.md b/pages/special-projects/centralized-calendar/index.md
new file mode 100644
index 0000000..3a66577
--- /dev/null
+++ b/pages/special-projects/centralized-calendar/index.md
@@ -0,0 +1,10 @@
+# Centralized Calendar
+
+The ics-centralized-calendar project is designed to enhance collaboration and cohesiveness within the ICS community. It is an API that aggregates calendar information from participating ICS clubs and provides easy access to events in both ICS and JSON formats.
+
+## Goals
+
+- **Foster Community:** Strengthen the sense of community within ICS.
+- **Enhance Cohesiveness:** Promote transparency and cooperation between clubs.
+- **Inform Students:** Provide ICS students with clear and accessible information about club events.
+- **Streamline Event Viewing:** Simplify the process of viewing events from each club.