X-Git-Url: https://harishankar.org/repos/?p=resumebuilder.git;a=blobdiff_plain;f=resumebuilder.go;h=79d821f1b8b8b1e49ed25059456ba37a3299b946;hp=09057c67d6ebcb0624335a11ed1a1b418a11da71;hb=HEAD;hpb=5960a1c589fcb3235edef412ab9827f0e9cfe6bd diff --git a/resumebuilder.go b/resumebuilder.go index 09057c6..79d821f 100644 --- a/resumebuilder.go +++ b/resumebuilder.go @@ -9,23 +9,34 @@ import ( ) type Applicant struct { - FirstName string - LastName string - Age int - Sex Sex - Education []Education + FirstName string + LastName string + DateOfBirth Date + Sex Sex + Address string + ContactNo string + Email string + Education []Education +} + +type Date struct { + Year uint + Month uint + Day uint } type Education struct { - SchoolName string - YearOfPassing int - PassPercentage float32 + Qualification string + Institution string + YearOfPassing uint + GradeOrPercentage string } type Sex int var ui *gtk.Builder var selectedsex Sex +var selecteddate Date const ( Male Sex = 1 @@ -47,50 +58,77 @@ const ( } } */ -func getBasicDetails() (*Applicant, error) { - // Retrieve all the fields. - obj, err := ui.GetObject("FirstName") +func setLineText(fieldname string, buf string) { + obj, err := ui.GetObject(fieldname) if err != nil { - return nil, err + return } - fsname, ok := obj.(*gtk.Entry) + field, ok := obj.(*gtk.Entry) if !ok { - return nil, err + return } - firstname, err := fsname.GetText() + field.SetText(buf) +} + +func getLineText(fieldname string) (string, error) { + obj, err := ui.GetObject(fieldname) if err != nil { - return nil, err + return "", err } - obj, err = ui.GetObject("LastName") + field, ok := obj.(*gtk.Entry) + if !ok { + return "", err + } + fieldstr, err := field.GetText() if err != nil { - return nil, err + return "", err + } + return fieldstr, nil +} + +func getMultilineText(fieldname string) (string, error) { + obj, err := ui.GetObject(fieldname) + if err != nil { + return "", err } - lsname, ok := obj.(*gtk.Entry) + fieldctl, ok := obj.(*gtk.TextView) if !ok { - return nil, err + return "", err } - lastname, err := lsname.GetText() + textbuf, err := fieldctl.GetBuffer() if err != nil { - return nil, err + return "", err + } + start, end := textbuf.GetBounds() + textstr, err := textbuf.GetText(start, end, true) + if err != nil { + return "", err } + return textstr, nil +} - obj, err = ui.GetObject("Age") +func getBasicDetails() (*Applicant, error) { + // Retrieve all the fields. + + firstname, err := getLineText("FirstName") if err != nil { return nil, err } - agectl, ok := obj.(*gtk.Entry) - if !ok { + lastname, err := getLineText("LastName") + if err != nil { return nil, err } - agetxt, err := agectl.GetText() + + address, err := getMultilineText("Address") if err != nil { return nil, err } - age, err := strconv.Atoi(agetxt) + + contact, err := getLineText("ContactNumber") if err != nil { return nil, err } - obj, err = ui.GetObject("Male") + email, err := getLineText("Email") if err != nil { return nil, err } @@ -100,8 +138,11 @@ func getBasicDetails() (*Applicant, error) { applicant.FirstName = firstname applicant.LastName = lastname - applicant.Age = age + applicant.DateOfBirth = selecteddate applicant.Sex = selectedsex + applicant.Address = address + applicant.ContactNo = contact + applicant.Email = email return applicant, nil } @@ -119,20 +160,7 @@ func getWindow() (*gtk.Window, error) { return wnd, nil } -func getSaveButton() (*gtk.Button, error) { - btnobj, err := ui.GetObject("SaveButton") - if err != nil { - fmt.Println(err.Error()) - return nil, err - } - btn, ok := btnobj.(*gtk.Button) - if !ok { - return nil, err - } - return btn, nil -} - -func LoadMain() { +func loadMain() { gtk.Init(nil) var err error ui, err = gtk.BuilderNew() @@ -148,7 +176,8 @@ func LoadMain() { ui.AddFromString(string(asset)) ui.ConnectSignals(map[string]interface{}{"SexMaleSelected": sexMaleSelected, "SexFemaleSelected": sexFemaleSelected, "SexOtherSelected": sexOtherSelected, - "SaveButtonClicked": SaveButtonClicked}) + "SaveButtonClicked": saveButtonClicked, "DoBSelected": doBSelected, + "AddEducationClicked": addEducationClicked}) wnd, err := getWindow() if err != nil { @@ -183,7 +212,66 @@ func sexOtherSelected(other *gtk.RadioButton) { } } -func SaveButtonClicked() { +func doBSelected(dob *gtk.Calendar) { + selecteddate.Year, selecteddate.Month, selecteddate.Day = dob.GetDate() +} + +func getEducationFields() (*Education, error) { + ed := new(Education) + qual, err := getLineText("QualificationTitle") + if err != nil { + return nil, err + } + inst, err := getLineText("InstitutionName") + if err != nil { + return nil, err + } + yearp, err := getLineText("YearPassing") + if err != nil { + return nil, err + } + year, err := strconv.Atoi(yearp) + if err != nil { + return nil, err + } + gradep, err := getLineText("GradeOrPercentag") + if err != nil { + return nil, err + } + ed.Qualification = qual + ed.Institution = inst + ed.YearOfPassing = uint(year) + ed.GradeOrPercentage = gradep + + return ed, nil +} + +func addEducationClicked() { + ed, err := getEducationFields() + if err != nil { + return + } + lstore, err := ui.GetObject("EducationStore") + if err != nil { + return + } + edustore, ok := lstore.(*gtk.ListStore) + if !ok { + return + } + iter := edustore.Append() + edustore.SetValue(iter, 0, ed.Qualification) + edustore.SetValue(iter, 1, ed.Institution) + edustore.SetValue(iter, 2, ed.YearOfPassing) + edustore.SetValue(iter, 3, ed.GradeOrPercentage) + + setLineText("QualificationTitle", "") + setLineText("InstitutionName", "") + setLineText("YearPassing", "") + setLineText("GradeOrPercentag", "") +} + +func saveButtonClicked() { a, err := getBasicDetails() if err != nil { fmt.Println(err.Error()) @@ -193,5 +281,5 @@ func SaveButtonClicked() { } func main() { - LoadMain() + loadMain() }