Unlimited Plugins, WordPress themes, videos & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Code
  2. Startups
Code

Building Your Startups: Pulong kasama ang maraming mga kalahok

by
Difficulty:IntermediateLength:MediumLanguages:
This post is part of a series called Building Your Startup With PHP.
Building Your Startup: Requesting Scheduling Changes
Building Your Startup: Completing Group Scheduling

Tagalog (Wikang Tagalog) translation by Anna Nelson (you can also view the original English article)

Final product image
What You'll Be Creating

Ang tutorial na ito ay bahagi ngserye tungkol sa pagbuo ng iyong startup gamit ang PHP sa Envato Tuts+. Sa seryeng ito, gagabayan ko kayo sa paglulunsad ng isang startup mula sa konsepto sa kasalukuyan gamit ang aking Meeting Planner app bilang isang makatotohanan na halimbawa. Bawat hakbang sa kahabaan ng proseso, ibibigay ko ang open-source code ng aking Meeting Planner app bilang halimbawa kung saan maaari mong malaman ang pinagmulan. Tatalakayin ko din angmga isyu tungkol sa negosyo kung meron tayong madaanan.

Panimula sa pulong ng mga grupo

Pagiiskedyul ng pulong kasama ang mga maraming kalahok ay palaging parte na ng aking plano – ngunit hindi parte ng naunang Minimum Viable Product (MVP).  Ang unang pagpapalabas ng taga-plano ng pulong na inilunsad nang mayroon lamang 1:1 na pag iskedyul. Ang layunin ng pag suporta sa pag-iskedyul ng grupo ay gaya ng isang listahan ng isang umaakyat sa bundok Everest na hangad marating ang pitong tuktok (at ako namaý hindi umaakyat sa labas).

Ang maraming kalahok sa pulong ay ang pinaka mahirap na gawan ng iskedyul kung kaya’t mahalaga para sa tagaplano ng pulong ang mga produkto na maiaalok. Akoý natutuwa nang ang beta task list ay narating ang punto kung saan akoý maari nang magsimula.

Ako ay nagpaplano, architecting at coding nang pulong ng grupo sa aking isipan nung halos simula pa lamang. Umaasa ako na ang pagbabago sa site para sa tampok na ito ay hindi nangangailangan ng makahulugang UX na pagbabago o coding updates. Ito palaý nangangailangan ng taga-ugnay, 7-10 araw na nakatuon sa trabaho at pagsubok ngunit wala namang malakihang re-architecting. 

Sa katunayan, ang pagsubok ay nagpapatunay na ito ang pinakamahirap na aspeto ng pagbuo ng tampok na ito. Ito rin ay nakatulong sa paghahayag ng mga pagkukulang sa mga naunang mga code. Itoý hindi ganun kadali….pagpapadala sa maramihang email addresses, pagtingin na dapat lahat sila ay nakatanggap ng tamang abiso at hindi ang maling abiso — at Makita ang lahat ng tamang talaan ng mga pagpipilian sa kabuuan ng site. 

Sa pagtuturo ngayon, aking sasakupin kung paano mag- enable ng maramihang kalahok, pag-upgrade ng UX para sa grupo, paghirang sa mga bumubuo, pagtanggal sa mga kalahok, at paghihiwalay ng pagpipilian ng sa petsa, oras at lugar sa pamamagitan ng kung ano ang mas alam ng mga kalahok.

Sa susunod na pagtuturo, aking ilalarawan ang iba pang gagawin: pag-aralan ang lahat ng lugar nang site na maapektuhan ng maraming kalahok sa mga pulong, ang paggawa at maayos na pag display ng listahan ng mga tatanggap ng mga ibat ibang katayuan, tamang pangangasiwa ng mga abiso, at pag-sala ng mga abiso para sa grupo, at sa huli ay ang pag -upgrade ng kamakailan lamang na inilunsad na kahilingan na tampok na pagbabago sa pulong. 

Subukang mag-iskedyul ng pulong ng mga grupo

Kung maari sana ay mag iskedyul ng pulong ng mga grupo ngayon! Ibahagi ang inyong mga saloobin at katugunan sa mga komento sa ilalim.

Sumasali talaga ako sa mga diskusyon ng mga komento sa ibaba, ngunit  Maaari mo din akong makausap nang direkta sa Twitter @reifman. Bukas ang aking isipan sa mga bagong ideya para sa taga-plano ng pulong pati na rin ang mga mungkahi para sa panghinaharap pang mga serye.

