001/*
002 * #%L
003 * HAPI FHIR - Core Library
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 *      http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.rest.param;
021
022import ca.uhn.fhir.i18n.Msg;
023import ca.uhn.fhir.model.api.ICompositeDatatype;
024import ca.uhn.fhir.model.api.IElement;
025import ca.uhn.fhir.model.api.IQueryParameterType;
026import ca.uhn.fhir.model.api.annotation.Child;
027import ca.uhn.fhir.model.api.annotation.Description;
028import ca.uhn.fhir.model.base.composite.BaseCodingDt;
029import ca.uhn.fhir.model.base.composite.BaseResourceReferenceDt;
030import ca.uhn.fhir.model.primitive.BooleanDt;
031import ca.uhn.fhir.model.primitive.CodeDt;
032import ca.uhn.fhir.model.primitive.StringDt;
033import ca.uhn.fhir.model.primitive.UriDt;
034import ca.uhn.fhir.util.CoverageIgnore;
035
036import java.util.List;
037
038@CoverageIgnore
039public class InternalCodingDt extends BaseCodingDt implements ICompositeDatatype {
040
041        private static final long serialVersionUID = 993056016725918652L;
042
043        /**
044         * Constructor
045         */
046        public InternalCodingDt() {
047                super();
048        }
049
050        /**
051         * Creates a new Coding with the given system and code
052         */
053        public InternalCodingDt(String theSystem, String theCode) {
054                setSystem(theSystem);
055                setCode(theCode);
056        }
057
058        @Child(name = "system", type = UriDt.class, order = 0, min = 0, max = 1)
059        @Description(
060                        shortDefinition = "Identity of the terminology system",
061                        formalDefinition =
062                                        "The identification of the code system that defines the meaning of the symbol in the code.")
063        private UriDt mySystem;
064
065        @Child(name = "version", type = StringDt.class, order = 1, min = 0, max = 1)
066        @Description(
067                        shortDefinition = "Version of the system - if relevant",
068                        formalDefinition =
069                                        "The version of the code system which was used when choosing this code. Note that a well-maintained code system does not need the version reported, because the meaning of codes is consistent across versions. However this cannot consistently be assured. and When the meaning is not guaranteed to be consistent, the version SHOULD be exchanged")
070        private StringDt myVersion;
071
072        @Child(name = "code", type = CodeDt.class, order = 2, min = 0, max = 1)
073        @Description(
074                        shortDefinition = "Symbol in syntax defined by the system",
075                        formalDefinition =
076                                        "A symbol in syntax defined by the system. The symbol may be a predefined code or an expression in a syntax defined by the coding system (e.g. post-coordination)")
077        private CodeDt myCode;
078
079        @Child(name = "display", type = StringDt.class, order = 3, min = 0, max = 1)
080        @Description(
081                        shortDefinition = "Representation defined by the system",
082                        formalDefinition =
083                                        "A representation of the meaning of the code in the system, following the rules of the system.")
084        private StringDt myDisplay;
085
086        @Child(name = "primary", type = BooleanDt.class, order = 4, min = 0, max = 1)
087        @Description(
088                        shortDefinition = "If this code was chosen directly by the user",
089                        formalDefinition =
090                                        "Indicates that this code was chosen by a user directly - i.e. off a pick list of available items (codes or displays)")
091        private BooleanDt myPrimary;
092
093        @Override
094        public boolean isEmpty() {
095                return super.isBaseEmpty()
096                                && ca.uhn.fhir.util.ElementUtil.isEmpty(mySystem, myVersion, myCode, myDisplay, myPrimary);
097        }
098
099        @Deprecated // override deprecated method
100        @Override
101        public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
102                return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(
103                                theType, mySystem, myVersion, myCode, myDisplay, myPrimary);
104        }
105
106        /**
107         * Gets the value(s) for <b>system</b> (Identity of the terminology system). creating it if it does not exist. Will not return <code>null</code>.
108         *
109         * <p>
110         * <b>Definition:</b> The identification of the code system that defines the meaning of the symbol in the code.
111         * </p>
112         */
113        @Override
114        public UriDt getSystemElement() {
115                if (mySystem == null) {
116                        mySystem = new UriDt();
117                }
118                return mySystem;
119        }
120
121        /**
122         * Sets the value(s) for <b>system</b> (Identity of the terminology system)
123         *
124         * <p>
125         * <b>Definition:</b> The identification of the code system that defines the meaning of the symbol in the code.
126         * </p>
127         */
128        public InternalCodingDt setSystem(UriDt theValue) {
129                mySystem = theValue;
130                return this;
131        }
132
133        /**
134         * Sets the value for <b>system</b> (Identity of the terminology system)
135         *
136         * <p>
137         * <b>Definition:</b> The identification of the code system that defines the meaning of the symbol in the code.
138         * </p>
139         */
140        @Override
141        public InternalCodingDt setSystem(String theUri) {
142                mySystem = new UriDt(theUri);
143                return this;
144        }
145
146        /**
147         * Gets the value(s) for <b>version</b> (Version of the system - if relevant). creating it if it does not exist. Will not return <code>null</code>.
148         *
149         * <p>
150         * <b>Definition:</b> The version of the code system which was used when choosing this code. Note that a well-maintained code system does not need the version reported, because the meaning of codes
151         * is consistent across versions. However this cannot consistently be assured. and When the meaning is not guaranteed to be consistent, the version SHOULD be exchanged
152         * </p>
153         */
154        @Override
155        public StringDt getVersionElement() {
156                if (myVersion == null) {
157                        myVersion = new StringDt();
158                }
159                return myVersion;
160        }
161
162        @Override
163        public BooleanDt getUserSelectedElement() {
164                return new BooleanDt();
165        }
166
167        /**
168         * Legacy name for {@link #getVersionElement()}
169         */
170        @Deprecated(since = "7.0.0")
171        public StringDt getVersion() {
172                return getVersionElement();
173        }
174
175        /**
176         * Sets the value(s) for <b>version</b> (Version of the system - if relevant)
177         *
178         * <p>
179         * <b>Definition:</b> The version of the code system which was used when choosing this code. Note that a well-maintained code system does not need the version reported, because the meaning of codes
180         * is consistent across versions. However this cannot consistently be assured. and When the meaning is not guaranteed to be consistent, the version SHOULD be exchanged
181         * </p>
182         */
183        public InternalCodingDt setVersion(StringDt theValue) {
184                myVersion = theValue;
185                return this;
186        }
187
188        /**
189         * Sets the value for <b>version</b> (Version of the system - if relevant)
190         *
191         * <p>
192         * <b>Definition:</b> The version of the code system which was used when choosing this code. Note that a well-maintained code system does not need the version reported, because the meaning of codes
193         * is consistent across versions. However this cannot consistently be assured. and When the meaning is not guaranteed to be consistent, the version SHOULD be exchanged
194         * </p>
195         */
196        public InternalCodingDt setVersion(String theString) {
197                myVersion = new StringDt(theString);
198                return this;
199        }
200
201        /**
202         * Gets the value(s) for <b>code</b> (Symbol in syntax defined by the system). creating it if it does not exist. Will not return <code>null</code>.
203         *
204         * <p>
205         * <b>Definition:</b> A symbol in syntax defined by the system. The symbol may be a predefined code or an expression in a syntax defined by the coding system (e.g. post-coordination)
206         * </p>
207         */
208        @Override
209        public CodeDt getCodeElement() {
210                if (myCode == null) {
211                        myCode = new CodeDt();
212                }
213                return myCode;
214        }
215
216        /**
217         * Sets the value(s) for <b>code</b> (Symbol in syntax defined by the system)
218         *
219         * <p>
220         * <b>Definition:</b> A symbol in syntax defined by the system. The symbol may be a predefined code or an expression in a syntax defined by the coding system (e.g. post-coordination)
221         * </p>
222         */
223        public InternalCodingDt setCode(CodeDt theValue) {
224                myCode = theValue;
225                return this;
226        }
227
228        /**
229         * Sets the value for <b>code</b> (Symbol in syntax defined by the system)
230         *
231         * <p>
232         * <b>Definition:</b> A symbol in syntax defined by the system. The symbol may be a predefined code or an expression in a syntax defined by the coding system (e.g. post-coordination)
233         * </p>
234         */
235        @Override
236        public InternalCodingDt setCode(String theCode) {
237                myCode = new CodeDt(theCode);
238                return this;
239        }
240
241        /**
242         * Gets the value(s) for <b>display</b> (Representation defined by the system). creating it if it does not exist. Will not return <code>null</code>.
243         *
244         * <p>
245         * <b>Definition:</b> A representation of the meaning of the code in the system, following the rules of the system.
246         * </p>
247         */
248        public StringDt getDisplay() {
249                if (myDisplay == null) {
250                        myDisplay = new StringDt();
251                }
252                return myDisplay;
253        }
254
255        /**
256         * Sets the value(s) for <b>display</b> (Representation defined by the system)
257         *
258         * <p>
259         * <b>Definition:</b> A representation of the meaning of the code in the system, following the rules of the system.
260         * </p>
261         */
262        public InternalCodingDt setDisplay(StringDt theValue) {
263                myDisplay = theValue;
264                return this;
265        }
266
267        /**
268         * Sets the value for <b>display</b> (Representation defined by the system)
269         *
270         * <p>
271         * <b>Definition:</b> A representation of the meaning of the code in the system, following the rules of the system.
272         * </p>
273         */
274        @Override
275        public InternalCodingDt setDisplay(String theString) {
276                myDisplay = new StringDt(theString);
277                return this;
278        }
279
280        /**
281         * Gets the value(s) for <b>primary</b> (If this code was chosen directly by the user). creating it if it does not exist. Will not return <code>null</code>.
282         *
283         * <p>
284         * <b>Definition:</b> Indicates that this code was chosen by a user directly - i.e. off a pick list of available items (codes or displays)
285         * </p>
286         */
287        public BooleanDt getPrimary() {
288                if (myPrimary == null) {
289                        myPrimary = new BooleanDt();
290                }
291                return myPrimary;
292        }
293
294        /**
295         * Sets the value(s) for <b>primary</b> (If this code was chosen directly by the user)
296         *
297         * <p>
298         * <b>Definition:</b> Indicates that this code was chosen by a user directly - i.e. off a pick list of available items (codes or displays)
299         * </p>
300         */
301        public InternalCodingDt setPrimary(BooleanDt theValue) {
302                myPrimary = theValue;
303                return this;
304        }
305
306        /**
307         * Sets the value for <b>primary</b> (If this code was chosen directly by the user)
308         *
309         * <p>
310         * <b>Definition:</b> Indicates that this code was chosen by a user directly - i.e. off a pick list of available items (codes or displays)
311         * </p>
312         */
313        public InternalCodingDt setPrimary(boolean theBoolean) {
314                myPrimary = new BooleanDt(theBoolean);
315                return this;
316        }
317
318        /**
319         * Gets the value(s) for <b>valueSet</b> (Set this coding was chosen from). creating it if it does not exist. Will not return <code>null</code>.
320         *
321         * <p>
322         * <b>Definition:</b> The set of possible coded values this coding was chosen from or constrained by
323         * </p>
324         */
325        public BaseResourceReferenceDt getValueSet() {
326                throw new UnsupportedOperationException(Msg.code(1949));
327        }
328
329        @Override
330        public StringDt getDisplayElement() {
331                return getDisplay();
332        }
333
334        @Deprecated // override deprecated method
335        @Override
336        public Boolean getMissing() {
337                throw new UnsupportedOperationException(Msg.code(1950));
338        }
339
340        @Deprecated // override deprecated method
341        @Override
342        public IQueryParameterType setMissing(Boolean theMissing) {
343                throw new UnsupportedOperationException(Msg.code(1951));
344        }
345}