Maison >interface Web >js tutoriel >Latio Team : une communauté de hackers technologiques qui bâtit ensemble

Latio Team : une communauté de hackers technologiques qui bâtit ensemble

DDD
DDDoriginal
2024-10-31 01:50:02515parcourir

Ceci est une soumission pour le Wix Studio Challenge : Community Edition.

Ma plateforme communautaire

Latio Team est une communauté créée pour les constructeurs technologiques basés en Amérique latine. C'est un endroit pour s'engager, apprendre, grandir et se connecter ensemble tout en participant à des hackathons. La page de la communauté comprend les fonctionnalités suivantes :

  1. Un vivier de talents : les membres voient leur profil répertorié sur une page publique qui a pour but d'être vu par les recruteurs ou autres entrepreneurs.
  2. Opportunités d'emploi : un site d'emploi qui présente les derniers emplois à distance pour nos membres (API fournie par RemoteOK), les membres peuvent voir et postuler aux offres d'emploi au sein de la page de la communauté.
  3. Hackathon Listings : l'endroit où partager et publier de nouvelles opportunités de hackathon pour nos membres.
  4. Connect : un espace pour discuter avec les autres membres, publier des mises à jour sur le travail et également trouver de nouveaux collaborateurs.
  5. Demandes d'emploi : chaque profil de membre comporte un bouton de contact où les recruteurs peuvent leur envoyer un message ou demander une demande d'emploi. Les membres peuvent alors voir les messages reçus dans une page de liste personnalisée sans avoir à exposer leurs informations privées.

Démo

Lien du projet : https://fredoist.wixstudio.io/latio-team

Page d'accueil :
Latio Team: A community for tech hackers building togheter

Pool de talents :
Latio Team: A community for tech hackers building togheter

Tableau d'emploi et publication
Latio Team: A community for tech hackers building togheter
Latio Team: A community for tech hackers building togheter

Listes du hackathon :
Latio Team: A community for tech hackers building togheter

Connecter :
Latio Team: A community for tech hackers building togheter

Profil du membre :
Latio Team: A community for tech hackers building togheter

Formulaire de demande de travail et listes :
Latio Team: A community for tech hackers building togheter
Latio Team: A community for tech hackers building togheter

Parcours de développement

Construire avec Wix's Studio et les API Velo était assez simple si vous connaissez déjà JavaScript.

Toute la documentation des API Velo est claire et très complète. De plus, l'éditeur de Wix Studio possède d'excellentes fonctionnalités de saisie semi-automatique qui rendent l'utilisation très facile. Une fois que vous avez commencé à créer et à tester l'éditeur, vous comprenez son fonctionnement et vous pouvez rapidement implémenter de nouvelles API.

En outre, les modèles de Wix vous permettent de créer très rapidement un site Web époustouflant, le design s'adapte à chaque nouvelle application pour l'élément que vous ajoutez, ce qui est plutôt cool puisque vous n'avez besoin de toucher à rien d'autre.

Voici les blocs de code de certaines fonctionnalités afin que vous puissiez les reproduire :

Offres d'emploi

import { Permissions, webMethod } from "wix-web-module";
import { getJSON } from "wix-fetch";

const formatPrice = (p) =>
    new Intl.NumberFormat('en-US', {
        notation: 'compact',
        maximumFractionDigits: p < 1 ? 3 : 1,
    }).format(Number(p));

// GET call using getJSON
export const getJobs = webMethod(Permissions.Anyone, async () => {
    const response = await getJSON(
        "https://remoteok.com/api",
    );
    const jobs = response.slice(1).map(job => {
        job._id = job.id;
        job.salary_range = `$ ${formatPrice(job.salary_min)}-${formatPrice(job.salary_max)}`
        job.company_logo = job.company_logo ? `https://remoteok.com/cdn-cgi/image/format=auto,fit=contain,width=100,height=100,quality=50/${job.company_logo}` : null;
        job.logo = job.logo ? `https://remoteok.com/cdn-cgi/image/format=auto,fit=contain,width=100,height=100,quality=50/${job.logo}` : null;
        job.image = job.company_logo ?? job.logo ?? `https://ui-avatars.com/api/?name=${job.company}`
        return job;
    })
    return jobs;
});

