mirror of
				https://github.com/ClusterCockpit/cc-backend
				synced 2025-10-26 14:25:06 +01:00 
			
		
		
		
	Adapt TagManagement to new urql version
This commit is contained in:
		| @@ -15,33 +15,36 @@ | ||||
|     let pendingChange = false | ||||
|     let isOpen = false | ||||
|  | ||||
|     const client = getContextClient(); | ||||
|  | ||||
|     const createTagMutation = ({ type, name }) => { | ||||
|     result = mutationStore({ | ||||
|         client: getContextClient(), | ||||
|         query: gql`mutation($type: String!, $name: String!) { | ||||
|             createTag(type: $type, name: $name) { id, type, name } | ||||
|         }`, | ||||
|         variables: { type, name} | ||||
|     }) | ||||
|         return mutationStore({ | ||||
|             client: client, | ||||
|             query: gql`mutation($type: String!, $name: String!) { | ||||
|                 createTag(type: $type, name: $name) { id, type, name } | ||||
|             }`, | ||||
|             variables: { type, name} | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     const addTagsToJobMutation = ({ job, tagIds }) => { | ||||
|     result = mutationStore({ | ||||
|         client: getContextClient(), | ||||
|         query: gql`mutation($job: ID!, $tagIds: [ID!]!) { | ||||
|             addTagsToJob(job: $job, tagIds: $tagIds) { id, type, name } | ||||
|         }`, | ||||
|         variables: {job, tagIds} | ||||
|     }) | ||||
|         return mutationStore({ | ||||
|             client: client, | ||||
|             query: gql`mutation($job: ID!, $tagIds: [ID!]!) { | ||||
|                 addTagsToJob(job: $job, tagIds: $tagIds) { id, type, name } | ||||
|             }`, | ||||
|             variables: {job, tagIds} | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     const removeTagsFromJobMutation = ({ job, tagIds }) => { | ||||
|     result = mutationStore({ | ||||
|         client: getContextClient(), | ||||
|         query: gql`mutation($job: ID!, $tagIds: [ID!]!) { | ||||
|             removeTagsFromJob(job: $job, tagIds: $tagIds) { id, type, name } | ||||
|         }` | ||||
|     }) | ||||
|         return mutationStore({ | ||||
|             client: client, | ||||
|             query: gql`mutation($job: ID!, $tagIds: [ID!]!) { | ||||
|                 removeTagsFromJob(job: $job, tagIds: $tagIds) { id, type, name } | ||||
|             }`, | ||||
|             variables: {job, tagIds} | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     let allTagsFiltered // $initialized is in there because when it becomes true, allTags is initailzed. | ||||
| @@ -66,43 +69,47 @@ | ||||
|  | ||||
|     function createTag(type, name) { | ||||
|         pendingChange = true | ||||
|         return createTagMutation({ type: type, name: name }) | ||||
|             .then(res => { | ||||
|                 if (res.error) | ||||
|                     throw res.error | ||||
|  | ||||
|         createTagMutation({ type: type, name: name }) | ||||
|         .subscribe(res => { | ||||
|             if (res.fetching === false && !res.error) { | ||||
|                 pendingChange = false | ||||
|                 allTags = [...allTags, res.data.createTag] | ||||
|                 newTagType = '' | ||||
|                 newTagName = '' | ||||
|                 return res.data.createTag | ||||
|             }, err => console.error(err)) | ||||
|                 addTagToJob(res.data.createTag) | ||||
|             } else if (res.fetching === false && res.error) { | ||||
|                 throw res.error | ||||
|                 // console.log('Error on subscription: ' + res.error) | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     function addTagToJob(tag) { | ||||
|         pendingChange = tag.id | ||||
|         addTagsToJobMutation({ job: job.id, tagIds: [tag.id] }) | ||||
|             .then(res => { | ||||
|                 if (res.error) | ||||
|                     throw res.error | ||||
|  | ||||
|         .subscribe(res => { | ||||
|             if (res.fetching === false && !res.error) { | ||||
|                 jobTags = job.tags = res.data.addTagsToJob; | ||||
|                 pendingChange = false; | ||||
|             }) | ||||
|             .catch(err => console.error(err)) | ||||
|             } else if (res.fetching === false && res.error) { | ||||
|                 throw res.error | ||||
|                 // console.log('Error on subscription: ' + res.error) | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     function removeTagFromJob(tag) { | ||||
|         pendingChange = tag.id | ||||
|         removeTagsFromJobMutation({ job: job.id, tagIds: [tag.id] }) | ||||
|             .then(res => { | ||||
|                 if (res.error) | ||||
|                     throw res.error | ||||
|  | ||||
|         .subscribe(res => { | ||||
|             if (res.fetching === false && !res.error) { | ||||
|                 jobTags = job.tags = res.data.removeTagsFromJob | ||||
|                 pendingChange = false | ||||
|             }) | ||||
|             .catch(err => console.error(err)) | ||||
|             } else if (res.fetching === false && res.error) { | ||||
|                 throw res.error | ||||
|                 // console.log('Error on subscription: ' + res.error) | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
| </script> | ||||
|  | ||||
| @@ -165,8 +172,7 @@ | ||||
|         <br/> | ||||
|         {#if newTagType && newTagName && isNewTag(newTagType, newTagName)} | ||||
|             <Button outline color="success" | ||||
|                 on:click={e => (e.preventDefault(), createTag(newTagType, newTagName)) | ||||
|                     .then(tag => addTagToJob(tag))}> | ||||
|                 on:click={e => (e.preventDefault(), createTag(newTagType, newTagName))}> | ||||
|                 Create & Add Tag: | ||||
|                 <Tag tag={({ type: newTagType, name: newTagName })} clickable={false}/> | ||||
|             </Button> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user