Bilang paalala, ang lahat ng mga code para sa Meeting Planner ay nakasulat sa Yii2 Framework para sa PHP. Kung gusto mong matuto nang iba pa tungkol sa Yii2, tingnan ang aming parallel series Programming Sa Yii2. Kung gusto mong matuto nang iba pa tungkol sa Yii2, tingnan ang aming parallel series Programming Sa Yii2. Marami akong narinig na magagandang bagay tungkol sa Laravel, ngunit ang Yii2 sa kadalasan ay nakakamit ang aking mga pangangailangan ng mas mabilis at walang hirap.

Pagbabalik-tanaw 

Noong una kong dinisenyo ang Meeting Planner scheduling interface, ipinakikita nito ang kung anong mayroon sa kasalukuyan ang isang kalahok na makikita sa sarili nitong hanay. At ito ay medyo nakakalito dahil mayroon mga disabled controls. 

Meeting Planner Startup Series - The old You Them Availability Panel

SA mga oras na iyon, Nag-aalala ako kung paano ko gagawan ng espasyo para maipakita ang availability ng grupo.

Sa kabutihang-palad, Nang aking binuo ulit ang UX para sa mas mabuting karanasan, Pinalitan ko ang participant availability column nang maigsing text summary:

Meeting Planner Startup Series - The newer built for mobile responsive planning view

Ang text summary of availability ay nagkataon namang aayon sa pulong ng mga grupo.

Sa muling pagdidisenyo ng mobile first, Nalutas ko ang pinaka importanteng UX barrier sa maramihang kalahok sa pulong! 

Coding para sa pulong ng mga grupo

Ating simulan sa pamamagitan ng pagtingin sa lahat ng codes at subukan na ang maramihang kalahok sa pulong ay kinakailangan.

Enabling Multiple Participants

Meeting Planner Startup Series - Who Panel - Enabled Button for More Participants

Ang nakakatuwang aspeto sa pulong ng mga grupo ay ang paganahin sila nang diretsuhan. Kailangan ko lang isara ang disabling ng plus icon button sa Who panel para sa pulong sa yugto ng pagpaplano: 

Pagkatapos, sinumulan ko sa paglikha ng MEETING_LIMIT sa Participant model:

Ito’y ginamit sa ParticipantController::actionCreate() na pagsumite:

Pagsulong sa UX at iba pang kahalintulad na tampok

Sa matagal na panahon, Gusto kong payagan ang mga taga-organiza ng pulong na magtanggal ng mga kalahok, mga lugar at petsa nang hindi nagugulo ang user interface. Katulad nito, napagtanto ko na maaring may mga ilang commands na maaring gawin sa mga kalahok.

Pagkatapos makahanap ng maraming utility sa compact Bootstrap dropdown button sa Advanced Commands tutorial, nagdesisyon akong gamitin ito para idisplay ang dadalo sa pulong:

Meeting Planner Startup Series - New Buttons and Dropdown Menu for Organizers

Ang mga taga-organiza ay minarkahan ng bituin. Ang mga dadalo na tumanggi sa pulong ay nakamarka ng orange. Ang mga dadalo na tinanggal ng mga organizers ay nakamarka ng red.

Narito ang mga code sa aking bagong partial /frontend/views/participant/_buttons.php:

Sino man ay maaring magpadala ng mensahe sa kahit na sinong kalahok (ang mga tampok na tala ay kasalukuyang nakapamahagi sa lahat ng kalahok sa pulong).

Ang mga taga-organiza ay nakakakita ng mas malalim na dropdown kung saan pinahihintulutan silang makapagdagdag ng taga-organiza, i.e. Make organizer. Ito ngayon ay isa nang magandang katangian Ang mga taga-organiza ay makakatanggap ng mas kumpletong abiso at mas may kapanyarihan sa lahat ng parte ng pagpapalano. Maaari din nila alisin mga kalahok.

Pagbuo ng AJAX Features para sa Participant Buttons

Nagdesisyon ako para ma-AJAXify ang lahat ng talaan ng pagpipilian. Na nangangailangan pala ng madaming oras nang pag-coding. 

Narito ang mga code na tumutukoy sa mga initial button menu at maihanda ang JavaScript:

Napakaraming button states, kulay at bituin para i-update dahil ang pagbabago ay ginawa interactively sa pahina kung saan ang mga code ay nagiging masikot. Dinagdagan ko ng functions sa meeting.js Javascript file para sa toggleOrganizer( ), i.e. make/unset organizer, at toggleParticipant( ), i.e. remove/restore participant as attendee. 