Page d'emploi

import { ok, notFound, WixRouterSitemapEntry } from "wix-router";
import { getJobs } from "backend/fetch-jobs.web"

export async function job_Router(request) {

    // Get item name from URL request
    const slug = request.path[0];

    // Get the item data by name
    const jobs = await getJobs();
    const data = jobs.filter(job => job.slug === slug)

    if (data.length) {
        const job = data[0];

        // Define SEO tags 
        const seoData = {
            title: job.position,
            description: "This is a description of " + job.position + " page",
            noIndex: false,
            metaTags: [{
                "property": "og:title",
                "content": job.position
            }, ]
        };

        // Render item page 
        return ok("job-page", job, seoData);
    }

    // Return 404 if item is not found 
    return notFound();
}

export async function job_SiteMap(sitemapRequest) {
    const jobs = await getJobs()

    // Convert the data to site map entries
    const siteMapEntries = jobs.map((job) => {
        const data = job;
        const entry = new WixRouterSitemapEntry(job.slug);
        entry.pageName = "job-page"; // The name of the page in the Wix editor to render
        entry.url = "/job/" + job.slug; // Relative URL of the page
        entry.title = data.position; // For better SEO - Help Google
        return entry;
    });

    // Return the site map entries
    return siteMapEntries;
}

Envoi de demandes de renseignements pour tout membre

import { Permissions, webMethod } from "wix-web-module";
import wixData from "wix-data";

export const sendInquiry = webMethod(
    Permissions.Anyone,
    async (username, email, details, budget) => {
        const results = await wixData.query("Members/PrivateMembersData").eq('slug', username).find()
        const member = results.items.length > 0 ? results.items[0] : null;
        if(member) {
          const memberId = member._id;
          const result = await wixData.save("WorkInquiries", {
            recipientId: memberId,
            contactEmail: email,
            details,
            budget
          })
          if(result) {
            return true
          }
        }
        return false;
    }
);

Récupération des demandes des membres

import { Permissions, webMethod } from "wix-web-module";
import { query } from "wix-data";
import { currentMember } from "wix-members-backend"

export const getInquiries = webMethod(
  Permissions.SiteMember, 
  async () => { 
    const member = await currentMember.getMember();
    const data = await query("WorkInquiries").eq('recipientId', member._id).find();

    return data.items;
  }
);

API Velo

  1. wix-data : il est utilisé pour stocker, récupérer et restituer les données des collections personnalisées ainsi que les données des membres dans les fonctionnalités publiques/privées.
  2. wix-fetch : les offres d'emploi sont fournies par l'API de RemoteOK et celles-ci sont récupérées à l'aide des méthodes de récupération de Wix, puis les offres d'emploi sont restituées dans des blocs de répéteurs.
  3. wix-router : les offres d'emploi sont également affichées sur sa propre page pour laquelle le routeur de Wix est utilisé.
  4. wix-members-backend : il est utilisé pour lier le formulaire de demande de renseignements à une collection personnalisée, une fois les données envoyées, le memberId est récupéré à l'aide de cette API en faisant correspondre le slug du profil, il est ensuite transmis à la collection avec les données du formulaire.
  5. wix-location-frontend et wix-window-frontend : ils sont simplement utilisés pour obtenir des données d'URL telles que le chemin ou le slug du membre.

Applications Wix

  1. Espace membres Wix : utilisé pour les profils utilisateur et l'authentification.
  2. Wix Groups : utilisé pour la fonctionnalité de connexion.
  3. FAQ Wix : pour inclure une FAQ dans la page d'accueil.
  4. CMS : j'ai utilisé certaines connexions CMS pour afficher les données à l'intérieur des pages.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn