{"id":21082515,"url":"https://github.com/code9g/ohmyfood","last_synced_at":"2026-04-29T23:02:41.908Z","repository":{"id":197593419,"uuid":"698863576","full_name":"code9g/ohmyfood","owner":"code9g","description":"Projet 3 de la formation \"Développeur JavaScript / React\" de OpenClassRooms","archived":false,"fork":false,"pushed_at":"2024-08-14T05:19:06.000Z","size":8963,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-10-13T19:37:25.206Z","etag":null,"topics":["animation-css","css3","git","github","html5","openclassrooms","sass","school-project"],"latest_commit_sha":null,"homepage":"https://code9g.github.io/ohmyfood/","language":"HTML","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/code9g.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2023-10-01T07:50:05.000Z","updated_at":"2024-08-14T05:19:09.000Z","dependencies_parsed_at":"2023-10-17T06:22:07.414Z","dependency_job_id":"5e214115-708c-4298-ba48-7fa59f0c8c11","html_url":"https://github.com/code9g/ohmyfood","commit_stats":null,"previous_names":["code9g/ohmyfood"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/code9g/ohmyfood","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/code9g%2Fohmyfood","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/code9g%2Fohmyfood/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/code9g%2Fohmyfood/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/code9g%2Fohmyfood/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/code9g","download_url":"https://codeload.github.com/code9g/ohmyfood/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/code9g%2Fohmyfood/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279016928,"owners_count":26085888,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-13T02:00:06.723Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["animation-css","css3","git","github","html5","openclassrooms","sass","school-project"],"created_at":"2024-11-19T20:14:23.578Z","updated_at":"2025-10-13T19:37:25.840Z","avatar_url":"https://github.com/code9g.png","language":"HTML","funding_links":[],"categories":[],"sub_categories":[],"readme":"# ohmyfood\n\n![HTML5](https://img.shields.io/badge/html5-%23E34F26.svg?style=for-the-badge\u0026logo=html5\u0026logoColor=white)\n![CSS3](https://img.shields.io/badge/css3-%231572B6.svg?style=for-the-badge\u0026logo=css3\u0026logoColor=white)\n![JavaScript](https://img.shields.io/badge/javascript-%23323330.svg?style=for-the-badge\u0026logo=javascript\u0026logoColor=%23F7DF1E)\n\nProjet 3 du parcours \"**Développeur d'application - JavaScript React**\" chez [OpenClassroom](https://openclassrooms.com/fr/).\n\nDynamisez une page web avec des animations CSS\n\n![home](./images/home.png)\n\n# Description\n\nVous avez intégré Ohmyfood en tant que développeur junior. Il s’agit d’une jeune startup qui voudrait s'imposer sur le marché de la restauration. Déjà présente à New-York, elle souhaite désormais faire sa place à Paris.\n\n# Objectifs\n\n- Intégrer une maquette (depuis Figma),\n- Dynamiser une page web avec des animations en CSS.\n\n## Marque\n\n### Identité\n\nOhmyfood est une entreprise de commande de repas en ligne. Notre concept permet aux\nutilisateurs de composer leur propre menu et de réduire leur temps d’attente dans les\nrestaurants, car leur menu est préparé à l’avance. Plus de perte de temps à consulter la\ncarte !\n\n### Proposition\n\nNous souhaitons proposer à nos clients les menus de restaurants gastronomiques. Après\nl’avoir développé à New-York dans un premier temps, nous souhaitons désormais élargir\nnotre concept à la capitale de la gastronomie : Paris.\n\n### Positionnement\n\nNous nous positionnons sur un marché de niche, avec les restaurants luxueux des villes\ndans lesquelles nous sommes établis. Nous souhaitons être identiﬁés comme une\nentreprise proposant des services haut de gamme.\n\n## Problématique\n\nNous souhaitons ouvrir nos services à la capitale française.\n\n### Objectifs\n\n- Phase 1 : Développer un site proposant le menu de 4 grands restaurants parisiens.\n- Phase 2 : Permettre la réservation en ligne et la composition de menus.\n\n## Identité graphique\n\n### Polices\n\n- _Shrikhand_ pour le **logo** et les **titres**.\n- _Roboto_ pour le **_texte_**.\n\n### Couleurs\n\n- **Primaire**: #9356dc\n- **Secondaire**: #ff79da\n- **Tertiaire**: #99e2d0\n\n## Technologies\n\n- Le développement doit se faire en CSS, sans JavaScript.\n- Le code CSS doit être disponible dans un ou plusieurs ﬁchiers dédiés.\n- Le site devra être réalisé en adoptant le Mobile First, c’est-à-dire qu’il faudra d’abord\n  réaliser l'intégration de la maquette mobile, puis tablette, et enﬁn l'intégration du\n  responsive vers le desktop.\n- Aucun framework ne devra être utilisé ; en revanche l’utilisation de SASS serait un\n  plus.\n- Aucun code CSS ne doit être appliqué via un attribut style dans une balise HTML.\n- Tout le code doit être versionné sur GitHub avec des commits réguliers pour\n  suivre l’avancement et publier le site en ligne plus facilement.\n- Le site devra être accessible sur GitHub Pages une fois terminé.\n\n## Compatibilité\n\nLa cible étant les personnes connectées et pressées, le site sera développé en utilisant\nl’approche mobile-first.\nLe site devra donc être intégré en suivant les maquettes mobile, puis le responsive suivra\npour les tablettes et ordinateurs en suivant les maquettes ordinateur données par notre\ndesigner.\n\n- L’ensemble du site devra être responsive sur mobile, tablette et desktop.\n- Les pages devront passer la validation W3C en HTML et CSS sans erreur.\n- Le site doit être parfaitement compatible avec les dernières versions desktop de\n  Chrome et Firefox.\n\n## Contenu des pages\n\n### Page d'accueil (x1)\n\n- Affichage de la localisation des restaurants. À terme, il sera possible de choisir sa\n  localisation pour trouver des restaurants proches d’un certain lieu.\n- Une courte présentation de l’entreprise.\n- Une section contenant les 4 menus sous forme de cartes. Au clic sur la carte,\n  l’utilisateur est redirigé vers la page du menu.\n\n### Pages des menus (x4)\n\n- 4 pages contenant chacune le menu d’un restaurant.\n\n### Footer\n\n- Le footer est identique sur toutes les pages.\n- Au clic sur \"Contact\", un renvoi vers une adresse mail est effectué.\n\n### Header\n\n- Le header est présent sur toutes les pages.\n- Sur la page d'accueil, il contient le logo du site.\n- Sur les pages de menu, il contient en plus un bouton de retour vers la page d'accueil\n\n## Effets graphiques et animations\n\nLes effets accessibles au clic ou au survol sont visibles sur la maquette. Ils devront utiliser\nles animations ou transitions CSS, pas de JavaScript ni de librairie. Pour toutes les\nanimations, afin de soigner le rendu du site, il est important que lorsque nous avons un effet\nau hover ou lors d’un clic, nous ayons l’effet inverse lorsque l’on quitte le survol.\n\n### Boutons\n\n- Au survol, la couleur de fond des boutons principaux devra légèrement s’éclaircir.\n  L’ombre portée devra également être plus visible.\n- À terme, les visiteurs pourront sauvegarder leurs menus préférés. Pour ça, un\n  bouton \"J’aime\" en forme de cœur est présent sur la maquette. Au clic, il devra se\n  remplir progressivement. Pour cette première version, l’effet peut apparaître au\n  survol sur desktop au lieu du clic.\n\n### Page d’accueil\n\n- Quand l’application aura plus de menus, un “loader” sera nécessaire. Sur cette\n  maquette, nous souhaitons en avoir un aperçu. Il devra apparaître pendant 1 à 3\n  secondes quand on arrive sur la page d'accueil, couvrir l'intégralité de l'écran, et\n  utiliser les animations CSS. Le design de ce loader n’est pas défini, toute proposition\n  est donc la bienvenue tant qu’elle est cohérente avec la charte graphique du site.\n\n### Pages de menu\n\n- À l’arrivée sur la page, les plats devront apparaître progressivement avec un léger\n  décalage dans le temps. Ils pourront apparaître soit un par un, soit par groupe\n  “Entrée”, “Plat” et “Dessert”.\n- Le visiteur peut ajouter les plats qu'il souhaite à sa commande en cliquant dessus.\n  Cela fait apparaître une petite coche à droite du plat. Cette coche devra coulisser de\n  la droite vers la gauche. Pour cette première version, l’effet peut apparaître au survol\n  sur desktop au lieu du clic. Si l’intitulé du plat est trop long, il devra être rogné avec\n  des points de suspension.\n\n## Tester le projet\n\nPour tester simplement et rapidement : [https://code9g.github.io/ohmyfood/](https://code9g.github.io/ohmyfood/)\n\nSinon, clonez le projet\n\n```terminal\ngit clone https://github.com/code9g/ohmyfood.git\n```\n\nEt lancez la page\n\n```terminal\nindex.html\n```\n\n[![Github Pages](https://img.shields.io/badge/github%20pages-121013?style=for-the-badge\u0026logo=github\u0026logoColor=white)](\u003c[http://](https://github.com/code9g/)\u003e)\n[![LinkedIn](https://img.shields.io/badge/linkedin-%230077B5.svg?style=for-the-badge\u0026logo=linkedin\u0026logoColor=white)](https://www.linkedin.com/in/pierre-andre-henry/)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcode9g%2Fohmyfood","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fcode9g%2Fohmyfood","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcode9g%2Fohmyfood/lists"}