v0.5.0
added year duplication
This commit is contained in:
		
							parent
							
								
									8fbdffc965
								
							
						
					
					
						commit
						45b220c69f
					
				| @ -102,6 +102,23 @@ func (s *HolidayService) Delete(id uuid.UUID) error { | |||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (s *HolidayService) Copy(country string, from int, to int) error { | ||||||
|  | 	holidays, err := s.findByYear(from, nil, nil, country) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	var diff = to - from | ||||||
|  | 
 | ||||||
|  | 	for _, holiday := range holidays { | ||||||
|  | 		holiday.Date = holiday.Date.AddDate(diff, 0, 0) | ||||||
|  | 		_, err := s.Create(holiday) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func getDateOrDefault(date *time.Time, year int) time.Time { | func getDateOrDefault(date *time.Time, year int) time.Time { | ||||||
| 	if date == nil { | 	if date == nil { | ||||||
| 		return time.Date(year, 1, 1, 0, 0, 0, 0, time.UTC) | 		return time.Date(year, 1, 1, 0, 0, 0, 0, time.UTC) | ||||||
|  | |||||||
							
								
								
									
										29
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								main.go
									
									
									
									
									
								
							| @ -110,6 +110,8 @@ func loadTemplates(g *gin.Engine) { | |||||||
| 		"templates/admin_dashboard.gohtml", | 		"templates/admin_dashboard.gohtml", | ||||||
| 		"templates/countries.gohtml", | 		"templates/countries.gohtml", | ||||||
| 
 | 
 | ||||||
|  | 		"templates/dialogs/copy-year.gohtml", | ||||||
|  | 
 | ||||||
| 		"templates/dialogs/add-holiday.gohtml", | 		"templates/dialogs/add-holiday.gohtml", | ||||||
| 		"templates/dialogs/edit-holiday.gohtml", | 		"templates/dialogs/edit-holiday.gohtml", | ||||||
| 		"templates/dialogs/delete-holiday.gohtml", | 		"templates/dialogs/delete-holiday.gohtml", | ||||||
| @ -189,6 +191,24 @@ func setupAdminDashboard(adminDashboard *gin.RouterGroup, service holiday.Holida | |||||||
| 			c.Redirect(http.StatusSeeOther, "/admin?country="+request.Country+"&year="+strconv.FormatInt(int64(request.Date.Year()), 10)) | 			c.Redirect(http.StatusSeeOther, "/admin?country="+request.Country+"&year="+strconv.FormatInt(int64(request.Date.Year()), 10)) | ||||||
| 		} | 		} | ||||||
| 	}) | 	}) | ||||||
|  | 	adminDashboard.POST("/holidays/copy", func(c *gin.Context) { | ||||||
|  | 		request := struct { | ||||||
|  | 			From    int    `form:"from"` | ||||||
|  | 			To      int    `form:"to"` | ||||||
|  | 			Country string `form:"country" binding:"len=2"` | ||||||
|  | 		}{} | ||||||
|  | 		if err := c.ShouldBind(&request); err != nil { | ||||||
|  | 			c.AbortWithError(http.StatusBadRequest, err) | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		err := service.Copy(request.Country, request.From, request.To) | ||||||
|  | 		if err != nil { | ||||||
|  | 			c.AbortWithError(http.StatusInternalServerError, err) | ||||||
|  | 		} else { | ||||||
|  | 			c.Redirect(http.StatusSeeOther, "/admin?country="+request.Country+"&year="+strconv.FormatInt(int64(request.To), 10)) | ||||||
|  | 		} | ||||||
|  | 	}) | ||||||
| 	adminDashboard.POST("/holidays/:id/delete", func(c *gin.Context) { | 	adminDashboard.POST("/holidays/:id/delete", func(c *gin.Context) { | ||||||
| 		id := uuid.MustParse(c.Param("id")) | 		id := uuid.MustParse(c.Param("id")) | ||||||
| 		hol, err := service.FindById(id) | 		hol, err := service.FindById(id) | ||||||
| @ -266,6 +286,15 @@ func setupAdminDashboard(adminDashboard *gin.RouterGroup, service holiday.Holida | |||||||
| 		countries, _ := countryService.Find() | 		countries, _ := countryService.Find() | ||||||
| 		c.HTML(http.StatusOK, "edit-holiday.gohtml", gin.H{"Countries": countries, "Holiday": hol}) | 		c.HTML(http.StatusOK, "edit-holiday.gohtml", gin.H{"Countries": countries, "Holiday": hol}) | ||||||
| 	}) | 	}) | ||||||
|  | 	adminDashboard.GET("/dialogs/copy-year", func(c *gin.Context) { | ||||||
|  | 		country := c.Query("country") | ||||||
|  | 		year, err := strconv.ParseInt(c.Query("year"), 10, 32) | ||||||
|  | 		if err != nil { | ||||||
|  | 			c.AbortWithError(http.StatusNotFound, err) | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 		c.HTML(http.StatusOK, "copy-year.gohtml", gin.H{"Country": country, "Year": year}) | ||||||
|  | 	}) | ||||||
| 	adminDashboard.GET("/dialogs/edit-country", func(c *gin.Context) { | 	adminDashboard.GET("/dialogs/edit-country", func(c *gin.Context) { | ||||||
| 		id := uuid.MustParse(c.Query("id")) | 		id := uuid.MustParse(c.Query("id")) | ||||||
| 		country, err := countryService.FindById(id) | 		country, err := countryService.FindById(id) | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								makefile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								makefile
									
									
									
									
									
								
							| @ -1,7 +1,7 @@ | |||||||
| # scripts for building app
 | # scripts for building app
 | ||||||
| # requires go 1.19+ and git installed
 | # requires go 1.19+ and git installed
 | ||||||
| 
 | 
 | ||||||
| VERSION := 0.4.0 | VERSION := 0.5.0 | ||||||
| 
 | 
 | ||||||
| serve: | serve: | ||||||
| 	go run ./... | 	go run ./... | ||||||
|  | |||||||
| @ -64,8 +64,11 @@ | |||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div style="flex-grow: 1; background: transparent"> |     <div style="flex-grow: 1; background: transparent"> | ||||||
|         <button style="float: right; margin-top: 0" data-type="dialog" data-trigger="#create-card" data-url="/admin/dialogs/add-holiday" class="primary">Dodaj novi praznik</button> |         <div style="display: flex; flex-direction: row; flex-wrap: wrap; justify-content: end; background: transparent; gap: 0.5em"> | ||||||
|         <section class="dialog table-results" style="margin: 0; margin-top: 3.5em" id="results"> |             <button data-type="dialog" data-trigger="#copy-year" data-url="/admin/dialogs/copy-year?year={{$.Search.Year}}&country={{$.Search.Country}}" class="secondary">Kopiraj godinu</button> | ||||||
|  |             <button data-type="dialog" data-trigger="#create-card" data-url="/admin/dialogs/add-holiday" class="primary">Dodaj novi praznik</button> | ||||||
|  |         </div> | ||||||
|  |         <section class="dialog table-results" style="margin: 0; margin-top: 0.5em" id="results"> | ||||||
|             <table> |             <table> | ||||||
|                 <thead> |                 <thead> | ||||||
|                 <tr> |                 <tr> | ||||||
|  | |||||||
| @ -17,8 +17,10 @@ | |||||||
| </header> | </header> | ||||||
| <main class="admin-dashboard"> | <main class="admin-dashboard"> | ||||||
|     <div style="width: 640px; max-width: 100%; margin: auto; background: transparent"> |     <div style="width: 640px; max-width: 100%; margin: auto; background: transparent"> | ||||||
|  |         <div style="display: flex; flex-direction: row; flex-wrap: wrap; justify-content: end; background: transparent"> | ||||||
|             <button style="float: right; margin-top: 0" data-type="dialog" data-trigger="#create-card" data-url="/admin/dialogs/add-country" class="primary">Dodaj državu</button> |             <button style="float: right; margin-top: 0" data-type="dialog" data-trigger="#create-card" data-url="/admin/dialogs/add-country" class="primary">Dodaj državu</button> | ||||||
|         <section class="dialog table-results" style="margin: 0; margin-top: 3.5em" id="results"> |         </div> | ||||||
|  |         <section class="dialog table-results" style="margin: 0; margin-top: 0.5em" id="results"> | ||||||
|             <table style="width: 100%"> |             <table style="width: 100%"> | ||||||
|                 <thead> |                 <thead> | ||||||
|                 <tr> |                 <tr> | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								templates/dialogs/copy-year.gohtml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								templates/dialogs/copy-year.gohtml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | |||||||
|  | 
 | ||||||
|  | <dialog class="card" id="copy-year"> | ||||||
|  |     <h3 class="card-title">Kopiraj godinu {{.Year}}</h3> | ||||||
|  | 
 | ||||||
|  |     <p>Na koji godinu želite kopirati praznike iz godine {{.Year}}?</p> | ||||||
|  |     <form method="post" action="/admin/holidays/copy"> | ||||||
|  |         <input type="hidden" name="from" value="{{.Year}}"> | ||||||
|  |         <input type="hidden" name="country" value="{{.Country}}"> | ||||||
|  |         <section class="form-field"> | ||||||
|  |             <label for="to">Godina:</label> | ||||||
|  |             <input required id="to" name="to" type="number" step="1"> | ||||||
|  |         </section> | ||||||
|  |         <section class="actions"> | ||||||
|  |             <button class="primary" type="submit">Kopiraj</button> | ||||||
|  |             <button class="secondary" type="button" onclick="closeDialog('#copy-year')">Odustani</button> | ||||||
|  |         </section> | ||||||
|  |     </form> | ||||||
|  | </dialog> | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user