fhir_path 0.5.0-7 fhir_path: ^0.5.0-7 copied to clipboard
FHIRPath navigation and extraction language implemented in pure Dart to be used with base FHIR packages.
import 'dart:convert';
import 'package:url_launcher/link.dart';
import 'package:example/resource.dart';
import 'package:fhir/r4.dart';
import 'package:fhir_path/fhir_path.dart';
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) => MaterialApp(
title: 'FHIRPath Demo in Dart/Flutter',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'FHIRPath Demo in Dart/Flutter'),
);
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
final TextEditingController path =
TextEditingController(text: "Patient.name.where(use = 'official')");
final TextEditingController resource =
TextEditingController(text: openingResource);
var displayString = '';
var numLines = 30;
void _runPath() {
setState(() {
try {
final newResource = Resource.fromJson(jsonDecode(resource.text));
JsonEncoder encoder = new JsonEncoder.withIndent(' ');
displayString = encoder.convert(jsonDecode(
jsonEncode(walkFhirPath(newResource.toJson(), path.text))));
} catch (e) {
displayString = e.toString();
}
});
}
@override
Widget build(BuildContext context) {
_runPath();
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Padding(
padding: const EdgeInsets.all(8.0),
child: Row(
children: [
SizedBox(
width: MediaQuery.of(context).size.width * 0.5,
child: Column(
children: [
TextFormField(
controller: path,
decoration: InputDecoration(
border: OutlineInputBorder(),
hintText: 'Enter FHIRPath expression'),
onChanged: (_) => _runPath(),
),
TextFormField(
maxLines: numLines,
controller: resource,
decoration: InputDecoration(
border: OutlineInputBorder(),
hintText:
'Enter JSON FHIR Resource Here' + ('\n' * numLines),
),
onChanged: (_) => _runPath(),
),
],
),
),
SizedBox(width: 20),
Column(
children: [
Link(
uri: Uri.parse('https://hl7.github.io/fhirpath.js/'),
target: LinkTarget.blank,
builder: (ctx, openLink) {
return TextButton.icon(
onPressed: openLink,
label: Text(
'Completely Inspired By: https://hl7.github.io/fhirpath.js/'),
icon: Icon(Icons.read_more),
);
},
),
SizedBox(height: 10),
Text('Results', style: TextStyle(fontSize: 22)),
SizedBox(height: 10),
Expanded(
child: SingleChildScrollView(
child: SizedBox(
width: MediaQuery.of(context).size.width * 0.3,
child: Text(
displayString,
textAlign: TextAlign.start,
style: TextStyle(fontSize: 17),
),
),
),
),
],
),
],
),
),
);
}
}