You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
			
		
		
		
		
			
		
			
				
					
					
						
							43 lines
						
					
					
						
							1.2 KiB
						
					
					
				
			
		
		
	
	
							43 lines
						
					
					
						
							1.2 KiB
						
					
					
				| <script>
 | |
|   let Data = new GetJson("/api/admin/table/{{ .Table }}/{{ .Id }}/");
 | |
| 
 | |
|   const PostForm = async (url, data) => {
 | |
|     console.log("DATA", JSON.stringify(data));
 | |
|     return await fetch(url, {
 | |
|       method: "POST",
 | |
|       mode: "same-origin",
 | |
|       body: JSON.stringify(data),
 | |
|       headers: {
 | |
|         'Content-Type': 'application/json'
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| </script>
 | |
| 
 | |
| <blockstart>
 | |
| <h1>Admin Tables</h1>
 | |
| 
 | |
| <block x-init="item = await Data.oneThing()" x-data="{item: {}}">
 | |
|   <form method="POST" action="/api/admin/table/{{ .Table }}/{{ .Id }}/">
 | |
|     <card>
 | |
|     <top><h1>{{ .Table }} : {{ .Id }}</h1></top>
 | |
|     <middle>
 | |
|       <template x-for="(value, key) in item">
 | |
|         <div>
 | |
|           <label x-text="key" x-bind:for="key"></label>
 | |
|           <input x-text="value" x-model="item[key]" x-bind:id="key" />
 | |
|         </div>
 | |
|       </template>
 | |
|     </middle>
 | |
|     <bottom>
 | |
|       <button-group>
 | |
|         <button type="button">Back</button>
 | |
|         <button type="button" @click.prevent="PostForm('/api/admin/table/{{ .Table }}/{{ .Id }}/', item)">Update</button>
 | |
|         <button type="button" @click.prevent="console.log('DELETE', item.id)">Delete</button>
 | |
|       </button-group>
 | |
|     </bottom>
 | |
|     </card>
 | |
|   </form>
 | |
| </block>
 | |
| 
 | |
| </blockstart>
 | |
| 
 |