Simplify things
This commit is contained in:
		
							parent
							
								
									8e17cc3103
								
							
						
					
					
						commit
						85f4cda716
					
				
					 13 changed files with 63 additions and 348 deletions
				
			
		
							
								
								
									
										15
									
								
								src/App.vue
									
										
									
									
									
								
							
							
						
						
									
										15
									
								
								src/App.vue
									
										
									
									
									
								
							|  | @ -1,9 +1,22 @@ | |||
| <template> | ||||
|   <div id="app" class="min-h-screen antialiased bg-gray-200 font-sans flex flex-col flex-1"> | ||||
|     <div class="flex flex-col flex-1"> | ||||
|       <router-view class="flex flex-col flex-1"></router-view> | ||||
|       <router-view :applications="applications" :types="types" class="flex flex-col flex-1"/> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| <style src="./assets/css/tailwind.css"/> | ||||
| 
 | ||||
| <script> | ||||
| import { applications, types } from '@/data' | ||||
| 
 | ||||
| export default { | ||||
|   data () { | ||||
|     return { | ||||
|       applications, | ||||
|       types | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  |  | |||
|  | @ -1,40 +0,0 @@ | |||
| import _ from 'lodash' | ||||
| 
 | ||||
| let data = require('./data').default | ||||
| 
 | ||||
| export default { | ||||
|   methods: { | ||||
|     setData (newData) { | ||||
|       data = newData | ||||
|     }, | ||||
| 
 | ||||
|     getData () { | ||||
|       return data | ||||
|     }, | ||||
| 
 | ||||
|     getTypes () { | ||||
|       return data.types | ||||
|     }, | ||||
| 
 | ||||
|     getApplications () { | ||||
|       return data.applications | ||||
|     }, | ||||
| 
 | ||||
|     getApplication (applicationId) { | ||||
|       return _(data.applications).get(applicationId) | ||||
|     }, | ||||
| 
 | ||||
|     getEnvironment (applicationId, environment) { | ||||
|       return _(this.getApplication(applicationId)) | ||||
|         .get('environments')[environment] | ||||
|     }, | ||||
| 
 | ||||
|     getApplicationType (application) { | ||||
|       return this.getTypes()[application.type] | ||||
|     }, | ||||
| 
 | ||||
|     getVersion (type, environment) { | ||||
|       return _(environment).get(`versions.${type}`) | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | @ -9,7 +9,7 @@ | |||
|             </div> | ||||
| 
 | ||||
|             <div class="truncate text-blue-300"> | ||||
|               <a href="#0" class="text-inherit no-underline hover:underline focus:underline focus:outline-none">{{ application.environments['prod'].url }}</a> | ||||
|               <a href="#0" class="text-inherit no-underline hover:underline focus:underline focus:outline-none" v-text="prodUrl"/> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|  | @ -27,20 +27,22 @@ | |||
|         <div class="flex flex-row-reverse items-center justify-between"> | ||||
|           <div class="flex flex-1 justify-between items-center -mx-2"> | ||||
|             <div class="flex-1 px-2"> | ||||
|               <router-link :to="{name: 'environments', params: {id: id}}" class="text-blue-300 no-underline hover:underline focus:underline"><h2 class="text-base font-normal mb-1">{{ application.name }}</h2></router-link> | ||||
|               <router-link :to="{name: 'environments', params: { id }}" class="text-blue-300 no-underline hover:underline focus:underline"> | ||||
|                 <h2 class="text-base font-normal mb-1">{{ application.name }}</h2> | ||||
|               </router-link> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="w-2/5 px-2"> | ||||
|               <a href="#0" class="text-blue-300 no-underline hover:underline focus:underline">{{ application.environments['prod'].url }}</a> | ||||
|               <a href="#0" class="text-blue-300 no-underline hover:underline focus:underline" v-text="prodUrl"/> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="w-1/5 px-2"> | ||||
|               <php-version :application="application"></php-version> | ||||
|               <php-version :application="application"/> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="px-2"> | ||||
|             <star-toggle :application="application" :starred="starred" @toggle="starred = !starred"></star-toggle> | ||||
|             <star-toggle :application="application" :starred="starred" @toggle="starred = !starred"/> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|  | @ -49,17 +51,11 @@ | |||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import ApiClient from '@/api-client.js' | ||||
| import PhpVersion from '@/components/Application/PhpVersion' | ||||
| import StarToggle from '@/components/Application/StarToggle' | ||||
| 
 | ||||
| export default { | ||||
|   mixins: [ApiClient], | ||||
| 
 | ||||
|   components: { | ||||
|     PhpVersion, | ||||
|     StarToggle | ||||
|   }, | ||||
|   components: { PhpVersion, StarToggle }, | ||||
| 
 | ||||
|   props: { | ||||
|     application: Object, | ||||
|  | @ -71,6 +67,12 @@ export default { | |||
|     return { | ||||
|       starred: false | ||||
|     } | ||||
|   }, | ||||
| 
 | ||||
|   computed: { | ||||
|     prodUrl () { | ||||
|       return this.application.environments['prod'].url | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  |  | |||
|  | @ -1,8 +1,8 @@ | |||
| <template> | ||||
|   <div> | ||||
|     <ul class="list-reset flex flex-wrap -mr-2 -mb-2"> | ||||
|       <li class="tag" :data-type="type.id">{{ type.name }}</li> | ||||
|       <li class="tag">{{ level }}</li> | ||||
|       <li class="tag" :data-type="application.type" v-text="applicationTypeName"/> | ||||
|       <li class="tag">{{ application.level }}</li> | ||||
|     </ul> | ||||
|   </div> | ||||
| </template> | ||||
|  | @ -10,8 +10,13 @@ | |||
| <script> | ||||
| export default { | ||||
|   props: { | ||||
|     level: String, | ||||
|     type: Object | ||||
|     application: Object | ||||
|   }, | ||||
| 
 | ||||
|   computed: { | ||||
|     applicationTypeName () { | ||||
|       return this.$attrs.types[this.application.type].name | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  |  | |||
|  | @ -6,11 +6,7 @@ | |||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import ApiClient from '@/api-client.js' | ||||
| 
 | ||||
| export default { | ||||
|   mixins: [ApiClient], | ||||
| 
 | ||||
|   props: { | ||||
|     application: Object | ||||
|   }, | ||||
|  | @ -21,7 +17,7 @@ export default { | |||
|         return null | ||||
|       } | ||||
| 
 | ||||
|       return this.getVersion('php', this.getEnvironment(this.application.id, 'prod')) | ||||
|       return this.application.environments['prod'].versions['php'] | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| <template> | ||||
|   <div class="mb-6"> | ||||
|     <div class="flex flex-wrap -mx-4 -mb-6"> | ||||
|       <div v-for="(environment, key) in environments" class="w-full md:w-1/2 xl:w-1/3 px-4 mb-6" :key="key"> | ||||
|       <div v-for="(environment, key) in application.environments" class="w-full md:w-1/2 xl:w-1/3 px-4 mb-6" :key="key"> | ||||
|         <div class="border border-gray-400 rounded overflow-hidden shadow"> | ||||
|            <div class="bg-white"> | ||||
|             <div class="border-t-4 border-teal p-3"> | ||||
|  | @ -51,7 +51,7 @@ | |||
| <script> | ||||
| export default { | ||||
|   props: { | ||||
|     environments: Object, | ||||
|     application: Object, | ||||
|     id: String | ||||
|   } | ||||
| } | ||||
|  |  | |||
|  | @ -1,4 +1,4 @@ | |||
| export default { | ||||
| module.exports = { | ||||
|   types: { | ||||
|     drupal: { | ||||
|       id: 'drupal', | ||||
|  |  | |||
|  | @ -59,12 +59,20 @@ | |||
| 
 | ||||
| <script> | ||||
| import sortBy from 'lodash/sortBy' | ||||
| import ApiClient from '@/api-client.js' | ||||
| import ApplicationCard from '@/components/Application/ApplicationCard' | ||||
| import ApplicationDisplaySwitcher from '@/components/Application/ApplicationDisplaySwitcher' | ||||
| 
 | ||||
| export default { | ||||
|   mixins: [ApiClient], | ||||
|   props: { | ||||
|     applications: { | ||||
|       type: Array, | ||||
|       required: true | ||||
|     }, | ||||
|     types: { | ||||
|       type: Object, | ||||
|       required: true | ||||
|     } | ||||
|   }, | ||||
| 
 | ||||
|   components: { | ||||
|     ApplicationCard, | ||||
|  | @ -73,7 +81,6 @@ export default { | |||
| 
 | ||||
|   data () { | ||||
|     return { | ||||
|       applications: this.getApplications(), | ||||
|       display: 'grid' | ||||
|     } | ||||
|   }, | ||||
|  |  | |||
|  | @ -23,7 +23,7 @@ | |||
|             <div> | ||||
|               <h1 class="text-4xl font-thin mb-2">Overview</h1> | ||||
| 
 | ||||
|               <application-tags :type="getApplicationType(application)" :level="application.level"></application-tags> | ||||
|               <application-tags :application="application" :types="$attrs.types"/> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="my-10"> | ||||
|  | @ -132,11 +132,13 @@ | |||
| 
 | ||||
| <script> | ||||
| import ActionCards from '@/components/Environment/ActionCards' | ||||
| import ApiClient from '@/api-client.js' | ||||
| import ApplicationTags from '@/components/Application/ApplicationTags' | ||||
| 
 | ||||
| export default { | ||||
|   mixins: [ApiClient], | ||||
|   mounted () { | ||||
|     // console.log(this.$attrs) | ||||
|     // console.log(this.$props) | ||||
|   }, | ||||
| 
 | ||||
|   components: { | ||||
|     ActionCards, | ||||
|  | @ -150,11 +152,11 @@ export default { | |||
| 
 | ||||
|   computed: { | ||||
|     application: function () { | ||||
|       return this.getApplication(this.id) | ||||
|       return this.$attrs.applications[this.id] | ||||
|     }, | ||||
| 
 | ||||
|     environment: function () { | ||||
|       return this.getEnvironment(this.id, this.environmentName) | ||||
|       return this.application.environments[this.environmentName] | ||||
|     }, | ||||
| 
 | ||||
|     gitUrl: function () { | ||||
|  | @ -170,7 +172,7 @@ export default { | |||
|     }, | ||||
| 
 | ||||
|     phpVersion: function () { | ||||
|       return this.getVersion('php', this.environment) | ||||
|       return this.environment.versions.php | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  |  | |||
|  | @ -31,7 +31,7 @@ | |||
|               <div class="mr-16 mb-4 lg:mb-0"> | ||||
|                 <h1 class="text-4xl font-thin mb-2">Environments</h1> | ||||
| 
 | ||||
|                 <application-tags :type="getApplicationType(application)" :level="application.level"></application-tags> | ||||
|                 <application-tags :application="application" :types="$attrs.types"/> | ||||
|               </div> | ||||
| 
 | ||||
|               <div class="lg:flex lg:flex-row-reverse flex-1 justify-between _bg-blue items-baseline"> | ||||
|  | @ -49,7 +49,7 @@ | |||
|           </div> | ||||
| 
 | ||||
|           <quick-help :hidden="help.hidden"></quick-help> | ||||
|           <environment-cards :environments="application.environments" :id="id"></environment-cards> | ||||
|           <environment-cards :application="application" :id="id"/> | ||||
|           <task-log :tasks="application.tasks" v-if="application.tasks[0]"></task-log> | ||||
|         </div> | ||||
| 
 | ||||
|  | @ -65,7 +65,6 @@ | |||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import ApiClient from '@/api-client.js' | ||||
| import ApplicationTags from '@/components/Application/ApplicationTags' | ||||
| import EnvironmentCards from '@/components/Environment/EnvironmentCards' | ||||
| import QuickHelp from '@/components/Environment/QuickHelp' | ||||
|  | @ -73,8 +72,6 @@ import TaskLog from '@/components/Environment/TaskLog/TaskLog' | |||
| import ToggleHelp from '@/components/Environment/ToggleHelp' | ||||
| 
 | ||||
| export default { | ||||
|   mixins: [ApiClient], | ||||
| 
 | ||||
|   components: { | ||||
|     ApplicationTags, | ||||
|     EnvironmentCards, | ||||
|  | @ -96,8 +93,8 @@ export default { | |||
|   }, | ||||
| 
 | ||||
|   computed: { | ||||
|     application: function () { | ||||
|       return this.getApplication(this.id) | ||||
|     application () { | ||||
|       return this.$attrs.applications[this.id] | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  |  | |||
		Reference in a new issue