#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<vector>
#define ll long long
#define inf 1e9
#define eps 1e-8
#define md
#define N 100010
#define TR 6500100
using namespace std;
struct yts { int x,t,ne;} e[2*N];
int v[N],dep[N],fa[N][20],root[N],ans[N];
int ch[TR][2],mx[TR],ID[TR];
vector<int> vec[N];
int num=0,cnt=0,n;
void put(int x,int y)
{
num++; e[num].x=x; e[num].t=y;
e[num].ne=v[x]; v[x]=num;
}
void insert(int &i,int l,int r,int x,int d)
{
if (!i) i=++cnt;
if (l==r) { mx[i]+=d; ID[i]=l; return;}
int mid=(l+r)>>1;
if (x<=mid) insert(ch[i][0],l,mid,x,d);
else insert(ch[i][1],mid+1,r,x,d);
if (!ch[i][1]||mx[ch[i][0]]>=mx[ch[i][1]]) { mx[i]=mx[ch[i][0]]; ID[i]=ID[ch[i][0]];}
else { mx[i]=mx[ch[i][1]]; ID[i]=ID[ch[i][1]];}
}
int merge(int x,int y,int l,int r)
{
if (!x) return y;
if (!y) return x;
if (l==r) { mx[x]+=mx[y]; return x;}
int mid=(l+r)>>1;
ch[x][0]=merge(ch[x][0],ch[y][0],l,mid); ch[x][1]=merge(ch[x][1],ch[y][1],mid+1,r);
if (!ch[x][1]||mx[ch[x][0]]>=mx[ch[x][1]]) { mx[x]=mx[ch[x][0]]; ID[x]=ID[ch[x][0]];}
else { mx[x]=mx[ch[x][1]]; ID[x]=ID[ch[x][1]];}
return x;
}
void dfs1(int x)
{
for (int i=v[x];i;i=e[i].ne)
{
int y=e[i].t;
if (y!=fa[x][0])
{
dep[y]=dep[x]+1; fa[y][0]=x;
dfs1(y);
}
}
}
void dfs2(int x)
{
for (int i=v[x];i;i=e[i].ne)
{
int y=e[i].t;
if (y!=fa[x][0])
{
dfs2(y);
root[x]=merge(root[x],root[y],0,1e9);
}
}
for (int i=0;i<vec[x].size();i++) insert(root[x],0,1e9,vec[x][i],-1);
if (mx[root[x]]) ans[x]=ID[root[x]];
}
void build_lca()
{
for (int j=1;j<=18;j++)
for (int i=1;i<=n;i++)
fa[i][j]=fa[fa[i][j-1]][j-1];
}
int lca(int x,int y)
{
if (dep[x]<dep[y]) { int c=x; x=y; y=c;}
int t=dep[x]-dep[y];
for (int i=18;i>=0;i--)
if (t&(1<<i)) x=fa[x][i];
if (x==y) return x;
for (int i=18;i>=0;i--)
if (fa[x][i]!=fa[y][i])
x=fa[x][i],y=fa[y][i];
return fa[x][0];
}
int main()
{
//printf("%d\n",(sizeof(ch)*2+sizeof(v)*30)/1024/1024);
int m;
scanf("%d%d",&n,&m);
for (int i=1;i<n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
put(x,y); put(y,x);
}
dep[1]=1; dfs1(1); build_lca();
for (int i=1;i<=m;i++)
{
int x,y,c;
scanf("%d%d%d",&x,&y,&c);
int z=lca(x,y);
insert(root[x],0,1e9,c,1); insert(root[y],0,1e9,c,1);
vec[z].push_back(c);
if (fa[z][0]) vec[fa[z][0]].push_back(c);
}
dfs2(1);
for (int i=1;i<=n;i++) printf("%d\n",ans[i]);
return 0;
}