Compare commits

..

1 commit

Author SHA1 Message Date
eb7ab07888 chore(calendars.json): Remove unused calendars 2024-01-26 11:07:17 +01:00
8 changed files with 47 additions and 135 deletions

View file

@ -1,18 +1,8 @@
{ {
"tree": { "tree": {
"Rentrée": {
"Évènements pour les masteriens": {},
"Exchange and international students": {},
"Départements": {},
"Amphis de rentrée": {},
"Divers rentrée": {},
"Associatif divers": {},
"Visites": {}
},
"Délégation Générale Numérique": {},
"COF": { "COF": {
"Évènements (COF)": {},
"Rentrée du COF": {}, "Rentrée du COF": {},
"Évènements (COF)": {},
"Assemblées Générales (COF)": {}, "Assemblées Générales (COF)": {},
"BdA": { "BdA": {
"Évènements (BdA)": {}, "Évènements (BdA)": {},
@ -40,7 +30,6 @@
"Rentrée du BDS": {} "Rentrée du BDS": {}
}, },
"Clubs BDS": { "Clubs BDS": {
"Valse": {},
"Créneaux encadrés": {}, "Créneaux encadrés": {},
"ENSelle": {} "ENSelle": {}
}, },
@ -48,20 +37,10 @@
"Délégation Générale": {}, "Délégation Générale": {},
"K-Fêt": {}, "K-Fêt": {},
"Écocampus": {}, "Écocampus": {},
"La Psychédéliste": {},
"Ambassadeur·rice·s santé": {} "Ambassadeur·rice·s santé": {}
}, },
"sources": { "sources": {
"dgnum-nc": {
"dmo7DgdmTnsMd8zo": {
"name": "Valse"
},
"eEPk6miCzozgPb42": {
"name": "Délégation Générale Numérique",
"short_name": "DGNum",
"color": "#27327a"
}
},
"eleves-ens": { "eleves-ens": {
"qG6jpJPfK37Nw8ZC": { "qG6jpJPfK37Nw8ZC": {
"name": "PLS" "name": "PLS"
@ -81,7 +60,7 @@
"w442JdS5AaQ6czrP": { "w442JdS5AaQ6czrP": {
"name": "Écriv'ENS" "name": "Écriv'ENS"
}, },
"aoazRGFcjHSe4LxG": { "QXGnDTA8GS6r876F": {
"name": "K-Fêt", "name": "K-Fêt",
"color": "#c63b52", "color": "#c63b52",
"default_location": "K-Fêt" "default_location": "K-Fêt"
@ -124,10 +103,6 @@
"short_name": "Jeux", "short_name": "Jeux",
"color": "#5f9ae0" "color": "#5f9ae0"
}, },
"22rQF3gjjz8LifZC": {
"name": "La Psychédéliste",
"short_name": "Psychédéliste"
},
"AfHYkm3gqQ4fRRj5": { "AfHYkm3gqQ4fRRj5": {
"name": "HackENS", "name": "HackENS",
"default_location": "Cave d'hackENS" "default_location": "Cave d'hackENS"
@ -138,8 +113,7 @@
"name": "ENSelle" "name": "ENSelle"
}, },
"K6iGBG47WXaKWs3Q": { "K6iGBG47WXaKWs3Q": {
"name": "Créneaux encadrés", "name": "Créneaux encadrés"
"initial": false
}, },
"TFjE83ASCMK9rfRi": { "TFjE83ASCMK9rfRi": {
"name": "BandarrêtdurgENS", "name": "BandarrêtdurgENS",
@ -168,46 +142,20 @@
"AYNpoC674yAjEmRy": { "AYNpoC674yAjEmRy": {
"name": "L'Hômonerie" "name": "L'Hômonerie"
}, },
"MJf2wnQafbLc2arS": { "TcwNdrs6iyBRxFzk": {
"name": "Arts pla'", "name": "Divers"
"color": "#ffb969"
}, },
"qS7WJwyBaGRQFyX3": { "dJofECeczaGgNiKs": {
"name": "Exchange and international students",
"short_name": "Exchange"
},
"fGmpGCNZrHQkNt7L": {
"name": "Départements",
"short_name": "Dpt",
"initial": false
},
"W6qjeqEzEekNieWk": {
"name": "Évènements pour les masteriens",
"short_name": "Master"
},
"oDPMTBSma2bfo6WS": {
"name": "Amphis de rentrée",
"short_name": "Amphis",
"initial": false
},
"aPXtDmXDxmLxkERg": {
"name": "Divers rentrée",
"short_name": "Rentrée"
},
"fqK3nqqPtXLyo4Y4": {
"name": "Rentrée du COF",
"short_name": "COF"
},
"YQnfcozPDoRgNSBb": {
"name": "Rentrée du BDS", "name": "Rentrée du BDS",
"short_name": "BDS" "short_name": "BDS"
}, },
"tfA32kgc3GM2fH2C": { "7Rwd8JERwBsso7XG": {
"name": "Visites" "name": "Rentrée du COF",
"short_name": "COF"
}, },
"KDNA4GrFMkkJrwNd": { "MJf2wnQafbLc2arS": {
"name": "Associatif divers", "name": "Arts pla'",
"short_name": "Asso" "color": "#ffb969"
} }
} }
} }

View file

@ -6,15 +6,7 @@
"Salle Jean Ibanes (Jourdan, R1-07)": "Salle Jean Ibanes (R1-07)", "Salle Jean Ibanes (Jourdan, R1-07)": "Salle Jean Ibanes (R1-07)",
"Salle Madeleine Rebérioux (Jourdan, R2-02)": "Salle Madeleine Rebérioux (R2-02)", "Salle Madeleine Rebérioux (Jourdan, R2-02)": "Salle Madeleine Rebérioux (R2-02)",
"Salle Marcel Roncayolo (Jourdan, R2-05)": "Salle Marcel Roncayolo (R2-05)", "Salle Marcel Roncayolo (Jourdan, R2-05)": "Salle Marcel Roncayolo (R2-05)",
"Cour des bibliothèques": "Cour du NIR", "Cour des bibliothèques": "Cour du NIR"
"Salle Jaurès": "Amphithéâtre Jaurès",
"Jaurès": "Amphithéâtre Jaurès",
"Dussane": "Salle Dussane",
"Cour aux Ernest": "Cour aux Ernests",
"Restaurant": "Pôt",
"29 rue d'Ulm": "Bâtiment du 29",
"Gymnase": "Gymnase Jean Prévost",
"Pôt (Restaurant)": "Pôt"
}, },
"rooms": { "rooms": {
@ -31,10 +23,6 @@
"Salle Cartan", "Salle Cartan",
"Salle Noether", "Salle Noether",
"Salle Bourbaki", "Salle Bourbaki",
"Petite salle ECLA",
"Salle Reig ECLA",
"Salle Césaire ECLA",
"Salle Beckett",
"Cour aux Ernests", "Cour aux Ernests",
"Cour du NIR", "Cour du NIR",
"Cour Pasteur", "Cour Pasteur",
@ -43,17 +31,11 @@
"Canopée", "Canopée",
"K-Fêt", "K-Fêt",
"Cave d'hackENS", "Cave d'hackENS",
"Gymnase Jean Prévost", "Gymnase"
"Salle d'expression artistique (SEA)",
"Locaux des départements lettres et sciences humaines et sociales"
], ],
"24 rue Lhomond": ["Salle CONF IV"], "24 rue Lhomond": ["Salle CONF IV"],
"29 rue d'Ulm": [ "29 rue d'Ulm": ["Bibliothèque des sciences expérimentales", "Salle Jaurès"],
"Bâtiment du 29",
"Bibliothèque des sciences expérimentales",
"Amphithéâtre Jaurès"],
"Jourdan": [ "Jourdan": [
"Campus de Jourdan",
"Bibliothèque de Jourdan", "Bibliothèque de Jourdan",
"Salle Marcel Roncayolo (R2-05)", "Salle Marcel Roncayolo (R2-05)",
"Salle Madeleine Rebérioux (R2-02)", "Salle Madeleine Rebérioux (R2-02)",

View file

@ -1,44 +1,13 @@
{ pkgs ? import (import ./npins).nixpkgs {} }:
{ {
sources ? import ./npins, production = pkgs.buildNpmPackage {
pkgs ? import sources.nixpkgs { },
}:
let
inherit (pkgs.lib.fileset)
fileFilter
gitTrackedWith
intersection
toSource
;
in
{
package = pkgs.buildNpmPackage {
name = "metis"; name = "metis";
src = ./.;
src = toSource {
root = ./.;
fileset = intersection (gitTrackedWith { } ./.) (
fileFilter ({ name, hasExt, ... }: !(hasExt "nix") && name != "npins") ./.
);
};
npmDepsHash = "sha256-RbjWNVY8KlPP9ajQRnrsWhOZiiyyMGQSY39lmZnTC1I="; npmDepsHash = "sha256-RbjWNVY8KlPP9ajQRnrsWhOZiiyyMGQSY39lmZnTC1I=";
installPhase = '' installPhase = ''
cp -r public $out cp -r public $out
''; '';
}; };
shell = import ./shell.nix { inherit pkgs; };
devShell = pkgs.mkShell { providers = import ./providers.nix;
name = "metis.dev";
packages = [ pkgs.nodejs ];
};
providers = {
eleves-ens = "cloud.eleves.ens.fr";
frama-agenda = "framagenda.org";
dgnum-nc = "cloud.dgnum.eu";
};
} }

View file

@ -3,8 +3,8 @@
"nixpkgs": { "nixpkgs": {
"type": "Channel", "type": "Channel",
"name": "nixpkgs-unstable", "name": "nixpkgs-unstable",
"url": "https://releases.nixos.org/nixpkgs/nixpkgs-24.11pre696114.dfffb2e7a52d/nixexprs.tar.xz", "url": "https://releases.nixos.org/nixpkgs/nixpkgs-23.11pre506449.f465da16626/nixexprs.tar.xz",
"hash": "15dj4hcx5wqcnxwfhh1gx2rpcwyip794bkmv0vpz4f01hibr7wd2" "hash": "14jsw1gv83qjz82384gfhn78sv9m14i1bs5l97xrab26vyi9b5ay"
} }
}, },
"version": 3 "version": 3

7
providers.nix Normal file
View file

@ -0,0 +1,7 @@
let
providers = {
eleves-ens = "cloud.eleves.ens.fr";
frama-agenda = "framagenda.org";
};
in
builtins.mapAttrs (name: value: "https://${value}/remote.php/dav/public-calendars/") providers

View file

@ -1 +1,4 @@
(import ./. { }).devShell { pkgs ? import (import ./npins).nixpkgs {} }:
pkgs.mkShell {
packages = [ pkgs.nodejs ];
}

View file

@ -102,7 +102,6 @@
title: room title: room
})) }))
), ),
filterResourcesWithEvents: true,
height: '100%', height: '100%',
schedulerLicenseKey: 'CC-Attribution-NonCommercial-NoDerivatives', schedulerLicenseKey: 'CC-Attribution-NonCommercial-NoDerivatives',
nowIndicator: true, nowIndicator: true,
@ -206,11 +205,7 @@
<EventModal event={$event} open={openModal} {toggle} /> <EventModal event={$event} open={openModal} {toggle} />
<script <script defer data-domain="calendrier.dgnum.eu" src="https://analytics.dgnum.eu/js/script.js"></script>
defer
data-domain="calendrier.dgnum.eu"
src="https://analytics.dgnum.eu/js/script.js"
></script>
</div> </div>
<style> <style>

View file

@ -190,6 +190,14 @@ function fcEventFromjCalEvent(cal) {
} }
} }
function mkEventsFromCalendar(id, cal) {
return fetchCalendar(id, cal).then(calendar => {
if (calendar[0] !== 'vcalendar') return
const cal = new Calendar(id, calendar)
return cal.events.map(fcEventFromjCalEvent(cal))
})
}
export function mkSource(name) { export function mkSource(name) {
const calendarId = calendarsByName[name] const calendarId = calendarsByName[name]
if (!calendarId) return null if (!calendarId) return null