Ang mga ito ay kailangan sabayan ng JSON controller methods sa ParticipantController,php upang ma proseso ang toggle requests at update ng databases: 

Pag-Activate sa Accordion Feature on Panels

Meeting Planner Startup Series - Open and Closed Panels with Bootstrap Accordion Feature

Sa oras na ito, napagtanto ko na habang ang plano sa pulong ay mas nagiging kumplikado kasabay nang mas marami pang tatanggap at pagpipilian, magkakaroon ng mas higit pang pag-scrolling. Nagdesisyon akong ipatupad ang Bootstrap accordion feature para sa lahat ng panels sa ating meeting view. 

Sa madaling salita, maari mo nang i-click  sa heading upang maisara o mabuksan ang bawat isa o ang lahat ng mga panels.

Narito ang mga pagbabago para sa partials ng meeting place _panel.php: 

Tandaan, ang settings sa itaas ng panel-heading at pagkatapos ay ang nakapaligid na div para sa panel-body. Ang mga ito ay nag kokontrol ng pagbukas at pagsara ng bawat panel.

Itoý naghatid ng ilang maliliit na problema sa itsura gaya nang unwanted padding na nakapalibot sa listahan ng mga bagay, kung saan ay kailangan ko itong ayusin sa darating na panahon.

Model Infrastructure para sa pulong ng mga grupo

Habang akoý nagpaplano para sa maramihang kalahok na halos mula pa sa umpisa, mayroon mga maliliit hanggang sa katamtamang imprastrakturang pinahusay upang suportahan ang mga ito.

Habang ang MeetingTimeChoice at MeetingPlaceChoice models ay na-aantabayanan kung ang mga kalahok ay may gustong partikular na araw, oras at mga lugar, Gusto kong antabayanan ang kabuuan kung saan ay  pwede ang lahat ng kalahok sa bawat araw, oras at lugar. Akoý mapahihintulutan nitong mai-bukod ang lugar at oras ayon sa kung gaano sila ka-sikat – at maipapakita ang pinaka-sikat na settings sa pinaka-tuktok ng panels. 

Una, lumikha ako ng migration upang mkapagdagdag sa parehong modelo. Madalang na ang naggawa kong migration ay nakaka-apekto sa maramihang mga modelo, kung kaya’t ang isang ito ay espesyal:

Sa kapasidad nito, naggawa kong simulang idisplay ang mga posibleng araw, oras at lugar ng pulong na kung saan ay magkakabukod ayon sa kanilang kasikatan sa mga kalahok, mula MeetingController::actionView():

Makikita mo ang mga akto na ito na nasa ibaba na planning screenshot:

Meeting Planner Startup Series - Sorted Date Times and Places By Popularity

Para masubaybayan kung ang kalahok ay taga- organisa at para mapahintulutan para sa panghinaharap na mapiling hindi maisama sa partikular na abiso ng pulong, Idinagdag ko ang migration na ito para Participant table:

Nagdagdag din ako ng mga number of constants sa Participant.php upang makapag-trabaho sa mga properties na ito:

At alam kong makakatulong kung meron pang ibang makatuwang sa pagtitipon sa loob ng naglalakihang modelo ng pulong. Halimbawa, IsOrganizer () nagsasabi sa akin kung ang kasalukuyang tumitingin ay isang taga-organiza ng pulong:

Saglit, meron pa?

Gaya ng iyong nakikita, Marami pang dapat sakupin upang mabuo ang tampok na ito. Sa susunod na kabanata, Aking sasakupin and ikalawang hati ng pagbuo at pagsubok na kinakailangan upang mai-sulong ang maramihang kalahok sa pulong: hanay ng tatanggap, abiso, kahilingan, at pagtugon sa mga kahilingan.

Kung wala ka pa, mag iskedyul ka ng iyong unang pulong sa taga-plano ng pulong at subukan itong lahat. Pakiusap na sanaý ibahagi ang inyong katugunan sa mga komento sa ilalim.

Pagtuturo ng crowdfunding ay inuumpisahan na, kung kaya’t sana ay sundan nyo ang aming WeFunder Meeting Planner pahina.

Maari nyo rin akong maabot sa @reifman. Akoý laging bukas para sa mga bagong tampok na mga ideya at mga mungkahing paksa para sa panghinaharap na pagtuturo.

Hintayin lamang ang lahat ng mga ito at marami pang mga darating na pagtuturo sa pamamagitan ng pagtingin sa Building Your Startup With PHP series.

Related Links

Advertisement
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.